:root{
  --bg:#FFFFFF; --surface:#EDEBD8; --surface-2:#F6F3E8;
  --ink:#1A1A2E; --ink-soft:#5A5A6B;
  --accent:#7D2A3A; --accent-2:#9C3A4C; --accent-on:#FFFFFF;
  --night:#160A10; --night-2:#241019;
  --line:rgba(26,26,46,.12);
  --radius:999px; --card-radius:18px; --maxw:1240px;
  --shadow:0 24px 60px rgba(26,26,46,.16);
  --ease:cubic-bezier(.22,.61,.27,1);
}
@font-face{font-family:'Playfair Display';font-weight:400;font-display:optional;src:url(/assets/fonts/playfair-400.woff2) format('woff2');}
@font-face{font-family:'Playfair Display';font-weight:600;font-display:optional;src:url(/assets/fonts/playfair-600.woff2) format('woff2');}
@font-face{font-family:'Playfair Display';font-weight:700;font-display:optional;src:url(/assets/fonts/playfair-700.woff2) format('woff2');}
@font-face{font-family:'Playfair Display';font-weight:800;font-display:optional;src:url(/assets/fonts/playfair-800.woff2) format('woff2');}
@font-face{font-family:'Poppins';font-weight:400;font-display:optional;src:url(/assets/fonts/poppins-400.woff2) format('woff2');}
@font-face{font-family:'Poppins';font-weight:500;font-display:optional;src:url(/assets/fonts/poppins-500.woff2) format('woff2');}
@font-face{font-family:'Poppins';font-weight:600;font-display:optional;src:url(/assets/fonts/poppins-600.woff2) format('woff2');}
@font-face{font-family:'Poppins';font-weight:700;font-display:optional;src:url(/assets/fonts/poppins-700.woff2) format('woff2');}
@font-face{font-family:'Birthstone';font-weight:400;font-display:swap;src:url(/assets/fonts/birthstone-400.woff2) format('woff2');}
@font-face{font-family:'Playfair Fallback';src:local('Times New Roman'),local('Georgia'),local('Times');ascent-override:96.54%;descent-override:26.21%;line-gap-override:0%;size-adjust:109.23%;}
@font-face{font-family:'Poppins Fallback';src:local('Arial'),local('Helvetica Neue'),local('Helvetica');ascent-override:92.06%;descent-override:30.69%;line-gap-override:8.77%;size-adjust:112.16%;}


