/* ============================================================
   Море внутри — design tokens
   Dark-dominant palette: deep marine night as the room.
   Cream surfaces are rare "islands of light" (lobby, tea, gift).
   Clay accent stays under 5% of the page.
   ============================================================ */

:root {
  /* Deep — the night sea, dominant background */
  --deep-base:    oklch(0.13 0.040 250);   /* page canvas */
  --deep-night:   oklch(0.16 0.045 248);   /* hero, footer, primary surfaces */
  --deep:         oklch(0.20 0.060 247);   /* deep cards, inset blocks */
  --deep-soft:    oklch(0.32 0.055 245);   /* hover, subtle surface raise */
  --deep-glass:   oklch(0.55 0.040 240);   /* hairlines on dark, glass borders */
  --deep-veil:    oklch(0.10 0.035 250);   /* deepest, gradient pools */

  /* Light "islands" — tea ceremony, lobby, gift surface */
  --paper:        oklch(0.96 0.012 78);
  --paper-soft:   oklch(0.94 0.014 76);
  --sand:         oklch(0.91 0.020 75);
  --sand-deep:    oklch(0.86 0.024 72);

  /* Accent — fired clay, used sparingly (≤5%) */
  --clay:         oklch(0.66 0.10 38);
  --clay-soft:    oklch(0.78 0.07 50);
  --clay-deep:    oklch(0.54 0.10 36);

  /* Sage — natural support tone */
  --sage:         oklch(0.74 0.030 145);

  /* Ink */
  --ink:                oklch(0.18 0.012 60);   /* on light surfaces */
  --ink-soft:           oklch(0.42 0.010 60);
  --ink-faint:          oklch(0.62 0.012 65);
  --ink-on-deep:        oklch(0.94 0.012 80);   /* on deep surfaces */
  --ink-on-deep-soft:   oklch(0.74 0.014 82);
  --ink-on-deep-faint:  oklch(0.55 0.020 86);

  /* Lines */
  --hairline:           oklch(0.85 0.010 75);   /* on light */
  --hairline-strong:    oklch(0.75 0.012 70);
  --hairline-deep:      oklch(0.30 0.040 245);  /* on dark */
  --hairline-deep-soft: oklch(0.25 0.035 245);

  /* Easing — Emil's strong custom curves */
  --ease-out:    cubic-bezier(0.23, 1, 0.32, 1);
  --ease-in-out: cubic-bezier(0.77, 0, 0.175, 1);
  --ease-drawer: cubic-bezier(0.32, 0.72, 0, 1);  /* iOS drawer */

  /* Layout scale */
  --gutter: clamp(20px, 4vw, 56px);
  --section-y-deep:  clamp(120px, 12vw, 180px);
  --section-y-light: clamp(80px, 8vw, 120px);
  --section-y: var(--section-y-deep);

  /* Container */
  --content-max: 1320px;
  --content-narrow: 880px;

  /* Type scale clamps */
  --t-display: clamp(56px, 9vw, 128px);
  --t-h1:      clamp(40px, 5.5vw, 72px);
  --t-h2:      clamp(32px, 4vw, 56px);
  --t-h3:      clamp(20px, 2vw, 26px);
  --t-lede:    clamp(17px, 1.4vw, 21px);
  --t-body:    16px;
  --t-small:   14px;
  --t-eyebrow: 12px;
}

html {
  background: var(--deep-base);
}

/* ============================================================
   Reset, base typography
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
  scroll-padding-top: 92px;
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  background: var(--deep-base);
  color: var(--ink-on-deep);
  font-family: "Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: var(--t-body);
  line-height: 1.65;          /* a touch more on dark — light type reads thinner */
  font-feature-settings: "ss01", "kern", "calt";
  font-weight: 400;
  -webkit-text-size-adjust: 100%;
  position: relative;
  overflow-x: hidden;
}

/* Page-wide film grain — fixed pseudo-element, no repaint cost.
   z-index sits BELOW the header (50) and drawer (70) so it doesn't break
   iOS Safari's paint order under the safe-area-inset zone. */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.05;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.65 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
@media (prefers-reduced-motion: reduce) {
  body::before { opacity: 0.035; }
}

img, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
ul, ol { list-style: none; }

::selection { background: var(--clay); color: var(--deep-night); }

/* Headings — editorial serif */
h1, h2, h3, h4 {
  font-family: "Spectral", "Times New Roman", serif;
  font-weight: 300;
  letter-spacing: -0.02em;
  line-height: 1.0;
  color: var(--ink-on-deep);
}
h2 { line-height: 1.06; letter-spacing: -0.018em; }
h3 { font-weight: 400; line-height: 1.22; letter-spacing: -0.005em; }

em, .italic { font-style: italic; }

:focus-visible {
  outline: 2px solid var(--clay);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ============================================================
   Layout primitives
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.container--narrow { max-width: var(--content-narrow); }

.section {
  padding-block: var(--section-y);
  position: relative;
}
.section--tight { padding-block: var(--section-y-light); }

/* Light "island" — opt-in cream surface */
.island {
  background: var(--paper);
  color: var(--ink);
  position: relative;
}
.island h1, .island h2, .island h3, .island h4 { color: var(--ink); }

/* Hairline stitching between sections (dark-on-dark) */
.section + .section::before,
.island + .section::before,
.section + .island::before,
.island + .island::before {
  content: "";
  position: absolute;
  top: 0; left: var(--gutter); right: var(--gutter);
  height: 1px;
  background: var(--hairline-deep);
  opacity: 0.55;
}
.island + .section::before,
.section + .island::before { background: var(--hairline-strong); opacity: 0.4; }

.eyebrow {
  font-family: "Manrope", sans-serif;
  font-size: var(--t-eyebrow);
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-on-deep-soft);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
/* Let long eyebrows wrap evenly on narrow screens instead of dumping
   one or two trailing words onto a stub line. */
@media (max-width: 720px) {
  .eyebrow {
    flex-wrap: wrap;
    text-wrap: balance;
    line-height: 1.5;
  }
}
.eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--deep-glass);
  display: inline-block;
}
.island .eyebrow { color: var(--ink-soft); }
.island .eyebrow::before { background: var(--hairline-strong); }

.lede {
  font-size: var(--t-lede);
  line-height: 1.55;
  color: var(--ink-on-deep-soft);
  max-width: 56ch;
}
.island .lede { color: var(--ink-soft); }

.hairline { height: 1px; background: var(--hairline-deep); border: 0; }
.island .hairline { background: var(--hairline); }

