/* ============================================================
   MIRAE SKIN ATELIER — Design System
   Modern Korean Beauty · Editorial Atelier
   ============================================================ */

/* ── 1. Tokens ─────────────────────────────────────────────── */
:root {
	/* Color: warm ivory base, blush, sage, deep espresso */
	--c-ink:        #1a1410;          /* primary text — warm espresso */
	--c-ink-soft:   #4a3f38;          /* secondary text */
	--c-ink-mute:   #8a7d72;          /* muted */
	--c-ivory:      #faf6f1;          /* base bg */
	--c-cream:      #f4ebe2;          /* secondary bg */
	--c-blush:      #f5d8cb;          /* accent blush */
	--c-blush-deep: #e8b3a0;          /* hover/active blush */
	--c-sage:       #c8d4c4;          /* accent sage */
	--c-sage-deep:  #95a994;
	--c-pearl:      #ebe4dc;          /* dividers / subtle bg */
	--c-bronze:     #b89968;          /* metallic accent */
	--c-rose:       #d68a87;          /* deep rose */

	/* Surface — for glassmorphism */
	--surface-1: rgba(255, 251, 247, 0.72);
	--surface-2: rgba(255, 251, 247, 0.92);
	--surface-glass-blur: 18px;
	--hairline: rgba(26, 20, 16, 0.08);
	--hairline-strong: rgba(26, 20, 16, 0.16);

	/* Typography */
	--ff-display: 'Fraunces', 'Times New Roman', serif;
	--ff-body:    'Inter Tight', system-ui, -apple-system, 'Segoe UI', sans-serif;
	--ff-mono:    'JetBrains Mono', ui-monospace, monospace;
	/* (Pretendard Hangul font removed — single Latin display + body system) */

	/* Type scale (fluid) */
	--fs-xs:   clamp(0.75rem, 0.72rem + 0.15vw, 0.8125rem);
	--fs-sm:   clamp(0.875rem, 0.83rem + 0.22vw, 0.9375rem);
	--fs-base: clamp(1rem, 0.95rem + 0.25vw, 1.0625rem);
	--fs-md:   clamp(1.125rem, 1.05rem + 0.4vw, 1.25rem);
	--fs-lg:   clamp(1.5rem, 1.3rem + 1vw, 1.875rem);
	--fs-xl:   clamp(2rem, 1.6rem + 2vw, 2.875rem);
	--fs-2xl:  clamp(2.75rem, 2rem + 3.5vw, 4.5rem);
	--fs-3xl:  clamp(3.75rem, 2.4rem + 6vw, 7.25rem);
	--fs-hero: clamp(4.5rem, 3rem + 8vw, 10.5rem);

	/* Spacing (fluid) */
	--sp-1:  clamp(0.25rem, 0.22rem + 0.15vw, 0.375rem);
	--sp-2:  clamp(0.5rem, 0.45rem + 0.25vw, 0.625rem);
	--sp-3:  clamp(0.75rem, 0.68rem + 0.35vw, 0.875rem);
	--sp-4:  clamp(1rem, 0.9rem + 0.5vw, 1.25rem);
	--sp-5:  clamp(1.5rem, 1.3rem + 1vw, 2rem);
	--sp-6:  clamp(2rem, 1.7rem + 1.5vw, 2.75rem);
	--sp-7:  clamp(3rem, 2.4rem + 3vw, 4.5rem);
	--sp-8:  clamp(4.5rem, 3.4rem + 5.5vw, 7.5rem);
	--sp-9:  clamp(6rem, 4rem + 10vw, 11rem);

	/* Layout */
	--container: 1320px;
	--container-narrow: 920px;
	--gutter: clamp(1.25rem, 1rem + 1.25vw, 2.25rem);
	--radius-xs: 8px;
	--radius-sm: 14px;
	--radius-md: 20px;
	--radius-lg: 32px;
	--radius-xl: 48px;
	--radius-pill: 999px;

	/* Motion */
	--ease-out: cubic-bezier(0.22, 1, 0.36, 1);
	--ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
	--ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
	--dur-fast: 220ms;
	--dur-base: 380ms;
	--dur-slow: 620ms;

	/* Shadow — layered, soft */
	--shadow-1: 0 1px 2px rgba(26,20,16,0.04), 0 2px 6px rgba(26,20,16,0.04);
	--shadow-2: 0 2px 4px rgba(26,20,16,0.05), 0 8px 18px rgba(26,20,16,0.06);
	--shadow-3: 0 6px 14px rgba(26,20,16,0.07), 0 24px 48px rgba(26,20,16,0.08);
	--shadow-glass: 0 1px 0 rgba(255,255,255,0.7) inset, 0 1px 2px rgba(26,20,16,0.04), 0 12px 32px rgba(26,20,16,0.06);
}

/* ── 2. Reset ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	background: var(--c-ivory);
	color: var(--c-ink);
	font-family: var(--ff-body);
	font-size: var(--fs-base);
	line-height: 1.6;
	font-feature-settings: 'ss01', 'cv11';
	min-height: 100vh;
	overflow-x: hidden;
}
img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { background: none; border: none; cursor: pointer; padding: 0; }
a { color: inherit; text-decoration: none; }
a:focus-visible, button:focus-visible {
	outline: 2px solid var(--c-ink);
	outline-offset: 3px;
	border-radius: 4px;
}
::selection { background: var(--c-blush); color: var(--c-ink); }

/* ── 3. Typography ────────────────────────────────────────── */
h1, h2, h3, h4, h5 {
	font-family: var(--ff-display);
	font-weight: 400;
	letter-spacing: -0.02em;
	line-height: 1.05;
	font-variation-settings: 'opsz' 96, 'SOFT' 30;
	color: var(--c-ink);
}
h1 { font-size: var(--fs-3xl); font-variation-settings: 'opsz' 144, 'SOFT' 50; letter-spacing: -0.035em; }
h2 { font-size: var(--fs-2xl); font-variation-settings: 'opsz' 96, 'SOFT' 40; letter-spacing: -0.025em; }
h3 { font-size: var(--fs-xl); font-variation-settings: 'opsz' 64, 'SOFT' 30; }
h4 { font-size: var(--fs-lg); font-variation-settings: 'opsz' 36, 'SOFT' 20; }

