/* =====================================================================
   Luma Biohacking Resort — Cliff Sanctuary v03 (colour-harmony pass)
   Concept: Uluwatu cliff / ocean / jungle, dark luxury. Real renders.
   Dark retreat & silence as the hero. Negative space is BLACK, not white.
   Brand strict: Base Black #0A0A0A, Medical White, Deep Jungle / Soft Jade,
   sunset Nude #D1C2AF as the ONLY warm accent (UI-chrome). Photography keeps
   its real warmth (dusk, wood) — warmth lives in the photo, brand in the chrome.
   Fonts: Onest (sans, Cyrillic-safe, prod->TT Hoves Pro) + Cormorant (serif accent, prod->Roca One Light).
   ===================================================================== */

:root{
  --black:        #0A0A0A;
  --black-2:      #060606;
  --white:        #FFFFFF;
  --jungle:       #004B49;
  --jade:         #739B98;
  --bio-light:    #A7C0DE;
  --nude:         #D1C2AF;
  --stone:        #B6B6B6;

  --ink-85: rgba(255,255,255,.85);
  --ink-70: rgba(255,255,255,.70);
  --ink-50: rgba(255,255,255,.50);
  --ink-34: rgba(255,255,255,.34);
  --ink-18: rgba(255,255,255,.18);
  --ink-10: rgba(255,255,255,.10);
  --ink-06: rgba(255,255,255,.06);

  --jade-line: rgba(115,155,152,.34);
  --jade-soft: rgba(115,155,152,.12);
  --jungle-fill: rgba(0,75,73,.30);

  /* Cyrillic-safe stacks. Prod licensed fonts lead the stack -> one-line swap. */
  --sans: "TT Hoves Pro", "Onest", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --serif: "Roca One", "Cormorant", Georgia, serif; /* accent display only, upright */

  --gut: clamp(20px, 5vw, 80px);
  --maxw: 1320px;
  --r: 0px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0; background:var(--black); color:var(--white);
  font-family:var(--sans); font-size:16px; line-height:1.5; letter-spacing:.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
h1,h2,h3,p,ul,figure{ margin:0; }
ul{ list-style:none; padding:0; }

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

/* ---------- shared atoms ---------- */
.eyebrow{
  font-size:.72rem; letter-spacing:.26em; text-transform:uppercase;
  color:var(--jade); font-weight:500;
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{ content:""; width:32px; height:1px; background:var(--jade-line); display:inline-block; }
.serif{ font-family:var(--serif); font-weight:400; font-style:normal; letter-spacing:-.005em; }

.section-head{ max-width:760px; margin-bottom:clamp(40px,6vw,72px); }
.section-title{ font-size:clamp(2.1rem,5.2vw,4rem); line-height:1.04; font-weight:600; letter-spacing:-.025em; margin-top:1rem; }
.section-title span{ display:block; }
.section-lede{ margin-top:1.4rem; max-width:46ch; color:var(--ink-70); font-size:clamp(1rem,1.4vw,1.18rem); line-height:1.55; }

.btn{
  display:inline-flex; align-items:center; gap:.6em; padding:1.05em 1.7em; border-radius:var(--r);
  font-size:.86rem; letter-spacing:.06em; font-weight:600; text-transform:uppercase;
  transition:all .35s var(--ease); border:1px solid transparent; white-space:nowrap;
}
.btn--primary{ background:var(--white); color:var(--black); }
.btn--primary:hover{ background:var(--jade); color:var(--black); }
.btn--line{ border-color:var(--ink-18); color:var(--white); }
.btn--line:hover{ border-color:var(--jade); color:var(--jade); }
.btn--ghost{ padding:.7em 1.2em; border-color:var(--ink-18); font-size:.74rem; }
.btn--ghost:hover{ border-color:var(--jade); color:var(--jade); }

/* =====================================================================
   HEADER
   ===================================================================== */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding:18px var(--gut);
  transition:background .4s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{ background:rgba(10,10,10,.80); backdrop-filter:blur(14px); border-bottom-color:var(--ink-06); }
.brand{ display:flex; align-items:center; gap:12px; }
.brand__mark{ width:26px; height:26px; color:var(--white); display:block; }
.brand__mark svg{ width:100%; height:100%; }
.brand__mark--sm{ width:22px; height:22px; }
.brand__word{ font-weight:600; letter-spacing:.34em; font-size:.94rem; padding-left:.18em; }

.site-nav{ display:flex; gap:34px; }
.site-nav a{ font-size:.8rem; letter-spacing:.08em; color:var(--ink-70); text-transform:uppercase; position:relative; padding:4px 0; transition:color .3s var(--ease); }
.site-nav a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--jade); transition:width .35s var(--ease); }
.site-nav a:hover{ color:var(--white); }
.site-nav a:hover::after{ width:100%; }