/* ============================================================
   Header / nav
   ============================================================ */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: calc(18px + env(safe-area-inset-top)) var(--gutter) 18px;
  color: var(--ink-on-deep);
  transition:
    background 240ms var(--ease-out),
    box-shadow 240ms var(--ease-out);
}
.site-header[data-condensed="true"] {
  background: oklch(0.12 0.040 250 / 0.96);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  box-shadow: 0 1px 0 var(--hairline-deep);
}
@media (max-width: 720px) {
  .site-header[data-condensed="true"] {
    background: oklch(0.12 0.040 250);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.brand-mark {
  font-family: "Spectral", serif;
  font-weight: 400;
  font-size: 19px;
  letter-spacing: 0.04em;
  line-height: 1;
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  color: var(--ink-on-deep);
}
.brand-mark__sub {
  font-family: "Manrope", sans-serif;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--ink-on-deep-faint);
}

.nav {
  display: none;
  align-items: center;
  gap: 32px;
}
@media (min-width: 1024px) { .nav { display: inline-flex; } }
.nav-link {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.01em;
  position: relative;
  color: var(--ink-on-deep-soft);
  transition: color 200ms var(--ease-out);
  display: inline-flex;
  align-items: center;
  min-height: 44px;             /* WCAG 2.5.5 hit target */
  padding-inline: 2px;
}
@media (hover: hover) and (pointer: fine) { .nav-link:hover { color: var(--ink-on-deep); } }
.nav-link:active { transform: scale(0.98); }
.nav-link::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: 12px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  opacity: 0.6;
  transition: transform 240ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .nav-link:hover::after,
  .nav-link[aria-current="page"]::after { transform: scaleX(1); }
}

.header-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  height: 44px;
  padding: 0 20px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.02em;
  border: 1px solid var(--ink-on-deep);
  color: var(--ink-on-deep);
  background: oklch(0.13 0.04 250 / 0.78);
  transition: background 220ms var(--ease-out), border-color 220ms var(--ease-out), transform 120ms var(--ease-out);
}
/* On narrow phones the brand + pill + hamburger collide; the sticky
   bottom CTA already covers the booking action. */
@media (max-width: 480px) {
  .header-cta { display: none; }
}
.header-cta svg { width: 14px; height: 14px; }
@media (hover: hover) and (pointer: fine) {
  .header-cta:hover { background: oklch(0.13 0.04 250 / 0.55); border-color: var(--paper); }
}
.header-cta:active { transform: scale(0.97); }
/* When header is condensed, drop the inline blur — section bg already provides surface */
.site-header[data-condensed="true"] .header-cta {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-color: var(--ink-on-deep-soft);
}
@media (hover: hover) and (pointer: fine) {
  .site-header[data-condensed="true"] .header-cta:hover {
    background: oklch(1 0 0 / 0.06);
    border-color: var(--ink-on-deep);
  }
}

.menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: 999px;
  color: var(--ink-on-deep);
}
@media (min-width: 1024px) { .menu-toggle { display: none; } }
.menu-toggle:active { transform: scale(0.95); transition: transform 120ms var(--ease-out); }

/* Mobile drawer — iOS-curve */
.drawer {
  position: fixed;
  inset: 0;
  z-index: 80;
  background: var(--deep-base);
  color: var(--ink-on-deep);
  display: flex;
  flex-direction: column;
  padding: 24px var(--gutter) 36px;
  visibility: hidden;
  opacity: 0;
  transform: translateY(-12px);
  /* Exit (system response) — fast, 200ms ease-out. */
  transition:
    opacity 200ms var(--ease-out),
    transform 200ms var(--ease-out),
    visibility 0s linear 200ms;
}
.drawer[data-open="true"] {
  visibility: visible;
  opacity: 1;
  transform: translateY(0);
  /* Enter (user is deciding) — slower, 380ms iOS curve. */
  transition: opacity 380ms var(--ease-drawer), transform 380ms var(--ease-drawer);
}
.drawer__head {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--hairline-deep);
}
.drawer__close {
  width: 44px; height: 44px;
  color: var(--ink-on-deep);
  transition: transform 120ms var(--ease-out);
}
.drawer__close:active { transform: scale(0.92); }
.drawer__nav {
  display: flex;
  flex-direction: column;
  padding-block: 28px;
  gap: 4px;
}
.drawer__link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 16px 0;
  border-bottom: 1px solid var(--hairline-deep);
  font-family: "Spectral", serif;
  font-size: 24px;
  letter-spacing: -0.01em;
  color: var(--ink-on-deep);
  transition: color 200ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) { .drawer__link:hover { color: var(--clay-soft); } }
.drawer__link:active { transform: scale(0.98); }
.drawer__link span:last-child {
  font-family: "Manrope", sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--ink-on-deep-faint);
}
.drawer__cta { margin-top: auto; }
.drawer__contact {
  display: flex; flex-wrap: wrap; gap: 18px;
  font-size: 14px; color: var(--ink-on-deep-soft);
  padding-top: 24px; margin-top: 24px;
  border-top: 1px solid var(--hairline-deep);
}
@media (hover: hover) and (pointer: fine) { .drawer__contact a:hover { color: var(--ink-on-deep); } }

/* ============================================================
   Buttons — Emil-style with :active scale feedback
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  height: 56px;
  padding: 0 28px;
  border-radius: 999px;
  font-family: "Manrope", sans-serif;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.005em;
  border: 1px solid var(--ink-on-deep-soft);
  background: transparent;
  color: var(--ink-on-deep);
  transition:
    background 240ms var(--ease-out),
    border-color 240ms var(--ease-out),
    color 240ms var(--ease-out),
    transform 120ms var(--ease-out);
  white-space: nowrap;
}
.btn svg {
  width: 16px; height: 16px;
  transition: transform 240ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) {
  .btn:hover { background: oklch(1 0 0 / 0.06); border-color: var(--ink-on-deep); }
  .btn:hover svg { transform: translateX(3px); }
}
.btn:active { transform: scale(0.97); }

.btn--clay {
  background: var(--clay);
  border-color: var(--clay);
  color: var(--deep-night);
}
@media (hover: hover) and (pointer: fine) {
  .btn--clay:hover { background: var(--clay-deep); border-color: var(--clay-deep); color: var(--ink-on-deep); }
}

.btn--on-light {
  border-color: var(--hairline-strong);
  color: var(--ink);
}
@media (hover: hover) and (pointer: fine) {
  .btn--on-light:not(.btn--clay):hover {
    background: var(--paper-soft);
    border-color: var(--ink);
    color: var(--ink);
  }
}
/* Clay variant on light surfaces — keep clay fill, deepen on hover. */
.btn--on-light.btn--clay {
  color: var(--paper);
  border-color: var(--clay);
}
@media (hover: hover) and (pointer: fine) {
  .btn--on-light.btn--clay:hover {
    background: var(--clay-deep);
    border-color: var(--clay-deep);
    color: var(--paper);
  }
}

.btn--small { height: 44px; padding: 0 20px; font-size: 13px; gap: 10px; }
.btn--large { height: 60px; padding: 0 32px; font-size: 16px; }