.h-display {
	font-family: var(--ff-display);
	font-weight: 300;
	font-style: italic;
	font-variation-settings: 'opsz' 144, 'SOFT' 80;
	letter-spacing: -0.04em;
	line-height: 0.92;
}
.eyebrow {
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--c-ink-soft);
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
}
.eyebrow::before {
	content: "";
	width: 24px;
	height: 1px;
	background: currentColor;
	display: inline-block;
	opacity: 0.4;
}
/* (deprecated .hangul utility — removed) */

p { font-size: var(--fs-base); line-height: 1.65; color: var(--c-ink-soft); max-width: 62ch; }
p.lead { font-size: var(--fs-md); color: var(--c-ink); line-height: 1.55; max-width: 56ch; }

/* Text utility */
.t-mono { font-family: var(--ff-mono); font-feature-settings: 'tnum'; }
.t-mute { color: var(--c-ink-mute); }
.t-soft { color: var(--c-ink-soft); }
.t-display { font-family: var(--ff-display); }
.t-italic { font-style: italic; }

/* ── 4. Layout ────────────────────────────────────────────── */
.container {
	width: 100%;
	max-width: calc(var(--container) + var(--gutter) * 2);
	margin: 0 auto;
	padding-inline: var(--gutter);
}
.container-narrow {
	width: 100%;
	max-width: calc(var(--container-narrow) + var(--gutter) * 2);
	margin: 0 auto;
	padding-inline: var(--gutter);
}
.section { padding-block: var(--sp-9); position: relative; }
.section--snug { padding-block: var(--sp-7); }
.section--tight { padding-block: var(--sp-6); }

/* Skip to content */
.skip-link {
	position: absolute;
	top: -100px;
	left: 1rem;
	background: var(--c-ink);
	color: var(--c-ivory);
	padding: 0.75rem 1.25rem;
	border-radius: var(--radius-pill);
	z-index: 1000;
}
.skip-link:focus { top: 1rem; }

/* ── 5. Site Header ──────────────────────────────────────── */
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	padding-block: var(--sp-3);
	transition: background var(--dur-base) var(--ease-out), backdrop-filter var(--dur-base), top var(--dur-fast);
}

/* WordPress admin bar offset — keep header below it instead of behind */
.admin-bar .site-header { top: 32px; }
@media screen and (max-width: 782px) {
	.admin-bar .site-header { top: 0; position: absolute; }
}
.admin-bar .mobile-nav { top: 32px; }
@media screen and (max-width: 782px) {
	.admin-bar .mobile-nav { top: 46px; }
}
.site-header.is-stuck {
	background: var(--surface-2);
	backdrop-filter: blur(var(--surface-glass-blur)) saturate(1.4);
	-webkit-backdrop-filter: blur(var(--surface-glass-blur)) saturate(1.4);
	border-bottom: 1px solid var(--hairline);
}
.site-header__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: var(--sp-5);
}
.site-brand {
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	font-family: var(--ff-display);
	color: var(--c-ink);
	text-decoration: none;
}
.site-brand__mark {
	display: inline-grid;
	place-items: center;
	width: 32px;
	height: 32px;
	color: var(--c-ink);
	flex-shrink: 0;
}
.site-brand__mark svg { width: 100%; height: 100%; }
.site-brand__name {
	font-family: var(--ff-display);
	font-weight: 400;
	font-size: 1.375rem;
	letter-spacing: -0.02em;
	font-variation-settings: 'opsz' 36, 'SOFT' 20;
	line-height: 1;
}
.site-brand__sub {
	font-family: var(--ff-display);
	font-style: italic;
	font-weight: 300;
	font-size: 0.8125rem;
	color: var(--c-ink-mute);
	letter-spacing: 0.01em;
	line-height: 1;
	border-left: 1px solid var(--hairline-strong);
	padding-left: 0.625rem;
	margin-left: 0.125rem;
}
@media (max-width: 600px) {
	.site-brand__sub { display: none; }
	.site-brand__mark { width: 28px; height: 28px; }
	.site-brand__name { font-size: 1.25rem; }
}
.primary-nav {
	display: flex;
	gap: var(--sp-5);
	justify-content: center;
	font-size: var(--fs-sm);
	font-weight: 500;
}
.primary-nav a {
	position: relative;
	padding-block: 0.5rem;
	letter-spacing: 0.02em;
	transition: color var(--dur-fast);
}
.primary-nav a::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0.25rem;
	width: 0;
	height: 1px;
	background: currentColor;
	transition: width var(--dur-base) var(--ease-out), left var(--dur-base) var(--ease-out);
}
.primary-nav a:hover::after,
.primary-nav .current-menu-item > a::after {
	width: 100%;
	left: 0;
}
.site-header__cta {
	display: flex;
	gap: var(--sp-3);
	align-items: center;
	justify-content: flex-end;
}
.lang-switch {
	display: flex;
	gap: var(--sp-2);
	font-size: var(--fs-xs);
	font-weight: 500;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.lang-switch a { padding: 0.25rem 0.5rem; border-radius: var(--radius-xs); }
.lang-switch a.is-active { color: var(--c-ink); background: var(--c-pearl); }

.menu-toggle {
	display: none;
	width: 44px;
	height: 44px;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--c-ink);
	color: var(--c-ivory);
}
.menu-toggle__bars { width: 16px; height: 10px; position: relative; }
.menu-toggle__bars::before,
.menu-toggle__bars::after {
	content: "";
	position: absolute;
	left: 0;
	width: 100%;
	height: 1.5px;
	background: currentColor;
	transition: transform var(--dur-base) var(--ease-out);
}
.menu-toggle__bars::before { top: 0; }
.menu-toggle__bars::after { bottom: 0; }
.menu-toggle[aria-expanded="true"] .menu-toggle__bars::before { transform: translateY(4px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] .menu-toggle__bars::after { transform: translateY(-4px) rotate(-45deg); }

@media (max-width: 880px) {
	.primary-nav,
	.lang-switch { display: none; }
	.menu-toggle { display: inline-flex; }
}

/* Mobile drawer */
.mobile-nav {
	position: fixed;
	inset: 0;
	z-index: 99;
	background: var(--c-ivory);
	padding: var(--sp-9) var(--gutter) var(--sp-7);
	display: flex;
	flex-direction: column;
	gap: var(--sp-5);
	transform: translateY(-100%);
	transition: transform var(--dur-slow) var(--ease-in-out);
	overflow-y: auto;
}
.mobile-nav.is-open { transform: translateY(0); }
.mobile-nav__menu {
	display: flex;
	flex-direction: column;
	gap: var(--sp-4);
	font-family: var(--ff-display);
	font-size: var(--fs-xl);
	font-variation-settings: 'opsz' 64, 'SOFT' 40;
	letter-spacing: -0.02em;
}
.mobile-nav__menu a { display: inline-block; }

/* ── 6. Buttons ──────────────────────────────────────────── */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.625rem;
	padding: 0.875rem 1.625rem;
	font-family: var(--ff-body);
	font-weight: 500;
	font-size: var(--fs-sm);
	letter-spacing: 0.02em;
	border-radius: var(--radius-pill);
	transition: transform var(--dur-fast) var(--ease-out),
		background var(--dur-base) var(--ease-out),
		color var(--dur-base) var(--ease-out),
		box-shadow var(--dur-base);
	cursor: pointer;
	white-space: nowrap;
	will-change: transform;
}
.btn--primary {
	background: var(--c-ink);
	color: var(--c-ivory);
	box-shadow: var(--shadow-1);
}
.btn--primary:hover {
	background: var(--c-rose);
	transform: translateY(-1px);
	box-shadow: var(--shadow-2);
}
.btn--ghost {
	background: transparent;
	color: var(--c-ink);
	border: 1px solid var(--hairline-strong);
}
.btn--ghost:hover {
	background: var(--c-ink);
	color: var(--c-ivory);
	border-color: var(--c-ink);
}
.btn--blush {
	background: var(--c-blush);
	color: var(--c-ink);
}
.btn--blush:hover { background: var(--c-blush-deep); }
.btn--sm { padding: 0.625rem 1.125rem; font-size: var(--fs-xs); }
.btn--lg { padding: 1.125rem 2.125rem; font-size: var(--fs-base); }
.btn__arrow {
	width: 18px;
	height: 18px;
	display: inline-grid;
	place-items: center;
	transition: transform var(--dur-base) var(--ease-out);
}
.btn:hover .btn__arrow { transform: translateX(4px); }

