/* ==========================================================================
   ADARA BEAUTY — "Botanical Sanctuary"
   Warm countryside-luxe design system. Classic theme stylesheet.
   ========================================================================== */

/* ----------------------------------------------------------------- Fonts -- */
@font-face {
	font-family: "Fraunces";
	src: url("../fonts/Fraunces-Variable.woff2") format("woff2-variations");
	font-weight: 300 900;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: "Fraunces";
	src: url("../fonts/Fraunces-Italic-Variable.woff2") format("woff2-variations");
	font-weight: 300 900;
	font-style: italic;
	font-display: swap;
}
@font-face {
	font-family: "Hanken Grotesk";
	src: url("../fonts/HankenGrotesk-Variable.woff2") format("woff2-variations");
	font-weight: 100 900;
	font-style: normal;
	font-display: swap;
}

/* ---------------------------------------------------------------- Tokens -- */
:root {
	/* color */
	--c-ivory: #f7f3ec;
	--c-card: #fcfaf5;
	--c-sage: #6e7a5e;
	--c-sage-700: #59634b;
	--c-clay: #c08457;
	--c-clay-600: #a86f45;
	--c-clay-text: #8f5d38;       /* clay used as TEXT on light bg — AA 5.0:1 */
	--c-clay-btn: #9a6238;        /* clay fill behind white text — AA 5.0:1 */
	--c-clay-btn-hover: #875327;
	--c-forest: #2e3a2c;
	--c-forest-800: #243023;
	--c-ink: #20211c;
	--c-ink-70: rgba(32, 33, 28, .7);
	--c-ink-45: rgba(32, 33, 28, .45);
	--c-line: rgba(46, 58, 44, .14);
	--c-line-strong: rgba(46, 58, 44, .26);

	--bg: var(--c-ivory);
	--surface: var(--c-card);
	--text: var(--c-ink);
	--text-muted: var(--c-ink-70);
	--brand: var(--c-sage);
	--accent: var(--c-clay);
	--on-dark: #efe9dd;
	--on-dark-muted: rgba(239, 233, 221, .72);

	/* type */
	--ff-display: "Fraunces", Georgia, "Times New Roman", serif;
	--ff-body: "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;

	--fs-200: clamp(.75rem, .72rem + .14vw, .82rem);
	--fs-300: clamp(.875rem, .85rem + .12vw, .94rem);
	--fs-400: clamp(1rem, .97rem + .16vw, 1.07rem);
	--fs-500: clamp(1.125rem, 1.04rem + .42vw, 1.38rem);
	--fs-600: clamp(1.375rem, 1.18rem + .9vw, 1.9rem);
	--fs-700: clamp(1.75rem, 1.38rem + 1.65vw, 2.85rem);
	--fs-800: clamp(2.25rem, 1.65rem + 2.7vw, 3.85rem);
	--fs-900: clamp(2.75rem, 1.85rem + 4.3vw, 5.4rem);

	--lh-tight: 1.06;
	--lh-snug: 1.18;
	--lh-body: 1.66;
	--track-eyebrow: .18em;
	--track-tight: -.02em;

	/* space */
	--sp-1: .25rem; --sp-2: .5rem; --sp-3: .75rem; --sp-4: 1rem;
	--sp-5: 1.5rem; --sp-6: 2rem; --sp-7: 3rem; --sp-8: 4rem; --sp-9: 6rem; --sp-10: 8rem;
	--section-y: clamp(3.5rem, 2rem + 6vw, 8rem);
	--gutter: clamp(1.25rem, .8rem + 2vw, 2.5rem);

	/* layout */
	--container: 1200px;
	--container-wide: 1440px;
	--container-narrow: 760px;

	/* radii */
	--r-sm: 6px; --r-md: 12px; --r-lg: 20px; --r-xl: 34px; --r-pill: 999px;
	--r-organic: 58% 42% 47% 53% / 53% 47% 53% 47%;
	--r-organic-2: 42% 58% 56% 44% / 47% 53% 47% 53%;

	/* shadows (warm) */
	--sh-sm: 0 1px 2px rgba(46, 58, 44, .06), 0 1px 1px rgba(46, 58, 44, .04);
	--sh-md: 0 8px 22px rgba(46, 58, 44, .09);
	--sh-lg: 0 22px 48px rgba(46, 58, 44, .14);
	--sh-clay: 0 12px 26px rgba(192, 132, 87, .26);

	/* motion */
	--ease-out: cubic-bezier(.22, .61, .36, 1);
	--ease-soft: cubic-bezier(.4, 0, .2, 1);
	--dur-fast: 140ms; --dur: 280ms; --dur-slow: 560ms;
	--reveal-shift: 26px;

	--grain-opacity: .04;
}

@media (prefers-reduced-motion: reduce) {
	:root { --dur-fast: 0ms; --dur: 0ms; --dur-slow: 0ms; --reveal-shift: 0px; }
	* { scroll-behavior: auto !important; }
	.booking-skeleton__spinner, .hero__img { animation: none !important; }
}

