/**
 * Studio Harm Hasenaar - Main Stylesheet
 *
 * Custom styles for the Studio Harm Hasenaar WordPress block theme
 */

/* ==========================================================================
	CSS Custom Properties
========================================================================== */

:root {
	--shh-transition: 0.3s ease;
}

/* ==========================================================================
	Base Styles
========================================================================== */

html {
	scroll-behavior: smooth;
}

body {
	overflow-x: clip;
}

/* ==========================================================================
	Typography
========================================================================== */

strong,
b {
	font-weight: 400;
}

a {
	text-decoration: none;
	transition: color var(--shh-transition);
}

/* ==========================================================================
	Header
========================================================================== */

header.wp-block-template-part:has(.site-header) {
	position: sticky;
	top: 0;
	z-index: 100;
	background-color: var(--wp--preset--color--white);
}

.site-header img.custom-logo,
.site-footer img.custom-logo {
	transition: transform var(--shh-transition);
}

.site-header img.custom-logo:hover,
.site-footer img.custom-logo:hover {
	transform: scale(1.05);
}

.site-footer .footer-navigation p a {
	position: relative;
}

.site-footer .footer-navigation p a::after {
	content: '';
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 0;
	height: 1px;
	background-color: var(--wp--preset--color--burgundy-rose);
	transition: width var(--shh-transition);
}

.site-footer .footer-navigation p a:hover::after {
	width: 100%;
}

/* ==========================================================================
	Search page and search box in navigation overlay
========================================================================== */