/* ── 7. Hero ─────────────────────────────────────────────── */
.hero {
	position: relative;
	padding-block: clamp(4rem, 3.2rem + 2.5vw, 6rem) var(--sp-6);
	overflow: hidden;
	background: linear-gradient(180deg, var(--c-ivory) 0%, var(--c-cream) 60%, var(--c-ivory) 100%);
}
.hero__layout {
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
	gap: var(--sp-7);
	align-items: end;
	position: relative;
	z-index: 2;
}
@media (max-width: 880px) {
	.hero__layout { grid-template-columns: 1fr; gap: var(--sp-6); align-items: start; }
}

.hero__title {
	font-size: var(--fs-hero);
	font-family: var(--ff-display);
	font-weight: 300;
	line-height: 0.88;
	letter-spacing: -0.045em;
	font-variation-settings: 'opsz' 144, 'SOFT' 70;
	color: var(--c-ink);
}
.hero__title .it {
	font-style: italic;
	font-weight: 300;
	font-variation-settings: 'opsz' 144, 'SOFT' 100;
	color: var(--c-rose);
	display: inline-block;
}
/* (.hero__korean removed — Hangul accent retired) */
.hero__lede {
	font-size: var(--fs-md);
	color: var(--c-ink-soft);
	max-width: 38ch;
	margin-block: var(--sp-4) var(--sp-5);
}
.hero__cta { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.hero__meta {
	display: grid;
	gap: var(--sp-4);
	padding: var(--sp-5);
	background: var(--surface-1);
	backdrop-filter: blur(var(--surface-glass-blur));
	-webkit-backdrop-filter: blur(var(--surface-glass-blur));
	border: 1px solid rgba(255,255,255,0.5);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-glass);
}
.hero__meta-row {
	display: grid;
	grid-template-columns: 88px 1fr;
	gap: var(--sp-4);
	align-items: baseline;
	font-size: var(--fs-sm);
}
.hero__meta-row dt {
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}
.hero__meta-row dd { color: var(--c-ink); }
.hero__meta-row + .hero__meta-row { border-top: 1px solid var(--hairline); padding-top: var(--sp-3); }

/* Hero decorative blobs */
.hero__blob {
	position: absolute;
	border-radius: 50%;
	filter: blur(60px);
	opacity: 0.5;
	z-index: 1;
	pointer-events: none;
}
.hero__blob--1 { top: 8%; right: -8%; width: 460px; height: 460px; background: radial-gradient(circle, var(--c-blush) 0%, transparent 70%); }
.hero__blob--2 { bottom: -10%; left: -10%; width: 520px; height: 520px; background: radial-gradient(circle, var(--c-sage) 0%, transparent 70%); }
.hero__blob--3 { top: 50%; left: 30%; width: 280px; height: 280px; background: radial-gradient(circle, var(--c-cream) 0%, transparent 70%); opacity: 0.7; }

/* Hero scroll indicator */
.hero__scroll {
	position: absolute;
	bottom: var(--sp-5);
	left: 50%;
	transform: translateX(-50%);
	font-size: var(--fs-xs);
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 0.625rem;
	z-index: 2;
}
.hero__scroll::after {
	content: "";
	width: 1px;
	height: 32px;
	background: linear-gradient(180deg, var(--c-ink-mute) 0%, transparent 100%);
	animation: scrollHint 2.4s var(--ease-in-out) infinite;
}
@keyframes scrollHint {
	0%, 100% { transform: scaleY(0.4); transform-origin: top; opacity: 0.5; }
	50% { transform: scaleY(1); opacity: 1; }
}

/* ── 8. Marquee ───────────────────────────────────────────── */
.marquee {
	overflow: hidden;
	border-block: 1px solid var(--hairline);
	padding-block: var(--sp-4);
	background: var(--c-ivory);
	position: relative;
}
.marquee::before,
.marquee::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 80px;
	z-index: 2;
	pointer-events: none;
}
.marquee::before { left: 0; background: linear-gradient(90deg, var(--c-ivory), transparent); }
.marquee::after  { right: 0; background: linear-gradient(-90deg, var(--c-ivory), transparent); }
.marquee__track {
	display: flex;
	gap: var(--sp-6);
	width: max-content;
	animation: mirae-marquee 42s linear infinite;
	will-change: transform;
}
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__item {
	flex: 0 0 auto;
	font-family: var(--ff-display);
	font-style: italic;
	font-size: var(--fs-lg);
	color: var(--c-ink);
	font-variation-settings: 'opsz' 64, 'SOFT' 50;
	display: inline-flex;
	align-items: center;
	gap: var(--sp-6);
	white-space: nowrap;
}
.marquee__item::after {
	content: "✦";
	color: var(--c-rose);
	font-style: normal;
	font-size: 0.6em;
	margin-left: var(--sp-6);
}
@keyframes mirae-marquee {
	0%   { transform: translate3d(0, 0, 0); }
	100% { transform: translate3d(-50%, 0, 0); }
}
@media (prefers-reduced-motion: reduce) {
	.marquee__track { animation-duration: 120s; }
}