/* Underline link with arrow */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--ink-on-deep);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--deep-glass);
  transition: border-color 240ms var(--ease-out), color 240ms var(--ease-out), transform 120ms var(--ease-out);
}
.link-arrow svg { width: 14px; height: 14px; transition: transform 240ms var(--ease-out); }
@media (hover: hover) and (pointer: fine) { .link-arrow:hover { border-color: var(--clay-soft); color: var(--clay-soft); } }
@media (hover: hover) and (pointer: fine) { .link-arrow:hover svg { transform: translateX(3px); } }
.link-arrow:active { transform: scale(0.98); }
.island .link-arrow { color: var(--ink); border-bottom-color: var(--hairline-strong); }
@media (hover: hover) and (pointer: fine) { .island .link-arrow:hover { border-color: var(--clay); color: var(--clay); } }

/* ============================================================
   Hero — full-bleed water, layered noise, blend-mode photo
   ============================================================ */
.hero {
  position: relative;
  min-height: 110svh;
  display: flex;
  align-items: flex-end;
  padding-top: 152px;
  padding-bottom: clamp(56px, 8vw, 112px);
  background: var(--deep-veil);
  color: var(--ink-on-deep);
  overflow: hidden;
  isolation: isolate;
}
@media (max-width: 720px) {
  .hero {
    min-height: 100svh;
    padding-top: 120px;
  }
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: url("../images/hero-underwater.jpg");
  background-size: cover;
  background-position: center 38%;
  opacity: 0.62;
  mix-blend-mode: luminosity;
  filter: saturate(0.7) contrast(1.05);
  transform: scale(1.04);
  animation: hero-float 40s var(--ease-in-out) infinite alternate;
}
@keyframes hero-float {
  from { transform: scale(1.04) translateY(0); }
  to   { transform: scale(1.07) translateY(-1.2%); }
}
@media (prefers-reduced-motion: reduce) {
  .hero__bg { animation: none; }
}
.hero__veil {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(ellipse 70% 50% at 18% 100%, oklch(0.10 0.04 250 / 0.85), transparent 65%),
    radial-gradient(ellipse 80% 60% at 90% 0%, oklch(0.22 0.07 248 / 0.5), transparent 60%),
    linear-gradient(180deg, oklch(0.13 0.04 250 / 0.55) 0%, oklch(0.10 0.035 250 / 0.20) 32%, oklch(0.08 0.03 250 / 0.75) 100%);
}
.hero__inner {
  width: 100%;
  display: grid;
  gap: clamp(40px, 6vw, 80px);
  grid-template-columns: 1fr;
  align-items: end;
}
@media (min-width: 920px) {
  .hero__inner { grid-template-columns: 1.5fr 1fr; }
}
.hero__intro { display: flex; flex-direction: column; gap: 32px; max-width: 920px; }
.hero__title {
  font-size: var(--t-display);
  font-weight: 300;
  line-height: 0.96;
  letter-spacing: -0.025em;
  color: var(--ink-on-deep);
}
.hero__title em {
  font-style: italic;
  font-weight: 300;
  color: var(--clay-soft);
}
.hero__lede {
  max-width: 52ch;
  font-size: var(--t-lede);
  color: var(--ink-on-deep-soft);
  line-height: 1.55;
}
.hero__cta-row {
  display: flex; flex-wrap: wrap; gap: 16px;
  align-items: center;
}

.hero__meta {
  display: flex;
  flex-direction: column;
  gap: 22px;
  align-self: end;
  border-left: 1px solid var(--hairline-deep);
  padding-left: clamp(24px, 3vw, 36px);
}
.hero__meta-row {
  display: grid; grid-template-columns: 14px 1fr; gap: 14px;
  font-size: 14px; color: var(--ink-on-deep-soft);
  line-height: 1.5;
}
.hero__meta-row strong { color: var(--ink-on-deep); font-weight: 500; }
.hero__meta-row svg { width: 14px; height: 14px; margin-top: 5px; opacity: 0.65; }

/* ============================================================
   Strip — editorial 4-row hairline list (no cards)
   ============================================================ */
.strip {
  background: var(--deep-base);
  padding-block: clamp(40px, 5vw, 72px);
}
.strip__list {
  display: flex;
  flex-direction: column;
}
.strip__row {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: clamp(20px, 3vw, 56px);
  padding-block: clamp(24px, 2.6vw, 36px);
  border-bottom: 1px solid var(--hairline-deep);
  align-items: baseline;
}
.strip__row:last-child { border-bottom: 0; }
@media (min-width: 720px) {
  .strip__row { grid-template-columns: 80px 1.2fr 2fr; }
}
.strip__num {
  font-family: "Spectral", serif;
  font-size: 14px;
  font-style: italic;
  font-weight: 400;
  letter-spacing: 0.04em;
  color: var(--clay-soft);
}
.strip__title {
  font-family: "Spectral", serif;
  font-size: clamp(22px, 2.2vw, 30px);
  font-weight: 300;
  letter-spacing: -0.012em;
  color: var(--ink-on-deep);
  line-height: 1.1;
}
.strip__text {
  font-size: 15px;
  color: var(--ink-on-deep-soft);
  line-height: 1.55;
  max-width: 52ch;
}
@media (max-width: 719px) {
  .strip__text { grid-column: 2; }
}

/* ============================================================
   Section header (reusable)
   ============================================================ */
.sec-head {
  display: grid;
  gap: 24px;
  margin-bottom: clamp(40px, 5vw, 72px);
  grid-template-columns: 1fr;
  align-items: end;
}
@media (min-width: 920px) {
  .sec-head { grid-template-columns: 1.5fr 1fr; gap: clamp(40px, 5vw, 96px); }
}
.sec-head__title {
  font-size: var(--t-h2);
  font-weight: 300;
  letter-spacing: -0.018em;
}
.sec-head__title em { font-style: italic; color: var(--clay-soft); }
.island .sec-head__title em { color: var(--clay); }
.sec-head__intro { display: flex; flex-direction: column; gap: 16px; }

/* ============================================================
   Services — bento 2x2 (one large + 2 small)
   ============================================================ */
.services { background: var(--deep-base); }
.services__bento {
  display: grid;
  gap: 1px;
  background: var(--hairline-deep);
  border-block: 1px solid var(--hairline-deep);
  grid-template-columns: 1fr;
  grid-auto-rows: minmax(380px, auto);
}
@media (min-width: 880px) {
  .services__bento {
    grid-template-columns: 1.6fr 1fr;
    grid-template-rows: 1fr 1fr;
    grid-auto-rows: auto;
  }
  .services__bento .service-card--feature {
    grid-row: span 2;
  }
}

/* Default service card: photo on top, content on solid dark surface below.
   Image becomes a discrete editorial composition, NOT a backdrop the text
   has to fight for legibility. */
.service-card {
  background: var(--deep-night);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  display: flex;
  flex-direction: column;
  min-height: 380px;
  color: var(--ink-on-deep);
  transition: background 320ms var(--ease-out);
}
.service-card__media {
  position: relative;
  aspect-ratio: 16 / 11;
  overflow: hidden;
  flex: none;
}
.service-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 480ms var(--ease-out), filter 320ms var(--ease-out);
  filter: saturate(0.92);
}
.service-card__media::after { content: none; }
@media (hover: hover) and (pointer: fine) {
  .service-card:hover { background: var(--deep); }
  .service-card:hover .service-card__media img {
    transform: scale(1.04);
  }
}