/* P2 v03: skip-nav — visually hidden until focused (UC-12) */
.skip-nav{
  position:fixed; top:10px; left:10px; z-index:1000;
  transform:translateY(-160%); transition:transform .2s var(--ease);
  background:var(--white); color:var(--black); padding:.7em 1.1em;
  font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; font-weight:600;
}
.skip-nav:focus{ transform:translateY(0); outline:2px solid var(--jade); outline-offset:2px; }

.header-actions{ display:flex; align-items:center; gap:18px; }

/* P2 v03: mobile-nav disclosure toggle — hidden on desktop, shown ≤980px */
.nav-toggle{ display:none; width:34px; height:34px; align-items:center; justify-content:center; flex-direction:column; gap:5px; }
.nav-toggle__bar{ width:20px; height:1.5px; background:var(--white); transition:transform .3s var(--ease), opacity .3s var(--ease); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1){ transform:translateY(3.25px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2){ transform:translateY(-3.25px) rotate(-45deg); }
.mobile-nav{ display:none; }
.mobile-nav[hidden]{ display:none; }
.lang-switch{ display:flex; align-items:center; gap:.4em; font-size:.78rem; letter-spacing:.08em; }
.lang{ color:var(--ink-34); padding:2px 1px; transition:color .25s var(--ease); }
.lang.is-active{ color:var(--white); }
.lang:hover{ color:var(--jade); }
.lang-sep{ color:var(--ink-18); }

/* =====================================================================
   HERO — real dusk exterior render, dark veil for legibility
   ===================================================================== */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; padding:0 var(--gut) clamp(48px,8vh,96px); overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__photo{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 38%; will-change:transform; }
.hero__veil{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,10,10,.42) 0%, rgba(10,10,10,.12) 34%, rgba(10,10,10,.55) 64%, rgba(10,10,10,.92) 100%); }
.hero__inner{ position:relative; z-index:3; width:100%; max-width:var(--maxw); margin:0 auto; }
.hero__title{ font-size:clamp(2.6rem,8vw,7rem); line-height:.98; font-weight:600; letter-spacing:-.035em; margin:1.4rem 0 1.4rem; max-width:16ch; overflow-wrap:break-word; }
.hero__line{ display:block; }
/* color-harmony v03: serif headline word was jade ON the dusk photo — colored text on a
   variable-value photo reads muddy where the frame turns teal. Switched to white (value-led,
   guaranteed AA over the veil); jade stays on solid-bg UI accents (eyebrow, line, hover). */
.hero__line--serif{ font-family:var(--serif); font-weight:400; letter-spacing:-.01em; color:var(--white); }
.hero__sub{ max-width:44ch; color:var(--ink-70); font-size:clamp(1.02rem,1.5vw,1.28rem); line-height:1.55; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:2.2rem; }
.hero__pulse{ margin-top:3rem; height:64px; max-width:560px; opacity:.92; }
.pulseline{ width:100%; height:100%; }
.pulseline__path{ fill:none; stroke:var(--jade); stroke-width:5; stroke-linecap:round; stroke-linejoin:round; vector-effect:non-scaling-stroke; }
.hero__scroll{ margin-top:1.3rem; font-size:.68rem; letter-spacing:.24em; text-transform:uppercase; color:var(--ink-34); }
.hero__mobile-book{ display:none; }