/* ── 9. Section heading ──────────────────────────────────── */
.section__head {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr);
	gap: var(--sp-6);
	align-items: end;
	margin-bottom: var(--sp-7);
}
@media (max-width: 880px) {
	.section__head { grid-template-columns: 1fr; gap: var(--sp-3); }
}
.section__title {
	font-size: var(--fs-2xl);
	font-family: var(--ff-display);
	font-weight: 300;
	letter-spacing: -0.025em;
	font-variation-settings: 'opsz' 96, 'SOFT' 50;
	line-height: 0.95;
}
.section__title .it { font-style: italic; color: var(--c-rose); font-variation-settings: 'opsz' 96, 'SOFT' 80; }
.section__lede { font-size: var(--fs-md); color: var(--c-ink-soft); max-width: 52ch; }
.section__index {
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.18em;
	color: var(--c-ink-mute);
	text-transform: uppercase;
	display: inline-flex;
	gap: var(--sp-2);
}

/* ── 10. Service Cards (homepage grid) ──────────────────── */
.services-grid {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: var(--sp-4);
}
@media (max-width: 880px) {
	.services-grid { grid-template-columns: 1fr; }
}
.service-card {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-lg);
	background: var(--c-cream);
	color: var(--c-ink);
	padding: var(--sp-6);
	min-height: 380px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	transition: transform var(--dur-base) var(--ease-out),
		box-shadow var(--dur-base);
	will-change: transform;
}
.service-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-3); }
.service-card--lg { grid-column: span 7; min-height: 540px; background: var(--c-blush); }
.service-card--md { grid-column: span 5; min-height: 540px; background: var(--c-sage); }
.service-card--sm { grid-column: span 4; min-height: 380px; }
.service-card--wide { grid-column: span 8; min-height: 380px; background: var(--c-pearl); }

@media (max-width: 880px) {
	.service-card--lg, .service-card--md, .service-card--sm, .service-card--wide {
		grid-column: span 12;
		min-height: 320px;
	}
}

.service-card__index {
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.18em;
	color: var(--c-ink-soft);
	text-transform: uppercase;
}
.service-card__title {
	font-family: var(--ff-display);
	font-size: var(--fs-xl);
	font-weight: 400;
	line-height: 1;
	letter-spacing: -0.02em;
	margin-block: var(--sp-3) var(--sp-2);
	font-variation-settings: 'opsz' 64, 'SOFT' 50;
}
.service-card--lg .service-card__title { font-size: var(--fs-2xl); }
.service-card__excerpt { color: var(--c-ink-soft); margin-bottom: var(--sp-4); max-width: 36ch; }
.service-card__foot {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: var(--sp-3);
	border-top: 1px solid var(--hairline);
	margin-top: auto;
}
.service-card__price {
	font-family: var(--ff-mono);
	font-size: var(--fs-md);
	font-feature-settings: 'tnum';
	letter-spacing: -0.01em;
}
.service-card__price small {
	font-family: var(--ff-body);
	font-weight: 400;
	color: var(--c-ink-mute);
	font-size: var(--fs-xs);
	margin-left: 0.25rem;
}
.service-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: var(--fs-sm);
	font-weight: 500;
}
.service-card__cta-arrow {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--c-ink);
	color: var(--c-ivory);
	display: inline-grid;
	place-items: center;
	transition: transform var(--dur-base) var(--ease-spring);
}
.service-card:hover .service-card__cta-arrow {
	transform: rotate(-45deg) scale(1.05);
}

/* ── 11. Pricing list ────────────────────────────────────── */
.price-list {
	display: flex;
	flex-direction: column;
	gap: 0;
}
.price-row {
	display: grid;
	grid-template-columns: 1fr auto auto;
	gap: var(--sp-4);
	padding-block: var(--sp-4);
	border-bottom: 1px solid var(--hairline);
	align-items: baseline;
}
.price-row:first-child { border-top: 1px solid var(--hairline); }
.price-row__name {
	font-family: var(--ff-display);
	font-size: var(--fs-md);
	font-weight: 400;
	font-variation-settings: 'opsz' 36, 'SOFT' 30;
	color: var(--c-ink);
	letter-spacing: -0.01em;
}
.price-row__desc {
	font-size: var(--fs-sm);
	color: var(--c-ink-mute);
	display: block;
	font-family: var(--ff-body);
	font-variation-settings: normal;
	margin-top: 0.25rem;
}
.price-row__duration {
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.1em;
	color: var(--c-ink-mute);
	text-transform: uppercase;
}
.price-row__price {
	font-family: var(--ff-mono);
	font-size: var(--fs-md);
	font-feature-settings: 'tnum';
	color: var(--c-ink);
	min-width: 5ch;
	text-align: right;
}

/* ── 12. Editorial split ─────────────────────────────────── */
.editorial {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
	gap: var(--sp-7);
	align-items: center;
}
@media (max-width: 880px) { .editorial { grid-template-columns: 1fr; } }
.editorial--reverse > :first-child { order: 2; }
@media (max-width: 880px) { .editorial--reverse > :first-child { order: 0; } }
.editorial__media {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 4/5;
	background: var(--c-cream);
}
.editorial__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 1.2s var(--ease-out);
}
.editorial:hover .editorial__media img { transform: scale(1.04); }
.editorial__copy { padding: var(--sp-3) 0; }
.editorial__copy h2 { margin-bottom: var(--sp-4); }
.editorial__copy p + p { margin-top: 1em; }
.editorial__list {
	list-style: none;
	padding: 0;
	margin-top: var(--sp-5);
	display: grid;
	gap: var(--sp-3);
}
.editorial__list li {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--sp-3);
	font-size: var(--fs-base);
}
.editorial__list li::before {
	content: "01";
	counter-increment: list;
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	color: var(--c-rose);
	letter-spacing: 0.1em;
	padding-top: 0.25em;
}
.editorial__list { counter-reset: list; }
.editorial__list li:nth-child(1)::before { content: "01 ／"; }
.editorial__list li:nth-child(2)::before { content: "02 ／"; }
.editorial__list li:nth-child(3)::before { content: "03 ／"; }
.editorial__list li:nth-child(4)::before { content: "04 ／"; }
.editorial__list li:nth-child(5)::before { content: "05 ／"; }
.editorial__list li:nth-child(6)::before { content: "06 ／"; }

