/*
Theme Name: eirinimessini
Theme URI: http://underscores.me/
Author: Leonidas Michalopoulos
Author URI: http://leomichalopoulos.com
Description: Custom WP Theme for Eirini Messini
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: eirinimessini
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

eirinimessini is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/
@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-100.woff2") format("woff2");
    font-style: normal;
    font-weight: 100;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-100italic.woff2") format("woff2");
    font-style: italic;
    font-weight: 100;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-200.woff2") format("woff2");
    font-style: normal;
    font-weight: 200;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-200italic.woff2") format("woff2");
    font-style: italic;
    font-weight: 200;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-300.woff2") format("woff2");
    font-style: normal;
    font-weight: 300;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-300italic.woff2") format("woff2");
    font-style: italic;
    font-weight: 300;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-regular.woff2") format("woff2");
    font-style: normal;
    font-weight: 400;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-italic.woff2") format("woff2");
    font-style: italic;
    font-weight: 400;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-500.woff2") format("woff2");
    font-style: normal;
    font-weight: 500;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-500italic.woff2") format("woff2");
    font-style: italic;
    font-weight: 500;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-600.woff2") format("woff2");
    font-style: normal;
    font-weight: 600;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-600italic.woff2") format("woff2");
    font-style: italic;
    font-weight: 600;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-700.woff2") format("woff2");
    font-style: normal;
    font-weight: 700;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-700italic.woff2") format("woff2");
    font-style: italic;
    font-weight: 700;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-800.woff2") format("woff2");
    font-style: normal;
    font-weight: 800;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-800italic.woff2") format("woff2");
    font-style: italic;
    font-weight: 800;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-900.woff2") format("woff2");
    font-style: normal;
    font-weight: 900;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("./fonts/inter-v20-greek_latin-900italic.woff2") format("woff2");
    font-style: italic;
    font-weight: 900;
    font-display: swap;
}

:root {
	--em-color-accent: #e8e3dc;
	--em-color-accent-dark: #d8d0c5;
	--em-color-accent-contrast: #182230;
    --em-color-white: #ffffff;
    --em-color-text: #182230;
    --em-color-text-muted: #667085;
    --em-color-surface: #ffffff;
    --em-color-surface-soft: #f7f7f5;
    --em-color-border: #d0d5dd;
}

html,
body {
	overflow-x: hidden;
}

body {
    font-family: "Inter", sans-serif !important;
    color: var(--em-color-text);
}


/* Global Styles */
.serif-regular {
    font-family: "Inter", sans-serif;
    font-weight: 400;
    font-style: normal;
}

.serif-bold {
    font-family: "Inter", sans-serif;
    font-weight: 700;
    font-style: normal;
}

.mes-color {
    text-decoration: none !important;
    color: var(--em-color-text) !important;
}

.mes-color a {
    text-decoration: none !important;
    color: var(--em-color-text) !important;
}

/* Hero SECTION */
.messini__hero {
    min-height: 60vh;
}

.hero-copy {
	max-width: 40rem;
}

.hero-title {
	font-size: clamp(2rem, 1.7rem + 1.2vw, 2.8rem);
	letter-spacing: -0.03em;
	line-height: 1.08;
}

.hero-text {
	max-width: 36rem;
	font-size: clamp(1rem, 0.95rem + 0.2vw, 1.15rem);
}

@media (min-width: 992px) {
	.hero-copy {
		max-width: 46rem;
	}

	.hero-text {
		max-width: 40rem;
	}
}

.hero-actions .btn-em-primary,
.hero-actions .btn-em-secondary {
	padding: 0.75rem 1.1rem;
	font-size: 0.95rem;
}

.hero-image {
	display: block;
}