.service-card__num {
  font-family: "Spectral", serif;
  font-size: 12px;
  font-style: italic;
  letter-spacing: 0.06em;
  color: var(--clay-soft);
  padding-inline: clamp(28px, 3.5vw, 44px);
  padding-top: clamp(24px, 2.4vw, 32px);
  margin-bottom: 12px;
}
.service-card__title {
  font-family: "Spectral", serif;
  font-weight: 300;
  letter-spacing: -0.015em;
  color: var(--ink-on-deep);
  line-height: 1.04;
  padding-inline: clamp(28px, 3.5vw, 44px);
  margin-bottom: 14px;
  font-size: clamp(26px, 2.4vw, 34px);
}
.service-card__title em { font-style: italic; color: var(--clay-soft); }

.service-card__desc {
  font-size: 14px;
  color: var(--ink-on-deep-soft);
  line-height: 1.6;
  max-width: 42ch;
  padding-inline: clamp(28px, 3.5vw, 44px);
  margin-bottom: 20px;
}

.service-card__foot {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  padding: 16px clamp(28px, 3.5vw, 44px) clamp(28px, 3.5vw, 44px);
  border-top: 1px solid var(--hairline-deep);
  margin-top: auto;
}

/* === Feature card: full-bleed photo + overlay text + dim image === */
.service-card--feature {
  justify-content: flex-end;
  min-height: clamp(520px, 62vh, 720px);
  padding: clamp(32px, 3.8vw, 52px);
}
.service-card--feature .service-card__media {
  position: absolute;
  inset: 0;
  z-index: -2;
  aspect-ratio: auto;
}
.service-card--feature .service-card__media img {
  filter: saturate(0.78) brightness(0.55);
}
.service-card--feature .service-card__media::after {
  content: "";
  position: absolute; inset: 0;
  z-index: 1;
  background: linear-gradient(
    to top,
    oklch(0.10 0.035 250 / 0.92) 0%,
    oklch(0.12 0.04 250 / 0.72) 35%,
    oklch(0.13 0.045 248 / 0.45) 65%,
    oklch(0.13 0.045 248 / 0.20) 100%
  );
}
.service-card--feature .service-card__num,
.service-card--feature .service-card__title,
.service-card--feature .service-card__desc {
  padding-inline: 0;
}
.service-card--feature .service-card__num { padding-top: 0; margin-bottom: 14px; }
.service-card--feature .service-card__title {
  font-size: clamp(36px, 4.4vw, 60px);
  margin-bottom: 18px;
}
.service-card--feature .service-card__desc {
  font-size: 16px;
  max-width: 48ch;
  color: var(--ink-on-deep);
}
.service-card--feature .service-card__foot {
  padding: 18px 0 0;
  margin-top: 0;
  border-top-color: oklch(1 0 0 / 0.18);
}
@media (hover: hover) and (pointer: fine) {
  .service-card--feature:hover { background: var(--deep-night); }
  .service-card--feature:hover .service-card__media img {
    filter: saturate(0.85) brightness(0.62);
    transform: scale(1.04);
  }
}
.service-card__price {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  font-family: "Spectral", serif;
  white-space: nowrap;
}
.service-card__price-label {
  font-family: "Manrope", sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-on-deep-faint);
  font-weight: 500;
}
.service-card__price-value {
  font-size: clamp(24px, 2.4vw, 32px);
  font-weight: 300;
  letter-spacing: -0.005em;
  color: var(--ink-on-deep);
  line-height: 1;
}
.service-card__price-value em {
  font-style: italic;
  color: var(--ink-on-deep-faint);
  font-size: 0.5em;
  font-weight: 400;
  margin-left: 0.32em;
  letter-spacing: 0;
}

.services__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  padding-top: clamp(28px, 3vw, 40px);
  flex-wrap: wrap;
}
.services__foot-note {
  font-size: 14px;
  color: var(--ink-on-deep-soft);
  max-width: 56ch;
}

/* ============================================================
   Story — used as light "island" on home, but dark-first on subs
   ============================================================ */
.story__grid {
  display: grid;
  gap: clamp(40px, 5vw, 96px);
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 920px) {
  .story__grid { grid-template-columns: 1fr 1.05fr; }
}
.story__media {
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--deep-night);
  position: relative;
}
.story__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1400ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) { .story:hover .story__media img { transform: scale(1.02); } }

.story__copy { display: flex; flex-direction: column; gap: 26px; max-width: 56ch; }
.story__title {
  font-size: var(--t-h2);
  font-weight: 300;
  line-height: 1.05;
  letter-spacing: -0.018em;
  color: var(--ink-on-deep);
}
.story__title em { font-style: italic; color: var(--clay-soft); }
.island .story__title { color: var(--ink); }
.island .story__title em { color: var(--clay); }
.island .story__media { background: var(--sand-deep); }

/* Editorial pull-quote with serif open quote */
.story__pull {
  position: relative;
  font-family: "Spectral", serif;
  font-style: italic;
  font-weight: 400;
  font-size: clamp(22px, 1.8vw, 28px);
  line-height: 1.4;
  color: var(--ink-on-deep);
  padding-left: 72px;
  padding-top: 8px;
  margin-block: 8px;
}
.story__pull::before {
  content: "\201C";
  position: absolute;
  left: 0; top: -24px;
  font-family: "Spectral", serif;
  font-style: italic;
  font-weight: 300;
  font-size: 120px;
  line-height: 1;
  color: var(--clay-soft);
  opacity: 0.95;
}
.island .story__pull { color: var(--deep); }
.island .story__pull::before { color: var(--clay); opacity: 0.85; }

.story p { color: var(--ink-on-deep-soft); line-height: 1.7; font-size: 16px; }
.island .story p { color: var(--ink-soft); }

/* ============================================================
   Benefits — single column editorial with big roman numerals
   ============================================================ */