/* Editorial wrapper — contains media (overflow hidden) + decorative badge (escapes media bounds) */
.editorial__wrap {
	position: relative;
	width: 100%;
	height: 100%;
}

/* Decorative number badge for editorial */
.editorial__badge {
	position: absolute;
	top: -22px;
	right: -22px;
	width: 124px;
	height: 124px;
	border-radius: 50%;
	background: var(--c-blush);
	color: var(--c-ink);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.125rem;
	font-family: var(--ff-display);
	transform: rotate(-12deg);
	box-shadow: var(--shadow-2);
	line-height: 1;
	text-align: center;
	z-index: 2;
}
.editorial__badge em {
	font-style: italic;
	font-size: 0.875rem;
	font-weight: 400;
	font-variation-settings: 'opsz' 24, 'SOFT' 60;
	letter-spacing: 0.04em;
	color: var(--c-ink-soft);
}
.editorial__badge strong {
	font-family: var(--ff-display);
	font-style: italic;
	font-weight: 300;
	font-size: 2rem;
	font-variation-settings: 'opsz' 64, 'SOFT' 100;
	letter-spacing: -0.02em;
	color: var(--c-ink);
}
@media (max-width: 880px) {
	.editorial__badge { width: 96px; height: 96px; top: -16px; right: -16px; }
	.editorial__badge em { font-size: 0.75rem; }
	.editorial__badge strong { font-size: 1.5rem; }
}

/* ── 13. Process steps ───────────────────────────────────── */
.process {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: var(--sp-5);
	counter-reset: step;
}
.process__step {
	position: relative;
	padding: var(--sp-5);
	background: var(--surface-1);
	backdrop-filter: blur(var(--surface-glass-blur));
	-webkit-backdrop-filter: blur(var(--surface-glass-blur));
	border: 1px solid rgba(255,255,255,0.6);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-glass);
	counter-increment: step;
}
.process__step::before {
	content: "0" counter(step);
	font-family: var(--ff-display);
	font-size: var(--fs-xl);
	font-weight: 300;
	font-style: italic;
	color: var(--c-rose);
	font-variation-settings: 'opsz' 64, 'SOFT' 80;
	display: block;
	line-height: 1;
	margin-bottom: var(--sp-3);
}
.process__step h4 { margin-bottom: var(--sp-2); }
.process__step p { font-size: var(--fs-sm); color: var(--c-ink-soft); max-width: none; }

/* ── 14. Testimonials ────────────────────────────────────── */
.testimonial {
	background: var(--c-cream);
	border-radius: var(--radius-lg);
	padding: var(--sp-7) var(--sp-6);
	text-align: center;
	max-width: 720px;
	margin: 0 auto;
}
.testimonial__quote {
	font-family: var(--ff-display);
	font-style: italic;
	font-size: var(--fs-xl);
	font-weight: 300;
	line-height: 1.25;
	font-variation-settings: 'opsz' 64, 'SOFT' 70;
	letter-spacing: -0.015em;
	color: var(--c-ink);
	margin-bottom: var(--sp-5);
}
.testimonial__quote::before { content: "「"; color: var(--c-rose); font-style: normal; }
.testimonial__quote::after { content: "」"; color: var(--c-rose); font-style: normal; }
.testimonial__author {
	font-size: var(--fs-sm);
	font-weight: 500;
	letter-spacing: 0.05em;
}
.testimonial__role { color: var(--c-ink-mute); font-weight: 400; }