/* ------------------------------------------------------------------ Reset -- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
	font-family: var(--ff-body);
	font-size: var(--fs-400);
	line-height: var(--lh-body);
	color: var(--text);
	background: var(--bg);
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
svg { fill: currentColor; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: 0; }
ul, ol { list-style: none; padding: 0; }
:focus-visible { outline: 2px solid var(--c-forest); outline-offset: 3px; border-radius: 3px; }

/* Subtle film grain over the whole page */
body.has-grain::after {
	content: "";
	position: fixed;
	inset: 0;
	z-index: 9999;
	pointer-events: none;
	opacity: var(--grain-opacity);
	mix-blend-mode: multiply;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ------------------------------------------------------------- Typography -- */
h1, h2, h3, h4 { font-family: var(--ff-display); font-weight: 460; line-height: var(--lh-snug); letter-spacing: var(--track-tight); color: var(--text); font-optical-sizing: auto; }
h1 { font-size: var(--fs-800); line-height: var(--lh-tight); }
h2 { font-size: var(--fs-700); }
h3 { font-size: var(--fs-600); }
h4 { font-size: var(--fs-500); }
h1 em, h2 em, h3 em, .hero__title em { font-style: italic; font-weight: 380; color: var(--c-clay-600); }
p { max-width: 68ch; }
p a { color: var(--c-sage-700); text-decoration: underline; text-underline-offset: .18em; text-decoration-thickness: 1px; transition: color var(--dur-fast); }
p a:hover { color: var(--c-clay-text); }
strong { font-weight: 600; }

.eyebrow {
	font-family: var(--ff-body);
	font-size: var(--fs-200);
	font-weight: 600;
	letter-spacing: var(--track-eyebrow);
	text-transform: uppercase;
	color: var(--c-clay-text);
	margin: 0;
}
.lead { font-size: var(--fs-500); line-height: 1.5; color: var(--text-muted); }
.muted { color: var(--text-muted); }
.serif { font-family: var(--ff-display); }

/* --------------------------------------------------------------- Layout --- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.container--narrow { max-width: var(--container-narrow); }
.container--wide { max-width: var(--container-wide); }
.section { padding-block: var(--section-y); }
.section--tight { padding-block: clamp(2.5rem, 1.5rem + 4vw, 5rem); }
.section--forest { background: var(--c-forest); color: var(--on-dark); }
.section--forest h1, .section--forest h2, .section--forest h3 { color: var(--on-dark); }
.section--forest .eyebrow { color: #d8b48c; }
.section--sage-tint { background: linear-gradient(180deg, var(--bg), #eef0e6); }
.section--card { background: var(--surface); }

.grid { display: grid; gap: var(--gutter); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
.grid--auto { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid--auto-lg { grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); }

.stack > * + * { margin-top: var(--sp-4); }
.center { text-align: center; }
.flow > * + * { margin-top: 1em; }

/* ---------------------------------------------------------- Reveal anim --- */
.js [data-reveal] {
	opacity: 0;
	transform: translateY(var(--reveal-shift));
	transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out);
	transition-delay: var(--reveal-delay, 0ms);
}
.js [data-reveal].is-visible { opacity: 1; transform: none; }