.benefits { background: var(--deep-base); color: var(--ink-on-deep); }
.benefits__grid {
  display: grid;
  gap: 0;
}
.benefit {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  padding-block: clamp(40px, 4.5vw, 72px);
  border-bottom: 1px solid var(--hairline-deep);
  position: relative;
}
.benefit:last-child { border-bottom: 0; }
@media (min-width: 880px) {
  .benefit {
    grid-template-columns: minmax(180px, 220px) 1fr 1.4fr;
    gap: clamp(32px, 5vw, 80px);
    align-items: start;
  }
}
.benefit__num {
  font-family: "Spectral", serif;
  font-style: italic;
  font-weight: 300;
  font-size: clamp(56px, 7vw, 96px);
  line-height: 0.9;
  color: var(--clay-soft);
  letter-spacing: -0.02em;
}
.benefit__head {
  display: flex; flex-direction: column; gap: 12px;
  padding-top: 8px;
}
.benefit__category {
  font-family: "Manrope", sans-serif;
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-on-deep-faint);
  font-weight: 500;
}
.benefit__title {
  font-family: "Spectral", serif;
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 300;
  letter-spacing: -0.015em;
  line-height: 1.05;
  color: var(--ink-on-deep);
}
.benefit__title em { font-style: italic; color: var(--clay-soft); }
.benefit__list {
  display: flex; flex-direction: column; gap: 0;
  padding-top: 14px;
}
.benefit__list li {
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 14px;
  padding-block: 12px;
  font-size: 15px;
  color: var(--ink-on-deep-soft);
  line-height: 1.55;
  border-bottom: 1px solid var(--hairline-deep-soft);
}
.benefit__list li:last-child { border-bottom: 0; }
.benefit__list li::before {
  content: "—";
  color: var(--clay-soft);
  font-size: 13px;
}

/* ============================================================
   Trust — dark, with liquid-glass card on the photo
   ============================================================ */
.trust {
  background: var(--deep-night);
  color: var(--ink-on-deep);
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.trust::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 80% 0%, oklch(0.32 0.075 248 / 0.5), transparent 55%),
    radial-gradient(ellipse at 0% 100%, oklch(0.08 0.04 250 / 0.6), transparent 60%);
  z-index: -1;
}
.trust__grid {
  display: grid;
  gap: clamp(40px, 5vw, 80px);
  align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width: 920px) { .trust__grid { grid-template-columns: 1.05fr 1fr; } }
.trust__copy { display: flex; flex-direction: column; gap: 26px; max-width: 60ch; }
.trust__title {
  font-size: var(--t-h2);
  color: var(--ink-on-deep);
  font-weight: 300;
  letter-spacing: -0.018em;
}
.trust__title em { font-style: italic; color: var(--clay-soft); }
.trust__copy p { color: var(--ink-on-deep-soft); line-height: 1.7; }

.trust__points {
  display: grid;
  gap: 0;
  margin-top: 6px;
}
.trust__point {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 20px;
  padding-block: 22px;
  border-bottom: 1px solid var(--hairline-deep);
}
.trust__point:last-child { border-bottom: 0; }
.trust__point-num {
  font-family: "Spectral", serif;
  font-style: italic;
  font-weight: 400;
  font-size: 24px;
  color: var(--clay-soft);
  line-height: 1.1;
}
.trust__point-text {
  font-size: 15px;
  color: var(--ink-on-deep-soft);
  line-height: 1.6;
}
.trust__point-text strong {
  color: var(--ink-on-deep);
  font-weight: 500;
  display: block;
  margin-bottom: 6px;
  font-size: 16px;
  letter-spacing: -0.005em;
}
.trust__media {
  aspect-ratio: 3/4;
  overflow: hidden;
  position: relative;
  border: 1px solid var(--hairline-deep);
}
.trust__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(0.9);
}

/* Liquid glass caption */
.trust__caption {
  position: absolute;
  left: 18px; bottom: 18px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  background: oklch(0.18 0.05 248 / 0.92);
  border: 1px solid oklch(1 0 0 / 0.10);
  box-shadow: inset 0 1px 0 oklch(1 0 0 / 0.10);
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--ink-on-deep);
}
.trust__caption::before {
  content: "";
  width: 6px; height: 6px; border-radius: 999px;
  background: var(--clay-soft);
  box-shadow: 0 0 12px var(--clay-soft);
}

/* ============================================================
   Flow — vertical timeline (left line, big italic numbers)
   ============================================================ */
.flow { background: var(--deep-base); color: var(--ink-on-deep); }
.flow__list {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.flow__list::before {
  content: "";
  position: absolute;
  left: 32px;
  top: 0;
  bottom: 0;
  width: 1px;
  background: linear-gradient(to bottom, transparent 0%, var(--hairline-deep) 8%, var(--hairline-deep) 92%, transparent 100%);
}
@media (min-width: 720px) {
  .flow__list::before { left: 48px; }
}
.flow__step {
  position: relative;
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: clamp(24px, 3vw, 48px);
  padding-block: clamp(36px, 4vw, 60px);
  align-items: start;
}
/* On mobile the step has 3 grid children (num, title-wrapper, text);
   force the text into column 2 so it doesn't fall back into the 64px
   numeral column and wrap one word per line. */
@media (max-width: 719px) {
  .flow__step-text { grid-column: 2; }
}
@media (min-width: 720px) {
  .flow__step {
    grid-template-columns: 96px 1fr 1fr;
    gap: clamp(40px, 5vw, 80px);
  }
}
.flow__step::before {
  content: "";
  position: absolute;
  left: 28px;
  top: clamp(40px, 4.4vw, 64px);
  width: 9px; height: 9px;
  border-radius: 999px;
  background: var(--clay);
  box-shadow: 0 0 0 4px var(--deep-base), 0 0 16px var(--clay-soft);
}
@media (min-width: 720px) {
  .flow__step::before { left: 44px; }
}
.flow__step-num {
  font-family: "Spectral", serif;
  font-size: clamp(48px, 5vw, 72px);
  font-style: italic;
  font-weight: 300;
  color: var(--clay-soft);
  line-height: 0.9;
  letter-spacing: -0.02em;
}
.flow__step-title {
  font-family: "Spectral", serif;
  font-size: clamp(24px, 2.4vw, 32px);
  font-weight: 300;
  letter-spacing: -0.012em;
  line-height: 1.1;
  color: var(--ink-on-deep);
  margin-bottom: 12px;
}
.flow__step-text {
  color: var(--ink-on-deep-soft);
  font-size: 15px;
  line-height: 1.65;
}
.flow__foot {
  margin-top: clamp(36px, 4vw, 56px);
  display: flex; gap: 14px; flex-wrap: wrap; align-items: center;
}

/* ============================================================
   Gift — light island, liquid-glass envelope
   ============================================================ */
.gift {
  background: var(--paper);
  color: var(--ink);
  position: relative;
  overflow: hidden;
}
.gift__inner {
  display: grid;
  gap: clamp(40px, 5vw, 96px);
  align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width: 920px) { .gift__inner { grid-template-columns: 1fr 1fr; } }
.gift__copy { display: flex; flex-direction: column; gap: 24px; max-width: 56ch; }
.gift__title {
  font-size: var(--t-h2);
  font-weight: 300;
  letter-spacing: -0.018em;
  color: var(--ink);
}
.gift__title em { font-style: italic; color: var(--clay); }
.gift__copy p { color: var(--ink-soft); line-height: 1.7; }
.gift__details { display: grid; gap: 0; margin-top: 10px; }
.gift__details li {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 14px;
  padding-block: 14px;
  border-bottom: 1px solid var(--hairline-strong);
  font-size: 14px;
  color: var(--ink-soft);
  line-height: 1.55;
}
.gift__details li::before { content: "→"; color: var(--clay); }

.gift__media {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--deep-night);
  isolation: isolate;
}
.gift__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.96;
  filter: saturate(0.85);
}
.gift__media::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(135deg, oklch(0.10 0.035 250 / 0.05) 30%, oklch(0.10 0.035 250 / 0.55));
}
.gift__envelope {
  position: absolute;
  left: 24px; right: 24px; bottom: 24px;
  display: flex; flex-direction: column; gap: 12px;
  padding: 22px 26px;
  background: oklch(0.18 0.05 248 / 0.94);
  border: 1px solid oklch(1 0 0 / 0.12);
  box-shadow:
    inset 0 1px 0 oklch(1 0 0 / 0.10),
    0 24px 60px -28px oklch(0 0 0 / 0.5);
  border-radius: 4px;
  color: var(--ink-on-deep);
}
.gift__envelope-row {
  display: flex; justify-content: space-between;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-on-deep-faint);
  font-weight: 500;
}
.gift__envelope-from {
  font-family: "Spectral", serif;
  font-style: italic;
  font-size: clamp(22px, 2vw, 28px);
  font-weight: 300;
  color: var(--ink-on-deep);
  letter-spacing: -0.008em;
  line-height: 1.15;
}
.gift__envelope-amount {
  font-family: "Spectral", serif;
  font-size: 13px;
  color: var(--clay-soft);
  font-style: italic;
}