/* =====================================================================
   PROOF BAND
   ===================================================================== */
.proof{ border-top:1px solid var(--ink-06); border-bottom:1px solid var(--ink-06); padding:clamp(48px,7vw,84px) var(--gut); background:var(--black-2); }
.proof__grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--ink-06); }
.proof__item{ background:var(--black-2); padding:clamp(20px,3vw,40px) clamp(8px,2vw,28px); display:flex; flex-direction:column; gap:.6rem; }
.proof__num{ font-family:var(--serif); font-weight:400; line-height:1; font-size:clamp(2.6rem,5.4vw,4.6rem); color:var(--white); letter-spacing:-.01em; }
.proof__lbl{ font-size:.82rem; color:var(--ink-50); letter-spacing:.04em; line-height:1.4; max-width:18ch; }
.proof__foot{ max-width:var(--maxw); margin:clamp(28px,4vw,44px) auto 0; font-size:.82rem; letter-spacing:.05em; color:var(--ink-34); text-transform:uppercase; }

/* =====================================================================
   CONCEPT
   ===================================================================== */
.concept{ padding:clamp(80px,11vw,160px) var(--gut) clamp(40px,6vw,80px); max-width:var(--maxw); margin:0 auto; }
.concept__pulse{ height:38px; margin:clamp(8px,2vw,18px) 0 clamp(40px,6vw,68px); opacity:.5; }
.concept__pulse .pulseline{ width:100%; height:100%; }
.pulseline__path--hair{ stroke:var(--jade); stroke-width:2; }
.concept__cols{ display:grid; grid-template-columns:1fr 1fr 1.25fr; gap:1px; background:var(--ink-06); border:1px solid var(--ink-06); }
.concept__col{ background:var(--black); padding:clamp(28px,3.4vw,52px); display:flex; flex-direction:column; }
.concept__idx{ font-family:var(--serif); font-weight:400; font-size:1.2rem; color:var(--jade); letter-spacing:.1em; margin-bottom:1.4rem; }
.concept__col h3{ font-size:clamp(1.4rem,2.2vw,1.9rem); font-weight:600; letter-spacing:-.02em; }
.concept__lede{ margin-top:.9rem; color:var(--ink-70); font-size:1rem; line-height:1.55; max-width:34ch; }
.modality{ margin-top:2rem; display:flex; flex-wrap:wrap; gap:8px; }
/* color-harmony v03: was jade text on jade-tint fill (same hue, near value = muddy).
   Fixed: text -> neutral white-85% (value-led readability), jade lives on the LINE (border) only. */
