/* =========================================================
   NÚRIA BOLADERES — Relationship Coaching, Austin
   Website prototype · "Rooms through Windows"
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Mulish:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --olive:#4A5A38; --olive-d:#3C4A2E;
  --lemon:#D4A72C;
  --terracotta:#A85B49; --orange:#BE8478;
  --beige:#E2D2BC; --linen:#EBE3D6; --cream:#FBF6EC; --paper:#F4EFE6;
  --sea:#8FC6D9; --sea-d:#5E8696;            /* fresher oceanside */
  --sun:#EFC94F;                             /* sunny lemon room  */
  --navy:#123846;                            /* slightly lifted, warmer-deep */
  --ink:#2B2B2B; --ink-soft:#6B6256; --hairline:#CDC2B0;

  --on-navy:#EAF1F2; --on-olive:#EEF0E6; --on-sea:#0E2A36; --on-cream:#2B2B2B; --on-beige:#3a352c; --on-sun:#3C4A2E; --on-terra:#FBEEE7;

  --display:"Cormorant Garamond",Georgia,serif;
  --sans:"Mulish",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;

  --pad:clamp(22px,5vw,96px);
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-room:cubic-bezier(.76,0,.24,1);
}

*{ box-sizing:border-box; }
html,body{ margin:0; height:100%; }
body{
  font-family:var(--sans); color:var(--ink); background:#000;
  font-size:18px; line-height:1.6; -webkit-font-smoothing:antialiased;
  overflow:hidden; text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
button{ font-family:inherit; cursor:pointer; }

/* language visibility */
body.lang-en [data-lang="es"]{ display:none !important; }
body.lang-es [data-lang="en"]{ display:none !important; }

/* ---------- text atoms ---------- */
.eyebrow{ font-family:var(--mono); font-size:clamp(10px,1vw,12px); font-weight:500; letter-spacing:.26em; text-transform:uppercase; margin:0; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:300; margin:0; letter-spacing:-.01em; }
.h-hero{ font-size:clamp(38px,5.6vw,82px); line-height:1.02; }
.h-room{ font-size:clamp(34px,4.6vw,64px); line-height:1.04; }
.h-sub{ font-size:clamp(23px,2.5vw,34px); line-height:1.12; font-weight:400; }
.serif-it{ font-style:italic; }
.lede{ font-family:var(--display); font-weight:300; font-size:clamp(20px,2.2vw,30px); line-height:1.36; }
p{ margin:0 0 1em; }
.muted{ color:var(--ink-soft); }

/* =========================================================
   STAGE & ROOMS
   ========================================================= */
.stage{ position:fixed; inset:0; overflow:hidden; background:#000; }
.room{
  position:absolute; inset:0;
  display:flex; flex-direction:column; justify-content:center;
  padding:clamp(78px,9vh,120px) var(--pad) clamp(56px,8vh,90px);
  overflow:hidden;
  visibility:hidden; opacity:0; z-index:1;
  will-change:transform, clip-path;
}
.room.active{ visibility:visible; opacity:1; z-index:2; }
.room.moving{ visibility:visible; opacity:1; }
.room-inner{ width:100%; max-width:1240px; margin:0 auto; max-height:100%; overflow-y:auto; overflow-x:hidden; scrollbar-width:none; }
.room-inner::-webkit-scrollbar{ display:none; }

/* room palettes */
.room.bg-navy{ background:var(--navy); color:var(--on-navy); }
.room.bg-olive{ background:var(--olive); color:var(--on-olive); }
.room.bg-sea{ background:linear-gradient(165deg, #9FD0E0 0%, var(--sea) 60%, #7FB8CD 100%); color:var(--on-sea); }
.room.bg-cream{ background:var(--cream); color:var(--on-cream); }
.room.bg-beige{ background:var(--beige); color:var(--on-beige); }
.room.bg-linen{ background:var(--linen); color:var(--on-cream); }
.room.bg-sun{ background:linear-gradient(160deg, #F4D873 0%, var(--sun) 55%, #E8B93C 100%); color:var(--on-sun); }
.room.bg-sunset{ background:linear-gradient(180deg, #EFDFCB 0%, #F2CFAB 30%, #EFBC92 55%, #E9AA7E 76%, #E5A177 100%); color:var(--ink); }

/* accent helpers per bg */
.bg-navy .eyebrow{ color:var(--lemon); }
.bg-olive .eyebrow{ color:#cdd9b3; }
.bg-sea .eyebrow{ color:var(--navy); opacity:.62; }
.bg-sun .eyebrow{ color:var(--olive); }
.bg-cream .eyebrow,.bg-linen .eyebrow,.bg-beige .eyebrow{ color:var(--terracotta); }

/* =========================================================
   CONTENT REVEAL (after a room lands)
   ========================================================= */
.r-reveal{ opacity:0; transform:translateY(26px); }
.room.shown .r-reveal{ opacity:1; transform:none; transition:opacity .7s var(--ease), transform .7s var(--ease); }
.room.shown .r-reveal.d1{ transition-delay:.08s; }
.room.shown .r-reveal.d2{ transition-delay:.16s; }
.room.shown .r-reveal.d3{ transition-delay:.24s; }
.room.shown .r-reveal.d4{ transition-delay:.32s; }
.room.shown .r-reveal.d5{ transition-delay:.40s; }
@media(prefers-reduced-motion:reduce){
  .r-reveal{ opacity:1 !important; transform:none !important; }
}

/* =========================================================
   WINDOW FRAMES
   ========================================================= */
.win{ position:relative; overflow:hidden; background:rgba(0,0,0,.08); }
.win img{ width:100%; height:100%; object-fit:cover; }
.win--arch{ border-radius:999px 999px 26px 26px; }
.win--oval{ border-radius:50%/44%; }
.win--soft{ border-radius:28px; }
.win--archL{ border-radius:999px 26px 26px 999px; }

/* =========================================================
   TOP BAR
   ========================================================= */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:40;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px var(--pad);
  mix-blend-mode:normal;
}
.brandmark{ display:inline-flex; flex-direction:column; gap:3px; font-family:var(--display); color:currentColor; text-decoration:none; line-height:1; letter-spacing:.005em; transition:color .4s; }
.brandmark .bm-name{ font-size:clamp(19px,2vw,24px); font-weight:400; line-height:1; }
.brandmark .bm-sub{ font-family:var(--mono); font-size:9px; letter-spacing:.16em; text-transform:uppercase; opacity:.62; font-weight:400; }
.brandmark b{ font-weight:500; }
.nav-c{ display:flex; align-items:center; gap:clamp(14px,2vw,30px); }
.nav-links{ display:flex; gap:clamp(14px,1.6vw,26px); }
.nav-links a{ font-family:var(--mono); font-size:11px; letter-spacing:.13em; text-transform:uppercase; text-decoration:none; color:currentColor; opacity:.62; transition:opacity .25s; position:relative; padding:4px 0; background:none; border:0; }
.nav-links a:hover{ opacity:1; }
.nav-links a.active{ opacity:1; }
.nav-links a.active::after{ content:""; position:absolute; left:0; right:0; bottom:-2px; height:1px; background:currentColor; }

.bar-right{ display:flex; align-items:center; gap:14px; }
.lang-toggle{ display:inline-flex; align-items:center; gap:2px; font-family:var(--mono); font-size:11px; letter-spacing:.08em; border:1px solid currentColor; border-radius:999px; padding:4px; opacity:.85; }
.lang-toggle button{ background:none; border:0; color:currentColor; padding:3px 9px; border-radius:999px; opacity:.55; letter-spacing:.08em; transition:.2s; }
.lang-toggle button.on{ opacity:1; background:currentColor; }
.lang-toggle button.on span{ mix-blend-mode:difference; color:#fff; }
.btn-book{
  font-family:var(--mono); font-size:11px; letter-spacing:.13em; text-transform:uppercase;
  background:var(--olive); color:#F7F2E9; border:0; padding:11px 20px; border-radius:999px;
  transition:transform .2s var(--ease), background .2s;
}
.btn-book:hover{ transform:translateY(-1px); background:var(--olive-d); }
@media(max-width:860px){ .nav-links{ display:none; } }

/* =========================================================
   BUTTONS / PILLS
   ========================================================= */
.cta{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  padding:15px 28px; border-radius:999px; text-decoration:none; border:0;
  transition:transform .2s var(--ease), background .25s, color .25s;
}
.cta:hover{ transform:translateY(-2px); }
.cta-solid{ background:var(--olive); color:#F7F2E9; }
.cta-solid:hover{ background:var(--olive-d); }
.cta-ghost{ background:transparent; color:currentColor; border:1px solid currentColor; }
.cta-ghost:hover{ background:currentColor; }
.cta-ghost:hover span{ mix-blend-mode:difference; color:#000; }
.cta .arr{ font-family:var(--sans); font-size:15px; }

.tag-row{ display:flex; flex-wrap:wrap; gap:8px; }
.tag{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; padding:6px 13px; border-radius:999px; border:1px solid currentColor; opacity:.7; }

/* =========================================================
   LAYOUT HELPERS
   ========================================================= */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,5vw,80px); align-items:center; }
.split.img-left{ grid-template-columns:.95fr 1.05fr; }
.stack-s>*+*{ margin-top:14px; }
.stack-m>*+*{ margin-top:24px; }
.eyebrow-line{ display:flex; align-items:center; gap:14px; }
.eyebrow-line .num{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; opacity:.5; }

/* two-column lists */
.cols-2{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(26px,4vw,64px); }
.feature-list{ list-style:none; padding:0; margin:0; }
.feature-list li{ position:relative; padding:13px 0 13px 26px; border-top:1px solid currentColor; font-size:clamp(15px,1.5vw,17px); line-height:1.4; }
.feature-list li:first-child{ border-top:0; }
.feature-list li::before{ content:""; position:absolute; left:0; top:21px; width:9px; height:9px; border-radius:50%; background:currentColor; opacity:.55; }
.list-head{ font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; margin-bottom:6px; display:flex; align-items:baseline; gap:10px; }
.list-head .ic{ font-family:var(--display); font-style:italic; font-size:24px; letter-spacing:0; }

/* testimonials */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,30px); }
.quote{ background:rgba(255,255,255,.5); border:1px solid var(--hairline); border-radius:24px; padding:clamp(22px,2.6vw,34px); display:flex; flex-direction:column; gap:16px; }
.quote .q{ font-family:var(--display); font-size:clamp(17px,1.5vw,20px); line-height:1.45; font-weight:400; font-style:italic; }
.quote .who{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--terracotta); margin-top:auto; }
@media(max-width:820px){ .quotes{ grid-template-columns:1fr; } }

/* ===== TESTIMONIALS — photo strip + one rotating quote on the sun ===== */
.exp-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(14px,1.8vw,26px); align-items:start; max-width:1000px; margin:0 auto clamp(34px,5.5vh,62px); }
.exp-strip .frame{ aspect-ratio:3/4; box-shadow:0 22px 50px rgba(120,90,24,.22); }
.exp-strip .frame:nth-child(2){ margin-top:clamp(22px,3.6vh,40px); }
.exp-strip .frame:nth-child(4){ margin-top:clamp(22px,3.6vh,40px); }

.exp-quote{ position:relative; max-width:760px; margin:0 auto; text-align:center; }
.exp-quote .slide{ display:none; }
.exp-quote .slide.on{ display:block; animation:qfade .5s ease both; }
@keyframes qfade{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:none; } }
.exp-quote .q{ font-family:var(--display); font-style:italic; font-weight:400; font-size:clamp(19px,1.85vw,26px); line-height:1.5; color:var(--olive-d); margin:0; text-wrap:pretty; }
.exp-quote .q p{ margin:0 0 .7em; }
.exp-quote .q p:last-child{ margin-bottom:0; }
.exp-quote .cite{ margin-top:clamp(20px,2.8vh,30px); display:flex; flex-direction:column; gap:5px; font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; }
.exp-quote .cite .who{ color:var(--terracotta); font-weight:500; }
.exp-quote .cite .tag{ color:var(--olive); opacity:.62; }
.exp-nav{ display:flex; align-items:center; justify-content:center; gap:24px; margin-top:clamp(22px,3.2vh,34px); }
.exp-nav .arr{ width:46px; height:46px; border-radius:50%; border:1.4px solid rgba(60,74,46,.42); background:none; color:var(--olive-d); font-size:17px; line-height:1; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background .2s, color .2s, border-color .2s; }
.exp-nav .arr:hover{ background:var(--olive-d); color:var(--sun); border-color:var(--olive-d); }
.exp-dots{ display:flex; gap:10px; }
.exp-dots i{ width:7px; height:7px; border-radius:50%; background:rgba(60,74,46,.3); cursor:pointer; transition:transform .2s, background .2s; }
.exp-dots i.on{ background:var(--terracotta); transform:scale(1.3); }
@media(max-width:820px){
  .exp-strip{ grid-template-columns:repeat(2,1fr); max-width:440px; }
  .exp-strip .frame:nth-child(2),.exp-strip .frame:nth-child(4){ margin-top:0; }
}

/* ----- paired continuous-scroll room (testimonials → about) ----- */
.room.pair-scroll{ padding:0; }
.room.pair-scroll .pair-inner{ max-width:none; height:100%; max-height:100%; }
.pair-panel{ box-sizing:border-box; min-height:100%; display:flex; flex-direction:column; justify-content:safe center; padding:clamp(96px,12vh,140px) var(--pad) clamp(56px,8vh,90px); }
.pair-panel .panel-content{ width:100%; max-width:1240px; margin:0 auto; }
.panel-sun{ background:linear-gradient(160deg, #F4D873 0%, var(--sun) 55%, #E8B93C 100%); color:var(--on-sun); }
.panel-cream{ background:var(--cream); color:var(--on-cream); }
.panel-sun .eyebrow{ color:var(--olive); }
.panel-cream .eyebrow{ color:var(--terracotta); }
.pull-q .cite{ margin-top:12px; display:flex; align-items:baseline; gap:14px; flex-wrap:wrap; font-family:var(--mono); font-size:11px; letter-spacing:.13em; text-transform:uppercase; }
.pull-q .cite .who{ color:var(--terracotta); font-weight:500; white-space:nowrap; }
.pull-q .cite .tag{ border:0; padding:0; border-radius:0; background:none; color:rgba(60,74,46,.6); white-space:nowrap; }
@media(max-width:860px){
  .exp2{ grid-template-columns:1fr; gap:34px; }
  .exp2-feature{ max-width:380px; }
  .pull-q:nth-child(2),.pull-q:nth-child(3){ margin-left:0; }
}

/* stat / credential grid */
.creds{ display:grid; grid-template-columns:1fr 1fr; gap:0 clamp(30px,4vw,64px); }
.creds li{ list-style:none; padding:13px 0; border-top:1px solid rgba(231,238,240,.22); font-size:15px; line-height:1.4; display:flex; gap:12px; }
.creds li .k{ font-family:var(--mono); font-size:11px; opacity:.5; padding-top:3px; min-width:20px; }

/* process steps */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(14px,1.8vw,26px); }
.step{ border-radius:22px; padding:clamp(18px,2vw,26px); background:rgba(255,255,255,.42); border:1px solid var(--hairline); display:flex; flex-direction:column; gap:10px; min-height:0; }
.step .n{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; color:var(--terracotta); }
.step h4{ font-size:clamp(20px,2vw,26px); }
.step p{ font-size:14px; line-height:1.45; color:var(--ink-soft); margin:0; }
@media(max-width:820px){ .steps{ grid-template-columns:1fr 1fr; } }

/* session details — stacked spec list (label over value) */
.spec-list{ margin:0; display:grid; grid-template-columns:1fr 1fr; gap:0 clamp(20px,3vw,44px); border-top:1px solid currentColor; }
.spec-row{ display:flex; flex-direction:column; gap:5px; padding:16px 2px; border-bottom:1px solid currentColor; }
.spec-row dt{ font-family:var(--mono); font-size:11px; letter-spacing:.13em; text-transform:uppercase; opacity:.6; }
.spec-row dd{ margin:0; font-family:var(--display); font-size:clamp(20px,1.7vw,24px); line-height:1.1; }
.spec-row.full{ grid-column:1/-1; }

/* FAQ / AEO accordion */
.faq{ border-top:1px solid currentColor; }
.faq details{ border-bottom:1px solid currentColor; }
.faq summary{ list-style:none; cursor:pointer; padding:16px 0; display:flex; justify-content:space-between; align-items:center; gap:20px; font-family:var(--display); font-size:clamp(18px,1.9vw,23px); font-weight:400; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .pm{ font-family:var(--sans); font-weight:300; font-size:26px; line-height:1; transition:transform .3s; flex-shrink:0; }
.faq details[open] summary .pm{ transform:rotate(45deg); }
.faq .ans{ padding:0 0 18px; max-width:74ch; font-size:15.5px; line-height:1.6; color:var(--ink-soft); }
.bg-sea .faq .ans{ color:rgba(14,42,54,.78); }
.bg-olive .faq .ans{ color:rgba(238,240,230,.78); }

/* pricing */
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,1.6vw,22px); }
.price{ border:1px solid var(--hairline); border-radius:22px; padding:clamp(20px,2.2vw,30px); background:rgba(255,255,255,.5); display:flex; flex-direction:column; gap:8px; }
.price .nm{ font-family:var(--display); font-size:clamp(22px,2.2vw,28px); }
.price .amt{ font-family:var(--mono); font-size:13px; letter-spacing:.04em; color:var(--terracotta); }
.price .meta{ font-size:13.5px; color:var(--ink-soft); }
.pkg-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(16px,2vw,28px); }
.pkg{ border:1px solid var(--hairline); border-radius:24px; padding:clamp(22px,2.4vw,34px); background:rgba(255,255,255,.55); }
.pkg h4{ font-size:clamp(24px,2.4vw,32px); }
.pkg .amt{ font-family:var(--mono); font-size:13px; color:var(--terracotta); letter-spacing:.03em; margin-top:4px; }
.pkg p{ font-size:14.5px; line-height:1.5; color:var(--ink-soft); margin:14px 0 0; }
@media(max-width:820px){ .price-grid{ grid-template-columns:1fr; } .pkg-grid{ grid-template-columns:1fr; } }

/* =========================================================
   PROGRESS DOTS + ARROWS (outside scaled content)
   ========================================================= */
.dots{ position:fixed; right:clamp(14px,2vw,30px); top:50%; transform:translateY(-50%); z-index:35; display:flex; flex-direction:column; gap:11px; }
.dots button{ width:9px; height:9px; padding:0; border-radius:50%; border:1px solid currentColor; background:transparent; color:#fff; mix-blend-mode:difference; opacity:.5; transition:.25s; }
.dots button.on{ opacity:1; background:#fff; transform:scale(1.25); }
@media(max-width:860px){ .dots{ right:8px; gap:9px; } }

.scroll-hint{ position:fixed; left:50%; bottom:20px; transform:translateX(-50%); z-index:35; font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:#fff; mix-blend-mode:difference; opacity:.6; display:flex; flex-direction:column; align-items:center; gap:7px; pointer-events:none; transition:opacity .4s; }
.scroll-hint .ln{ width:1px; height:22px; background:currentColor; animation:hintpulse 1.8s var(--ease) infinite; transform-origin:top; }
@keyframes hintpulse{ 0%,100%{ transform:scaleY(.3); opacity:.3; } 50%{ transform:scaleY(1); opacity:1; } }
.scroll-hint.hide{ opacity:0; }
.scroll-hint{ display:none; }

/* =========================================================
   BOOKING MODAL
   ========================================================= */
.modal{ position:fixed; inset:0; z-index:80; display:none; align-items:center; justify-content:center; padding:20px; }
.modal.open{ display:flex; }
.modal-bg{ position:absolute; inset:0; background:rgba(14,42,54,.55); backdrop-filter:blur(6px); opacity:0; transition:opacity .3s; }
.modal.open .modal-bg{ opacity:1; }
.modal-card{
  position:relative; width:min(560px,100%); max-height:90vh; overflow-y:auto;
  background:var(--cream); border-radius:28px; padding:clamp(26px,4vw,44px);
  box-shadow:0 40px 90px rgba(0,0,0,.34);
  transform:translateY(20px) scale(.98); opacity:0; transition:transform .35s var(--ease), opacity .35s;
}
.modal.open .modal-card{ transform:none; opacity:1; }
.modal-card .x{ position:absolute; top:16px; right:16px; width:34px; height:34px; border-radius:50%; border:1px solid var(--hairline); background:transparent; color:var(--ink); font-size:18px; line-height:1; display:grid; place-items:center; }
.modal-card .x:hover{ background:var(--ink); color:var(--cream); }

/* "my story" text link with plus */
.story-link{ align-self:flex-start; display:inline-flex; align-items:center; gap:11px; background:none; border:0; padding:0; margin-top:6px; font-family:var(--mono); font-size:12px; letter-spacing:.15em; text-transform:uppercase; color:var(--terracotta); cursor:pointer; }
.story-link .pl{ display:inline-grid; place-items:center; width:26px; height:26px; border:1px solid currentColor; border-radius:50%; font-family:var(--sans); font-weight:300; font-size:17px; line-height:1; transition:background .2s, color .2s; }
.story-link:hover .pl{ background:var(--terracotta); color:var(--cream); }

/* bio modal — get to know me */
.bio-modal{ position:fixed; inset:0; z-index:82; display:none; align-items:center; justify-content:center; padding:20px; }
.bio-modal.open{ display:flex; }
.bio-bg{ position:absolute; inset:0; background:rgba(14,42,54,.55); backdrop-filter:blur(6px); opacity:0; transition:opacity .3s; }
.bio-modal.open .bio-bg{ opacity:1; }
.bio-card{ position:relative; width:min(680px,100%); max-height:88vh; overflow-y:auto; background:var(--cream); border-radius:28px; padding:clamp(30px,4vw,52px); box-shadow:0 40px 90px rgba(0,0,0,.34); transform:translateY(20px) scale(.98); opacity:0; transition:transform .38s var(--ease), opacity .35s; }
.bio-modal.open .bio-card{ transform:none; opacity:1; }
.bio-card .x{ position:absolute; top:16px; right:16px; width:36px; height:36px; border-radius:50%; border:1px solid var(--hairline); background:var(--cream); color:var(--ink); font-size:18px; line-height:1; display:grid; place-items:center; z-index:2; }
.bio-card .x:hover{ background:var(--ink); color:var(--cream); }
.bio-body p{ font-size:15.5px; line-height:1.6; color:var(--ink); margin:0 0 1em; max-width:60ch; }
.bio-body p:last-child{ margin-bottom:0; }
.bio-creds{ list-style:none; margin:0; padding:0; display:grid; gap:0; }
.bio-creds li{ font-size:14.5px; line-height:1.4; color:var(--ink); padding:11px 0 11px 26px; border-top:1px solid var(--hairline); position:relative; }
.bio-creds li:first-child{ border-top:0; }
.bio-creds li::before{ content:""; position:absolute; left:2px; top:18px; width:7px; height:7px; border-radius:50%; background:var(--terracotta); opacity:.7; }

/* terracotta solid variant of the bio modal */
.bio-card{ background:var(--terracotta); color:var(--on-terra); }
.bio-card .h-sub{ color:var(--on-terra); }
.bio-card .eyebrow{ color:rgba(251,238,231,.92) !important; }
.bio-card .bio-body p{ color:var(--on-terra); }
.bio-card .bio-creds li{ color:var(--on-terra); border-top-color:rgba(251,238,231,.26); }
.bio-card .bio-creds li::before{ background:var(--sun); opacity:.9; }
.bio-card .hairline{ opacity:.32; }
.bio-card .x{ background:transparent; color:var(--on-terra); border-color:rgba(251,238,231,.42); }
.bio-card .x:hover{ background:var(--on-terra); color:var(--terracotta); }
.form-row{ display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.form-row label{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); }
.form-row input,.form-row textarea,.form-row select{
  font-family:var(--sans); font-size:16px; color:var(--ink);
  background:#fff; border:1px solid var(--hairline); border-radius:12px; padding:12px 14px; width:100%;
}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{ outline:2px solid var(--olive); outline-offset:0; border-color:var(--olive); }
.seg{ display:flex; gap:8px; flex-wrap:wrap; }
.seg label{ flex:1; min-width:120px; text-transform:none; letter-spacing:0; font-family:var(--sans); font-size:15px; color:var(--ink); border:1px solid var(--hairline); border-radius:12px; padding:11px 14px; display:flex; align-items:center; gap:9px; cursor:pointer; }
.seg input{ width:auto; accent-color:var(--olive); }
.seg label:has(input:checked){ border-color:var(--olive); background:rgba(74,90,56,.08); }
.form-done{ text-align:center; padding:12px 0; display:none; }
.form-done.show{ display:block; }
.form-done .ico{ width:58px; height:58px; border-radius:50%; background:var(--olive); color:#fff; display:grid; place-items:center; margin:0 auto 18px; font-size:26px; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:760px){
  .split,.split.img-left{ grid-template-columns:1fr; gap:24px; }
  .cols-2{ grid-template-columns:1fr; gap:22px; }
  .creds{ grid-template-columns:1fr; }
  .room{ justify-content:flex-start; }
  .room-inner{ padding-block:6px; }
}
.hide-sm{ }
@media(max-width:760px){ .hide-sm{ display:none !important; } }

/* =========================================================
   EDITORIAL COMPOSITIONS  (layered window frames, scaffolding)
   ========================================================= */
:root{ --fig: clamp(340px, 60vh, 560px); }

.hairline{ height:1px; background:currentColor; opacity:.22; border:0; margin:0; width:100%; }
.cap-mono{ font-family:var(--mono); font-size:10.5px; letter-spacing:.15em; text-transform:uppercase; opacity:.6; }
.vlabel{ writing-mode:vertical-rl; text-orientation:mixed; font-family:var(--mono); font-size:11px; letter-spacing:.42em; text-transform:uppercase; opacity:.5; white-space:nowrap; }
.meta-line{ display:flex; gap:18px; flex-wrap:wrap; font-family:var(--mono); font-size:11px; letter-spacing:.13em; text-transform:uppercase; opacity:.6; }
.meta-line span{ display:inline-flex; align-items:center; gap:18px; }
.meta-line span::before{ content:""; width:4px; height:4px; border-radius:50%; background:currentColor; opacity:.7; }
.meta-line span:first-child::before{ display:none; }

/* shared float-frame helpers */
.frame{ position:relative; overflow:hidden; background:rgba(0,0,0,.06); box-shadow:0 24px 56px rgba(43,43,43,.20); }
.frame img,.frame video{ width:100%; height:100%; object-fit:cover; display:block; }
.frame.arch{ border-radius:999px 999px 30px 30px; }
.frame.oval{ border-radius:50%; }
.frame.soft{ border-radius:26px; }
.frame .ftag{ position:absolute; left:12px; bottom:12px; font-family:var(--mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase; color:#fff; background:rgba(43,43,43,.4); backdrop-filter:blur(4px); padding:5px 10px; border-radius:999px; }
.dot-accent{ position:absolute; border-radius:50%; background:var(--lemon); }

/* ---------- HERO ---------- */
.hero-ed{ display:grid; grid-template-columns:1.06fr .94fr; gap:clamp(26px,4vw,70px); align-items:center; }
.hero-copy{ display:flex; flex-direction:column; gap:clamp(16px,2vw,22px); }
.hero-plate{ position:relative; height:var(--fig); }
.hero-plate .plate-bg{ position:absolute; left:8%; top:0; width:74%; height:90%; background:var(--olive); border-radius:300px 300px 30px 30px; }
.hero-plate .portrait{ position:absolute; left:20%; top:8%; width:74%; height:92%; border-radius:300px 300px 30px 30px; }
.hero-plate .mini{ position:absolute; left:2%; bottom:6%; width:30%; aspect-ratio:1/1; z-index:3; }
.hero-plate .dot-accent{ width:clamp(40px,5vw,66px); height:clamp(40px,5vw,66px); top:2%; left:2%; z-index:2; }
.hero-plate .pcap{ position:absolute; right:0; top:42%; }

/* ---------- WHO I WORK WITH ---------- */
.work-grid{ display:grid; grid-template-columns:1.55fr .85fr; gap:clamp(30px,4.5vw,66px); align-items:center; }
.work-lists{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(22px,3vw,46px); }
.work-figs{ position:relative; height:var(--fig); }
.work-figs .tall{ position:absolute; left:0; top:2%; width:74%; height:84%; }
.work-figs .small{ position:absolute; right:0; bottom:0; width:56%; aspect-ratio:4/5; z-index:2; }
.work-figs .dot-accent{ width:clamp(34px,4vw,54px); height:clamp(34px,4vw,54px); right:8%; top:-2%; z-index:3; }

/* yellow left-third frame + mirrored two-column split */
.room-work .work-frame{ position:absolute; left:0; top:0; bottom:0; width:50%; background:var(--terracotta); z-index:0; }
.room-work .room-inner{ position:relative; z-index:1; }
/* left half sits over terracotta — light text */
.room-work .eyebrow{ color:var(--on-terra); opacity:.82; }
.room-work .eyebrow-line .num{ color:var(--on-terra); opacity:.5; }
.room-work .h-room{ color:var(--on-terra); max-width:13ch; }

.work-split{ display:grid; grid-template-columns:1fr 9px 1fr; align-items:start; }
.ws-col{ display:flex; flex-direction:column; }
.ws-label{ font-family:var(--mono); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); margin:0 0 6px; }
.ws-list{ list-style:none; margin:0; padding:0; }
.ws-list li{ display:flex; align-items:center; gap:18px; padding:15px 0; border-bottom:1px solid var(--hairline); cursor:pointer; font-family:var(--sans); font-weight:500; font-size:clamp(15px,1.2vw,17px); line-height:1.3; letter-spacing:.004em; transition:padding .25s var(--ease); }
.ws-plus{ font-family:var(--sans); font-weight:300; font-size:21px; line-height:1; color:var(--terracotta); opacity:.55; transition:opacity .2s, transform .25s; flex-shrink:0; }
.ws-list li:hover .ws-plus{ opacity:1; transform:rotate(90deg); }

/* individuals: text right-aligned, + on the far left */
.ws-individuals{ text-align:right; padding-right:clamp(20px,3vw,52px); }
.ws-individuals .ws-label{ text-align:right; color:rgba(251,238,231,.7); }
.ws-individuals li{ justify-content:space-between; color:var(--on-terra); border-bottom-color:rgba(251,238,231,.26); }
.ws-individuals li:hover{ padding-right:8px; }
.ws-individuals .ws-plus{ color:var(--on-terra); opacity:.6; }

/* couples: offset down, text left-aligned, + on the far right */
.ws-couples{ text-align:left; padding-left:clamp(20px,3vw,52px); padding-top:clamp(70px,12vh,150px); }
.ws-couples li{ justify-content:space-between; }
.ws-couples li:hover{ padding-left:8px; }
.ws-couples .ws-plus{ color:var(--sea-d); }

/* center divider with ruler ticks */
.ws-divider{ align-self:stretch; position:relative; }
.ws-divider::before{ content:""; position:absolute; left:50%; top:0; bottom:0; width:1px; transform:translateX(-50%); background:var(--hairline); }
.ws-divider::after{ content:""; position:absolute; left:0; right:0; top:0; bottom:0; background:repeating-linear-gradient(to bottom, var(--ink-soft) 0 1px, transparent 1px 26px); opacity:.45; }

@media(max-width:760px){
  /* Hide absolute frame — backgrounds handled directly below */
  .room-work .work-frame{ display:none; }
  .work-split{ grid-template-columns:1fr; gap:0; }
  .ws-divider{ display:none; }

  /* Whole room becomes terracotta (overrides .bg-linen) */
  .room.room-work{ background:var(--terracotta); color:var(--on-terra); }
  .room-work .eyebrow{ color:rgba(251,238,231,.7); }
  .room-work .num{ color:rgba(251,238,231,.5); }

  /* Individuals inherits terracotta from room */
  .ws-individuals{ text-align:left; padding-right:0; }
  .ws-individuals .ws-label{ text-align:left; }
  .ws-individuals li{ flex-direction:row-reverse; justify-content:flex-end; }

  /* Couples: linen panel bleeding edge-to-edge */
  .ws-couples{
    padding-left:0; padding-top:0;
    background:var(--linen); color:var(--on-cream);
    margin-left:calc(-1 * var(--pad));
    margin-right:calc(-1 * var(--pad));
    padding-left:var(--pad);
    padding-right:var(--pad);
    padding-top:clamp(24px,4vh,40px);
    padding-bottom:clamp(24px,4vh,40px);
  }
  .ws-couples .ws-label{ color:var(--ink-soft); }
  .ws-couples li{ color:var(--ink); border-bottom-color:var(--hairline); }
  .ws-couples .ws-plus{ color:var(--sea-d); }
}

/* ---------- ABOUT ---------- */
.about-ed{ display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(30px,4.5vw,72px); align-items:center; }
.about-gallery{ position:relative; height:var(--fig); }
.about-gallery .g-big{ position:absolute; left:3%; top:0; width:60%; height:90%; }
.about-gallery .g-oval{ position:absolute; right:2%; top:10%; width:46%; aspect-ratio:1/1; z-index:2; }
.about-gallery .g-mini{ position:absolute; right:14%; bottom:0; width:36%; aspect-ratio:5/4; z-index:3; }
.about-gallery .dot-accent{ width:clamp(34px,4vw,56px); height:clamp(34px,4vw,56px); left:0; bottom:14%; z-index:4; }
.about-copy{ display:flex; flex-direction:column; gap:clamp(14px,1.8vw,20px); }
.about-copy .story{ max-width:50ch; }

@media(max-width:860px){
  .hero-ed,.work-grid,.about-ed{ grid-template-columns:1fr; gap:26px; }
  .hero-plate,.work-figs,.about-gallery{ height:min(56vh,420px); order:-1; }
  .work-lists{ grid-template-columns:1fr 1fr; }
}
@media(max-width:560px){
  .work-lists{ grid-template-columns:1fr; gap:18px; }
  .meta-line{ gap:10px; }
}

/* =========================================================
   CINEMATIC PORTAL HERO  (monumental scale, atmospheric)
   ========================================================= */
.hero-cine{ min-height:clamp(460px, 94vh, 980px); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:clamp(12px,2vh,22px); position:relative; }

.portal-scene{ position:relative; display:flex; flex-direction:column; align-items:center; }
.hero-window-arch{ position:relative; height:clamp(440px,84vh,860px); width:auto; aspect-ratio:4/5; max-width:94%; border-radius:999px 999px 26px 26px; overflow:hidden; box-shadow:0 50px 110px rgba(14,42,54,.34); }
.hero-window-arch img{ width:100%; height:100%; object-fit:cover; object-position:center 26%; }
.hero-window-arch::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(14,42,54,0) 34%, rgba(14,42,54,.42) 60%, rgba(14,42,54,.8) 100%); }
.hw-overlay{ position:absolute; left:0; right:0; bottom:clamp(28px,5.5vh,66px); z-index:2; text-align:center; color:var(--linen); padding:0 22px; text-shadow:0 2px 26px rgba(14,42,54,.55); }
.hw-eyebrow{ font-family:var(--mono); font-size:clamp(11px,1.3vw,14px); letter-spacing:.5em; text-transform:uppercase; color:#f3d9b5; margin:0 0 14px; padding-left:.5em; }
.hw-name{ font-family:var(--display); font-weight:300; font-size:clamp(38px,5.4vw,82px); line-height:1; margin:0; letter-spacing:-.005em; white-space:nowrap; }
.hw-role{ font-family:var(--display); font-style:italic; font-weight:300; font-size:clamp(17px,2.2vw,28px); margin:12px 0 0; color:#f1e7da; }
@media(max-width:560px){ .hw-name{ white-space:normal; } }

.scroll-cue{ display:flex; flex-direction:column; align-items:center; gap:6px; font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; opacity:.55; margin-top:2px; }
.scroll-cue .ar{ font-size:14px; animation:cuebob 1.8s var(--ease) infinite; }
@keyframes cuebob{ 0%,100%{ transform:translateY(0); opacity:.5; } 50%{ transform:translateY(4px); opacity:1; } }

.hero-copy-stage{ min-height:clamp(360px,70vh,680px); display:flex; flex-direction:column; justify-content:center; align-items:center; text-align:center; padding-top:clamp(16px,3vh,40px); }
.hero-copy{ display:flex; flex-direction:column; align-items:center; gap:clamp(16px,2vw,22px); max-width:none; }
.hero-copy .h-hero{ max-width:16ch; }
.hero-copy .lede{ max-width:40ch; }
.hero-copy .hairline{ width:min(420px,80%); }

/* =========================================================
   SHAPED INFO POP-UPS  (clickable bullets)
   ========================================================= */
.feature-list li.expandable{ cursor:pointer; transition:padding-left .25s var(--ease); }
.feature-list li.expandable .li-txt{ transition:opacity .2s; }
.feature-list li.expandable::after{ content:"+"; position:absolute; right:2px; top:13px; font-family:var(--sans); font-weight:300; font-size:19px; line-height:1; opacity:.42; transition:opacity .2s, transform .25s; }
.feature-list li.expandable:hover{ padding-left:30px; }
.feature-list li.expandable:hover::after{ opacity:.9; transform:rotate(90deg); }
.feature-list li.expandable:hover::before{ opacity:1; }

.info-modal{ position:fixed; inset:0; z-index:85; display:none; align-items:center; justify-content:center; padding:24px; }
.info-modal.open{ display:flex; }
.info-bg{ position:absolute; inset:0; background:rgba(14,42,54,.5); backdrop-filter:blur(7px); opacity:0; transition:opacity .3s; }
.info-modal.open .info-bg{ opacity:1; }
.info-card{
  position:relative; width:min(540px,100%); background:var(--cream); color:var(--ink);
  padding:clamp(30px,4vw,52px); box-shadow:0 40px 100px rgba(0,0,0,.36);
  transform:scale(.92) translateY(16px); opacity:0;
  transition:transform .42s var(--ease-room), opacity .3s, border-radius .42s var(--ease-room);
  border-radius:28px;
}
.info-modal.open .info-card{ transform:none; opacity:1; }
/* shape signatures */
.info-card.shape-arch{ border-radius:160px 160px 28px 28px; padding-top:clamp(48px,6vw,76px); }
.info-card.shape-soft{ border-radius:30px; }
.info-card.shape-archL{ border-radius:160px 28px 28px 160px; }
.info-card.shape-archR{ border-radius:28px 160px 160px 28px; }
.info-card.shape-pill{ border-radius:60px; }
/* single rounded-square shape, colored by group */
.info-card.card-sq{ border-radius:28px; }
.info-card.card-ind{ background:var(--sun); color:var(--on-sun); }
.info-card.card-cpl{ background:var(--sea); color:var(--on-sea); }
.info-card.card-ind .kicker, .info-card.card-cpl .kicker{ color:inherit; opacity:.72; }
.info-card.card-ind h3, .info-card.card-cpl h3{ color:inherit; }
.info-card.card-ind .ibody, .info-card.card-cpl .ibody{ color:inherit; opacity:.82; }
.info-card.card-ind .inav, .info-card.card-cpl .inav{ border-top-color:rgba(0,0,0,.16); }
.info-card.card-ind .inav button, .info-card.card-cpl .inav button{ color:inherit; }
.info-card.card-ind .inav button:hover, .info-card.card-cpl .inav button:hover{ color:inherit; opacity:.6; }
.info-card.card-ind .ix, .info-card.card-cpl .ix{ border-color:rgba(0,0,0,.24); color:inherit; }
.info-card.card-ind .ix:hover{ background:var(--on-sun); color:var(--sun); }
.info-card.card-cpl .ix:hover{ background:var(--on-sea); color:var(--sea); }
.info-card .ix{ position:absolute; top:16px; right:18px; width:34px; height:34px; border-radius:50%; border:1px solid var(--hairline); background:transparent; color:var(--ink); font-size:18px; line-height:1; display:grid; place-items:center; }
.info-card .ix:hover{ background:var(--ink); color:var(--cream); }
.info-card .kicker{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--olive); display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.info-card .kicker .mk{ font-family:var(--display); font-style:italic; font-size:22px; letter-spacing:0; }
.info-card h3{ font-family:var(--display); font-weight:400; font-size:clamp(24px,2.6vw,34px); line-height:1.1; margin:0 0 14px; }
.info-card .ibody{ font-size:16px; line-height:1.6; color:var(--ink-soft); margin:0; }
.info-card .inav{ display:flex; justify-content:space-between; align-items:center; margin-top:24px; padding-top:16px; border-top:1px solid var(--hairline); }
.info-card .inav button{ background:none; border:0; font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink); opacity:.7; padding:6px 0; display:inline-flex; gap:8px; align-items:center; }
.info-card .inav button:hover{ opacity:1; color:var(--olive); }
.info-card .inav button:disabled{ opacity:.25; cursor:default; }
.info-card .icount{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; opacity:.5; }

/* =========================================================
   ADDITIONAL AREAS — circle-led cluster
   ========================================================= */
.areas-ed{ display:grid; grid-template-columns:1.02fr .98fr; gap:clamp(30px,4.5vw,72px); align-items:center; }
.areas-figs{ position:relative; height:var(--fig); }
.areas-figs .a-circle{ position:absolute; left:6%; top:4%; width:74%; aspect-ratio:1/1; }
.areas-figs .a-soft{ position:absolute; right:0; bottom:2%; width:48%; aspect-ratio:4/5; z-index:2; }
.areas-figs .a-ring{ position:absolute; left:0; top:0; width:74%; aspect-ratio:1/1; border-radius:50%; border:1px solid currentColor; opacity:.4; transform:translate(-5%,-6%); }
.areas-figs .dot-accent{ width:clamp(34px,4vw,56px); height:clamp(34px,4vw,56px); right:10%; top:0; z-index:3; }
@media(max-width:860px){
  .areas-ed{ grid-template-columns:1fr; gap:26px; }
  .areas-figs{ height:min(54vh,400px); order:-1; }
}