/* ── 15. CTA Banner ─────────────────────────────────────── */
.cta-banner {
	position: relative;
	background: var(--c-ink);
	color: var(--c-ivory);
	border-radius: var(--radius-xl);
	padding: var(--sp-8) var(--sp-7);
	overflow: hidden;
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: var(--sp-6);
	align-items: center;
}
@media (max-width: 880px) { .cta-banner { grid-template-columns: 1fr; padding: var(--sp-7) var(--sp-5); border-radius: var(--radius-lg); } }
.cta-banner h2 {
	color: var(--c-ivory);
	font-size: var(--fs-2xl);
	font-variation-settings: 'opsz' 96, 'SOFT' 50;
}
.cta-banner h2 .it { font-style: italic; color: var(--c-blush); font-variation-settings: 'opsz' 96, 'SOFT' 80; }
.cta-banner p { color: rgba(250,246,241,0.7); margin-top: var(--sp-3); }
.cta-banner__bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0.18;
	background:
		radial-gradient(circle at 20% 20%, var(--c-blush) 0%, transparent 35%),
		radial-gradient(circle at 80% 80%, var(--c-sage) 0%, transparent 35%);
}
.cta-banner__action {
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
	z-index: 2;
}
.cta-banner__action small {
	color: rgba(250,246,241,0.6);
	font-size: var(--fs-xs);
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

/* ── 16. Footer ──────────────────────────────────────────── */
.site-footer {
	background: var(--c-ivory);
	padding-block: var(--sp-8) var(--sp-5);
	border-top: 1px solid var(--hairline);
	font-size: var(--fs-sm);
}
.site-footer__top {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1.2fr;
	gap: var(--sp-6);
	margin-bottom: var(--sp-7);
}
@media (max-width: 880px) {
	.site-footer__top { grid-template-columns: 1fr 1fr; gap: var(--sp-5); }
}
.site-footer__brand { font-family: var(--ff-display); font-size: var(--fs-lg); font-variation-settings: 'opsz' 64, 'SOFT' 30; letter-spacing: -0.02em; }
.site-footer__tagline { color: var(--c-ink-mute); margin-top: var(--sp-3); max-width: 32ch; }
.site-footer__col h5 {
	font-family: var(--ff-body);
	font-size: var(--fs-xs);
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: var(--sp-3);
}
.site-footer__col ul { list-style: none; padding: 0; display: grid; gap: var(--sp-2); }
.site-footer__col a { transition: color var(--dur-fast); }
.site-footer__col a:hover { color: var(--c-rose); }
.site-footer__address { color: var(--c-ink-soft); display: grid; gap: var(--sp-3); }
.site-footer__address a {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: var(--c-ink-soft);
	transition: color var(--dur-fast);
}
.site-footer__address a:hover { color: var(--c-rose); }
.site-footer__address strong { color: var(--c-ink); font-weight: 500; }
.site-footer__addr-link span { line-height: 1.5; }
.site-footer__contact-line { font-size: var(--fs-sm); }
.site-footer__address .mirae-icon {
	flex-shrink: 0;
	color: var(--c-ink-mute);
	margin-top: 2px;
}
.site-footer__address a:hover .mirae-icon { color: var(--c-rose); }
.site-footer__brand-mark {
	display: inline-grid;
	place-items: center;
	width: 28px;
	height: 28px;
	color: var(--c-ink);
	margin-right: 0.5rem;
	vertical-align: middle;
}
.site-footer__brand { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }
.site-footer__bottom {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--sp-3);
	padding-top: var(--sp-5);
	border-top: 1px solid var(--hairline);
	color: var(--c-ink-mute);
	font-size: var(--fs-xs);
	letter-spacing: 0.05em;
}
.socials {
	display: flex;
	gap: var(--sp-2);
	list-style: none;
	padding: 0;
	margin: var(--sp-3) 0 0;
}
.socials a {
	width: 40px;
	height: 40px;
	display: grid;
	place-items: center;
	border-radius: 50%;
	border: 1px solid var(--hairline-strong);
	color: var(--c-ink);
	transition: background var(--dur-fast) var(--ease-out),
		color var(--dur-fast),
		border-color var(--dur-fast),
		transform var(--dur-base) var(--ease-spring);
}
.socials a:hover {
	background: var(--c-ink);
	color: var(--c-ivory);
	border-color: var(--c-ink);
	transform: translateY(-2px);
}
.socials a[aria-label="Whatsapp"]:hover { background: #25D366; border-color: #25D366; }
.socials a[aria-label="Instagram"]:hover { background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%); border-color: transparent; }
.socials a[aria-label="Tiktok"]:hover { background: #000; border-color: #000; }
.socials a[aria-label="Facebook"]:hover { background: #1877F2; border-color: #1877F2; }
.socials .mirae-icon { width: 18px; height: 18px; }
.socials .mirae-icon svg { width: 100%; height: 100%; }

/* ── 17. Forms ───────────────────────────────────────────── */
.field { display: flex; flex-direction: column; gap: 0.5rem; }
.field label {
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-ink-soft);
}
.field input,
.field textarea,
.field select {
	padding: 0.875rem 1rem;
	border: 1px solid var(--hairline-strong);
	border-radius: var(--radius-sm);
	background: var(--c-ivory);
	color: var(--c-ink);
	font-size: var(--fs-base);
	transition: border-color var(--dur-fast), box-shadow var(--dur-fast), background var(--dur-fast);
	width: 100%;
	font-family: inherit;
}
.field input:focus,
.field textarea:focus,
.field select:focus {
	outline: none;
	border-color: var(--c-ink);
	box-shadow: 0 0 0 3px rgba(214, 138, 135, 0.18);
}
.field textarea { min-height: 130px; resize: vertical; }
.field--error input { border-color: var(--c-rose); }
.field__error {
	font-size: var(--fs-xs);
	color: var(--c-rose);
}

/* ── 18. Page header ─────────────────────────────────────── */
.page-hero {
	padding-block: clamp(8rem, 6rem + 8vw, 12rem) var(--sp-7);
	background: linear-gradient(180deg, var(--c-cream) 0%, var(--c-ivory) 100%);
	position: relative;
}
.page-hero__title {
	font-size: var(--fs-3xl);
	font-family: var(--ff-display);
	font-weight: 300;
	font-variation-settings: 'opsz' 144, 'SOFT' 60;
	letter-spacing: -0.04em;
	line-height: 0.92;
	max-width: 18ch;
}
.page-hero__title .it { font-style: italic; color: var(--c-rose); font-variation-settings: 'opsz' 144, 'SOFT' 100; }
.page-hero__breadcrumb {
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: var(--sp-4);
	display: inline-flex;
	gap: var(--sp-2);
}
.page-hero__breadcrumb a:hover { color: var(--c-ink); }

/* ── 19. Anchor accent ───────────────────────────────────── */
.accent-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 500;
	color: var(--c-ink);
	border-bottom: 1px solid var(--hairline-strong);
	padding-bottom: 0.25rem;
	transition: border-color var(--dur-fast), color var(--dur-fast);
}
.accent-link:hover { border-color: var(--c-rose); color: var(--c-rose); }

/* ── 20. Reveal animation ────────────────────────────────── */
.reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 1s var(--ease-out), transform 1s var(--ease-out);
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; } }

/* Stagger children */
.stagger > * { opacity: 0; transform: translateY(16px); transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out); }
.stagger.is-visible > * { opacity: 1; transform: translateY(0); }
.stagger.is-visible > *:nth-child(1) { transition-delay: 0ms; }
.stagger.is-visible > *:nth-child(2) { transition-delay: 80ms; }
.stagger.is-visible > *:nth-child(3) { transition-delay: 160ms; }
.stagger.is-visible > *:nth-child(4) { transition-delay: 240ms; }
.stagger.is-visible > *:nth-child(5) { transition-delay: 320ms; }
.stagger.is-visible > *:nth-child(6) { transition-delay: 400ms; }

/* ── 21. Service detail ──────────────────────────────────── */
.service-detail {
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
	gap: var(--sp-7);
	align-items: start;
}
@media (max-width: 880px) { .service-detail { grid-template-columns: 1fr; } }
.service-detail__media {
	border-radius: var(--radius-lg);
	overflow: hidden;
	aspect-ratio: 4/5;
	background: var(--c-cream);
	position: sticky;
	top: 6rem;
}
.service-detail__media img { width: 100%; height: 100%; object-fit: cover; }
.service-detail__head {
	display: grid;
	gap: var(--sp-4);
	margin-bottom: var(--sp-5);
}
.service-detail__title { font-size: var(--fs-2xl); font-variation-settings: 'opsz' 96, 'SOFT' 50; }
.service-detail__pricebar {
	display: flex;
	gap: var(--sp-5);
	padding: var(--sp-4) 0;
	border-block: 1px solid var(--hairline);
	font-size: var(--fs-sm);
}
.service-detail__pricebar dt {
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: 0.25rem;
}
.service-detail__pricebar dd {
	font-family: var(--ff-display);
	font-size: var(--fs-md);
	font-variation-settings: 'opsz' 36, 'SOFT' 30;
}
.service-detail__price-amount { font-family: var(--ff-mono); }