/* ============================================================
   CTA Band — left-aligned (no centered hero per Taste rule)
   ============================================================ */
.cta-band {
  background: var(--deep-night);
  color: var(--ink-on-deep);
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.cta-band::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 80% 0%, oklch(0.32 0.075 248 / 0.5), transparent 50%),
    radial-gradient(ellipse at 0% 110%, oklch(0.08 0.035 250 / 0.7), transparent 60%);
  z-index: -1;
}
.cta-band__grid {
  display: grid;
  gap: clamp(40px, 5vw, 80px);
  grid-template-columns: 1fr;
  align-items: end;
}
@media (min-width: 920px) { .cta-band__grid { grid-template-columns: 1.4fr 1fr; } }
.cta-band__copy { display: flex; flex-direction: column; gap: 28px; max-width: 800px; }
.cta-band__title {
  font-size: var(--t-h1);
  font-weight: 300;
  line-height: 1.0;
  letter-spacing: -0.022em;
  color: var(--ink-on-deep);
}
.cta-band__title em { font-style: italic; color: var(--clay-soft); }
.cta-band__lede {
  font-size: var(--t-lede);
  color: var(--ink-on-deep-soft);
  max-width: 56ch;
  line-height: 1.55;
}
.cta-band__row { display: flex; gap: 16px; flex-wrap: wrap; }
.cta-band__note {
  font-size: 13px;
  color: var(--ink-on-deep-faint);
  max-width: 56ch;
  line-height: 1.65;
}
.cta-band__note a {
  border-bottom: 1px solid var(--deep-glass);
  padding-bottom: 1px;
  color: var(--ink-on-deep-soft);
  transition: color 200ms var(--ease-out), border-color 200ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) { .cta-band__note a:hover { color: var(--ink-on-deep); border-bottom-color: var(--ink-on-deep-soft); } }
.cta-band__aside {
  align-self: end;
  border-left: 1px solid var(--hairline-deep);
  padding-left: clamp(24px, 3vw, 36px);
  display: flex; flex-direction: column; gap: 12px;
}
.cta-band__aside-eyebrow {
  font-family: "Manrope", sans-serif;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-on-deep-faint);
  font-weight: 500;
}
.cta-band__aside p {
  font-family: "Spectral", serif;
  font-style: italic;
  font-size: clamp(18px, 1.5vw, 22px);
  font-weight: 300;
  line-height: 1.45;
  color: var(--ink-on-deep);
  letter-spacing: -0.005em;
}

/* ============================================================
   Contacts
   ============================================================ */
.contacts { background: var(--deep-base); color: var(--ink-on-deep); }
.contacts__grid {
  display: grid;
  gap: clamp(40px, 5vw, 80px);
  grid-template-columns: 1fr;
}
@media (min-width: 920px) { .contacts__grid { grid-template-columns: 0.95fr 1.05fr; } }
.contacts__copy { display: flex; flex-direction: column; gap: 26px; }
.contacts__title {
  font-size: var(--t-h2);
  font-weight: 300;
  letter-spacing: -0.018em;
  color: var(--ink-on-deep);
}
.contacts__title em { font-style: italic; color: var(--clay-soft); }
.contacts__rows { display: flex; flex-direction: column; gap: 0; margin-top: 8px; }
.contacts__row {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 16px;
  padding-block: 18px;
  border-bottom: 1px solid var(--hairline-deep);
  align-items: baseline;
}
.contacts__row:last-child { border-bottom: 0; }
.contacts__label {
  font-family: "Manrope", sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-on-deep-faint);
  font-weight: 500;
}
.contacts__value { font-size: 16px; color: var(--ink-on-deep); line-height: 1.55; }
.contacts__value strong { font-weight: 500; display: block; margin-bottom: 4px; }
.contacts__value a {
  border-bottom: 1px solid var(--hairline-deep);
  padding-bottom: 1px;
  transition: border-color 200ms var(--ease-out), color 200ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) { .contacts__value a:hover { border-color: var(--clay-soft); color: var(--clay-soft); } }

.contacts__channels {
  display: flex; gap: 12px; padding-top: 18px;
  flex-wrap: wrap;
}
.contacts__channel {
  display: inline-flex; align-items: center; gap: 10px;
  height: 44px; padding: 0 18px;
  border-radius: 999px;
  border: 1px solid var(--hairline-deep);
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-on-deep);
  transition: background 200ms var(--ease-out), border-color 200ms var(--ease-out), transform 120ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) { .contacts__channel:hover { background: oklch(1 0 0 / 0.05); border-color: var(--ink-on-deep-soft); } }
.contacts__channel:active { transform: scale(0.97); }
.contacts__channel svg { width: 16px; height: 16px; }

.contacts__map {
  aspect-ratio: 5/4;
  overflow: hidden;
  background: var(--deep-night);
  position: relative;
  border: 1px solid var(--hairline-deep);
}
@media (max-width: 720px) {
  .contacts__map {
    aspect-ratio: 4/5;
    min-height: 380px;
  }
}
.contacts__map iframe {
  width: 100%; height: 100%; border: 0;
  filter: brightness(0.95) saturate(0.9);
}
.contacts__map-card {
  position: absolute;
  left: 18px; bottom: 18px; right: 18px;
  display: flex; flex-direction: column; gap: 6px;
  padding: 16px 20px;
  background: oklch(0.18 0.05 248 / 0.94);
  border: 1px solid oklch(1 0 0 / 0.12);
  box-shadow: inset 0 1px 0 oklch(1 0 0 / 0.10);
  border-radius: 4px;
  font-size: 13px;
  color: var(--ink-on-deep);
  pointer-events: none;
  max-width: 360px;
}
.contacts__map-card strong { font-weight: 500; }
.contacts__map-card span { color: var(--ink-on-deep-soft); }