.site-header .wp-block-navigation__responsive-container-content .wp-block-search,
.search-results .wp-block-search {
	margin-top: 2rem;
	width: 100%;
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search {
	max-width: 320px;
}

.search-results .wp-block-search {
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 0;
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search__inside-wrapper,
.search-results .wp-block-search__inside-wrapper {
	border: 1px solid var(--wp--preset--color--navy-blue);
	border-radius: 0;
	overflow: hidden;
	transition:
		border-color 0.3s ease,
		box-shadow 0.3s ease;
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search__inside-wrapper:focus-within,
.search-results .wp-block-search__inside-wrapper:focus-within {
	border-color: var(--wp--preset--color--burgundy-rose);
	box-shadow: 0 0 0 1px var(--wp--preset--color--burgundy-rose);
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search__input,
.search-results .wp-block-search__input {
	border: none !important;
	background: transparent;
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.05em;
	color: var(--wp--preset--color--navy-blue);
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search__input::placeholder,
.search-results .wp-block-search__input::placeholder {
	color: var(--wp--preset--color--navy-blue-light);
	opacity: 1;
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search__input:focus,
.search-results .wp-block-search__input:focus {
	outline: none !important;
	box-shadow: none !important;
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search__button,
.search-results .wp-block-search__button {
	background: transparent !important;
	border: none !important;
	padding: 0.75rem 0.75rem !important;
	margin: -4px -4px -4px 0 !important;
	cursor: pointer;
	transition:
		background-color 0.3s ease,
		color 0.3s ease;
	position: relative;
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search__button::before,
.search-results .wp-block-search__button::before {
	content: '';
	position: absolute;
	left: 0;
	top: 8px;
	bottom: 8px;
	width: 1px;
	background-color: var(--wp--preset--color--navy-blue);
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search__button:hover,
.search-results .wp-block-search__button:hover {
	background: var(--wp--preset--color--navy-blue) !important;
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search__button:hover svg,
.search-results .wp-block-search__button:hover svg {
	fill: var(--wp--preset--color--white);
}

.site-header .wp-block-navigation__responsive-container-content .wp-block-search__button svg,
.search-results .wp-block-search__button svg {
	fill: var(--wp--preset--color--navy-blue);
	transition: fill 0.3s ease;
}

/* Fix for focus visible offset */
.search-results .wp-block-search__input:focus-visible,
.search-results .wp-block-search__button:focus-visible {
	outline-offset: 0;
}

/* ==========================================================================
	Footer
========================================================================== */

.site-footer a {
	transition: color var(--shh-transition);
}

footer figure a::after {
	background-color: var(--wp--preset--color--white);
}

footer figure img {
	transition: transform var(--shh-transition);
}

footer figure:hover img {
	transform: scale(1.05);
}

/* ==========================================================================
	Floating Contact Buttons
========================================================================== */

.floating-contact {
	position: fixed;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 8px;
	opacity: 0;
	animation: fadeInFloatingButtons 0.6s ease-out 1.5s forwards;
}

.floating-contact-buttons {
	gap: 0 !important;
}

@keyframes fadeInFloatingButtons {
	from {
		opacity: 0;
		transform: translateY(-50%) translateX(20px);
	}
	to {
		opacity: 1;
		transform: translateY(-50%) translateX(0);
	}
}

.floating-contact-buttons .wp-block-social-link {
	margin: 0 !important;
	border-radius: 0 !important;
}

.floating-contact-buttons .wp-block-social-link-anchor {
	transition: all var(--shh-transition);
	border-radius: 0 !important;
}

.floating-contact-buttons .wp-block-social-link:hover {
	transform: scale(1.1) translateX(-2px);
}

.floating-contact-buttons .wp-social-link-mail {
	background-color: var(--wp--preset--color--burgundy-rose);
}

.floating-contact-buttons .wp-social-link-whatsapp {
	background-color: var(--wp--preset--color--navy-blue-light);
}

.floating-contact-buttons .wp-social-link-mail:hover {
	background-color: var(--wp--preset--color--navy-blue);
}

.floating-contact-buttons .wp-social-link-whatsapp:hover {
	background-color: #25d366;
}

/* custom @ symbol for mail icon */
.floating-contact-buttons .wp-social-link-mail svg {
	display: none !important;
}

.floating-contact-buttons .wp-social-link-mail .wp-block-social-link-anchor::before {
	content: '';
	display: block;
	width: 24px;
	height: 24px;
	background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJub25lIiBzdHJva2U9IiNmZmZmZmYiIHN0cm9rZS13aWR0aD0iMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIj48Y2lyY2xlIGN4PSIxMiIgY3k9IjEyIiByPSI0Ij48L2NpcmNsZT48cGF0aCBkPSJNMTYgOHY1YTMgMyAwIDAgMCA2IDB2LTFhMTAgMTAgMCAxIDAtMy45MiA3Ljk0Ij48L3BhdGg+PC9zdmc+');
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}

.floating-whatsapp-panel {
	position: absolute;
	right: calc(100% + 14px);
	bottom: 0;
	min-width: 220px;
	padding: 12px;
	background-color: var(--wp--preset--color--white);
	border-radius: 12px;
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
	opacity: 0;
	transform: translateX(12px);
	pointer-events: none;
	transition: all var(--shh-transition);
}

.floating-whatsapp-panel::after {
	content: '';
	position: absolute;
	top: 0;
	right: -14px;
	width: 14px;
	height: 100%;
}

.floating-contact:has(.wp-social-link-whatsapp:hover) .floating-whatsapp-panel,
.floating-whatsapp-panel:hover {
	opacity: 1;
	transform: translateX(0);
	pointer-events: auto;
}

.floating-whatsapp-item {
	margin: 0;
}

.floating-whatsapp-title {
	margin: 0 0 10px;
	color: var(--wp--preset--color--navy-blue);
	font-size: 0.95rem;
	font-weight: 400;
}

.floating-whatsapp-name-icon {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background-color: #25d366;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	flex: 0 0 auto;
	margin-right: 10px;
}

.floating-whatsapp-name-icon svg {
	width: 18px;
	height: 18px;
}

.floating-whatsapp-item + .floating-whatsapp-item {
	margin-top: 8px;
}

.floating-whatsapp-item a {
	display: flex;
	align-items: center;
	padding: 10px 12px;
	background-color: #f4f5f7;
	color: var(--wp--preset--color--navy-blue);
	font-weight: 400;
	text-decoration: none;
	transition: transform var(--shh-transition), background-color var(--shh-transition);
}

.floating-whatsapp-item a:hover {
	background-color: #e7f6ee;
	transform: translateX(-2px);
}

/* ==========================================================================
	Video Group Hero
========================================================================== */

.video-group {
	position: relative;
	overflow: hidden;
	min-height: 50vh;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	align-items: center;
}

.video-group .cover-video-embed {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
	overflow: hidden;
}

.video-group .cover-video-embed::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;

	min-width: 100%;
	min-height: 100%;
	transform: translate(-50%, -50%);
	background-image: url('../images/video-placeholder.webp');
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.video-group .cover-video-embed iframe {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 177.7778vh;
	height: 56.25vw;
	min-width: 100%;
	min-height: 100%;
	transform: translate(-50%, -50%);
	display: block;
	border: 0;
	opacity: 0;
	transition: opacity 0.2s ease;
	animation: none !important;
}

.video-group .cover-video-embed.is-loaded iframe {
	opacity: 1;
}

.video-group .wp-block-site-logo {
	position: relative;
	z-index: 1;
	background-color: var(--wp--preset--color--light-gray);
}

@media (min-width: 768px) {
	.video-group {
		min-height: 75vh;
	}
}

/* ==========================================================================
	Project Cards
========================================================================== */

.project-card,
.story-card {
	position: relative;
	overflow: hidden;
}

/* placeholder for cards without featured image */
.project-card:not(:has(.wp-block-post-featured-image))::before,
.story-card:not(:has(.wp-block-post-featured-image))::before {
	content: '';
	display: block;
	aspect-ratio: 4/3;
	background-image: url('../images/placeholder-square.svg');
	background-size: cover;
	background-position: center;
	background-color: #e8e8e8;
}

.project-card .wp-block-post-featured-image img,
.story-card .wp-block-post-featured-image img {
	transition: transform var(--shh-transition);
}

.project-card:hover .wp-block-post-featured-image img,
.story-card:hover .wp-block-post-featured-image img {
	transform: scale(1.05);
}

.project-card__overlay,
.story-card__overlay {
	margin-top: 0;
}

.project-card__overlay a,
.story-card__overlay a {
	color: var(--wp--preset--color--white);
}

.project-card__overlay a:hover,
.story-card__overlay a:hover {
	color: var(--wp--preset--color--light-pink);
}

/* ==========================================================================
	Buttons
========================================================================== */

.wp-block-button.is-style-outline .wp-block-button__link {
	border: 1px solid var(--wp--preset--color--navy-blue);
	background: transparent;
	color: var(--wp--preset--color--navy-blue);
	padding: 0.75rem 1.5rem;
	transition: all var(--shh-transition);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--wp--preset--color--navy-blue);
	color: var(--wp--preset--color--white);
}

/* custom styles for square outline button */
.wp-block-button.is-style-square-outline .wp-block-button__link {
	border: 1px solid var(--wp--preset--color--navy-blue);
	background: transparent;
	color: var(--wp--preset--color--navy-blue);
	padding: 0.75rem;
	aspect-ratio: 1 / 1;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0;
	transition: all var(--shh-transition);
	max-width: 100px;
}

.wp-block-button.is-style-square-outline .wp-block-button__link:hover {
	background: var(--wp--preset--color--navy-blue);
	color: var(--wp--preset--color--white);
}

/* ==========================================================================
	Gallery
========================================================================== */

.wp-block-gallery.has-nested-images {
	display: flex !important;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--medium);
}

.wp-block-gallery.has-nested-images figure.wp-block-image {
	flex-grow: 1;
	flex-basis: 0;
	margin: 0 !important;
	width: auto;
}

.wp-block-gallery.has-nested-images figure.wp-block-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* gallery column support */
.wp-block-gallery.columns-2 figure.wp-block-image {
	flex-basis: calc(50% - var(--wp--preset--spacing--medium) / 2);
}

.wp-block-gallery.columns-3 figure.wp-block-image {
	flex-basis: calc(33.333% - var(--wp--preset--spacing--medium) * 2 / 3);
}

.wp-block-gallery.columns-4 figure.wp-block-image {
	flex-basis: calc(25% - var(--wp--preset--spacing--medium) * 3 / 4);
}

/* ==========================================================================
	responsive styles
========================================================================== */

/* tablet and below */
@media (max-width: 1024px) {
	.floating-contact-buttons {
		right: 0;
	}

}

/* mobile */
@media (max-width: 768px) {
	.project-grid .wp-block-post-template,
	.story-grid .wp-block-post-template {
		grid-template-columns: 1fr;
	}

	.project-archive-grid .wp-block-post-template,
	.story-archive-grid .wp-block-post-template {
		grid-template-columns: repeat(2, 1fr);
	}

	.site-footer .wp-block-columns {
		flex-direction: column;
		gap: 2rem;
	}
}

@media (max-width: 480px) {
	.project-archive-grid .wp-block-post-template,
	.story-archive-grid .wp-block-post-template {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
	Accessibility
========================================================================== */

/* focus styles - using focus-visible for keyboard navigation only */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
	outline: 2px solid var(--wp--preset--color--burgundy-rose);
	outline-offset: 2px;
}

/* remove default focus for mouse users */
a:focus:not(:focus-visible),
button:focus:not(:focus-visible) {
	outline: none;
}

/* navigation overlay links use underline animation for focus instead */
.site-header .wp-block-navigation__responsive-container-content a:focus-visible {
	outline: none;
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}

	html {
		scroll-behavior: auto;
	}
}

/* ==========================================================================
	Query Pagination
========================================================================== */

.wp-block-query-pagination {
	align-items: center;
}

a.wp-block-query-pagination-next {
	margin-left: 6px;
	display: inline-flex;
	align-items: center;
}

a.wp-block-query-pagination-previous {
	margin-right: 6px;
	display: inline-flex;
	align-items: center;
}

/* ==========================================================================
	team grid
========================================================================== */

@media (max-width: 768px) {
	.team-grid .is-layout-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.team-grid .is-layout-grid .wp-block-group {
		order: 1;
	}

	.team-grid .is-layout-grid .wp-block-image:nth-child(1) {
		order: 2;
	}

	.team-grid .is-layout-grid .wp-block-image:nth-child(2) {
		order: 3;
	}

	.team-grid .is-layout-grid .wp-block-image:nth-child(4) {
		order: 4;
	}

	.team-grid .is-layout-grid:nth-child(even) .wp-block-group {
		order: -1;
	}
}