*{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;}
body{font-family:'Poppins',system-ui,sans-serif;font-synthesis:none;color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
h1,h2,h3,h4{font-family:'Playfair Display','Playfair Fallback',Georgia,serif;font-weight:700;line-height:1.05;letter-spacing:-.018em;text-wrap:balance;}
.script{font-family:'Birthstone',cursive;font-weight:400;color:var(--accent);line-height:1;}
/* editorial italic accent word inside headlines (Playfair italic — not Birthstone) */
.hi{font-style:italic;font-weight:inherit;}
.hero h1 .hi,.page-hero h1 .hi{color:#F0B9C6;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
/* universal keyboard focus ring — accent outline + offset, replaces every bare outline.
   :focus-visible only, so mouse clicks stay clean while keyboard users get a clear ring.
   Light-on-dark surfaces (hero, footer, room panels, drawer, callbar) get a pink ring for contrast. */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px;}
a:focus-visible,.btn:focus-visible,summary:focus-visible{outline-offset:4px;}
.hero :focus-visible,.page-hero :focus-visible,.space :focus-visible,.sched :focus-visible,
.closer :focus-visible,.cta-band :focus-visible,.site-footer :focus-visible,.drawer :focus-visible,
.callbar :focus-visible,.callbar a:focus-visible{outline-color:#F0B9C6;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px);}
.eyebrow{font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.72rem;color:var(--accent);}
/* custom line-icon system (replaces emoji clip-art) — inherits currentColor of its circle */
.ico{width:1.45em;height:1.45em;display:block;}
.feat .ic .ico,.icard .ic .ico,.contact-info .ci .ic .ico{width:24px;height:24px;}
.grain::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:3;opacity:.5;mix-blend-mode:overlay;
  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='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");}

.btn{display:inline-flex;align-items:center;gap:.5em;font-family:'Poppins','Poppins Fallback',sans-serif;font-weight:600;font-size:1rem;padding:.95em 1.7em;border-radius:var(--radius);cursor:pointer;border:2px solid transparent;transition:transform .2s var(--ease),box-shadow .2s,background .2s,color .2s;line-height:1;white-space:nowrap;}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 12px 28px rgba(125,42,58,.32),inset 0 1px 0 rgba(255,255,255,.14);}
/* clean wine fill at rest by design; on hover a slight upward gradient sheen + deeper shadow, never a flat color swap */
@media (hover:hover){.btn-primary:hover{background:linear-gradient(160deg,var(--accent-2),var(--accent));transform:translateY(-2px);box-shadow:0 20px 44px rgba(125,42,58,.46),inset 0 1px 0 rgba(255,255,255,.2);}}
.btn-primary:active{transform:translateY(0);box-shadow:0 8px 20px rgba(125,42,58,.34);}
.btn-ghost{background:transparent;color:currentColor;border-color:currentColor;opacity:.92;}
.btn-ghost:hover{opacity:1;transform:translateY(-2px);}
.btn-light{background:#fff;color:var(--accent);}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow);}

/* header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:80;transition:background .35s,box-shadow .35s,backdrop-filter .35s;padding-top:env(safe-area-inset-top);}
.site-header .nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:78px;}
.site-header.solid{background:rgba(255,255,255,.95);backdrop-filter:saturate(140%) blur(10px);box-shadow:0 6px 24px rgba(26,26,46,.08);}
.brand{display:flex;align-items:center;gap:11px;}
.brand img{height:48px;width:auto;transition:opacity .3s;}
.brand .logo-dark{display:none;}
.solid .brand .logo-dark{display:block;}
.solid .brand .logo-white{display:none;}
.brand .bname{font-family:'Poppins','Poppins Fallback',sans-serif;font-weight:700;font-size:1.12rem;letter-spacing:.01em;color:#fff;text-shadow:0 1px 12px rgba(0,0,0,.5);transition:color .3s,text-shadow .3s;}
.solid .brand .bname{color:var(--ink);text-shadow:none;}
.brand .bname b{color:var(--accent-2);}
.solid .brand .bname b{color:var(--accent);}
.nav-links{display:flex;align-items:center;gap:26px;}
.nav-links a{font-weight:500;font-size:.95rem;color:rgba(255,255,255,.92);text-shadow:0 1px 10px rgba(0,0,0,.4);transition:color .3s,opacity .15s;}
.solid .nav-links a{color:var(--ink-soft);text-shadow:none;}
@media (hover:hover){.nav-links a:hover{color:#fff;}.solid .nav-links a:hover{color:var(--accent);}}
.nav-right{display:flex;align-items:center;gap:16px;}
.nav-phone{font-weight:600;font-size:.95rem;color:#fff;text-shadow:0 1px 10px rgba(0,0,0,.4);display:inline-flex;align-items:center;gap:7px;}
.solid .nav-phone{color:var(--ink);text-shadow:none;}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;color:#fff;}
.solid .nav-toggle{color:var(--ink);}
@media (max-width:1000px){.nav-links,.nav-phone{display:none;}.nav-toggle{display:block;}.nav-right .btn{display:none;}}

/* drawer */
.drawer{position:fixed;inset:0;z-index:90;background:var(--night);color:#fff;transform:translateX(100%);transition:transform .4s var(--ease);display:flex;flex-direction:column;padding:calc(env(safe-area-inset-top) + 22px) 28px 28px;visibility:hidden;}
.drawer.open{transform:translateX(0);visibility:visible;}
.drawer-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;}
.drawer a.dl{font-family:'Playfair Display','Playfair Fallback',serif;font-size:1.7rem;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.14);color:#fff;}
.drawer .btn{margin-top:26px;justify-content:center;}
.drawer-close{background:none;border:none;font-size:2rem;cursor:pointer;color:#fff;line-height:1;}

/* hero */
.hero{position:relative;height:100vh;height:100dvh;min-height:600px;overflow:hidden;display:flex;align-items:flex-end;color:#fff;}
.hero video,.hero .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.hero .scrim{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(22,10,16,.55) 0%,rgba(22,10,16,.15) 30%,rgba(22,10,16,.45) 65%,rgba(22,10,16,.92) 100%),
  linear-gradient(90deg,rgba(125,42,58,.35),transparent 60%);}
.hero .grain::before{z-index:2;}
.hero-inner{position:relative;z-index:4;padding-bottom:clamp(56px,9vh,120px);width:100%;}
/* subtle radial-gradient halo behind the hero headline — lifts the type off the video without a hard scrim box */
.hero-inner::before{content:"";position:absolute;z-index:-1;left:-6%;bottom:8%;width:min(72ch,86%);height:62%;pointer-events:none;
  background:radial-gradient(60% 70% at 22% 60%,rgba(125,42,58,.34) 0%,rgba(22,10,16,.22) 38%,transparent 72%);
  filter:blur(8px);}
.hero .script-tag{font-size:clamp(2.6rem,6vw,4rem);color:#F0B9C6;display:block;transform:rotate(-3deg);margin-bottom:-.05em;text-shadow:0 2px 20px rgba(0,0,0,.4);}
.hero h1{font-size:clamp(2.7rem,7vw,5.4rem);font-weight:800;max-width:16ch;text-shadow:0 1px 12px rgba(0,0,0,.55);}
.hero p.sub{margin-top:20px;font-size:clamp(1.05rem,1.6vw,1.3rem);max-width:46ch;color:rgba(255,255,255,.92);text-shadow:0 1px 16px rgba(0,0,0,.4);}
.hero-cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.hero-meta{margin-top:26px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-weight:500;font-size:.95rem;color:rgba(255,255,255,.9);text-shadow:0 1px 12px rgba(0,0,0,.5);}
.hero-meta .stars{color:#F0C24A;}
.scrollcue{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);z-index:4;color:rgba(255,255,255,.8);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:7px;}
.scrollcue .line{width:1px;height:34px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:cue 1.8s var(--ease) infinite;}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top;}40%{transform:scaleY(1);transform-origin:top;}60%{transform:scaleY(1);transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}

/* schedule anchor */
.sched{background:var(--night);color:#fff;position:relative;}
.sched .grain::before{opacity:.35;}
.sched-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,72px);padding:clamp(56px,8vw,104px) 0;align-items:start;}
@media (max-width:900px){.sched-grid{grid-template-columns:1fr;gap:34px;}}
.sched-aside{position:sticky;top:108px;}
@media (max-width:900px){.sched-aside{position:static;}}
.sched-aside .eyebrow{color:#F0B9C6;}
.sched-aside h2{color:#fff;font-size:clamp(2.1rem,4vw,3.2rem);margin:.3em 0 .5em;}
.sched-aside p{color:rgba(255,255,255,.75);margin-bottom:24px;max-width:38ch;}
.sched-note{font-size:.82rem;color:rgba(255,255,255,.5);margin-top:18px;max-width:36ch;}
.sched-list{display:flex;flex-direction:column;gap:12px;}
.sched-day{font-family:'Playfair Display','Playfair Fallback',serif;font-size:1.15rem;color:#F0B9C6;margin:14px 0 4px;}
.sched-day:first-child{margin-top:0;}
.srow{display:flex;align-items:center;gap:16px;padding:16px 18px;border:1px solid rgba(255,255,255,.13);border-radius:14px;background:rgba(255,255,255,.03);transition:border-color .2s,background .2s,transform .2s var(--ease);}
@media (hover:hover){.srow:hover{border-color:rgba(240,185,198,.5);background:rgba(255,255,255,.06);transform:translateX(4px);}}
.srow .time{font-weight:700;font-variant-numeric:tabular-nums;min-width:92px;color:#fff;}
.srow .cl{flex:1;}
.srow .cl b{display:block;font-weight:600;}
.srow .cl span{font-size:.85rem;color:rgba(255,255,255,.6);}
.srow .ask{flex:none;display:inline-flex;align-items:center;justify-content:center;min-height:44px;font-weight:600;font-size:.86rem;color:var(--night);background:#F0B9C6;border-radius:999px;padding:9px 18px;transition:transform .15s var(--ease),background .2s;white-space:nowrap;}
@media (hover:hover){.srow .ask:hover{background:#fff;transform:scale(1.04);}}

/* spaces journey */
.journey-intro{text-align:center;padding:clamp(64px,9vw,120px) 0 clamp(20px,3vw,40px);}
.journey-intro .eyebrow{color:var(--accent);}
.journey-intro h2{font-size:clamp(2.2rem,4.4vw,3.5rem);margin:.3em auto .4em;max-width:18ch;}
.journey-intro p{color:var(--ink-soft);font-size:1.12rem;max-width:46ch;margin:0 auto;}
.space{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;color:#fff;}
.space-bg{position:absolute;inset:-12% 0;z-index:0;background-size:cover;background-position:center;will-change:transform;transform:translateY(0) scale(1.12);}
.space-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(18,8,12,.9) 0%,rgba(18,8,12,.6) 42%,rgba(18,8,12,.2) 100%),linear-gradient(0deg,rgba(18,8,12,.7),transparent 55%);}
.space.right .space-scrim{background:linear-gradient(270deg,rgba(18,8,12,.9) 0%,rgba(18,8,12,.6) 42%,rgba(18,8,12,.2) 100%),linear-gradient(0deg,rgba(18,8,12,.7),transparent 55%);}
.space .grain::before{z-index:2;opacity:.3;}
.space-inner{position:relative;z-index:3;width:100%;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center;}
.space.right .space-inner{direction:rtl;}
.space.right .space-inner > *{direction:ltr;}
@media (max-width:880px){.space-inner{grid-template-columns:1fr;}.space-inner .space-photo{display:none;}}
.space-copy .eyebrow{color:#F0B9C6;opacity:1;text-shadow:0 2px 10px rgba(0,0,0,.5);}
.space-copy h3{font-size:clamp(2.3rem,5vw,4rem);font-weight:800;margin:.18em 0 .35em;text-shadow:0 2px 24px rgba(0,0,0,.4);}
.space-copy p{font-size:clamp(1.05rem,1.5vw,1.25rem);color:rgba(255,255,255,.9);max-width:40ch;margin-bottom:22px;}
.space-chips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:26px;}
.space-chips span{border:1px solid rgba(255,255,255,.4);border-radius:999px;padding:7px 15px;font-size:.85rem;font-weight:500;}
.space-photo{justify-self:center;}
.space-photo .pf{width:min(340px,80%);aspect-ratio:9/13;border-radius:16px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.5),inset 0 0 0 1px rgba(255,255,255,.55);border:5px solid rgba(255,255,255,.92);transform:rotate(2deg);}
.space.right .space-photo .pf{transform:rotate(-2deg);}
.space-photo .pf img{width:100%;height:100%;object-fit:cover;}

/* section base (light) */
section.block{padding:clamp(64px,9vw,120px) 0;}
.section-head{max-width:62ch;margin-bottom:clamp(34px,5vw,56px);}
.section-head.center{margin-inline:auto;text-align:center;}
.section-head h2{font-size:clamp(2rem,4vw,3.2rem);margin:.3em 0 .35em;}
.section-head p{color:var(--ink-soft);font-size:1.08rem;text-wrap:pretty;}
.alt{background:var(--surface);}

/* why */
.why-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(34px,5vw,64px);align-items:center;}
@media (max-width:900px){.why-grid{grid-template-columns:1fr;}}
.feat{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line);}
.feat:last-child{border-bottom:none;}
.feat .ic{flex:none;width:46px;height:46px;border-radius:13px;background:linear-gradient(150deg,var(--accent-2),var(--accent));color:#fff;display:grid;place-items:center;box-shadow:0 8px 20px rgba(125,42,58,.28),inset 0 1px 0 rgba(255,255,255,.18);}
.feat h3{font-family:'Poppins','Poppins Fallback',sans-serif;font-weight:700;font-size:1.1rem;margin-bottom:3px;letter-spacing:0;}
.feat p{color:var(--ink-soft);font-size:.98rem;}
.quote-card{background:#fff;border-radius:var(--card-radius);padding:36px 34px;box-shadow:var(--shadow);border:1px solid var(--line);}
.quote-card .qmark{font-family:'Playfair Display','Playfair Fallback',serif;font-size:3.6rem;color:var(--accent);line-height:.4;}
.quote-card blockquote{font-family:'Playfair Display','Playfair Fallback',serif;font-size:1.4rem;line-height:1.4;margin:16px 0 18px;}
.quote-card .by{font-weight:600;font-size:.95rem;}.quote-card .by span{color:var(--ink-soft);font-weight:400;}
.hl{position:relative;white-space:nowrap;}
@media (max-width:560px){.hl{white-space:normal;}}
.hl::after{content:"";position:absolute;left:-3px;right:-3px;bottom:.06em;height:.46em;background:rgba(125,42,58,.2);z-index:-1;border-radius:6px;transform:rotate(-1.2deg);}

/* reviews */
.rev-aggregate{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;margin-bottom:40px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:14px 28px;width:fit-content;margin-inline:auto;box-shadow:0 1px 2px rgba(26,26,46,.06);}
.rev-aggregate .big{font-family:'Playfair Display','Playfair Fallback',serif;font-size:2rem;color:var(--accent);}
.rev-aggregate .vsep{width:1px;height:32px;background:var(--line);}
.rev-grid{columns:2;column-gap:24px;}
@media (max-width:760px){.rev-grid{columns:1;}}
.rev{break-inside:avoid;background:#fff;border:1px solid var(--line);border-radius:var(--card-radius);padding:26px;margin-bottom:24px;transition:transform .2s var(--ease),box-shadow .2s,border-color .2s;}
@media (hover:hover){.rev:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--accent) 22%,var(--line));}}
.rev .rstars{color:#E0A92E;letter-spacing:1px;margin-bottom:12px;}
.rev p{font-size:1.04rem;line-height:1.55;margin-bottom:16px;}
.rev .who{display:flex;align-items:center;gap:11px;}
.rev .av{width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:600;font-family:'Playfair Display','Playfair Fallback',serif;}
.rev .who b{font-weight:600;font-size:.95rem;display:block;}.rev .who span{font-size:.8rem;color:var(--ink-soft);}

/* community */
.community-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,60px);align-items:center;}
@media (max-width:880px){.community-grid{grid-template-columns:1fr;}}
.community-media{position:relative;border-radius:var(--card-radius);overflow:hidden;box-shadow:var(--shadow),inset 0 0 0 1px rgba(255,255,255,.7);transition:transform .4s var(--ease),box-shadow .4s var(--ease);}
.community-media img{display:block;width:100%;height:auto;transition:transform .5s var(--ease);}
@media (hover:hover){.community-media:hover{transform:translateY(-6px);box-shadow:0 36px 80px rgba(26,26,46,.26),inset 0 0 0 1px rgba(255,255,255,.7);}.community-media:hover img{transform:scale(1.05);}}

/* area */
.area-list{display:flex;flex-wrap:wrap;gap:11px;margin-top:24px;}
.chip{background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 17px;font-weight:500;font-size:.92rem;}
.alt .chip{background:var(--bg);}

/* award band */
.award-band{background:radial-gradient(130% 150% at 50% 0%,var(--night-2),var(--night));color:#fff;}
.award-band .award-inner{display:flex;align-items:center;gap:clamp(26px,5vw,58px);max-width:940px;margin-inline:auto;}
.award-seal{width:clamp(118px,14vw,152px);height:auto;flex:none;filter:drop-shadow(0 18px 38px rgba(0,0,0,.5));}
.award-seal .s-goat{font-family:'Playfair Display','Playfair Fallback',serif;font-weight:800;font-size:23px;fill:#F4E1BC;letter-spacing:.03em;}
.award-seal .s-sub{font-family:'Poppins','Poppins Fallback',sans-serif;font-weight:600;font-size:7.4px;fill:#F4E1BC;letter-spacing:.24em;}
.award-seal .s-ban{font-family:'Poppins','Poppins Fallback',sans-serif;font-weight:700;font-size:7.2px;fill:#F8E9CC;letter-spacing:.05em;}
.award-band .eyebrow{color:#F0B9C6;}
.award-copy h2{font-size:clamp(1.75rem,3.4vw,2.55rem);line-height:1.12;margin:.25em 0 .45em;color:#fff;}
.award-copy p{color:rgba(255,255,255,.82);font-size:1.06rem;max-width:46ch;}
@media (max-width:720px){.award-band .award-inner{flex-direction:column;text-align:center;gap:26px;}.award-copy p{margin-inline:auto;}}

/* faq */
.faq-list{max-width:760px;margin-inline:auto;}
.faq{border-bottom:1px solid var(--line);}
.faq summary{list-style:none;cursor:pointer;padding:22px 4px;display:flex;justify-content:space-between;align-items:center;gap:18px;font-family:'Playfair Display','Playfair Fallback',serif;font-size:1.22rem;font-weight:600;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .pm{flex:none;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--accent);color:var(--accent);display:grid;place-items:center;font-size:1.1rem;transition:transform .25s;}
.faq[open] summary .pm{transform:rotate(45deg);}
.faq .ans{padding:0 4px 22px;color:var(--ink-soft);font-size:1.02rem;max-width:64ch;}

/* closer */
.closer{position:relative;color:#fff;text-align:center;overflow:hidden;padding:clamp(64px,10vw,140px) 0;}
.closer .space-bg{transform:scale(1.1);}
.closer .space-scrim{background:linear-gradient(0deg,rgba(18,8,12,.86),rgba(18,8,12,.7));}
.closer .inner{position:relative;z-index:3;}
.closer .script{color:#F0B9C6;font-size:clamp(3rem,6vw,4.4rem);display:block;margin-bottom:4px;transform:rotate(-2deg);text-shadow:0 2px 18px rgba(0,0,0,.45);}
.closer h2{color:#fff;font-size:clamp(2.2rem,4.6vw,3.6rem);margin-bottom:18px;}
.closer p{color:rgba(255,255,255,.85);max-width:48ch;margin:0 auto 30px;font-size:1.12rem;}
.closer .hero-cta{justify-content:center;}
.closer .meta{margin-top:26px;color:rgba(255,255,255,.7);font-size:.95rem;}

/* footer */
.site-footer{background:#100a13;color:rgba(255,255,255,.72);padding:64px 0 30px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1);}
@media (max-width:760px){.foot-grid{grid-template-columns:1fr;gap:30px;}}
.foot-brand img{height:66px;margin-bottom:16px;}
.foot-brand p{font-size:.95rem;max-width:32ch;}
.foot-col h3{font-family:'Poppins','Poppins Fallback',sans-serif;color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;}
.foot-col a,.foot-col p{display:block;color:rgba(255,255,255,.72);font-size:.96rem;margin-bottom:9px;}
@media (hover:hover){.foot-col a:hover{color:#fff;}}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding-top:24px;font-size:.85rem;color:rgba(255,255,255,.55);}
.foot-bottom a.lc{color:#F0B9C6;font-weight:600;}

/* mobile call bar */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:85;display:none;gap:10px;padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom));background:var(--accent);transform:translateY(calc(100% + env(safe-area-inset-bottom)));transition:transform .35s var(--ease);}
.callbar.show{transform:translateY(0);}
.callbar a{flex:1;display:inline-flex;align-items:center;justify-content:center;min-height:48px;text-align:center;font-weight:600;color:#fff;border:1.5px solid rgba(255,255,255,.5);border-radius:999px;padding:13px;font-size:.98rem;}
.callbar a.solid{background:#fff;color:var(--accent);border-color:#fff;}
@media (max-width:1000px){.callbar{display:flex;}}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}.reveal.d2{transition-delay:.16s;}.reveal.d3{transition-delay:.24s;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .space-bg{transform:scale(1.05)!important;}
  .scrollcue,.callbar{transition:none;}
}

/* ===================== interior page components ===================== */
.breadcrumb{padding:14px 0 0;font-size:.84rem;color:var(--ink-soft);}
.breadcrumb a{color:var(--accent);}
.breadcrumb span{opacity:.5;margin:0 6px;}
.page-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff;padding:120px 0 clamp(44px,7vh,80px);}
.page-hero .space-bg{position:absolute;inset:-10% 0;z-index:0;background-size:cover;background-position:center;transform:scale(1.08);}
.page-hero .space-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(22,10,16,.55),rgba(22,10,16,.3) 38%,rgba(22,10,16,.88));}
.page-hero .grain::before{z-index:2;opacity:.32;}
.page-hero .ph-inner{position:relative;z-index:3;width:100%;}
/* matching radial halo behind interior page-hero headlines */
.page-hero .ph-inner::before{content:"";position:absolute;z-index:-1;left:-5%;bottom:4%;width:min(64ch,84%);height:74%;pointer-events:none;
  background:radial-gradient(58% 68% at 20% 58%,rgba(125,42,58,.3) 0%,rgba(22,10,16,.18) 40%,transparent 72%);
  filter:blur(8px);}
.page-hero .eyebrow{color:#F0B9C6;opacity:1;text-shadow:0 2px 10px rgba(0,0,0,.45);}
.page-hero .script{font-family:'Birthstone',cursive;font-size:clamp(2rem,4vw,2.9rem);color:#F0B9C6;display:block;line-height:1;transform:rotate(-2deg);margin-bottom:2px;}
.page-hero h1{font-size:clamp(2.4rem,5.6vw,4.3rem);font-weight:800;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.45);max-width:18ch;margin:.12em 0 .32em;}
.page-hero p{font-size:clamp(1.05rem,1.5vw,1.22rem);color:rgba(255,255,255,.92);max-width:50ch;text-shadow:0 1px 14px rgba(0,0,0,.4);}
.page-hero .hero-cta{margin-top:28px;}
.lead{font-size:clamp(1.15rem,1.8vw,1.45rem);line-height:1.5;color:var(--ink);max-width:30ch;font-family:'Playfair Display','Playfair Fallback',serif;}
.prose p{color:var(--ink-soft);font-size:1.08rem;line-height:1.7;margin-bottom:18px;max-width:62ch;text-wrap:pretty;}
.cardgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(258px,1fr));gap:22px;}
.icard{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--card-radius);padding:28px;transition:transform .2s var(--ease),box-shadow .2s;}
.alt .icard{background:var(--bg);}
.icard:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.icard .ic{width:46px;height:46px;border-radius:12px;background:color-mix(in srgb,var(--accent) 12%,#fff);color:var(--accent);display:grid;place-items:center;margin-bottom:14px;box-shadow:0 6px 16px rgba(125,42,58,.14),inset 0 0 0 1px rgba(125,42,58,.16);}
.icard h3{font-size:1.35rem;margin-bottom:8px;}
.icard p{color:var(--ink-soft);font-size:.98rem;}
.icard .when{margin-top:12px;font-weight:600;color:var(--accent);font-size:.9rem;display:inline-block;}
.split2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center;}
@media(max-width:880px){.split2{grid-template-columns:1fr;}}
.split2.wide-text{grid-template-columns:1.1fr .9fr;}
.split2 .media{position:relative;border-radius:var(--card-radius);overflow:hidden;box-shadow:var(--shadow),inset 0 0 0 1px rgba(255,255,255,.7);transition:transform .4s var(--ease),box-shadow .4s var(--ease);}
.split2 .media::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(0deg,rgba(22,10,16,.34),transparent 46%);}
.split2 .media img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/5;transition:transform .5s var(--ease);}
@media (hover:hover){.split2 .media:hover{transform:translateY(-6px);box-shadow:0 36px 80px rgba(26,26,46,.26),inset 0 0 0 1px rgba(255,255,255,.7);}.split2 .media:hover img{transform:scale(1.05);}}
.process{display:grid;grid-template-columns:repeat(auto-fit,minmax(216px,1fr));gap:22px;counter-reset:p;}
.pstep{padding:26px;background:#fff;border:1px solid var(--line);border-radius:var(--card-radius);transition:transform .2s var(--ease),box-shadow .2s,border-color .2s;}
@media (hover:hover){.pstep:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--accent) 22%,var(--line));}}
.alt .pstep{background:var(--bg);}
.pstep .n{counter-increment:p;font-family:'Playfair Display','Playfair Fallback',serif;font-size:2rem;color:var(--accent);line-height:1;}
.pstep .n::before{content:"0" counter(p);}
.pstep h3{font-family:'Poppins','Poppins Fallback',sans-serif;font-weight:700;margin:8px 0 6px;letter-spacing:0;font-size:1.1rem;}
.pstep p{color:var(--ink-soft);font-size:.96rem;}
.form{display:flex;flex-direction:column;gap:15px;background:#fff;border:1px solid var(--line);border-radius:var(--card-radius);padding:clamp(24px,3vw,38px);box-shadow:var(--shadow);position:relative;}
.alt .form{background:var(--bg);}
.form--contact{overflow:hidden;}
.form--contact::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--accent),var(--accent-2));}
.form-expect{display:flex;flex-direction:column;gap:7px;margin:2px 0 4px;padding-left:16px;border-left:2px solid var(--accent);}
.form-expect span{font-weight:600;color:var(--ink);font-size:1rem;line-height:1.3;}
.form-expect span:nth-child(2){color:var(--accent);}
.form-expect span:last-child{font-weight:500;color:var(--ink-soft);}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:15px;}
@media(max-width:600px){.form .row2{grid-template-columns:1fr;}}
.form label{font-weight:600;font-size:.88rem;margin-bottom:6px;display:block;}
.form input,.form textarea,.form select{width:100%;font-family:inherit;font-size:16px;padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);}
/* field focus: suppress the native outline but ALWAYS replace it — accent border + soft halo ring.
   Keyboard users additionally get the universal :focus-visible accent outline (offset 3px) from above. */
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(125,42,58,.14);}
.form input:focus-visible,.form textarea:focus-visible,.form select:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}
.form textarea{min-height:120px;resize:vertical;}
.form .hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden;}
.form .btn{justify-content:center;margin-top:4px;}
.form .formnote{font-size:.875rem;color:var(--ink-soft);text-align:center;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,52px);align-items:start;}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr;}.contact-grid .form-col{order:-1;}}
.contact-info .ci{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--line);align-items:flex-start;}
.contact-info .ci:last-child{border-bottom:none;}
.contact-info .ci .ic{flex:none;width:42px;height:42px;border-radius:11px;background:var(--accent);color:#fff;display:grid;place-items:center;}
.contact-info .ci b{display:block;font-size:1.02rem;}
.contact-info .ci a,.contact-info .ci span{color:var(--ink-soft);}
.contact-info .ci a{color:var(--accent);font-weight:600;}
.mapwrap{border-radius:var(--card-radius);overflow:hidden;border:1px solid var(--line);margin-top:20px;}
.mapwrap iframe{width:100%;height:300px;border:0;display:block;filter:grayscale(.2) contrast(1.02);}
.cta-band{position:relative;overflow:hidden;color:#fff;text-align:center;padding:clamp(56px,8vw,118px) 0;}
.cta-band .space-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;transform:scale(1.06);}
.cta-band .space-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(18,8,12,.88),rgba(18,8,12,.72));}
.cta-band .grain::before{z-index:2;opacity:.3;}
.cta-band .inner{position:relative;z-index:3;}
.cta-band .script{color:#F0B9C6;font-size:clamp(2.4rem,5vw,3.4rem);display:block;transform:rotate(-2deg);margin-bottom:4px;text-shadow:0 2px 18px rgba(0,0,0,.45);}
.cta-band h2{color:#fff;font-size:clamp(2rem,4vw,3rem);margin-bottom:16px;}
.cta-band p{color:rgba(255,255,255,.84);max-width:48ch;margin:0 auto 28px;font-size:1.08rem;}
.cta-band .hero-cta{justify-content:center;}
.statband{display:flex;flex-wrap:wrap;gap:14px 36px;justify-content:center;padding:22px 0;}
.statband .s b{font-family:'Playfair Display','Playfair Fallback',serif;font-size:1.6rem;color:var(--accent);}
/* premium editorial stat row — display-face numerals, accent bar above each, small uppercase label */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,4vw,52px);max-width:880px;margin:0 auto;text-align:center;}
.stat-row .stat{display:flex;flex-direction:column;align-items:center;}
.stat-row .stat .bar{width:34px;height:3px;border-radius:2px;background:var(--accent);margin-bottom:16px;}
.stat-row .stat .num{font-family:'Playfair Display','Playfair Fallback',serif;font-weight:800;font-size:clamp(2.6rem,5vw,3.8rem);line-height:1;color:var(--ink);letter-spacing:-.02em;}
.stat-row .stat .num .u{color:var(--accent);}
.stat-row .stat .lbl{margin-top:10px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;font-size:.7rem;color:var(--ink-soft);max-width:16ch;}
@media (max-width:680px){.stat-row{grid-template-columns:1fr 1fr;gap:34px 20px;}}
.statband .s span{color:var(--ink-soft);font-size:.92rem;margin-left:6px;}