/* -------------------------------------------------------------- Buttons --- */
.btn {
	display: inline-flex; align-items: center; gap: .5em;
	font-family: var(--ff-body); font-weight: 600; font-size: var(--fs-300);
	letter-spacing: .01em;
	padding: .85em 1.5em;
	border-radius: var(--r-pill);
	transition: transform var(--dur) var(--ease-out), background var(--dur), color var(--dur), box-shadow var(--dur), border-color var(--dur);
	will-change: transform;
	line-height: 1;
	border: 1.5px solid transparent;
	white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
.btn--primary { background: var(--c-clay-btn); color: #fff; box-shadow: var(--sh-clay); }
.btn--primary:hover { background: var(--c-clay-btn-hover); }
.btn--secondary { border-color: var(--c-sage); color: var(--c-sage-700); background: transparent; }
.btn--secondary:hover { background: var(--c-sage-700); color: #fff; border-color: var(--c-sage-700); }
.btn--ghost { padding-inline: 0; border-radius: 0; }
.btn--ghost::after { content: ""; }
.btn--light { background: var(--on-dark); color: var(--c-forest); }
.btn--light:hover { background: #fff; }
.btn--outline-light { border-color: rgba(239, 233, 221, .5); color: var(--on-dark); }
.btn--outline-light:hover { background: rgba(239, 233, 221, .12); border-color: var(--on-dark); }
.btn--lg { padding: 1.05em 1.9em; font-size: var(--fs-400); }
.btn--block { width: 100%; justify-content: center; }
.btn__leaf { width: 1em; height: 1em; opacity: 0; max-width: 0; transition: opacity var(--dur), max-width var(--dur); }
.btn--primary:hover .btn__leaf { opacity: 1; max-width: 1em; }

.link-arrow {
	display: inline-flex; align-items: center; gap: .4em;
	font-weight: 600; font-size: var(--fs-300); color: var(--c-sage-700);
	letter-spacing: .01em;
}
.link-arrow svg { width: 1.05em; transition: transform var(--dur) var(--ease-out); }
.link-arrow:hover svg { transform: translateX(4px); }
.link-arrow:hover { color: var(--c-clay-text); }

/* -------------------------------------------------------- Pills / chips --- */
.pill {
	display: inline-flex; align-items: center; gap: .4em;
	font-size: var(--fs-200); font-weight: 600;
	padding: .4em .8em; border-radius: var(--r-pill);
	background: rgba(110, 122, 94, .12); color: var(--c-sage-700);
	white-space: nowrap;
}
.pill__icon { width: 1em; height: 1em; opacity: .8; }
.chip {
	display: inline-flex; align-items: center;
	font-size: var(--fs-200); font-weight: 500;
	padding: .35em .7em; border-radius: var(--r-pill);
	border: 1px solid var(--c-line-strong); color: var(--text-muted);
	background: transparent;
}
.chip-row { display: flex; flex-wrap: wrap; gap: .4rem; }
.badge {
	display: inline-flex; align-items: center; gap: .35em;
	font-size: var(--fs-200); font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
	padding: .4em .75em; border-radius: var(--r-pill);
	background: var(--c-clay-btn); color: #fff;
}
.badge--signature { background: var(--c-forest); }

/* ------------------------------------------------------------- Price row -- */
.price-row { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; }
.price { font-family: var(--ff-display); font-size: var(--fs-500); font-weight: 500; color: var(--c-forest); font-variant-numeric: tabular-nums; }
.price__from { font-family: var(--ff-body); font-size: .6em; font-weight: 500; color: var(--text-muted); text-transform: lowercase; }
.price--enquiry { font-size: var(--fs-400); font-style: italic; color: var(--c-sage-700); }

/* ----------------------------------------------------- Section heading ---- */
.section-head { display: grid; gap: var(--sp-3); margin-bottom: var(--sp-7); }
.section-head--center { justify-items: center; text-align: center; margin-inline: auto; max-width: 760px; }
.section-head--left { justify-items: start; text-align: left; }
.section-head__title { margin: 0; }
.section-head__text { color: var(--text-muted); font-size: var(--fs-500); line-height: 1.5; max-width: 60ch; }
.section-head--dark .section-head__text { color: var(--on-dark-muted); }
.section-head__divider { color: var(--c-sage); opacity: .8; }
.section-head__divider svg { width: 72px; height: auto; }
.section-head--left .section-head__divider svg { width: 60px; }

/* ============================================================== TOPBAR ==== */
.topbar { background: var(--c-forest); color: var(--on-dark); font-size: var(--fs-300); }
.topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 42px; padding-block: .35rem; }
.topbar a { display: inline-flex; align-items: center; gap: .45em; }
.topbar a:hover { color: #fff; }
.topbar__left { display: flex; align-items: center; gap: 1.5rem; }
.topbar__status { display: inline-flex; align-items: center; gap: .45em; color: var(--on-dark-muted); }
.topbar__dot { width: 7px; height: 7px; border-radius: 50%; background: #b9c69e; box-shadow: 0 0 0 3px rgba(185, 198, 158, .25); }
.topbar__dot--closed { background: #cf9b86; box-shadow: 0 0 0 3px rgba(207, 155, 134, .25); }
.topbar svg { width: 1.05em; height: 1.05em; }
@media (max-width: 760px) { .topbar__status, .topbar__sep { display: none; } }

/* ============================================================== HEADER ==== */
.site-header { position: sticky; top: 0; z-index: 100; background: transparent; transition: background var(--dur), box-shadow var(--dur), border-color var(--dur); border-bottom: 1px solid transparent; }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; min-height: 78px; }
.is-front .site-header { background: var(--bg); } /* solid by default; hero handles its own bg */
.site-header.is-stuck { background: rgba(247, 243, 236, .92); backdrop-filter: blur(10px); box-shadow: var(--sh-sm); border-bottom-color: var(--c-line); }

.brand { display: inline-flex; align-items: center; gap: .6rem; flex-shrink: 0; }
.brand--logo { line-height: 0; }
.custom-logo-link { display: inline-flex; align-items: center; line-height: 0; }
.custom-logo { height: 52px; width: auto; max-width: 220px; max-height: 52px; }
@media (max-width: 600px) { .custom-logo { height: 44px; max-height: 44px; } }
.brand__text { font-family: var(--ff-display); font-size: 1.5rem; font-weight: 500; letter-spacing: .01em; color: var(--c-forest); line-height: 1; }
.brand__text span { display: block; font-family: var(--ff-body); font-size: .58rem; letter-spacing: .34em; text-transform: uppercase; color: var(--c-sage-700); margin-top: .35em; font-weight: 600; }

/* primary nav */
.primary-nav__list { display: flex; align-items: center; gap: clamp(.5rem, 1.4vw, 1.6rem); list-style: none; margin: 0; padding: 0; }
.primary-nav .nav-item { position: relative; }
.nav-link { display: inline-flex; align-items: center; gap: .3em; padding: .6rem .2rem; font-size: var(--fs-300); font-weight: 500; color: var(--text); position: relative; }
.nav-link__chev svg { width: .7em; transition: transform var(--dur); }
.nav-item--has-dropdown:hover .nav-link__chev svg, .nav-item--has-dropdown:focus-within .nav-link__chev svg { transform: rotate(180deg); }
.nav-link::after { content: ""; position: absolute; left: .2rem; right: .2rem; bottom: .35rem; height: 2px; background: var(--c-sage); border-radius: 2px; transform: scaleX(0); transform-origin: left; transition: transform var(--dur) var(--ease-out); }
.nav-item:hover > .nav-link::after, .nav-item.is-current > .nav-link::after { transform: scaleX(1); }

.nav-dropdown {
	position: absolute; top: calc(100% + 6px); left: 50%; transform: translateX(-50%) translateY(8px);
	min-width: 240px; background: var(--surface); border: 1px solid var(--c-line);
	border-radius: var(--r-md); box-shadow: var(--sh-lg); padding: .6rem;
	display: grid; gap: 2px; opacity: 0; visibility: hidden; transition: opacity var(--dur), transform var(--dur); z-index: 50;
}
.nav-item--has-dropdown:hover > .nav-dropdown, .nav-item--has-dropdown:focus-within > .nav-dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.nav-dropdown .nav-link { display: block; padding: .55rem .8rem; border-radius: var(--r-sm); font-weight: 500; width: 100%; }
.nav-dropdown .nav-link::after { display: none; }
.nav-dropdown .nav-cat .nav-link:hover, .nav-dropdown li:hover > .nav-link { background: rgba(110, 122, 94, .1); color: var(--c-sage-700); }

.header__actions { display: flex; align-items: center; gap: .9rem; flex-shrink: 0; }
.header__icon { position: relative; display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: var(--r-pill); color: var(--text); transition: background var(--dur), color var(--dur); }
.header__icon:hover { background: rgba(110, 122, 94, .12); color: var(--c-sage-700); }
.header__icon svg { width: 20px; height: 20px; }
.cart-count { position: absolute; top: 2px; right: 0; min-width: 18px; height: 18px; padding: 0 4px; border-radius: var(--r-pill); background: var(--c-clay-btn); color: #fff; font-size: 11px; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.header__actions .btn { padding-block: .7em; }

.nav-toggle { display: none; width: 44px; height: 44px; align-items: center; justify-content: center; }
.nav-toggle svg { width: 26px; height: 26px; }

@media (max-width: 1024px) {
	.primary-nav, .header__actions .btn--book-desktop { display: none; }
	.nav-toggle { display: inline-flex; }
}

/* --------------------------------------------------------- Mobile drawer -- */
.drawer-overlay { position: fixed; inset: 0; background: rgba(36, 48, 35, .5); opacity: 0; visibility: hidden; transition: opacity var(--dur); z-index: 200; backdrop-filter: blur(2px); }
.mobile-drawer {
	position: fixed; top: 0; right: 0; bottom: 0; width: min(86vw, 380px);
	background: var(--c-forest); color: var(--on-dark); z-index: 210;
	transform: translateX(100%); transition: transform var(--dur-slow) var(--ease-out);
	display: flex; flex-direction: column; padding: 1.5rem; overflow-y: auto;
}
body.drawer-open { overflow: hidden; }
body.drawer-open .drawer-overlay { opacity: 1; visibility: visible; }
body.drawer-open .mobile-drawer { transform: translateX(0); }
.drawer__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 2rem; }
.drawer__close { width: 44px; height: 44px; color: var(--on-dark); display: inline-flex; align-items: center; justify-content: center; }
.drawer__close svg { width: 24px; }
.drawer__nav { display: grid; gap: .25rem; }
.drawer__nav a { font-family: var(--ff-display); font-size: 1.6rem; padding: .55rem 0; color: var(--on-dark); border-bottom: 1px solid rgba(239, 233, 221, .12); transition: color var(--dur), padding-left var(--dur); }
.drawer__nav a:hover { color: #fff; padding-left: .4rem; }
.drawer__cats { margin-top: .25rem; padding-left: .6rem; display: grid; gap: .1rem; }
.drawer__cats a { font-family: var(--ff-body); font-size: 1rem; color: var(--on-dark-muted); border: 0; padding: .4rem 0; }
.drawer__foot { margin-top: auto; padding-top: 2rem; display: grid; gap: 1rem; }
.drawer__foot .btn { width: 100%; justify-content: center; }
.drawer__contact { color: var(--on-dark-muted); font-size: var(--fs-300); display: grid; gap: .4rem; }
.drawer__contact a { color: var(--on-dark); }

/* ================================================================ HERO ==== */
.hero { position: relative; padding-block: clamp(3rem, 2rem + 8vw, 7rem) clamp(3.5rem, 2rem + 7vw, 8rem); overflow: hidden; }
.hero__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.hero__content { max-width: 36rem; }
.hero__title { font-size: var(--fs-900); line-height: var(--lh-tight); margin: .4em 0 .5em; }
.hero__sub { font-size: var(--fs-500); color: var(--text-muted); line-height: 1.5; max-width: 34ch; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2rem; }
.hero__media { position: relative; }
.hero__img { border-radius: var(--r-organic); aspect-ratio: 4/5; width: 100%; object-fit: cover; box-shadow: var(--sh-lg); animation: morph 18s ease-in-out infinite alternate; }
.hero__badge { position: absolute; background: var(--surface); border: 1px solid var(--c-line); box-shadow: var(--sh-md); border-radius: var(--r-md); padding: .9rem 1.1rem; display: flex; align-items: center; gap: .7rem; }
.hero__badge--tl { top: 6%; left: -6%; }
.hero__badge--br { bottom: 8%; right: -4%; }
.hero__badge .num { font-family: var(--ff-display); font-size: 1.5rem; color: var(--c-clay-text); line-height: 1; }
.hero__badge .lab { font-size: var(--fs-200); color: var(--text-muted); line-height: 1.2; }
.hero__sprig { position: absolute; color: var(--c-sage); opacity: .35; pointer-events: none; }
.hero__sprig--1 { top: -2rem; right: 38%; width: 120px; transform: rotate(12deg); }
.hero__trust { display: flex; align-items: center; gap: 1.2rem; margin-top: 2.4rem; color: var(--text-muted); font-size: var(--fs-300); flex-wrap: wrap; }
.hero__trust .leaf-rating { color: var(--c-clay); }

@keyframes morph {
	0% { border-radius: var(--r-organic); }
	100% { border-radius: var(--r-organic-2); }
}
@media (prefers-reduced-motion: reduce) { .hero__img { animation: none; } }

@media (max-width: 900px) {
	.hero__grid { grid-template-columns: 1fr; }
	.hero__media { max-width: 460px; margin-inline: auto; order: -1; }
	.hero__badge--tl { left: 0; }
	.hero__badge--br { right: 0; }
}

/* =============================================================== CARDS ==== */
.card { background: var(--surface); border: 1px solid var(--c-line); border-radius: var(--r-lg); overflow: hidden; transition: transform var(--dur) var(--ease-out), box-shadow var(--dur); display: flex; flex-direction: column; height: 100%; }
.card:hover { transform: translateY(-6px); box-shadow: var(--sh-lg); }
.card__media { position: relative; aspect-ratio: 4/3; overflow: hidden; background: #e9e4d8; }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease-out); }
.card:hover .card__media img { transform: scale(1.05); }
.card__body { padding: 1.4rem 1.4rem 1.6rem; display: flex; flex-direction: column; gap: .7rem; flex: 1; }
.card__title { font-size: var(--fs-600); line-height: 1.15; }
.card__title a { transition: color var(--dur); }
.card:hover .card__title a { color: var(--c-clay-600); }
.card__desc { color: var(--text-muted); font-size: var(--fs-300); line-height: 1.55; }
.card__foot { margin-top: auto; padding-top: .5rem; display: flex; align-items: center; justify-content: space-between; gap: .75rem; }
.card__badge { position: absolute; top: .9rem; left: .9rem; z-index: 2; }
.img-placeholder { display: grid; place-items: center; width: 100%; height: 100%; background: linear-gradient(135deg, #ece6d8, #e2ddcd); color: var(--c-sage); }
.img-placeholder svg { width: 40%; opacity: .5; }

/* Category card (image with overlaid label) */
.cat-card { position: relative; display: block; border-radius: var(--r-lg); overflow: hidden; aspect-ratio: 3/4; box-shadow: var(--sh-sm); transition: transform var(--dur) var(--ease-out), box-shadow var(--dur); }
.cat-card:hover { transform: translateY(-6px); box-shadow: var(--sh-lg); }
.cat-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease-out); }
.cat-card:hover img { transform: scale(1.06); }
.cat-card__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(36, 48, 35, .82) 0%, rgba(36, 48, 35, .2) 45%, transparent 75%); }
.cat-card--noimg { background: linear-gradient(155deg, var(--c-sage) 0%, var(--c-forest) 100%); }
.cat-card--noimg .cat-card__title, .cat-card--noimg .cat-card__meta { color: #fff; }
.cat-card__motif { position: absolute; top: 1.2rem; right: 1.2rem; width: 64px; color: rgba(255,255,255,.35); }
.cat-card__motif svg { width: 100%; height: auto; }
.cat-card__body { position: absolute; left: 0; right: 0; bottom: 0; padding: 1.4rem; color: #fff; }
.cat-card__title { font-family: var(--ff-display); font-size: var(--fs-600); color: #fff; line-height: 1.1; }
.cat-card__meta { font-size: var(--fs-200); color: rgba(255, 255, 255, .8); margin-top: .3rem; display: flex; align-items: center; gap: .5rem; }
.cat-card__count { display: inline-flex; align-items: center; gap: .3em; white-space: nowrap; }

/* Treatment list-row (category page) */
.treatment-row { display: grid; grid-template-columns: 1fr auto; gap: 1rem 2rem; align-items: start; padding: 1.5rem 0; border-bottom: 1px solid var(--c-line); }
.treatment-row:last-child { border-bottom: 0; }
.treatment-row__head { display: flex; align-items: baseline; gap: .75rem; flex-wrap: wrap; }
.treatment-row__title { font-size: var(--fs-500); font-weight: 500; font-family: var(--ff-display); }
.treatment-row__title a:hover { color: var(--c-clay-600); }
.treatment-row__desc { color: var(--text-muted); font-size: var(--fs-300); margin-top: .4rem; max-width: 60ch; }
.treatment-row__meta { display: flex; flex-direction: column; align-items: flex-end; gap: .6rem; text-align: right; }
.treatment-row__chips { margin-top: .6rem; }
@media (max-width: 600px) {
	.treatment-row { grid-template-columns: 1fr; }
	.treatment-row__meta { align-items: flex-start; text-align: left; flex-direction: row; justify-content: space-between; width: 100%; }
}

/* Team card */
.team-card { text-align: center; display: grid; gap: 1rem; }
.team-card__media { aspect-ratio: 4/5; border-radius: var(--r-organic); overflow: hidden; box-shadow: var(--sh-md); }
.team-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow); }
.team-card:hover .team-card__media img { transform: scale(1.04); }
.team-card__name { font-family: var(--ff-display); font-size: var(--fs-600); }
.team-card__role { color: var(--c-clay-600); font-weight: 600; font-size: var(--fs-300); }
.team-card__quote { color: var(--text-muted); font-style: italic; font-family: var(--ff-display); }

/* =========================================================== TESTIMONIALS = */
.testimonials { position: relative; }
.testi-track { display: flex; gap: var(--gutter); overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: 1rem; scrollbar-width: none; }
.testi-track::-webkit-scrollbar { display: none; }
.testi-track:focus-visible { outline: 2px solid var(--on-dark); outline-offset: 4px; border-radius: var(--r-md); }
.testi-card { scroll-snap-align: start; flex: 0 0 min(420px, 82vw); background: var(--surface); color: var(--text); border: 1px solid var(--c-line); border-radius: var(--r-lg); padding: 2rem; display: grid; gap: 1rem; box-shadow: var(--sh-sm); }
.testi-card__mark { font-family: var(--ff-display); font-size: 3.5rem; line-height: .6; color: var(--c-clay); opacity: .5; height: 1.4rem; }
.testi-card__text { font-family: var(--ff-display); font-style: italic; font-size: var(--fs-500); line-height: 1.45; color: var(--c-forest); }
.testi-card__foot { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-top: .4rem; }
.testi-card__author { font-weight: 600; }
.testi-card__source { font-size: var(--fs-200); color: var(--text-muted); display: inline-flex; align-items: center; gap: .35em; }
.leaf-rating { display: inline-flex; gap: 2px; color: var(--c-clay); }
.leaf-rating svg { width: 16px; height: 16px; }
.testi-nav { display: flex; gap: .6rem; justify-content: center; margin-top: 1.5rem; }
.testi-nav button { width: 46px; height: 46px; border-radius: var(--r-pill); border: 1.5px solid var(--c-line-strong); color: var(--c-forest); display: inline-flex; align-items: center; justify-content: center; transition: background var(--dur), color var(--dur), border-color var(--dur); }
.testi-nav button:hover { background: var(--c-sage); color: #fff; border-color: var(--c-sage); }
.testi-nav svg { width: 18px; }

/* ============================================================ ACCORDION === */
.accordion { border-top: 1px solid var(--c-line); }
.accordion__item { border-bottom: 1px solid var(--c-line); }
.accordion__btn { display: flex; align-items: center; justify-content: space-between; gap: 1rem; width: 100%; padding: 1.3rem 0; text-align: left; font-family: var(--ff-display); font-size: var(--fs-500); color: var(--text); }
.accordion__icon { position: relative; width: 22px; height: 22px; flex-shrink: 0; }
.accordion__icon::before, .accordion__icon::after { content: ""; position: absolute; background: var(--c-clay); border-radius: 2px; transition: transform var(--dur); }
.accordion__icon::before { top: 50%; left: 0; right: 0; height: 2px; transform: translateY(-50%); }
.accordion__icon::after { left: 50%; top: 0; bottom: 0; width: 2px; transform: translateX(-50%); }
.accordion__btn[aria-expanded="true"] .accordion__icon::after { transform: translateX(-50%) scaleY(0); }
.accordion__panel { overflow: hidden; height: 0; transition: height var(--dur) var(--ease-soft); }
.accordion__panel-inner { padding-bottom: 1.3rem; color: var(--text-muted); max-width: 70ch; }

/* ============================================================ HOURS ======= */
.hours-table { width: 100%; border-collapse: collapse; }
.hours-table td { padding: .7rem 0; border-bottom: 1px solid var(--c-line); font-size: var(--fs-300); }
.hours-table td:last-child { text-align: right; font-variant-numeric: tabular-nums; color: var(--text-muted); }
.hours-table tr.is-today td { color: var(--c-forest); font-weight: 700; }
.hours-table tr.is-today td:last-child { color: var(--c-forest); }
.hours-table tr.is-today { background: linear-gradient(90deg, rgba(110, 122, 94, .08), transparent); }
.status-pill { display: inline-flex; align-items: center; gap: .4em; font-size: var(--fs-200); font-weight: 700; padding: .3em .7em; border-radius: var(--r-pill); }
.status-pill--open { background: #e6ebdf; color: #4a523c; }
.status-pill--closed { background: #f1e3d5; color: #79491f; }

/* ============================================================ NEWSLETTER == */
.newsletter { position: relative; overflow: hidden; }
.newsletter__form { display: flex; gap: .6rem; max-width: 480px; margin-top: 1.5rem; }
.newsletter__form input { flex: 1; padding: .9em 1.2em; border-radius: var(--r-pill); border: 1.5px solid rgba(239, 233, 221, .3); background: rgba(239, 233, 221, .08); color: var(--on-dark); }
.newsletter__form input::placeholder { color: var(--on-dark-muted); }
.newsletter__form input:focus { border-color: var(--on-dark); outline: 2px solid var(--on-dark); outline-offset: 1px; }
.newsletter__sprig { position: absolute; right: -2%; bottom: -10%; width: 220px; color: #d8b48c; opacity: .25; }
@media (max-width: 540px) { .newsletter__form { flex-direction: column; } .newsletter__form .btn { width: 100%; justify-content: center; } }

/* ============================================================ BOOKING ===== */
.booking-section { position: relative; }
.booking-embed { background: var(--surface); border: 1px solid var(--c-line); border-radius: var(--r-lg); padding: clamp(1rem, 3vw, 2rem); box-shadow: var(--sh-md); min-height: 620px; margin-top: 2rem; }
.booking-embed .si-widget { min-height: 580px; }
.booking-embed iframe { width: 100%; border: 0; border-radius: var(--r-md); }
.booking-skeleton { display: grid; place-items: center; gap: 1rem; min-height: 560px; color: var(--text-muted); text-align: center; }
.booking-skeleton__spinner { width: 42px; height: 42px; border-radius: 50%; border: 3px solid var(--c-line); border-top-color: var(--c-sage); animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.booking-fallback { display: flex; align-items: center; justify-content: center; gap: 1rem; flex-wrap: wrap; margin-top: 1.5rem; color: var(--text-muted); font-size: var(--fs-300); }

/* ============================================================ FEATURE BAND  */
.feature { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.feature--reverse .feature__media { order: 2; }
.feature__media img { border-radius: var(--r-organic); aspect-ratio: 1/1; object-fit: cover; width: 100%; box-shadow: var(--sh-lg); }
.feature__body { max-width: 38rem; }
.feature__media .visit-photo { aspect-ratio: 4 / 3; border-radius: var(--r-lg); object-fit: cover; width: 100%; box-shadow: var(--sh-lg); }
@media (max-width: 820px) { .feature { grid-template-columns: 1fr; } .feature--reverse .feature__media { order: -1; } }

/* "Why Adara" promise items */
.promises { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--gutter); }
.promise { display: grid; gap: .7rem; }
.promise__icon { width: 54px; height: 54px; border-radius: var(--r-pill); display: grid; place-items: center; background: rgba(110, 122, 94, .12); color: var(--c-sage-700); }
.promise__icon svg { width: 26px; height: 26px; }
.promise__title { font-family: var(--ff-display); font-size: var(--fs-500); }
.promise__text { color: var(--text-muted); font-size: var(--fs-300); }

/* ========================================================= BREADCRUMB/PAGE  */
.breadcrumbs { font-size: var(--fs-200); color: var(--text-muted); padding-block: 1rem; }
.breadcrumbs a:hover { color: var(--c-sage-700); }
.breadcrumbs__sep { margin-inline: .5rem; opacity: .5; }
.page-hero { padding-block: clamp(2.5rem, 2rem + 4vw, 5rem) clamp(1.5rem, 1rem + 2vw, 2.5rem); text-align: center; }
.page-hero .eyebrow { margin-bottom: .8rem; }
.page-hero__title { font-size: var(--fs-800); }
.page-hero__intro { color: var(--text-muted); font-size: var(--fs-500); max-width: 56ch; margin: 1rem auto 0; }

.pagination ul { display: flex; gap: .4rem; justify-content: center; margin-top: 3rem; }
.pagination a, .pagination span { display: inline-flex; min-width: 44px; height: 44px; align-items: center; justify-content: center; border-radius: var(--r-pill); border: 1px solid var(--c-line); }
.pagination .current { background: var(--c-sage); color: #fff; border-color: var(--c-sage); }
.pagination a:hover { background: rgba(110, 122, 94, .12); }

/* =============================================================== FORMS ==== */
.field { display: grid; gap: .4rem; margin-bottom: 1.1rem; }
.field label { font-size: var(--fs-300); font-weight: 600; }
.input, input[type="text"], input[type="email"], input[type="tel"], input[type="search"], textarea, select {
	width: 100%; padding: .85em 1em; border-radius: var(--r-md); border: 1.5px solid var(--c-line-strong); background: var(--surface); color: var(--text); transition: border-color var(--dur), box-shadow var(--dur);
}
.input:focus, input:focus, textarea:focus, select:focus { outline: 2px solid var(--c-forest); outline-offset: 1px; border-color: var(--c-sage); box-shadow: 0 0 0 3px rgba(110, 122, 94, .18); }
textarea { min-height: 140px; resize: vertical; }

/* =============================================================== FOOTER === */
.site-footer { background: var(--c-forest); color: var(--on-dark-muted); position: relative; }
.site-footer__divider { color: var(--c-sage); opacity: .4; display: flex; justify-content: center; padding-top: 2.5rem; }
.site-footer__divider svg { width: 90px; }
.site-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 2.5rem; padding-block: 3.5rem; }
.site-footer h4, .site-footer .footer-h { color: var(--on-dark); font-family: var(--ff-body); font-size: var(--fs-300); text-transform: uppercase; letter-spacing: .12em; margin-bottom: 1.2rem; font-weight: 700; line-height: 1.2; }
.site-footer a:hover { color: #fff; }
.footer-brand__name { font-family: var(--ff-display); font-size: 1.8rem; color: var(--on-dark); margin-bottom: 1rem; }
.footer-brand__name span { display: block; font-family: var(--ff-body); font-size: .55rem; letter-spacing: .34em; text-transform: uppercase; color: #d8b48c; margin-top: .4rem; }
.footer-menu { display: grid; gap: .6rem; font-size: var(--fs-300); }
.footer-contact { display: grid; gap: .8rem; font-size: var(--fs-300); }
.footer-contact .row { display: flex; gap: .6rem; align-items: flex-start; }
.footer-contact svg { width: 1.1em; margin-top: .15em; color: #d8b48c; flex-shrink: 0; }
.footer-social { display: flex; gap: .6rem; margin-top: 1.2rem; }
.footer-social a { width: 40px; height: 40px; border-radius: var(--r-pill); border: 1px solid rgba(239, 233, 221, .2); display: inline-flex; align-items: center; justify-content: center; transition: background var(--dur), border-color var(--dur); }
.footer-social a:hover { background: rgba(239, 233, 221, .12); border-color: var(--on-dark); }
.footer-social svg { width: 18px; }
.site-footer__bottom { border-top: 1px solid rgba(239, 233, 221, .12); padding-block: 1.5rem; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; font-size: var(--fs-200); }
@media (max-width: 900px) { .site-footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem; } }
@media (max-width: 560px) { .site-footer__grid { grid-template-columns: 1fr; } }

/* ================================================== Responsive grids ====== */
@media (max-width: 980px) { .grid--4 { grid-template-columns: repeat(2, 1fr); } .grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; } }

/* skip link */
.skip-link { position: absolute; left: -999px; top: 0; background: var(--c-forest); color: #fff; padding: .8rem 1.2rem; z-index: 9999; border-radius: 0 0 var(--r-sm) 0; }
.skip-link:focus { left: 0; }

/* ---- Inline icon sizing safety (an unsized <svg> with a viewBox fills its container) ---- */
.btn svg, .pill svg, .chip svg, .link-arrow svg, .topbar svg, .nav-link svg,
.footer-contact svg, .drawer__contact svg, .status-pill svg, .header__icon svg,
.hours svg, .field svg { width: 1.1em; height: 1.1em; flex-shrink: 0; }
.badge svg, .testi-card__source svg, .cat-card__meta svg { width: 1em; height: 1em; flex-shrink: 0; }
.booking-fallback svg { width: 1.3em; height: 1.3em; flex-shrink: 0; color: var(--c-sage-700); }
.map-placeholder svg { width: 2.4em; height: 2.4em; margin: 0 auto .6rem; }

/* ---- Form notices + honeypot ---- */
.hp-field { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form-notice { display: flex; align-items: center; gap: .5rem; padding: 1rem 1.2rem; border-radius: var(--r-md); margin-bottom: 1.5rem; font-size: var(--fs-300); }
.form-notice svg { width: 1.2em; height: 1.2em; flex-shrink: 0; }
.form-notice--ok { background: rgba(110,122,94,.14); color: var(--c-sage-700); border: 1px solid rgba(110,122,94,.3); }
.form-notice--err { background: rgba(164,81,63,.1); color: #8a3f30; border: 1px solid rgba(164,81,63,.3); }

/* ---- Cookie consent banner ---- */
.cookie-banner { position: fixed; left: 0; right: 0; bottom: 0; z-index: 300; background: var(--c-forest); color: var(--on-dark); box-shadow: 0 -8px 30px rgba(46,58,44,.25); }
.cookie-banner.is-hidden { display: none; }
.cookie-banner__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding-block: 1rem; flex-wrap: wrap; }
.cookie-banner__text { color: var(--on-dark-muted); font-size: var(--fs-300); margin: 0; max-width: 62ch; }
.cookie-banner__text a { color: var(--on-dark); text-decoration: underline; }
.cookie-banner__actions { display: flex; gap: .6rem; flex-shrink: 0; }
.cookie-banner__actions .btn--secondary { border-color: rgba(239,233,221,.5); color: var(--on-dark); }
.cookie-banner__actions .btn--secondary:hover { background: rgba(239,233,221,.12); color: #fff; border-color: var(--on-dark); }
.footer-legal { display: flex; gap: .25rem; flex-wrap: wrap; align-items: center; }
.footer-legal a:hover { color: #fff; }
@media (max-width: 600px) { .cookie-banner__inner { justify-content: stretch; } .cookie-banner__actions { width: 100%; } .cookie-banner__actions .btn { flex: 1; justify-content: center; } }

/* helpers */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.mt-0 { margin-top: 0; } .text-balance { text-wrap: balance; }
.divider-soft { height: 1px; background: var(--c-line); border: 0; margin-block: var(--sp-6); }