/* ============================================================
   Footer — continuous with body
   ============================================================ */
.site-footer {
  background: var(--deep-base);
  color: var(--ink-on-deep);
  padding-block: clamp(48px, 6vw, 80px) 32px;
  border-top: 1px solid var(--hairline-deep);
}
.site-footer__top {
  display: grid;
  gap: clamp(32px, 4vw, 64px);
  grid-template-columns: 1fr;
  margin-bottom: clamp(48px, 6vw, 80px);
}
@media (min-width: 800px) { .site-footer__top { grid-template-columns: 1.4fr 1fr 1fr; } }
.site-footer__brand-mark {
  font-family: "Spectral", serif;
  font-size: 32px;
  font-weight: 300;
  letter-spacing: -0.005em;
  color: var(--ink-on-deep);
  display: block;
  margin-bottom: 16px;
}
.site-footer__brand-sub {
  font-size: 13px;
  color: var(--ink-on-deep-soft);
  max-width: 38ch;
  line-height: 1.65;
}
.site-footer__col-title {
  font-family: "Manrope", sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-on-deep-faint);
  font-weight: 500;
  margin-bottom: 18px;
}
.site-footer__list { display: flex; flex-direction: column; gap: 12px; font-size: 14px; }
.site-footer__list a { color: var(--ink-on-deep-soft); transition: color 200ms var(--ease-out); }
@media (hover: hover) and (pointer: fine) { .site-footer__list a:hover { color: var(--ink-on-deep); } }

.site-footer__seo {
  font-size: 13px;
  color: var(--ink-on-deep-faint);
  line-height: 1.7;
  max-width: 88ch;
  padding-top: clamp(32px, 4vw, 48px);
  border-top: 1px solid var(--hairline-deep);
}
.site-footer__legal {
  display: grid;
  gap: 16px;
  padding-top: 32px;
  margin-top: 32px;
  border-top: 1px solid var(--hairline-deep);
  font-size: 12px;
  color: var(--ink-on-deep-faint);
  grid-template-columns: 1fr;
}
@media (min-width: 700px) { .site-footer__legal { grid-template-columns: 1fr auto; align-items: center; } }
.site-footer__legal-text { line-height: 1.6; }
.site-footer__socials { display: flex; gap: 12px; }
.site-footer__social {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border-radius: 999px;
  border: 1px solid var(--hairline-deep);
  color: var(--ink-on-deep);
  transition: background 200ms var(--ease-out), border-color 200ms var(--ease-out), transform 120ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) { .site-footer__social:hover { background: oklch(1 0 0 / 0.05); border-color: var(--ink-on-deep-soft); } }
.site-footer__social:active { transform: scale(0.95); }

/* ============================================================
   Reveal — faster (Emil 380ms)
   ============================================================ */
.js .reveal {
  opacity: 0;
  transform: translateY(12px);
  transition:
    opacity 280ms var(--ease-out),
    transform 280ms var(--ease-out);
  transition-delay: var(--reveal-delay, 0ms);
}
.js .reveal.is-visible {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  .js .reveal { opacity: 1; transform: none; transition: none; }
}

/* Hero on-load — Emil-tight 600ms with stagger */
.fade-up {
  opacity: 0;
  transform: translateY(14px);
  animation: fade-up 600ms var(--ease-out) forwards;
  animation-delay: var(--fade-delay, 60ms);
}
@keyframes fade-up {
  to { opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce) {
  .fade-up { opacity: 1; transform: none; animation: none; }
}

/* ============================================================
   Mobile sticky CTA
   ============================================================ */
.mobile-cta {
  position: fixed;
  inset: auto 12px 12px 12px;
  z-index: 40;
  display: flex;
  gap: 8px;
  padding: 10px 12px;
  background: oklch(0.10 0.04 250 / 0.98);
  color: var(--ink-on-deep);
  border-radius: 999px;
  border: 1px solid oklch(1 0 0 / 0.10);
  box-shadow:
    inset 0 1px 0 oklch(1 0 0 / 0.08),
    0 12px 48px -24px oklch(0 0 0 / 0.6);
  align-items: center;
  justify-content: space-between;
  transform: translateY(120%);
  opacity: 0;
  transition: transform 380ms var(--ease-out), opacity 380ms var(--ease-out);
}
.mobile-cta[data-visible="true"] { transform: none; opacity: 1; }
@media (min-width: 920px) { .mobile-cta { display: none; } }
.mobile-cta__main {
  display: inline-flex; align-items: center; gap: 8px;
  height: 44px; padding: 0 18px;
  border-radius: 999px;
  background: var(--clay);
  color: var(--deep-night);
  font-size: 14px; font-weight: 500;
  flex: 1;
  justify-content: center;
  transition: transform 120ms var(--ease-out);
}
.mobile-cta__main:active { transform: scale(0.97); }
.mobile-cta__icon {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  border: 1px solid oklch(1 0 0 / 0.12);
  color: var(--ink-on-deep);
  transition: transform 120ms var(--ease-out);
}
.mobile-cta__icon:active { transform: scale(0.92); }

/* ============================================================
   Page-hero (sub-pages)
   ============================================================ */
.page-hero {
  background: var(--deep-base);
  color: var(--ink-on-deep);
  padding-top: 156px;
  padding-bottom: clamp(56px, 6vw, 96px);
  border-bottom: 1px solid var(--hairline-deep);
}
.page-hero__inner {
  display: grid;
  gap: clamp(24px, 3vw, 48px);
  grid-template-columns: 1fr;
}
@media (min-width: 920px) { .page-hero__inner { grid-template-columns: 1.2fr 1fr; align-items: end; } }
.page-hero__title {
  font-size: clamp(40px, 6vw, 80px);
  font-weight: 300;
  line-height: 1.0;
  letter-spacing: -0.022em;
  color: var(--ink-on-deep);
}
.page-hero__title em { font-style: italic; color: var(--clay-soft); }
.page-hero__intro { color: var(--ink-on-deep-soft); font-size: var(--t-lede); line-height: 1.55; }

.crumbs {
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-on-deep-faint);
  display: inline-flex;
  gap: 10px;
  align-items: center;
}
.crumbs a { color: inherit; transition: color 200ms var(--ease-out), transform 120ms var(--ease-out); }
@media (hover: hover) and (pointer: fine) { .crumbs a:hover { color: var(--ink-on-deep); } }
.crumbs a:active { transform: scale(0.98); }
.crumbs span { opacity: 0.4; }

/* ============================================================
   Pricing list (services.html) — kept on dark
   ============================================================ */
.pricing-grid {
  display: grid;
  gap: 1px;
  background: var(--hairline-deep);
  border-block: 1px solid var(--hairline-deep);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .pricing-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .pricing-grid { grid-template-columns: repeat(3, 1fr); } }