.modality li{ font-size:.74rem; letter-spacing:.04em; color:var(--ink-85); border:1px solid var(--jade-line); padding:.5em .85em; border-radius:var(--r); background:var(--jade-soft); transition:all .3s var(--ease); }
.modality li:hover{ background:var(--jungle-fill); border-color:var(--jade); color:var(--white); }
.concept__col--feature{ background:linear-gradient(180deg, #070b0b 0%, var(--black-2) 100%); }
.darkroom{ margin-top:auto; padding-top:2.2rem; position:relative; }
.darkroom img{ width:100%; height:220px; object-fit:cover; border:1px solid var(--ink-06); }

/* =====================================================================
   SANCTUARY SHOWPIECE — real pool + yoga renders
   ===================================================================== */
.sanctuary{ display:grid; grid-template-columns:1.6fr 1fr; gap:1px; background:var(--ink-06); border-top:1px solid var(--ink-06); border-bottom:1px solid var(--ink-06); }
.sanctuary__fig{ position:relative; background:var(--black); overflow:hidden; }
.sanctuary__fig img{ width:100%; height:100%; min-height:380px; object-fit:cover; display:block; }
.sanctuary__cap{ position:absolute; left:0; right:0; bottom:0; padding:20px clamp(18px,2.5vw,32px); font-size:.86rem; letter-spacing:.03em; color:var(--white); background:linear-gradient(0deg, rgba(10,10,10,.78), transparent); }

/* =====================================================================
   RESIDENCES — real interior renders
   ===================================================================== */
.residences{ padding:clamp(60px,9vw,130px) var(--gut); max-width:var(--maxw); margin:0 auto; }
.res__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(18px,2.4vw,36px); }
.res__card{ border:1px solid var(--ink-10); background:var(--black-2); display:flex; flex-direction:column; }
.res__photo{ position:relative; aspect-ratio:16/11; overflow:hidden; border-bottom:1px solid var(--ink-06); }
.res__photo img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.res__card:hover .res__photo img{ transform:scale(1.04); }
.res__body{ padding:clamp(24px,2.8vw,40px); display:flex; flex-direction:column; gap:1.6rem; flex:1; }
.res__row{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.res__row h3{ font-size:clamp(1.3rem,2vw,1.7rem); font-weight:600; letter-spacing:-.02em; }
.res__price{ display:flex; align-items:baseline; gap:.3em; }
.res__amt{ font-family:var(--serif); font-weight:400; font-size:clamp(1.9rem,3vw,2.6rem); color:var(--white); }
.res__per{ font-size:.78rem; letter-spacing:.06em; color:var(--ink-34); text-transform:uppercase; }
.res__meta{ display:grid; grid-template-columns:1fr 1fr; gap:.7rem 1.2rem; }
.res__meta li{ font-size:.86rem; color:var(--ink-50); border-left:1px solid var(--jade-line); padding-left:.9em; line-height:1.4; }
.res__cta{ margin-top:auto; font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; color:var(--white); border-top:1px solid var(--ink-10); padding-top:1.4rem; transition:color .3s var(--ease); align-self:flex-start; }
.res__cta:hover{ color:var(--jade); }
.res__longstay{ margin-top:clamp(28px,4vw,44px); color:var(--ink-34); font-size:.86rem; letter-spacing:.04em; }

/* =====================================================================
   LOCATION — real aerial render
   ===================================================================== */
.location{ position:relative; display:grid; grid-template-columns:1.1fr 1fr; min-height:80svh; }
.location__media{ position:relative; overflow:hidden; background:var(--black-2); }
/* P1 v03: render-09 is a bright daylight frame. v02 only darkened it flat -> read as
   "dim noon", broke the dusk tonal continuity. v03 builds a NATIVE twilight grade:
   the image is colour-graded toward dusk (lower brightness, warmer cast, harsh-green
   knocked down, contrast lifted), then a DIRECTIONAL sunset light is layered on top —
   warm brand Nude glow low-left fading into cool Base-Black night top-right, matching
   the page "first sunset" motif. Tonal temperature now matches the rest of the page. */
.location__media img{
  width:100%; height:100%; object-fit:cover;
  filter:brightness(.62) contrast(1.08) saturate(.82) sepia(.18) hue-rotate(-8deg);
}
.location__media::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:1;
  /* warm sunset light source, low-left -> dusk sky */
  background:
    radial-gradient(75% 60% at 18% 92%, rgba(209,194,175,.30) 0%, rgba(209,194,175,.10) 32%, transparent 62%),
    linear-gradient(155deg, rgba(0,75,73,.28) 0%, transparent 38%);
  mix-blend-mode:screen;
}
.location__media::after{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:2;
  /* night settling in from top-right + seam into the dark text panel */
  background:
    linear-gradient(150deg, rgba(6,6,6,.70) 0%, rgba(6,6,6,.14) 46%, transparent 70%),
    linear-gradient(90deg, transparent 58%, rgba(10,10,10,.62) 100%);
}
.location__inner{ padding:clamp(60px,8vw,120px) var(--gut); display:flex; flex-direction:column; justify-content:center; }
.loc__list{ margin-top:clamp(28px,4vw,48px); display:grid; gap:0; max-width:480px; }
.loc__list li{ display:flex; align-items:baseline; justify-content:space-between; gap:16px; padding:.95rem 0; border-bottom:1px solid var(--ink-06); }
.loc__t{ font-size:.98rem; color:var(--ink-70); }
.loc__d{ font-family:var(--serif); font-weight:400; font-size:1.1rem; color:var(--jade); letter-spacing:.02em; white-space:nowrap; }

/* =====================================================================
   ENQUIRE — the only warm moment (sunset Nude)
   ===================================================================== */
.enquire{ position:relative; padding:clamp(80px,12vw,170px) var(--gut); overflow:hidden; border-top:1px solid var(--ink-06); }
.enquire__glow{ position:absolute; left:50%; bottom:-40%; transform:translateX(-50%); width:120vw; height:90vh; pointer-events:none; background:radial-gradient(50% 50% at 50% 50%, rgba(209,194,175,.22) 0%, rgba(209,194,175,.06) 38%, transparent 70%); filter:blur(8px); }
.enquire__inner{ position:relative; z-index:2; max-width:680px; margin:0 auto; text-align:center; }
.enquire__title{ font-size:clamp(2.2rem,5.6vw,4.2rem); line-height:1.04; font-weight:600; letter-spacing:-.03em; margin:1.2rem 0; }
.enquire__title span{ display:block; }
.enquire__title .serif{ color:var(--nude); }
.enquire__sub{ color:var(--ink-70); font-size:1.06rem; max-width:42ch; margin:0 auto; }
.enquire__form{ margin-top:clamp(36px,5vw,56px); display:grid; grid-template-columns:1fr 1fr; gap:18px; text-align:left; }
.field{ display:flex; flex-direction:column; gap:.5rem; }
.field--dates{ grid-column:1 / -1; }
.field__lbl{ font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-34); }
.field input, .field select{ background:var(--black-2); border:1px solid var(--ink-10); border-radius:var(--r); color:var(--white); padding:.95em 1em; font:inherit; font-size:.96rem; transition:border-color .3s var(--ease); }
.field input:focus, .field select:focus{ outline:none; border-color:var(--jade); }
.field input::placeholder{ color:var(--ink-18); }
.field select{ appearance:none; }
.enquire__submit{ grid-column:1 / -1; justify-content:center; margin-top:.4rem; }
.enquire__fineprint{ grid-column:1 / -1; text-align:center; font-size:.74rem; color:var(--ink-34); letter-spacing:.03em; margin-top:.2rem; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer{ border-top:1px solid var(--ink-06); padding:clamp(48px,7vw,90px) var(--gut) 40px; }
.footer__line{ max-width:var(--maxw); margin:0 auto clamp(40px,6vw,72px); height:48px; opacity:.4; }
.footer__line svg{ width:100%; height:100%; }
.footer__line path{ fill:none; stroke:var(--jade); stroke-width:2.5; vector-effect:non-scaling-stroke; stroke-linecap:round; }
.footer__top{ max-width:var(--maxw); margin:0 auto; display:flex; align-items:flex-start; justify-content:space-between; gap:40px; flex-wrap:wrap; padding-bottom:clamp(32px,4vw,52px); border-bottom:1px solid var(--ink-06); }
.footer__brand{ display:flex; gap:16px; align-items:flex-start; }
.footer__brand .brand__mark{ color:var(--white); margin-top:2px; }
.footer__name{ font-weight:600; letter-spacing:.04em; }
.footer__tag{ font-family:var(--serif); font-weight:400; color:var(--jade); margin-top:.3rem; font-size:1.1rem; }
.footer__nav{ display:flex; flex-direction:column; gap:.8rem; }
.footer__nav a{ font-size:.84rem; color:var(--ink-50); letter-spacing:.04em; transition:color .3s var(--ease); }
.footer__nav a:hover{ color:var(--jade); }
.footer__bottom{ max-width:var(--maxw); margin:clamp(24px,3vw,36px) auto 0; display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-34); }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 980px){
  .site-nav{ display:none; }
  /* P2 v03: nav no longer silently vanishes — disclosure toggle takes over */
  .nav-toggle{ display:flex; }
  .header-cta{ display:none; } /* booking stays via persistent mobile bar (UC-8) */
  .site-header{ flex-wrap:wrap; }
  .mobile-nav{
    display:none; flex-basis:100%; width:100%; order:3;
    flex-direction:column; gap:2px; margin-top:14px;
    border-top:1px solid var(--ink-06); padding-top:10px;
  }
  .mobile-nav:not([hidden]){ display:flex; }
  .site-header:not(.is-scrolled) .mobile-nav:not([hidden]){ background:rgba(10,10,10,.92); backdrop-filter:blur(14px); }
  .mobile-nav a{ font-size:.92rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-70); padding:.85rem 0; border-bottom:1px solid var(--ink-06); transition:color .25s var(--ease); }
  .mobile-nav a:last-child{ border-bottom:none; }
  .mobile-nav a:hover, .mobile-nav a:focus{ color:var(--jade); }
  .concept__cols{ grid-template-columns:1fr; }
  .sanctuary{ grid-template-columns:1fr; }
  .location{ grid-template-columns:1fr; }
  .location__media{ min-height:46svh; }
  /* stacked layout: night from top, seam into the text panel below */
  .location__media::after{ background:linear-gradient(180deg, rgba(6,6,6,.5) 0%, transparent 34%, transparent 58%, rgba(10,10,10,.72) 100%); }
  .location__media::before{ background:radial-gradient(80% 55% at 22% 96%, rgba(209,194,175,.28) 0%, rgba(209,194,175,.08) 34%, transparent 64%); }
  .proof__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 720px){
  .res__grid{ grid-template-columns:1fr; }
  .enquire__form{ grid-template-columns:1fr; }
  .footer__top{ flex-direction:column; gap:28px; }
  .hero{ padding-bottom:clamp(96px,16vh,140px); } /* room for mobile booking bar */
  .hero__sub{ font-size:1rem; }
  .hero__cta{ display:none; } /* replaced by persistent mobile booking bar */
  .hero__pulse{ margin-top:2rem; height:50px; }
  /* UC-8: persistent booking entry on mobile, in first screen */
  .hero__mobile-book{
    display:flex; position:absolute; left:var(--gut); right:var(--gut); bottom:clamp(20px,5vh,40px); z-index:5;
    justify-content:center; align-items:center; padding:1.05em 1.7em;
    background:var(--white); color:var(--black); font-size:.86rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  }
}
@media (max-width: 460px){
  .hero__title{ font-size:clamp(1.9rem,8.2vw,2.6rem); max-width:100%; letter-spacing:-.025em; }
  .proof__grid{ grid-template-columns:1fr; }
  .res__meta{ grid-template-columns:1fr; }
}

/* ---------- signature interaction: heartbeat draw ---------- */
.pulseline__path{ stroke-dasharray:2400; stroke-dashoffset:2400; }
.is-drawn .pulseline__path{ animation:draw 2.6s var(--ease) forwards; }
@keyframes draw{ to{ stroke-dashoffset:0; } }

@media (prefers-reduced-motion: reduce){
  .pulseline__path{ stroke-dashoffset:0; animation:none; }
  .hero__photo{ transform:none !important; }
  *{ scroll-behavior:auto !important; }
}