/* ── 22. FAQ ─────────────────────────────────────────────── */
.faq__item {
	border-bottom: 1px solid var(--hairline);
}
.faq__question {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: var(--sp-4);
	padding-block: var(--sp-5);
	font-family: var(--ff-display);
	font-size: var(--fs-md);
	font-variation-settings: 'opsz' 36, 'SOFT' 30;
	letter-spacing: -0.01em;
	width: 100%;
	text-align: left;
	color: var(--c-ink);
	cursor: pointer;
}
.faq__icon {
	display: inline-block;
	width: 16px;
	height: 16px;
	position: relative;
	flex-shrink: 0;
}
.faq__icon::before, .faq__icon::after {
	content: "";
	position: absolute;
	background: var(--c-ink);
}
.faq__icon::before { top: 50%; left: 0; right: 0; height: 1.5px; transform: translateY(-50%); }
.faq__icon::after { top: 0; bottom: 0; left: 50%; width: 1.5px; transform: translateX(-50%); transition: transform var(--dur-base) var(--ease-out); }
.faq__item[open] .faq__icon::after { transform: translateX(-50%) rotate(90deg); }
.faq__answer {
	padding-block: 0 var(--sp-5);
	color: var(--c-ink-soft);
	max-width: 68ch;
}

/* ── 23. Contact ─────────────────────────────────────────── */
.contact-grid {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: var(--sp-7);
}
@media (max-width: 880px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-info {
	display: grid;
	gap: var(--sp-5);
	font-size: var(--fs-sm);
}
.contact-info dt {
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
	margin-bottom: 0.5rem;
}
.contact-info dd {
	font-family: var(--ff-display);
	font-size: var(--fs-md);
	font-variation-settings: 'opsz' 36, 'SOFT' 30;
	letter-spacing: -0.005em;
	color: var(--c-ink);
}
.contact-info dd a:hover { color: var(--c-rose); }

/* ── 24. 404 ─────────────────────────────────────────────── */
.error-404 {
	min-height: 80vh;
	display: grid;
	place-items: center;
	text-align: center;
	padding: var(--sp-8) var(--gutter);
}
.error-404__code {
	font-family: var(--ff-display);
	font-size: clamp(8rem, 4rem + 16vw, 18rem);
	font-style: italic;
	font-weight: 300;
	font-variation-settings: 'opsz' 144, 'SOFT' 100;
	color: var(--c-blush);
	line-height: 0.85;
	letter-spacing: -0.05em;
}

/* ── 25. Booking widget — see booking.css for full styles ── */
/* Booking shortcode brings its own enhanced styles. */

/* ── 26. Print friendly ──────────────────────────────────── */
@media print {
	.site-header, .site-footer, .menu-toggle, .hero__scroll { display: none; }
	body { color: black; background: white; }
}

/* ── 28. Hero portrait (homepage v2) ──────────────────────── */
.hero--with-portrait .hero__layout {
	grid-template-columns: minmax(0, 1fr) minmax(0, 0.95fr);
	align-items: center;
	gap: var(--sp-7);
}
@media (max-width: 880px) {
	.hero--with-portrait .hero__layout { grid-template-columns: 1fr; gap: var(--sp-6); }
}

.hero__portrait {
	position: relative;
	aspect-ratio: 4/5;
	max-height: 60vh;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: 0 30px 60px -20px rgba(26,20,16,0.18), 0 8px 24px rgba(26,20,16,0.06);
}
.hero__portrait::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 60%, rgba(26,20,16,0.45) 100%);
	pointer-events: none;
}
.hero__portrait-img {
	display: block;
	width: 100%;
	height: 100%;
}
.hero__portrait-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 12s linear;
}
.hero:hover .hero__portrait-img img { transform: scale(1.04); }

.hero__portrait-tag {
	position: absolute;
	top: var(--sp-4);
	left: var(--sp-4);
	display: inline-flex;
	align-items: center;
	gap: var(--sp-3);
	padding: 0.625rem 1rem;
	background: var(--surface-2);
	backdrop-filter: blur(20px) saturate(1.4);
	-webkit-backdrop-filter: blur(20px) saturate(1.4);
	border: 1px solid rgba(255,255,255,0.5);
	border-radius: var(--radius-pill);
	box-shadow: var(--shadow-glass);
}
.hero__portrait-tag-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #4caf50;
	box-shadow: 0 0 0 4px rgba(76, 175, 80, 0.18);
	flex-shrink: 0;
	animation: mirae-pulse 2.4s var(--ease-in-out) infinite;
}
@keyframes mirae-pulse {
	0%, 100% { box-shadow: 0 0 0 4px rgba(76, 175, 80, 0.18); }
	50%      { box-shadow: 0 0 0 8px rgba(76, 175, 80, 0.08); }
}
.hero__portrait-tag-label {
	font-size: var(--fs-xs);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-ink-soft);
	font-weight: 500;
}

.hero__portrait-meta {
	position: absolute;
	bottom: var(--sp-4);
	left: var(--sp-4);
	right: var(--sp-4);
	padding: var(--sp-4);
	background: rgba(26,20,16,0.78);
	color: var(--c-ivory);
	border-radius: var(--radius-md);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
}
.hero__portrait-meta dl {
	display: grid;
	gap: var(--sp-2);
	margin: 0;
}
.hero__portrait-meta dl > div {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: var(--sp-3);
	align-items: baseline;
	font-size: var(--fs-sm);
}
.hero__portrait-meta dt {
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(250,246,241,0.55);
}
.hero__portrait-meta dd { color: rgba(250,246,241,0.95); margin: 0; }

/* Trust signals row in hero */
.hero__trust {
	display: flex;
	gap: var(--sp-5);
	margin-top: var(--sp-4);
	padding-top: var(--sp-4);
	border-top: 1px solid var(--hairline);
}
.hero__trust-item {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.hero__trust-item strong {
	font-family: var(--ff-display);
	font-style: italic;
	font-size: var(--fs-xl);
	font-weight: 300;
	font-variation-settings: 'opsz' 64, 'SOFT' 80;
	color: var(--c-ink);
	line-height: 1;
}
.hero__trust-item small {
	font-size: var(--fs-xs);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-ink-mute);
}