.pricing-grid[data-cols="2"] { grid-template-columns: 1fr; }
@media (min-width: 720px) { .pricing-grid[data-cols="2"] { grid-template-columns: repeat(2, 1fr); } }

.price-card {
  background: var(--deep-base);
  padding: clamp(24px, 2.5vw, 36px);
  display: flex; flex-direction: column; gap: 14px;
  transition: background 280ms var(--ease-out);
  position: relative;
}
@media (hover: hover) and (pointer: fine) { .price-card:hover { background: var(--deep); } }
.price-card__head {
  display: flex; justify-content: space-between; align-items: baseline; gap: 12px;
}
.price-card__title {
  font-family: "Spectral", serif;
  font-weight: 400;
  font-size: 21px;
  letter-spacing: -0.005em;
  color: var(--ink-on-deep);
  line-height: 1.18;
}
.price-card__price {
  font-family: "Spectral", serif;
  font-size: 22px;
  font-weight: 400;
  color: var(--ink-on-deep);
  white-space: nowrap;
}
.price-card__price em {
  font-style: italic;
  font-size: 13px;
  color: var(--ink-on-deep-faint);
  margin-left: 6px;
  font-weight: 400;
  letter-spacing: 0;
}
.price-card__meta {
  font-size: 13px;
  color: var(--ink-on-deep-soft);
  line-height: 1.55;
  display: flex; flex-direction: column; gap: 6px;
  flex: 1;
}
.price-card__term {
  font-family: "Manrope", sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-on-deep-faint);
  margin-top: 12px;
}
.price-card__cta {
  display: inline-flex;
  align-items: center; justify-content: space-between;
  margin-top: 8px;
  padding-top: 14px;
  border-top: 1px solid var(--hairline-deep);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-on-deep);
  letter-spacing: 0.02em;
  transition: color 200ms var(--ease-out), transform 120ms var(--ease-out);
}
@media (hover: hover) and (pointer: fine) { .price-card__cta:hover { color: var(--clay-soft); } }
.price-card__cta:active { transform: scale(0.98); }
.price-card__cta svg { width: 14px; height: 14px; transition: transform 240ms var(--ease-out); }
@media (hover: hover) and (pointer: fine) { .price-card__cta:hover svg { transform: translateX(3px); } }

.price-card[data-tier="abonement"] { background: var(--deep-night); }
@media (hover: hover) and (pointer: fine) { .price-card[data-tier="abonement"]:hover { background: var(--deep); } }

.price-section-title {
  font-family: "Spectral", serif;
  font-weight: 300;
  font-size: clamp(26px, 2.8vw, 40px);
  letter-spacing: -0.014em;
  margin-bottom: 24px;
  display: flex;
  align-items: baseline;
  gap: 18px;
  color: var(--ink-on-deep);
}
@media (max-width: 720px) {
  .price-section-title {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
}
.price-section-title span {
  font-family: "Spectral", serif;
  font-style: italic;
  font-size: 14px;
  color: var(--ink-on-deep-faint);
  font-weight: 400;
  letter-spacing: 0;
}
.price-section + .price-section { margin-top: clamp(48px, 6vw, 96px); }

/* Tabs */
.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 28px;
  margin-bottom: clamp(32px, 4vw, 56px);
  border-bottom: 1px solid var(--hairline-deep);
  padding-bottom: 0;
}
/* On phones a 6-button row wraps into stubby second line; convert to a
   horizontal scroller with snap so tabs read as one continuous strip. */
@media (max-width: 720px) {
  .tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    gap: 22px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    margin-inline: calc(var(--gutter) * -1);
    padding-inline: var(--gutter);
  }
  .tabs::-webkit-scrollbar { display: none; }
  .tabs__btn {
    flex: none;
    scroll-snap-align: start;
    white-space: nowrap;
  }
}
.tabs__btn {
  padding: 12px 0;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--ink-on-deep-soft);
  border-bottom: 1px solid transparent;
  margin-bottom: -1px;
  transition: color 200ms var(--ease-out), border-color 200ms var(--ease-out), transform 120ms var(--ease-out);
}
.tabs__btn[data-active="true"] {
  color: var(--ink-on-deep);
  border-bottom-color: var(--clay);
}
.tabs__btn:active { transform: scale(0.97); }

/* ============================================================
   How it works (floating page) — used on sub-page
   ============================================================ */
.how-grid {
  display: grid;
  gap: clamp(32px, 4vw, 60px);
  grid-template-columns: 1fr;
}
@media (min-width: 920px) { .how-grid { grid-template-columns: 1fr 1fr; } }
.how-step {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 18px;
  padding-block: 28px;
  border-bottom: 1px solid var(--hairline-deep);
}
.island .how-step { border-bottom-color: var(--hairline); }
.how-step:last-child { border-bottom: 0; }
.how-step__num {
  font-family: "Spectral", serif;
  font-size: 28px;
  font-style: italic;
  font-weight: 300;
  color: var(--clay-soft);
  line-height: 1;
}
.how-step__body { display: flex; flex-direction: column; gap: 8px; }
.how-step__title {
  font-family: "Spectral", serif;
  font-size: 21px;
  font-weight: 400;
  letter-spacing: -0.005em;
  color: var(--ink-on-deep);
}
.island .how-step__title { color: var(--ink); }
.how-step__text { color: var(--ink-on-deep-soft); font-size: 15px; line-height: 1.65; }
.island .how-step__text { color: var(--ink-soft); }

.note-box {
  background: var(--deep);
  padding: clamp(20px, 2.4vw, 32px);
  border: 1px solid var(--hairline-deep);
  display: flex; flex-direction: column; gap: 10px;
  font-size: 14px; color: var(--ink-on-deep-soft); line-height: 1.65;
}
.island .note-box {
  background: var(--sand);
  border-color: var(--hairline);
  color: var(--ink-soft);
}
.note-box strong { color: var(--ink-on-deep); font-weight: 500; }
.island .note-box strong { color: var(--ink); }

/* Rules list */
.rules-list { display: flex; flex-direction: column; gap: 0; counter-reset: rules; }
.rules-list li {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 16px;
  padding: 18px 0;
  border-bottom: 1px solid var(--hairline-deep);
  font-size: 15px;
  color: var(--ink-on-deep-soft);
  line-height: 1.6;
}
.island .rules-list li { color: var(--ink-soft); border-bottom-color: var(--hairline); }
.rules-list li::before {
  content: counter(rules);
  counter-increment: rules;
  font-family: "Spectral", serif;
  font-style: italic;
  font-size: 14px;
  color: var(--clay-soft);
}

/* ============================================================
   Utility
   ============================================================ */
.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;
}
.muted { color: var(--ink-on-deep-soft); }
.island .muted { color: var(--ink-soft); }
.h-italic { font-style: italic; font-weight: 300; color: var(--clay-soft); }
.island .h-italic { color: var(--clay); }