/* Performance: above-the-fold content paints on first load, never gated behind the JS reveal (fixes mobile LCP). Below-fold reveals still animate. */
.hero .reveal,.page-hero .reveal,.hero .script,.hero h1,.hero .sub,.hero-cta,.hero-meta{opacity:1;transform:none;}

/* Hero montage autoplays on all sizes (mobile gets a 9:16 encode via JS), then holds its frozen final frame. Reduced-motion shows the static final frame (the .poster img) instead. */
@media (prefers-reduced-motion: reduce){ .hero video{display:none;} }

/* ===== Launch-audit: a11y skip link, touch, overscroll, print (Step 4) ===== */
.skip{position:absolute;left:10px;top:-56px;z-index:300;background:var(--accent,#7D2A3A);color:#fff;padding:11px 18px;border-radius:0 0 12px 12px;font:600 .95rem/1 'Poppins','Poppins Fallback',system-ui,sans-serif;text-decoration:none;transition:top .18s ease;}
.skip:focus{top:0;outline:3px solid #F0B9C6;outline-offset:2px;}
a,button,summary,[role="button"],.btn{touch-action:manipulation;}
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:3px solid #F0B9C6;outline-offset:2px;border-radius:4px;}
html{overscroll-behavior-y:none;}
.drawer{overscroll-behavior:contain;}
@media print{
  #header,.callbar,#callbar,.drawer,#navToggle,.hero video,.space-bg,.skip,.hero-cta,.cta-band{display:none!important;}
  *{background:#fff!important;color:#111!important;box-shadow:none!important;text-shadow:none!important;}
  a{text-decoration:underline;color:#111!important;}
  .hero,.page-hero{min-height:0!important;height:auto!important;padding:20px 0!important;}
  .space-scrim{display:none!important;}
}
/* footer-bottom: ≥24px tap targets (Privacy + attribution) */
.foot-bottom a{display:inline-block;padding:8px 3px;line-height:1.2;}
.foot-bottom{row-gap:6px;}

/* Hero emotional line (under the keyword H1) */
.hero-feel{font-family:'Playfair Display','Playfair Fallback',Georgia,serif;font-weight:700;font-size:clamp(1.5rem,3.6vw,2.3rem);line-height:1.12;color:#fff;max-width:20ch;margin:.06em 0 .5em;text-shadow:0 1px 10px rgba(0,0,0,.5);}

/* Nav "Lessons" dropdown (desktop); mobile uses the flat drawer */
.nav-dd{position:relative;display:inline-flex;}
.nav-dd-trigger{font-family:inherit;font-weight:500;font-size:.95rem;color:rgba(255,255,255,.92);text-shadow:0 1px 10px rgba(0,0,0,.4);background:none;border:0;padding:0;margin:0;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:color .3s;}
.solid .nav-dd-trigger{color:var(--ink-soft);text-shadow:none;}
@media (hover:hover){.nav-dd-trigger:hover{color:#fff;}.solid .nav-dd-trigger:hover{color:var(--accent);}}
.nav-dd-trigger svg{transition:transform .2s var(--ease,ease);}
.nav-dd:hover .nav-dd-trigger svg,.nav-dd:focus-within .nav-dd-trigger svg{transform:rotate(180deg);}
.nav-dd-menu{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);display:flex;flex-direction:column;gap:2px;min-width:190px;padding:8px;background:var(--cream,#EDEBD8);border-radius:14px;box-shadow:0 24px 60px rgba(26,26,46,.28),inset 0 0 0 1px rgba(0,0,0,.05);opacity:0;visibility:hidden;transition:opacity .18s,transform .18s;z-index:60;}
.nav-dd:hover .nav-dd-menu,.nav-dd:focus-within .nav-dd-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.nav-dd-menu a{color:var(--ink,#1A1A2E)!important;padding:10px 14px;border-radius:9px;white-space:nowrap;font-weight:600;}
.nav-dd-menu a:hover{background:rgba(125,42,58,.1);color:var(--accent,#7D2A3A)!important;}
.nav-dd-menu::before{content:"";position:absolute;bottom:100%;left:0;right:0;height:14px;}

/* "See all reviews" link in the hero meta */
.rev-link{color:#F0B9C6;font-weight:600;text-decoration:underline;text-underline-offset:2px;}
.rev-link:hover{color:#fff;}

/* ===== Hero ghost logo: fades in on the black open, then dissolves to nothing ===== */
.hero .hero-inner{position:relative;z-index:5;}
.hero .ghost-logo{position:absolute;top:46%;left:50%;width:min(360px,42vw);z-index:2;pointer-events:none;opacity:0;
  transform:translate(-50%,-50%) scale(.98);animation:ghostDissolve 1.4s var(--ease) forwards;animation-play-state:paused;filter:drop-shadow(0 0 40px rgba(0,0,0,.45));}
@keyframes ghostDissolve{0%{opacity:0;transform:translate(-50%,-50%) scale(.98);}26%{opacity:.15;}55%{opacity:.12;}100%{opacity:0;transform:translate(-50%,-50%) scale(1.04);}}

/* ===== Cinematic hero intro (JS-driven, synced to the montage) ===== */
.hero-intro{position:absolute;inset:0;z-index:6;display:flex;align-items:center;justify-content:center;pointer-events:none;padding:0 24px;}
/* trailer phrases on the black cards: same Birthstone script as the tagline, handwrite in then dissolve */
.hero-intro-phrase{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);max-width:92vw;text-align:center;font-family:'Birthstone',cursive;color:var(--pink,#F0B9C6);font-size:clamp(2.4rem,6.6vw,5.8rem);line-height:1.22;padding:.08em .06em .24em;text-shadow:0 2px 30px rgba(0,0,0,.55);opacity:0;}
.hero-intro-phrase .phr-line{display:block;clip-path:inset(0 100% 0 0);will-change:clip-path;}
.hero-intro-phrase.writing{opacity:1;}
.hero-intro-phrase.writing .phr-line{animation:handwrite .8s cubic-bezier(.5,.05,.5,.95) forwards;}
.hero-intro-phrase.writing .phr-line:nth-child(2){animation-delay:.78s;}   /* line 2 starts only after line 1 finishes */
.hero-intro-phrase.written{opacity:1;transition:opacity .7s ease;}
.hero-intro-phrase.written .phr-line{clip-path:inset(0 0% 0 0);}
.hero-intro-phrase.bye{opacity:0;}
.hero-intro-script{font-family:'Birthstone',cursive;color:var(--pink,#F0B9C6);font-size:clamp(2rem,6.4vw,5.6rem);line-height:1.62;padding:.12em .06em .3em;white-space:nowrap;text-shadow:0 2px 30px rgba(0,0,0,.55);clip-path:inset(0 100% 0 0);opacity:0;will-change:clip-path,transform;}
.hero-intro-script.writing{opacity:1;animation:handwrite 2.6s cubic-bezier(.5,.05,.5,.95) forwards;}
@keyframes handwrite{from{clip-path:inset(0 100% 0 0);}to{clip-path:inset(0 0% 0 0);}}
.hero-intro-script.flying{transition:transform 1s var(--ease);}  /* flies up and STAYS as the eyebrow (no fade) */

/* html.cine (set by an inline head script BEFORE first paint) hides the hero content so it never flashes; revealed only when the trailer resolves */
.cine .hero .script-tag{opacity:0;}                                     /* eyebrow stays hidden; the flown script becomes the eyebrow */
.cine .hero h1,.cine .hero .sub,.cine .hero .hero-cta,.cine .hero .hero-meta{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease),transform 1s var(--ease);}
.cine .hero.revealed h1{opacity:1;transform:none;transition-delay:.05s;}
.cine .hero.revealed .sub{opacity:1;transform:none;transition-delay:.2s;}
.cine .hero.revealed .hero-cta{opacity:1;transform:none;transition-delay:.35s;}
.cine .hero.revealed .hero-meta{opacity:1;transform:none;transition-delay:.5s;}

/* non-cinematic (reduced-motion / no-JS / capture): no intro, no ghost, content stays visible */
html:not(.cine) .hero-intro{display:none;}
@media (prefers-reduced-motion:reduce){.hero .ghost-logo{display:none;}.hero-intro{display:none;}}