/* Subtle grain overlay */
.hero__grain {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 1;
	opacity: 0.06;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.1 0 0 0 0 0.08 0 0 0 0 0.06 0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ── 29. Service cards with image ─────────────────────────── */
.service-card--has-img {
	position: relative;
	overflow: hidden;
}
.service-card__media {
	position: absolute;
	inset: 0;
	z-index: 0;
	overflow: hidden;
}
.service-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 1.4s var(--ease-out);
}
.service-card:hover .service-card__media img { transform: scale(1.06); }
.service-card__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(26,20,16,0.05) 0%, rgba(26,20,16,0.2) 60%, rgba(26,20,16,0.65) 100%);
}
.service-card--has-img .service-card__inner {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	height: 100%;
	color: var(--c-ivory);
}
.service-card--has-img .service-card__index { color: rgba(250,246,241,0.7); }
.service-card--has-img .service-card__title,
.service-card--has-img .service-card__title a { color: var(--c-ivory); }
.service-card--has-img .service-card__excerpt { color: rgba(250,246,241,0.85); }
.service-card--has-img .service-card__foot { border-top-color: rgba(250,246,241,0.18); }
.service-card--has-img .service-card__price { color: var(--c-ivory); }
.service-card--has-img .service-card__price small { color: rgba(250,246,241,0.6); }
.service-card--has-img .service-card__cta-arrow {
	background: var(--c-ivory);
	color: var(--c-ink);
}

/* ── 30. Ingredients grid ─────────────────────────────────── */
.ingredients-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.6fr);
	gap: var(--sp-7);
	align-items: start;
}
@media (max-width: 880px) { .ingredients-grid { grid-template-columns: 1fr; gap: var(--sp-5); } }
.ingredients-grid__list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--sp-4);
}
@media (max-width: 600px) { .ingredients-grid__list { grid-template-columns: 1fr; } }
.ingredient {
	padding: var(--sp-5);
	background: var(--c-cream);
	border-radius: var(--radius-md);
	transition: transform var(--dur-base) var(--ease-out), background var(--dur-base);
}
.ingredient:hover { transform: translateY(-3px); background: var(--c-blush); }
.ingredient__num {
	font-family: var(--ff-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.18em;
	color: var(--c-rose);
}
.ingredient__name {
	font-family: var(--ff-display);
	font-size: var(--fs-md);
	font-weight: 400;
	font-variation-settings: 'opsz' 36, 'SOFT' 30;
	margin: var(--sp-2) 0 var(--sp-3);
	color: var(--c-ink);
}
.ingredient p { font-size: var(--fs-sm); color: var(--c-ink-soft); }

/* ── 31. Gallery mosaic ───────────────────────────────────── */
.gallery-mosaic {
	display: grid;
	grid-template-columns: repeat(8, 1fr);
	grid-auto-rows: 100px;
	gap: var(--sp-3);
}
.gallery-mosaic > picture {
	overflow: hidden;
	border-radius: var(--radius-md);
	background: var(--c-cream);
	transition: transform var(--dur-base) var(--ease-out);
}
.gallery-mosaic > picture:hover { transform: scale(1.02); }
.gallery-mosaic > picture img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.gallery-mosaic__1 { grid-column: span 4; grid-row: span 4; }
.gallery-mosaic__2 { grid-column: span 4; grid-row: span 2; }
.gallery-mosaic__3 { grid-column: span 2; grid-row: span 2; }
.gallery-mosaic__4 { grid-column: span 2; grid-row: span 2; }
.gallery-mosaic__5 { grid-column: span 4; grid-row: span 2; }
.gallery-mosaic__caption {
	grid-column: span 4;
	grid-row: span 2;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: var(--sp-5);
	background: var(--c-ink);
	color: var(--c-ivory);
	border-radius: var(--radius-md);
	font-family: var(--ff-display);
	font-style: italic;
	font-size: var(--fs-md);
	font-variation-settings: 'opsz' 36, 'SOFT' 60;
	letter-spacing: -0.01em;
}
@media (max-width: 880px) {
	.gallery-mosaic { grid-template-columns: repeat(4, 1fr); }
	.gallery-mosaic__1 { grid-column: span 4; grid-row: span 3; }
	.gallery-mosaic__2 { grid-column: span 4; grid-row: span 2; }
	.gallery-mosaic__3 { grid-column: span 2; grid-row: span 2; }
	.gallery-mosaic__4 { grid-column: span 2; grid-row: span 2; }
	.gallery-mosaic__5 { grid-column: span 4; grid-row: span 2; }
	.gallery-mosaic__caption { grid-column: span 4; grid-row: span 2; }
}

/* ── 32. Testimonial grid ─────────────────────────────────── */
.testimonial-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: var(--sp-4);
}
.testimonial-card {
	padding: var(--sp-6);
	background: var(--c-cream);
	border-radius: var(--radius-md);
	margin: 0;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	min-height: 240px;
	transition: transform var(--dur-base) var(--ease-out), background var(--dur-base);
}
.testimonial-card:hover { transform: translateY(-3px); background: var(--c-blush); }
.testimonial-card__quote {
	font-family: var(--ff-display);
	font-style: italic;
	font-size: var(--fs-md);
	font-weight: 300;
	font-variation-settings: 'opsz' 64, 'SOFT' 70;
	letter-spacing: -0.005em;
	color: var(--c-ink);
	line-height: 1.45;
	margin: 0 0 var(--sp-4);
}
.testimonial-card footer {
	display: flex;
	flex-direction: column;
	gap: 2px;
	border-top: 1px solid var(--hairline);
	padding-top: var(--sp-3);
}
.testimonial-card cite {
	font-style: normal;
	font-weight: 600;
	font-size: var(--fs-sm);
	color: var(--c-ink);
	letter-spacing: 0.04em;
}
.testimonial-card small {
	font-size: var(--fs-xs);
	color: var(--c-ink-mute);
	letter-spacing: 0.02em;
}

/* ── 27. Selection & misc ─────────────────────────────────── */
.divider {
	width: 100%;
	height: 1px;
	background: var(--hairline);
	margin-block: var(--sp-5);
}
.tag {
	display: inline-flex;
	align-items: center;
	padding: 0.375rem 0.75rem;
	border-radius: var(--radius-pill);
	background: var(--c-pearl);
	font-size: var(--fs-xs);
	font-weight: 500;
	letter-spacing: 0.04em;
	color: var(--c-ink-soft);
}

/* Scroll snap utility */
@media (min-width: 881px) {
	.snap-y { scroll-snap-type: y proximity; }
	.snap-y > .section { scroll-snap-align: start; }
}