.section-kicker {
	color: var(--em-color-text-muted);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.section-title {
	font-size: clamp(1.5rem, 1.3rem + 0.8vw, 2rem);
	letter-spacing: -0.03em;
}

.section-copy {
	max-width: 42rem;
	color: var(--em-color-text-muted);
}

.service-card {
	position: relative;
	border: 1px solid var(--em-color-border);
	background-color: var(--em-color-surface);
	transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.service-card:hover,
.service-card:focus-within {
	border-color: var(--em-color-accent-dark);
	background-color: var(--em-color-surface-soft);
	box-shadow: 0 16px 32px rgba(24, 34, 48, 0.08);
	transform: translateY(-2px);
}

.service-card-label {
	color: var(--em-color-text-muted);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.service-card-media {
	height: 15rem;
}

.service-card .service-card-link {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	color: var(--em-color-text);
	font-weight: 600;
	text-decoration: none;
}

.services-swiper {
	overflow: visible;
}

.services-swiper .swiper-slide {
	height: auto;
}

.services-swiper .swiper-pagination-bullet {
	background-color: var(--em-color-accent-dark);
	opacity: 1;
}

.services-swiper .swiper-pagination-bullet-active {
	background-color: var(--em-color-text);
}

.services-swiper-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.75rem;
	height: 2.75rem;
	border: 1px solid var(--em-color-accent-dark);
	border-radius: 999px;
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
}

.approach-media {
	min-height: 28rem;
}

.approach-step-meta {
	color: var(--em-color-text-muted);
	font-size: 0.85rem;
}

.approach-timeline {
	position: relative;
	display: grid;
	gap: 2rem;
}

.approach-timeline::before {
	position: absolute;
	top: 0.4rem;
	bottom: 0.4rem;
	left: 1.1rem;
	width: 1px;
	background-color: var(--em-color-border);
	content: "";
}

.approach-timeline-item {
	position: relative;
	display: grid;
	grid-template-columns: 2.25rem 1fr;
	gap: 1.25rem;
	align-items: start;
}

.approach-timeline-index {
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 999px;
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
	font-size: 0.8rem;
	font-weight: 700;
}

@media (max-width: 991.98px) {
	.approach-media {
		min-height: 20rem;
	}
}



.navbar-toggler-icon {
    background-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" fill="%23182230" viewBox="0 0 16 16"><path d="M1.5 12.5a.5.5 0 0 1 0-1h13a.5.5 0 0 1 0 1h-13zm0-5a.5.5 0 0 1 0-1h13a.5.5 0 0 1 0 1h-13zm0-5a.5.5 0 0 1 0-1h13a.5.5 0 0 1 0 1h-13z"/></svg>') !important;
}

.navbar-toggler {
    border: 0 !important;
	padding: 0.5rem;
	background: transparent !important;
	box-shadow: none !important;
}

.navbar-toggler:focus,
.navbar-toggler:focus-visible,
.navbar-toggler:hover,
.navbar-toggler:active,
.navbar-toggler:visited {
	border: 0 !important;
	outline: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}

.site-header {
	border-bottom: 1px solid rgba(24, 34, 48, 0.08);
	box-shadow: 0 12px 30px rgba(24, 34, 48, 0.04);
}

.header-top {
	border-bottom: 1px solid rgba(24, 34, 48, 0.08);
}

.header-top-copy {
	color: var(--em-color-text);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-decoration: none;
	text-transform: uppercase;
}

.site-header .navbar-brand {
	color: var(--em-color-text);
	line-height: 1.2;
}

.brand-name {
	font-size: clamp(1rem, 0.85rem + 0.5vw, 1.25rem);
	font-weight: 700;
	letter-spacing: -0.02em;
}

.brand-tagline {
	margin-top: 0.15rem;
	color: var(--em-color-text-muted);
	font-size: 0.78rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.site-header .nav-link {
	position: relative;
	color: var(--em-color-text);
	font-weight: 500;
	padding-inline: 0.75rem !important;
}

.site-header .nav-link:hover,
.site-header .nav-link:focus-visible {
	color: var(--em-color-text);
	background-color: transparent;
}

.site-header .dropdown-item:hover,
.site-header .dropdown-item:focus-visible {
	color: var(--em-color-accent-contrast);
	background-color: var(--em-color-accent);
}

.site-header .nav-link::after {
	position: absolute;
	right: 0.75rem;
	bottom: 0.25rem;
	left: 0.75rem;
	height: 2px;
	background-color: var(--em-color-accent);
	content: "";
	transform: scaleX(0);
	transform-origin: center;
	transition: transform 0.2s ease;
}

.site-header .nav-link:hover::after,
.site-header .nav-link:focus-visible::after {
	transform: scaleX(1);
}

.site-header .dropdown-toggle::after {
	display: none;
}

.site-header .nav-link.dropdown-toggle,
.site-header .dropdown-item.dropdown-toggle {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.submenu-indicator,
.mobile-submenu-indicator {
	display: inline-block;
	width: 0.5rem;
	height: 0.5rem;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
}

.submenu-indicator-parent {
	margin-left: 0.1rem;
	transform: rotate(45deg);
}

.submenu-indicator-nested {
	margin-left: auto;
	transform: rotate(-45deg);
}

.site-header .dropdown-menu {
	margin-top: 0.75rem;
	border: 1px solid rgba(24, 34, 48, 0.08);
	border-radius: 1rem;
	box-shadow: 0 18px 45px rgba(24, 34, 48, 0.12);
	padding: 0.65rem;
}

.site-header .dropdown-item {
	border-radius: 0.65rem;
	padding: 0.65rem 0.8rem;
}

.site-header .dropdown-submenu {
	position: relative;
}

.site-header .dropdown-submenu-menu {
	top: 0;
	left: 100%;
	margin-top: -0.25rem;
}

@media (min-width: 992px) {
	.site-header .dropdown-submenu:hover > .dropdown-submenu-menu,
	.site-header .dropdown-submenu:focus-within > .dropdown-submenu-menu {
		display: block;
	}
}

.header-icon-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: 999px;
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
	text-decoration: none;
	transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.header-icon-link:hover,
.header-icon-link:focus-visible {
	background-color: var(--em-color-accent-dark);
	color: var(--em-color-accent-contrast);
	transform: translateY(-1px);
}

.header-icon-link svg {
	width: 1rem;
	height: 1rem;
	fill: currentColor;
}

.header-booking-cta {
	padding-inline: 1.25rem;
}

.offcanvas {
	max-width: min(24rem, 90vw);
}

.offcanvas-title {
	font-weight: 700;
}

.mobile-menu-item + .mobile-menu-item {
	border-top: 1px solid var(--em-color-border);
}

.mobile-menu-link {
	display: block;
	padding: 0.9rem 0;
	color: var(--em-color-text);
	font-weight: 500;
	text-decoration: none;
}

.mobile-menu .mobile-menu {
	padding-left: 1rem;
}

.mobile-menu-toggle {
	border: 0;
	background: transparent;
	color: var(--em-color-accent-contrast);
	font-size: 1rem;
	line-height: 1;
}

.mobile-submenu-indicator {
	transform: rotate(45deg);
	transition: transform 0.2s ease;
}

.mobile-menu-toggle[aria-expanded="true"] .mobile-submenu-indicator {
	transform: rotate(225deg);
}

@media (max-width: 991.98px) {
	.site-header .navbar {
		min-height: 4.75rem;
	}
}


/*END OF HERO SECTION */

/* Buttons */
.btn-em-primary,
.btn-em-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    border-radius: 999px;
    padding: 0.875rem 1.5rem;
    font-weight: 600;
    line-height: 1.2;
    text-decoration: none;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.btn-em-primary {
	border: 1px solid var(--em-color-accent);
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
}

.btn-em-primary:hover,
.btn-em-primary:focus-visible {
	border-color: var(--em-color-accent-dark);
	background-color: var(--em-color-accent-dark);
	color: var(--em-color-accent-contrast);
}

.btn-em-secondary {
	border: 1px solid var(--em-color-accent-dark);
	background-color: transparent;
	color: var(--em-color-accent-contrast);
}

.btn-em-secondary:hover,
.btn-em-secondary:focus-visible {
	border-color: var(--em-color-accent-dark);
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
}

.btn-em-primary:active,
.btn-em-secondary:active {
    transform: translateY(1px);
}

.cta,
.sign-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    border-radius: 999px;
    padding: 0.875rem 1.5rem;
    font-weight: 600;
    line-height: 1.2;
    text-decoration: none !important;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.cta,
.sign-btn {
	border: 1px solid var(--em-color-accent);
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
}

.cta:hover,
.cta:focus-visible,
.sign-btn:hover,
.sign-btn:focus-visible {
	border-color: var(--em-color-accent-dark);
	background-color: var(--em-color-accent-dark);
	color: var(--em-color-accent-contrast);
}

.cta:active,
.sign-btn:active {
    transform: translateY(1px);
}

/* End of Button */

/* Chatty */
.chaty-svg circle {
    fill: var(--em-color-accent);
}

.chaty-svg ellipse {
    fill: var(--em-color-accent);
}

.open-chaty,
.chaty-cta-button {
    background-color: var(--em-color-accent) !important;
}

/* END Chatty */

/* Contact Form 7 */
.wpcf7-form-control {
    border: none !important;
}

span .wpcf7-list-item {
    margin: 0 0 0 0 !important;
}

.wpcf7-list-item-label a {
    color: black;
}

/* END Contact Form 7 */

.em-primary {
    color: var(--em-color-accent-contrast) !important;
}

.section_heading__underline {
    position: relative;
    display: inline-block;
    padding-bottom: 0.5rem;
}

.section_heading__underline::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 60px;
    /* adjust width as needed */
    height: 3px;
  background-color: var(--em-color-accent);
    border-radius: 2px;
}

.site-footer {
	color: var(--em-color-text);
}

.site-footer-inner {
	border-top: 1px solid rgba(24, 34, 48, 0.08);
}

.footer-brand {
	color: var(--em-color-text);
	text-decoration: none;
}

.footer-brand-name {
	font-size: clamp(1.15rem, 1rem + 0.35vw, 1.35rem);
	font-weight: 700;
	letter-spacing: -0.02em;
}

.footer-brand-role {
	margin-top: 0.25rem;
	color: var(--em-color-text-muted);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.footer-copy {
	max-width: 24rem;
	color: var(--em-color-text-muted);
}

.footer-heading {
	margin-bottom: 1rem;
	font-size: 0.95rem;
	font-weight: 700;
	letter-spacing: -0.01em;
}

.footer-links {
	display: grid;
	gap: 0.75rem;
}

.footer-links a,
.footer-contact-item a,
.footer-legal-nav a {
	color: var(--em-color-text-muted);
	text-decoration: none;
	transition: color 0.2s ease;
}

.footer-links a:hover,
.footer-links a:focus-visible,
.footer-contact-item a:hover,
.footer-contact-item a:focus-visible,
.footer-legal-nav a:hover,
.footer-legal-nav a:focus-visible {
	color: var(--em-color-text);
}

.footer-contact-list {
	display: grid;
	gap: 1rem;
}

.footer-contact-item {
	display: grid;
	gap: 0.25rem;
	font-style: normal;
}

.footer-contact-item span {
	color: var(--em-color-text);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.footer-icon-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 999px;
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
	text-decoration: none;
	transition: background-color 0.2s ease, transform 0.2s ease;
}

.footer-icon-link:hover,
.footer-icon-link:focus-visible {
	background-color: var(--em-color-accent-dark);
	color: var(--em-color-accent-contrast);
	transform: translateY(-1px);
}

.footer-icon-link svg {
	width: 1rem;
	height: 1rem;
	fill: currentColor;
}

.footer-bottom {
	border-top: 1px solid rgba(24, 34, 48, 0.08);
	color: var(--em-color-text-muted);
	font-size: 0.9rem;
}

.footer-legal-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem 1.5rem;
}

.services-page-title {
	max-width: 48rem;
	font-size: clamp(2rem, 1.6rem + 1.4vw, 3rem);
	line-height: 1.05;
	letter-spacing: -0.04em;
}

.services-filter-link {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--em-color-border);
	border-radius: 999px;
	padding: 0.65rem 1rem;
	color: var(--em-color-text);
	font-weight: 500;
	text-decoration: none;
	transition: border-color 0.2s ease, background-color 0.2s ease;
}

.services-filter-link:hover,
.services-filter-link:focus-visible,
.services-filter-link.is-active {
	border-color: var(--em-color-accent-dark);
	background-color: var(--em-color-accent);
}

.services-archive-list {
	display: grid;
	gap: 3rem;
}

.service-groups {
	display: grid;
	gap: 4rem;
}

.service-feature + .service-feature {
	padding-top: 3rem;
	border-top: 1px solid var(--em-color-border);
}

.service-feature-media {
	min-height: 18rem;
}

.service-feature-meta {
	color: var(--em-color-text-muted);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.service-feature-title a {
	color: var(--em-color-text);
	text-decoration: none;
}

.service-feature-title a:hover,
.service-feature-title a:focus-visible {
	color: var(--em-color-text);
}

.service-feature-copy {
	max-width: 40rem;
	color: var(--em-color-text-muted);
}

.service-feature-link {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	color: var(--em-color-text);
	font-weight: 600;
	text-decoration: none;
}

.service-guidance {
	padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	background-color: var(--em-color-surface-soft);
}

.single-service-intro {
	max-width: 42rem;
	color: var(--em-color-text-muted);
	font-size: clamp(1rem, 0.95rem + 0.25vw, 1.15rem);
}

.single-service-media {
	min-height: 22rem;
}

.single-service-content {
	max-width: 48rem;
}

.single-service-content > * + * {
	margin-top: 1.25rem;
}

.single-service-content h2 {
	margin-top: 2.25rem;
	font-size: clamp(1.35rem, 1.2rem + 0.4vw, 1.7rem);
	letter-spacing: -0.02em;
}

.single-service-content p,
.single-service-content li {
	color: var(--em-color-text-muted);
	line-height: 1.85;
}

.single-service-aside {
	position: sticky;
	top: 2rem;
	padding: 1.5rem;
	border: 1px solid var(--em-color-border);
	border-radius: 1.5rem;
	background-color: var(--em-color-surface);
}

.single-service-highlight {
	padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	background-color: var(--em-color-surface-soft);
	color: var(--em-color-text);
	font-size: clamp(1.05rem, 1rem + 0.3vw, 1.25rem);
	line-height: 1.8;
}

@media (max-width: 991.98px) {
	.service-feature-media,
	.single-service-media {
		min-height: 18rem;
	}

	.single-service-aside {
		position: static;
	}
}

.blog-page-title {
	max-width: 54rem;
	font-size: clamp(2rem, 1.6rem + 1.4vw, 3rem);
	line-height: 1.05;
	letter-spacing: -0.04em;
}

.blog-feature-media {
	aspect-ratio: 16 / 9;
}

.blog-feature-title {
	font-size: clamp(1.5rem, 1.25rem + 0.8vw, 2rem);
	letter-spacing: -0.03em;
}

.blog-feature-title a,
.blog-card-title a,
.section-kicker a {
	color: var(--em-color-text);
	text-decoration: none;
}

.blog-meta,
.blog-date,
.single-post-meta {
	color: var(--em-color-text-muted);
	font-size: 0.85rem;
}

.blog-meta {
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.blog-card {
	display: flex;
	flex-direction: column;
}

.blog-card-media {
	aspect-ratio: 16 / 10;
}

.blog-feature-media img,
.blog-card-media img {
	display: block;
}

.blog-card-copy {
	color: var(--em-color-text-muted);
}

.blog-read-link {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	color: var(--em-color-text);
	font-weight: 600;
	text-decoration: none;
}

.blog-category-link {
	display: inline-flex;
	align-items: center;
	border: 1px solid var(--em-color-border);
	border-radius: 999px;
	padding: 0.65rem 1rem;
	color: var(--em-color-text);
	font-weight: 500;
	text-decoration: none;
	transition: border-color 0.2s ease, background-color 0.2s ease;
}

.blog-category-link:hover,
.blog-category-link:focus-visible {
	border-color: var(--em-color-accent-dark);
	background-color: var(--em-color-accent);
}

.blog-guidance {
	padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	background-color: var(--em-color-surface-soft);
}

.blog-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	height: 2.5rem;
	margin-right: 0.35rem;
	border: 1px solid var(--em-color-border);
	border-radius: 999px;
	color: var(--em-color-text);
	text-decoration: none;
}

.blog-pagination .page-numbers.current,
.blog-pagination .page-numbers:hover,
.blog-pagination .page-numbers:focus-visible {
	border-color: var(--em-color-accent-dark);
	background-color: var(--em-color-accent);
}

.single-post-media {
	min-height: 22rem;
}

.single-post-content {
	max-width: 48rem;
}

.single-post-content > * + * {
	margin-top: 1.25rem;
}

.single-post-content h2 {
	margin-top: 2.25rem;
	font-size: clamp(1.35rem, 1.2rem + 0.4vw, 1.7rem);
	letter-spacing: -0.02em;
}

.single-post-content p,
.single-post-content li {
	color: var(--em-color-text-muted);
	line-height: 1.9;
}

.single-post-content blockquote {
	margin: 2rem 0;
	padding-left: 1.25rem;
	border-left: 3px solid var(--em-color-accent-dark);
	color: var(--em-color-text);
	font-size: clamp(1.1rem, 1rem + 0.25vw, 1.25rem);
}

.single-post-author-link {
	color: var(--em-color-text);
	font-weight: 600;
	text-decoration: none;
}

.author-card {
	display: grid;
	grid-template-columns: 4.5rem 1fr;
	gap: 1rem;
	align-items: center;
	padding: 1.25rem;
	border: 1px solid var(--em-color-border);
	background-color: var(--em-color-surface-soft);
}

.author-card-media {
	width: 4.5rem;
	height: 4.5rem;
}

.author-card h2 a {
	color: var(--em-color-text);
	text-decoration: none;
}

.single-post-aside {
	position: sticky;
	top: 2rem;
	padding: 1.5rem;
	border: 1px solid var(--em-color-border);
	border-radius: 1.5rem;
	background-color: var(--em-color-surface);
}

.single-post-highlight {
	padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	background-color: var(--em-color-surface-soft);
	color: var(--em-color-text);
	font-size: clamp(1.05rem, 1rem + 0.3vw, 1.25rem);
	line-height: 1.8;
}

@media (max-width: 991.98px) {
	.single-post-aside {
		position: static;
	}
}

.floating-contact-widget {
	position: fixed;
	right: clamp(1rem, 1vw + 0.5rem, 1.5rem);
	bottom: clamp(1.75rem, 0.6vw + 1.45rem, 1.95rem);
	z-index: 1040;
}

.floating-contact-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3.5rem;
	height: 3.5rem;
	border: 1px solid var(--em-color-accent-dark);
	border-radius: 999px;
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
	box-shadow: 0 18px 38px rgba(24, 34, 48, 0.18);
}

.floating-contact-toggle svg {
	width: 1.35rem;
	height: 1.35rem;
	fill: currentColor;
}

.floating-contact-panel {
	position: absolute;
	right: 0;
	bottom: calc(100% + 0.75rem);
	display: grid;
	gap: 0.5rem;
	min-width: 10.5rem;
	padding: 0.65rem;
	border: 1px solid var(--em-color-border);
	border-radius: 1rem;
	background-color: var(--em-color-surface);
	box-shadow: 0 18px 38px rgba(24, 34, 48, 0.12);
	opacity: 0;
	pointer-events: none;
	transform: translateY(0.5rem);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.floating-contact-widget.is-open .floating-contact-panel {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

.floating-contact-panel a {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.7rem 0.8rem;
	border-radius: 0.75rem;
	color: var(--em-color-text);
	font-weight: 600;
	text-decoration: none;
}

.floating-contact-panel a:hover,
.floating-contact-panel a:focus-visible {
	background-color: var(--em-color-accent);
}

.floating-contact-panel span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.8rem;
	height: 1.8rem;
	border-radius: 999px;
	background-color: var(--em-color-surface-soft);
}

.floating-contact-panel span svg {
	width: 0.95rem;
	height: 0.95rem;
	fill: currentColor;
}

@media (max-width: 575.98px) {
	.floating-contact-widget {
		right: 0.75rem;
		bottom: 1.6rem;
	}

	.floating-contact-toggle {
		width: 3.25rem;
		height: 3.25rem;
	}

	.floating-contact-panel {
		min-width: 9.75rem;
	}
}

/* CONDITIONS SECTION */
.py-lg-6 {
    padding-top: 5rem;
    padding-bottom: 5rem;
}

.condition-card {
    padding: 2rem 1.75rem;
    border: 1px solid var(--em-color-border);
    border-radius: 1rem;
    background-color: var(--em-color-surface);
    transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.condition-card:hover {
    border-color: var(--em-color-accent-dark);
    background-color: var(--em-color-surface-soft);
    box-shadow: 0 16px 32px rgba(24, 34, 48, 0.08);
    transform: translateY(-3px);
}

.condition-card-index {
    display: inline-block;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: var(--em-color-accent-contrast);
    background-color: var(--em-color-accent);
    border-radius: 999px;
    padding: 0.3rem 0.7rem;
    margin-bottom: 1.25rem;
}

.condition-card-title {
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: 0.75rem;
    color: var(--em-color-text);
}

.condition-card-copy {
    color: var(--em-color-text-muted);
    font-size: 0.9rem;
    line-height: 1.65;
    margin-bottom: 0;
}

.condition-quote-strip {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1.5rem;
    padding: 2.5rem 2rem;
    background-color: var(--em-color-accent);
    border-radius: 1.5rem;
}

.condition-quote-text {
    font-size: clamp(1.05rem, 0.95rem + 0.4vw, 1.3rem);
    font-style: italic;
    font-weight: 500;
    color: var(--em-color-accent-contrast);
    max-width: 42rem;
    line-height: 1.55;
    margin-bottom: 0;
}

.condition-quote-cta {
    flex-shrink: 0;
    white-space: nowrap;
}

@media (min-width: 768px) {
    .condition-quote-strip {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        padding: 2.75rem 3rem;
    }
}

/* ── Shared utilities ──────────────────────────────── */
.em-card-hover {
    transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.em-card-hover:hover {
    border-color: var(--em-color-accent-dark) !important;
    transform: translateY(-3px);
    box-shadow: 0 16px 32px rgba(24, 34, 48, .08);
}

.em-img-zoom { overflow: hidden; }
.em-img-zoom img { transition: transform .4s ease; display: block; width: 100%; height: 100%; object-fit: cover; }
.em-card-hover:hover .em-img-zoom img { transform: scale(1.04); }

.line-clamp-2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.line-clamp-3 { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

/* ── Testimonials ──────────────────────────────────── */
.testimonial-card {
    border: 1px solid var(--em-color-border);
    border-radius: 1rem;
    padding: 2rem;
    background-color: var(--em-color-surface-soft);
    display: flex;
    flex-direction: column;
    height: 100%;
}

.testimonial-quote-icon {
    font-size: 3.5rem;
    line-height: .7;
    font-family: Georgia, serif;
    color: var(--em-color-accent-dark);
    display: block;
    margin-bottom: 1rem;
}

.testimonial-stars { color: #b8962e; font-size: .85rem; letter-spacing: .05em; }

.testimonial-body {
    font-size: .95rem;
    font-style: italic;
    line-height: 1.75;
    color: var(--em-color-text);
    flex-grow: 1;
    margin-bottom: 1.5rem;
}

.testimonial-author-name { font-weight: 700; font-size: .9rem; color: var(--em-color-text); margin-bottom: .15rem; }
.testimonial-author-role { font-size: .8rem; color: var(--em-color-text-muted); margin-bottom: 0; }

.testimonials-swiper .swiper-pagination-bullet { background-color: var(--em-color-accent-dark); opacity: 1; }
.testimonials-swiper .swiper-pagination-bullet-active { background-color: var(--em-color-text); }

/* ── Posts ─────────────────────────────────────────── */
.post-card-image { height: 13rem; flex-shrink: 0; }
.post-card-date {
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--em-color-text-muted);
    margin-bottom: .5rem;
}
.post-card-title {
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: -.02em;
    color: var(--em-color-text);
    line-height: 1.35;
    margin-bottom: .65rem;
}
.post-card-link {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .9rem;
    font-weight: 600;
    color: var(--em-color-text);
    text-decoration: none;
    transition: gap .2s ease;
    margin-top: auto;
    padding-top: 1rem;
}
.post-card-link:hover { gap: .6rem; color: var(--em-color-text); }

/* ── Events (full-poster cards) ──────────────────────── */
.event-poster-card {
    display: block;
    position: relative;
    border-radius: 1rem;
    overflow: hidden;
    text-decoration: none;
    border: 1px solid var(--em-color-border);
    transition: transform .2s ease, box-shadow .2s ease;
}
.event-poster-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 20px 40px rgba(24, 34, 48, .14);
    text-decoration: none;
}
.event-poster-image img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform .5s ease;
}
.event-poster-card:hover .event-poster-image img {
    transform: scale(1.03);
}
.event-poster-placeholder {
    aspect-ratio: 2 / 3;
    background-color: var(--em-color-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
    color: var(--em-color-accent-dark);
}
.event-poster-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 4rem 1.25rem 1.25rem;
    background: linear-gradient(to top, rgba(24, 34, 48, .9) 0%, transparent 100%);
}
.event-poster-overlay .event-card-date {
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, .65);
    margin-bottom: .35rem;
}
.event-poster-overlay .event-card-title {
    font-size: .95rem;
    font-weight: 700;
    letter-spacing: -.02em;
    color: #fff;
    line-height: 1.4;
    margin-bottom: 0;
}
.events-swiper .swiper-pagination-bullet { background-color: var(--em-color-accent-dark); opacity: 1; }
.events-swiper .swiper-pagination-bullet-active { background-color: var(--em-color-text); }

/* ── QnA ─────────────────────────────────────────────── */
.qna-cta-strip {
    background-color: var(--em-color-accent);
    border-radius: 1rem;
    padding: 2rem;
    margin-top: 2.5rem;
}

.qna-accordion .accordion-item {
    border: none !important;
    background: transparent;
    border-bottom: 1px solid var(--em-color-border) !important;
    border-radius: 0 !important;
    box-shadow: none;
}
.qna-accordion .accordion-item:first-child { border-top: 1px solid var(--em-color-border) !important; }
.qna-accordion .accordion-button {
    background: transparent !important;
    color: var(--em-color-text) !important;
    font-weight: 600;
    font-size: 1rem;
    padding: 1.25rem 0;
    box-shadow: none !important;
}
.qna-accordion .accordion-button:not(.collapsed),
.qna-accordion .accordion-button:hover { color: var(--em-color-text) !important; background: transparent !important; }
.qna-accordion .accordion-button:focus { box-shadow: none !important; outline: none !important; }
.qna-accordion .accordion-button::after { filter: brightness(0) !important; }
.qna-accordion .accordion-body {
    padding: 0 2rem 1.25rem 0;
    color: var(--em-color-text-muted);
    font-size: .95rem;
    line-height: 1.75;
}

/* ── Contact page ─────────────────────────────────── */
.contact-page-title {
	max-width: 52rem;
	font-size: clamp(2rem, 1.6rem + 1.4vw, 3rem);
	line-height: 1.05;
	letter-spacing: -0.04em;
}

.contact-form-shell,
.contact-side-panel {
	padding: clamp(1.25rem, 1rem + 1vw, 2rem);
}

.contact-form-shell {
	border: 1px solid var(--em-color-border);
	background-color: var(--em-color-surface);
}

.contact-side-panel {
	border-radius: 1.5rem;
	background-color: var(--em-color-surface-soft);
}

.contact-methods {
	display: grid;
	gap: 0.9rem;
}

.contact-method {
	display: flex;
	align-items: center;
	gap: 1rem;
	color: var(--em-color-text);
	text-decoration: none;
}

.contact-method strong,
.contact-method em {
	display: block;
}

.contact-method strong {
	font-size: 0.95rem;
}

.contact-method em {
	color: var(--em-color-text-muted);
	font-style: normal;
}

.contact-method-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 999px;
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
}

.contact-method-icon svg {
	width: 1rem;
	height: 1rem;
	fill: currentColor;
}

.contact-steps {
	display: grid;
	gap: 1.25rem;
}

.contact-steps li {
	display: grid;
	grid-template-columns: 2rem 1fr;
	gap: 1rem;
	align-items: start;
}

.contact-steps li > span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: 999px;
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
	font-size: 0.78rem;
	font-weight: 700;
}

.contact-steps p {
	color: var(--em-color-text-muted);
}

.contact-form-wrap .wpcf7-form {
	display: grid;
	gap: 1rem;
}

.contact-form-wrap .wpcf7-form p {
	margin-bottom: 0;
}

.contact-form-wrap input[type="text"],
.contact-form-wrap input[type="email"],
.contact-form-wrap input[type="tel"],
.contact-form-wrap input[type="url"],
.contact-form-wrap input[type="number"],
.contact-form-wrap textarea {
	width: 100%;
	border: 1px solid var(--em-color-border) !important;
	border-radius: 1rem;
	padding: 0.9rem 1rem;
	background-color: var(--em-color-white);
}

.contact-form-wrap textarea {
	min-height: 10rem;
}

.contact-form-wrap input[type="submit"] {
	border: 1px solid var(--em-color-accent);
	border-radius: 999px;
	padding: 0.875rem 1.5rem;
	background-color: var(--em-color-accent);
	color: var(--em-color-accent-contrast);
	font-weight: 600;
}

.contact-form-wrap .wpcf7-acceptance .wpcf7-list-item {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0;
}

.contact-form-wrap input[type="checkbox"] {
	width: auto;
	margin: 0;
	accent-color: var(--em-color-accent-dark);
}

.office-card {
	padding: 1.5rem;
	border: 1px solid var(--em-color-border);
	background-color: var(--em-color-surface);
}

.office-map-link {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	color: var(--em-color-text);
	font-weight: 600;
	text-decoration: none;
}

.contact-guidance {
	padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	background-color: var(--em-color-surface-soft);
	color: var(--em-color-text);
	font-size: clamp(1.05rem, 1rem + 0.3vw, 1.25rem);
	line-height: 1.8;
}

/* ── About page ───────────────────────────────────── */
.about-page-title {
	font-size: clamp(2rem, 1.6rem + 1.4vw, 3rem);
	line-height: 1.05;
	letter-spacing: -0.04em;
}

.about-role {
	color: var(--em-color-text-muted);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.about-hero-media {
	min-height: 28rem;
}

.about-stat {
	display: grid;
	gap: 0.35rem;
	padding: 1.5rem;
	border: 1px solid var(--em-color-border);
	background-color: var(--em-color-surface);
}

.about-stat strong {
	font-size: clamp(1.75rem, 1.4rem + 0.8vw, 2.25rem);
	line-height: 1;
	letter-spacing: -0.04em;
}

.about-stat span {
	color: var(--em-color-text-muted);
}

.about-copy {
	display: grid;
	gap: 1.25rem;
}

.about-copy p {
	margin-bottom: 0;
	color: var(--em-color-text-muted);
	line-height: 1.85;
}

.about-copy em {
	color: var(--em-color-text);
}

.about-credential-panel {
	padding: clamp(1.5rem, 1rem + 1vw, 2rem);
	background-color: var(--em-color-surface-soft);
}

.about-credential-list {
	display: grid;
	gap: 0.9rem;
}

.about-credential-list li {
	position: relative;
	padding-left: 1.25rem;
	color: var(--em-color-text);
}

.about-credential-list li::before {
	position: absolute;
	top: 0.6rem;
	left: 0;
	width: 0.45rem;
	height: 0.45rem;
	border-radius: 999px;
	background-color: var(--em-color-accent-dark);
	content: "";
}

.about-secondary-media {
	min-height: 24rem;
}

.about-philosophy {
	padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	background-color: var(--em-color-surface-soft);
}

@media (max-width: 991.98px) {
	.about-hero-media,
	.about-secondary-media {
		min-height: 20rem;
	}
}

/* ── Offices page ─────────────────────────────────── */
.offices-page-title {
	max-width: 56rem;
	font-size: clamp(2rem, 1.6rem + 1.4vw, 3rem);
	line-height: 1.05;
	letter-spacing: -0.04em;
}

.office-summary-card {
	padding: 1.5rem;
	border: 1px solid var(--em-color-border);
	background-color: var(--em-color-surface);
	color: var(--em-color-text);
	text-decoration: none;
	transition: border-color 0.2s ease, background-color 0.2s ease, transform 0.2s ease;
}

.office-summary-card p {
	color: var(--em-color-text-muted);
}

.office-summary-card span {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: 600;
}

.office-summary-card:hover,
.office-summary-card:focus-visible {
	border-color: var(--em-color-accent-dark);
	background-color: var(--em-color-surface-soft);
	transform: translateY(-2px);
}

.office-map-shell {
	min-height: 24rem;
}

.office-map-shell iframe {
	display: block;
	width: 100%;
	height: 24rem;
	border: 0;
}

.office-address {
	color: var(--em-color-text-muted);
	font-weight: 600;
}

.office-copy {
	display: grid;
	gap: 1rem;
}

.office-copy p {
	margin-bottom: 0;
	color: var(--em-color-text-muted);
	line-height: 1.85;
}

.offices-guidance {
	padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	background-color: var(--em-color-surface-soft);
}

@media (max-width: 991.98px) {
	.office-map-shell,
	.office-map-shell iframe {
		min-height: 18rem;
		height: 18rem;
	}
}

/* ── Generic pages ────────────────────────────────── */
.default-page-title,
.topic-page-title {
	font-size: clamp(2rem, 1.6rem + 1.4vw, 3rem);
	line-height: 1.05;
	letter-spacing: -0.04em;
}

.default-page-media,
.topic-page-media {
	min-height: 22rem;
}

.default-page-content,
.topic-page-content {
	max-width: 48rem;
}

.default-page-content > * + *,
.topic-page-content > * + * {
	margin-top: 1.25rem;
}

.default-page-content h2,
.topic-page-content h2 {
	margin-top: 2.25rem;
	font-size: clamp(1.35rem, 1.2rem + 0.4vw, 1.7rem);
	letter-spacing: -0.02em;
}

.default-page-content p,
.default-page-content li,
.topic-page-content p,
.topic-page-content li {
	color: var(--em-color-text-muted);
	line-height: 1.9;
}

.default-page-aside,
.topic-page-aside {
	position: sticky;
	top: 2rem;
	padding: 1.5rem;
	border: 1px solid var(--em-color-border);
	border-radius: 1.5rem;
	background-color: var(--em-color-surface);
}

.topic-page-highlight {
	padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
	background-color: var(--em-color-surface-soft);
}

@media (max-width: 991.98px) {
	.default-page-media,
	.topic-page-media {
		min-height: 18rem;
	}

	.default-page-aside,
	.topic-page-aside {
		position: static;
	}
}
