/* NOIR V5 — multipage layer
   Page-specific composition lives here; V4 remains the component foundation. */

:root{
  --v5-fast:180ms;
  --v5-ui:320ms;
  --v5-reveal:760ms;
  --v5-scene:980ms;
  --v5-ease:cubic-bezier(.22,1,.36,1);
}

body{overflow-x:clip}
button{font:inherit;color:inherit}
.text-button{border:0;border-bottom:1px solid rgba(226,201,140,.35);padding:7px 0;background:none;color:var(--paper);font-size:9px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;cursor:pointer}
.section-action{display:flex;justify-content:flex-end;margin-top:26px}

/* Multipage navigation */
.desktop-nav{gap:clamp(10px,1.25vw,24px)}
.desktop-nav a{position:relative;font-size:8px;white-space:nowrap}
.desktop-nav a::after{content:"";position:absolute;left:0;right:0;bottom:-9px;height:1px;background:var(--metal);transform:scaleX(0);transform-origin:left;transition:transform var(--v5-ui) var(--v5-ease)}
.desktop-nav a:hover::after,.desktop-nav a.is-active::after,.desktop-nav a[aria-current="page"]::after{transform:scaleX(1)}
.desktop-nav a.is-active,.desktop-nav a[aria-current="page"]{color:var(--paper)}
.menu-panel nav a.is-active,.menu-panel nav a[aria-current="page"]{color:var(--gold-hi);padding-left:13px}

/* MPA transition. Content stays usable without JS. */
.page-veil{position:fixed;z-index:1490;inset:0;pointer-events:none;background:#050606;opacity:0;transform:translateY(100%);transition:opacity 200ms ease,transform 200ms var(--v5-ease)}
.is-page-leaving .page-veil{opacity:1;transform:none}
.is-page-leaving{cursor:progress}
.is-page-leaving body{pointer-events:none}

/* Interior page hero */
.page-hero{position:relative;min-height:max(690px,88svh);display:grid;align-items:center;overflow:hidden;background:#050606}
.page-hero::before,.page-hero::after{content:"";position:absolute;z-index:2;inset:0;pointer-events:none}
.page-hero::before{background:linear-gradient(90deg,rgba(3,4,4,.99) 0%,rgba(3,4,4,.9) 37%,rgba(3,4,4,.35) 66%,rgba(3,4,4,.62)),linear-gradient(0deg,rgba(4,5,5,.97),transparent 43%,rgba(4,5,5,.25))}
.page-hero::after{box-shadow:inset 0 0 210px rgba(0,0,0,.65);background:linear-gradient(115deg,transparent 56%,rgba(226,201,140,.045) 56.15%,transparent 56.4%)}
.page-hero__media{position:absolute;inset:0;overflow:hidden}
.page-hero__media img{position:absolute;inset:-32px 0 auto;width:100%;height:calc(100% + 64px);object-fit:cover;object-position:center;filter:saturate(.66) contrast(1.08) brightness(.78);transform:translate3d(0,var(--hero-y,0px),0) scale(1.045);transition:transform 1.5s var(--v5-ease);will-change:transform}
.is-ready .page-hero__media img{transform:translate3d(0,var(--hero-y,0px),0) scale(1)}
.page-hero__content{position:relative;z-index:4;padding-top:calc(var(--header) + 9vh);padding-bottom:145px}
.page-hero__content h1{max-width:1050px;margin:0 0 34px;font-size:clamp(74px,9vw,148px);line-height:.77;letter-spacing:-.055em;text-wrap:balance;text-shadow:0 18px 65px rgba(0,0,0,.35)}
.page-hero__content h1 span{display:block}
.page-hero__content h1 em{color:transparent;background:linear-gradient(108deg,#efe5d2 8%,#b68b48 55%,#ead8b8);background-clip:text;-webkit-background-clip:text}
.page-hero__lead{max-width:650px;margin:0 0 28px;color:#c2bcb2;font-size:16px;line-height:1.65}
.page-hero__actions{display:flex;gap:10px;flex-wrap:wrap}
.page-hero__meta{position:absolute;z-index:5;right:0;bottom:0;width:min(650px,54%);display:grid;grid-template-columns:repeat(3,1fr);border:1px solid rgba(226,201,140,.16);border-right:0;background:rgba(8,10,9,.78);backdrop-filter:blur(16px)}
.page-hero__meta span{padding:23px 24px;border-right:1px solid rgba(255,255,255,.07);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:#b9b1a4}
.page-hero__ornament{position:absolute;z-index:4;right:5%;top:19%;width:120px;aspect-ratio:1;border:1px solid rgba(226,201,140,.22);border-radius:50%;display:grid;place-items:center;color:var(--gold-hi)}
.page-hero__ornament::before,.page-hero__ornament::after{content:"";position:absolute;background:rgba(226,201,140,.15)}
.page-hero__ornament::before{width:140%;height:1px}.page-hero__ornament::after{width:1px;height:140%}
.page-hero__ornament span{font:500 38px/1 "Cormorant Garamond"}.page-hero__ornament i{position:absolute;inset:18px;border:1px solid rgba(255,255,255,.08);border-radius:50%}
.page-hero--services .page-hero__media img{object-position:68% center}
.page-hero--catalog::before{background:linear-gradient(90deg,rgba(3,4,4,.99),rgba(3,4,4,.83) 43%,rgba(3,4,4,.24) 75%),linear-gradient(0deg,rgba(4,5,5,.98),transparent 45%)}
.page-hero--catalog .page-hero__media img{object-position:63% center;filter:saturate(.72) contrast(1.08) brightness(.74)}
.page-hero--experience .page-hero__media img,.page-hero--contact .page-hero__media img{object-position:72% 48%}
.page-hero--experience::before{background:linear-gradient(90deg,rgba(3,4,4,.98),rgba(3,4,4,.83) 48%,rgba(3,4,4,.18)),linear-gradient(0deg,rgba(4,5,5,.96),transparent 50%)}
.page-hero--contact{min-height:max(650px,82svh)}

/* Work hero collage */
.work-hero-collage{position:absolute;inset:0;display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:5px;opacity:.66;transform:translateX(35%)}
.work-hero-collage figure{margin:0;overflow:hidden;min-width:0}
.work-hero-collage img{width:100%;height:100%;object-fit:cover;object-position:center;filter:saturate(.55) contrast(1.06) brightness(.68);transform:scale(1.035);transition:transform 1.4s var(--v5-ease)}
.work-hero-collage figure:nth-child(2){transform:translateY(7%)}
.work-hero-collage figure:nth-child(3){transform:translateY(-6%)}
.is-ready .work-hero-collage img{transform:scale(1)}
.page-hero--work::before{background:linear-gradient(90deg,#030404 0%,rgba(3,4,4,.96) 33%,rgba(3,4,4,.67) 55%,rgba(3,4,4,.38)),linear-gradient(0deg,rgba(4,5,5,.98),transparent 45%)}

/* Home summaries */
.home-services{background:radial-gradient(circle at 82% 20%,rgba(197,164,100,.08),transparent 28rem),#090b0a}
.editorial-links{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.editorial-card{position:relative;min-height:480px;padding:30px;display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(255,255,255,.075);background:linear-gradient(150deg,#151817,#0c0e0d);transition:transform .55s var(--v5-ease),border-color .35s}
.editorial-card::before{content:"";position:absolute;right:-55px;top:58px;width:200px;aspect-ratio:1;border:1px solid rgba(226,201,140,.12);border-radius:50%;background:repeating-radial-gradient(circle,transparent 0 18px,rgba(226,201,140,.06) 19px 20px)}
.editorial-card:hover{transform:translateY(-6px);border-color:rgba(226,201,140,.34)}
.editorial-card>span{font-size:8px;letter-spacing:.15em;color:var(--gold);text-transform:uppercase}.editorial-card h3{max-width:80%;margin:125px 0 18px;font-size:clamp(42px,4vw,65px);line-height:.86}.editorial-card p{max-width:340px;color:var(--muted)}.editorial-card strong{margin-top:auto;padding-top:25px;border-top:1px solid rgba(255,255,255,.07);font:500 26px "Cormorant Garamond"}.editorial-card i{margin-top:13px;color:var(--gold-hi);font:600 8px Manrope;letter-spacing:.1em;text-transform:uppercase}.editorial-card--featured{border-color:rgba(226,201,140,.34);background:radial-gradient(circle at 82% 16%,rgba(226,201,140,.14),transparent 22rem),linear-gradient(150deg,#1a1915,#0c0e0d)}
.home-work{background:#050606}.result-teasers{display:grid;grid-template-columns:1.35fr .65fr;gap:14px;min-height:740px}.result-teaser{position:relative;display:block;overflow:hidden;border:1px solid rgba(255,255,255,.075)}.result-teaser img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--v5-ease);filter:saturate(.72) contrast(1.04)}.result-teaser:hover img{transform:scale(1.035)}.result-teaser::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(4,5,5,.92),transparent 55%)}.result-teaser span{position:absolute;z-index:2;left:28px;right:28px;bottom:25px;display:flex;justify-content:space-between;gap:20px;align-items:end}.result-teaser small{color:var(--gold-hi);font-size:9px;letter-spacing:.11em}.result-teaser strong{font-size:10px;text-transform:uppercase;letter-spacing:.08em}.result-teaser--large img{object-position:50% center}
.home-method{background:linear-gradient(120deg,#111310,#070808 65%)}.method-preview{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(45px,8vw,120px);align-items:center}.method-preview__visual{position:relative;min-height:690px;overflow:hidden;border:1px solid rgba(226,201,140,.16)}.method-preview__visual::after{content:"";position:absolute;inset:9px;border:1px solid rgba(255,255,255,.07)}.method-preview__visual img{width:100%;height:100%;object-fit:cover;filter:saturate(.65)}.method-preview__copy h2{font-size:clamp(60px,6vw,105px);line-height:.8}.method-preview__copy ol{list-style:none;padding:0;margin:42px 0}.method-preview__copy li{display:grid;grid-template-columns:60px 1fr;gap:20px;padding:20px 0;border-top:1px solid rgba(255,255,255,.08)}.method-preview__copy li>span{font:500 30px "Cormorant Garamond";color:var(--gold-hi)}.method-preview__copy strong{font:500 28px "Cormorant Garamond"}.method-preview__copy p{margin:3px 0 0;color:var(--muted);font-size:11px}
.home-catalog{background:#0b0d0c}.catalog-preview{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(50px,8vw,120px);align-items:center}.catalog-preview>div:first-child>p:not(.section-index){max-width:500px;color:var(--muted);font-size:15px}.catalog-preview h2{font-size:clamp(60px,6vw,104px);line-height:.8}.catalog-points{display:flex;gap:7px;flex-wrap:wrap;margin:28px 0}.catalog-points span{padding:8px 11px;border:1px solid rgba(226,201,140,.16);font-size:8px;letter-spacing:.1em;text-transform:uppercase}.catalog-preview__image{position:relative;min-height:590px;overflow:hidden;border:1px solid rgba(226,201,140,.16)}.catalog-preview__image img{width:100%;height:100%;object-fit:cover;filter:saturate(.72);transition:transform .9s var(--v5-ease)}.catalog-preview__image:hover img{transform:scale(1.035)}.catalog-preview__image span{position:absolute;left:20px;bottom:20px;padding:9px 11px;background:rgba(5,6,6,.75);border:1px solid rgba(255,255,255,.1);font-size:8px;letter-spacing:.1em;text-transform:uppercase}

/* Shared final CTA */
.site-cta{background:#050606}.site-cta__panel{position:relative;min-height:540px;padding:clamp(45px,7vw,100px);display:grid;grid-template-columns:1.3fr .7fr;gap:50px;align-items:end;overflow:hidden;border:1px solid rgba(226,201,140,.26);background:radial-gradient(circle at 85% 20%,rgba(226,201,140,.13),transparent 24rem),linear-gradient(140deg,#181a17,#090b0a)}
.site-cta__panel::before{content:"N";position:absolute;right:-1vw;bottom:-10vw;color:rgba(255,255,255,.025);font:500 34vw/.7 "Cormorant Garamond"}.site-cta__panel>*{position:relative;z-index:1}.site-cta__panel h2{max-width:900px;margin-bottom:24px;font-size:clamp(60px,7.5vw,120px);line-height:.78}.site-cta__panel p:not(.section-index){max-width:650px;color:#ada69c}.site-cta__actions{display:flex;flex-direction:column;align-items:stretch;gap:18px}.site-cta__actions .button{width:100%}.site-cta__actions .text-link,.site-cta__actions .text-button{text-align:center;align-self:center}

/* Services */
.choice-guide{background:#090b0a}.choice-guide__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:8vw}.choice-guide h2{font-size:clamp(58px,6vw,100px);line-height:.8}.choice-guide__items{border-top:1px solid rgba(255,255,255,.08)}.choice-guide__items article{display:grid;grid-template-columns:55px 1fr 1fr;gap:20px;align-items:center;padding:24px 0;border-bottom:1px solid rgba(255,255,255,.08)}.choice-guide__items span{color:var(--gold-hi);font:500 27px "Cormorant Garamond"}.choice-guide__items h3{font-size:30px}.choice-guide__items p{margin:0;color:var(--muted);font-size:11px}
.comparison-section{background:#050606}.service-comparison{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));border:1px solid rgba(255,255,255,.08)}.service-comparison article{position:relative;min-height:530px;padding:30px;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.08);background:linear-gradient(145deg,rgba(255,255,255,.025),transparent)}.service-comparison article:last-child{border-right:0;background:radial-gradient(circle at 80% 12%,rgba(226,201,140,.13),transparent 18rem)}.service-comparison>article>span{color:var(--gold);font-size:8px;letter-spacing:.14em}.service-comparison h3{margin:80px 0 35px;font-size:clamp(40px,4vw,62px);line-height:.86}.service-comparison dl{margin:0}.service-comparison dl div{padding:13px 0;border-top:1px solid rgba(255,255,255,.07)}.service-comparison dt{font-size:7px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}.service-comparison dd{margin:5px 0 0;color:#c0b9ad;font-size:11px}.service-comparison>article>strong{margin-top:auto;font:500 48px "Cormorant Garamond";color:var(--gold-hi)}
.diagnosis-banner{background:#0b0d0c}.diagnosis-banner__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:8vw;align-items:center}.diagnosis-banner__image{height:650px;overflow:hidden;border:1px solid rgba(226,201,140,.16)}.diagnosis-banner__image img{width:100%;height:100%;object-fit:cover;object-position:67% center;filter:saturate(.65)}.diagnosis-banner h2{font-size:clamp(60px,6vw,105px);line-height:.8}.diagnosis-banner p:not(.section-index){max-width:560px;color:var(--muted);font-size:15px}.diagnosis-banner .text-link{display:block;width:max-content;margin-top:20px}

/* Catalog */
.catalog-criteria{background:#090b0a}.catalog-criteria__grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:8vw}.catalog-criteria h2{font-size:clamp(60px,6vw,100px);line-height:.8}.catalog-criteria__list{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(255,255,255,.08)}.catalog-criteria__list article{padding:28px 22px;border-right:1px solid rgba(255,255,255,.08)}.catalog-criteria__list article:last-child{border-right:0}.catalog-criteria__list span{color:var(--gold-hi);font:500 25px "Cormorant Garamond"}.catalog-criteria__list h3{margin:70px 0 13px;font-size:29px}.catalog-criteria__list p{color:var(--muted);font-size:11px}
.catalog-checkout-bar{margin-top:18px;padding:20px 22px;display:flex;align-items:center;justify-content:space-between;gap:25px;border:1px solid rgba(226,201,140,.16);background:rgba(255,255,255,.02)}.catalog-checkout-bar span{font:500 24px "Cormorant Garamond"}.catalog-checkout-bar p{margin:4px 0 0;color:var(--muted);font-size:9px}.catalog-checkout-bar .button{min-width:230px}
.routine-guide{background:#070808}.routine-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.routine-grid article{min-height:390px;padding:29px;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.08);background:linear-gradient(145deg,#141716,#0c0e0d)}.routine-grid>article>span{font-size:8px;letter-spacing:.13em;color:var(--gold);text-transform:uppercase}.routine-grid h3{margin:105px 0 16px;font-size:clamp(34px,3.6vw,54px);line-height:.88}.routine-grid p{color:var(--muted)}.routine-grid .text-link{margin-top:auto}

/* Portfolio */
.transformation-grid--portfolio{grid-template-columns:repeat(3,minmax(0,1fr))}.transformation-grid--portfolio .transformation-card:last-child{grid-column:auto;display:flex;grid-template-columns:none}.transformation-grid--portfolio .transformation-card:last-child .compare{aspect-ratio:4/5}.style-guide{background:#090b0a}.style-guide__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.style-guide__grid article{min-height:450px;padding:30px;display:flex;flex-direction:column;border:1px solid rgba(226,201,140,.11);background:linear-gradient(150deg,#151817,#0b0d0c)}.style-guide__grid span{font-size:8px;letter-spacing:.14em;color:var(--gold)}.style-guide__grid h3{margin:125px 0 18px;font-size:clamp(38px,4vw,62px);line-height:.86}.style-guide__grid p{max-width:340px;color:var(--muted)}.style-guide__grid .text-link{margin-top:auto}.adaptation{background:linear-gradient(120deg,#111310,#070808)}.adaptation__grid{display:grid;grid-template-columns:1fr 1fr;gap:10vw;align-items:start}.adaptation h2{font-size:clamp(65px,7vw,115px);line-height:.75}.adaptation__grid>div:last-child>p{font:500 clamp(29px,3.2vw,48px)/1.15 "Cormorant Garamond"}.adaptation .button{margin-top:26px}

/* Experience */
.experience-prologue{background:#080a09}.experience-prologue__grid{display:grid;grid-template-columns:1fr 1fr;gap:9vw}.experience-prologue h2{font-size:clamp(62px,6.5vw,108px);line-height:.78}.experience-prologue__lead{font:500 clamp(28px,3.4vw,48px)/1.15 "Cormorant Garamond";color:#d8d0c4}.prologue-notes{display:flex;align-items:center;gap:12px;margin-top:35px;flex-wrap:wrap;color:var(--gold-hi);font-size:8px;letter-spacing:.12em;text-transform:uppercase}.prologue-notes i{width:25px;height:1px;background:rgba(226,201,140,.3)}
.experience--full{padding-bottom:0}.experience--full .experience-intro{margin-bottom:5vh}.experience--full .ritual-step{min-height:64vh!important}.ritual-stage__caption{display:flex;justify-content:space-between;gap:20px;margin:0 0 18px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08)}.ritual-stage__caption span{color:var(--gold-hi);font-size:8px;letter-spacing:.13em;text-transform:uppercase}.ritual-stage__caption p{max-width:310px;margin:0;text-align:right;color:var(--muted);font-size:9px}.ritual-detail{display:block;margin-top:22px;color:var(--gold);font-size:8px;letter-spacing:.1em;text-transform:uppercase}.experience-includes{background:#070808}.experience-includes__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.experience-includes__grid article{min-height:300px;padding:27px;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.08);background:linear-gradient(145deg,#141716,#0b0d0c)}.experience-includes__grid span{font-size:8px;letter-spacing:.14em;color:var(--gold)}.experience-includes__grid h3{margin:auto 0 15px;font-size:clamp(34px,3.5vw,53px);line-height:.87}.experience-includes__grid p{margin:0;color:var(--muted)}.experience-includes__price{border-color:rgba(226,201,140,.34)!important;background:radial-gradient(circle at 75% 10%,rgba(226,201,140,.16),transparent 16rem),#151611!important}.experience-includes__price strong{font:500 50px "Cormorant Garamond";color:var(--gold-hi)}

/* Contact */
.contact-channels{background:#090b0a}.contact-channel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.contact-channel{position:relative;min-height:400px;padding:30px;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.08);background:linear-gradient(145deg,#151817,#0c0e0d);transition:transform .5s var(--v5-ease),border-color .3s}.contact-channel:hover{transform:translateY(-5px);border-color:rgba(226,201,140,.34)}.contact-channel>span{font-size:8px;letter-spacing:.14em;color:var(--gold);text-transform:uppercase}.contact-channel>.status-dot{position:absolute;right:30px;top:30px}.contact-channel h3{max-width:90%;margin:auto 0 18px;font-size:clamp(38px,4.5vw,68px);line-height:.86;overflow-wrap:anywhere}.contact-channel p{max-width:500px;color:var(--muted)}.contact-channel>strong{margin-top:20px;font-size:9px;letter-spacing:.09em;text-transform:uppercase;color:var(--gold-hi)}.contact-channel--primary{border-color:rgba(226,201,140,.32);background:radial-gradient(circle at 86% 12%,rgba(127,155,130,.14),transparent 18rem),linear-gradient(145deg,#191a16,#0d0f0e)}.contact-channel--social>div{display:flex;gap:9px;margin-top:20px}.contact-channel--social a{padding:10px 12px;border:1px solid rgba(226,201,140,.18);font-size:9px;text-transform:uppercase}
.studio-visit{background:#050606}.studio-visit__grid{display:grid;grid-template-columns:1.08fr .92fr;gap:8vw;align-items:center}.studio-visit__map{position:relative;height:720px;overflow:hidden;border:1px solid rgba(226,201,140,.18)}.studio-visit__map>img{width:100%;height:100%;object-fit:cover;filter:saturate(.6) brightness(.72)}.studio-visit__map::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(4,5,5,.8),transparent 50%)}.studio-visit__map>a{position:absolute;z-index:3;left:25px;bottom:25px;padding:11px 14px;border:1px solid rgba(226,201,140,.25);background:rgba(5,6,6,.78);font-size:8px;letter-spacing:.1em;text-transform:uppercase}.map-art--large{position:absolute;z-index:2;right:25px;top:25px;width:150px;height:150px;background:rgba(5,6,6,.6);backdrop-filter:blur(10px)}.studio-visit h2{font-size:clamp(62px,6.5vw,108px);line-height:.78}.studio-visit dl{margin:35px 0}.studio-visit dl div{display:grid;grid-template-columns:120px 1fr;gap:20px;padding:15px 0;border-top:1px solid rgba(255,255,255,.08)}.studio-visit dt{color:var(--gold);font-size:8px;letter-spacing:.12em;text-transform:uppercase}.studio-visit dd{margin:0;color:#c1baaf;font-size:12px;line-height:1.6}
.message-guide{background:#0b0d0c}.message-steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);border:1px solid rgba(255,255,255,.08)}.message-steps li{min-height:330px;padding:27px;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.08)}.message-steps li:last-child{border-right:0}.message-steps>li>span{font:500 35px "Cormorant Garamond";color:var(--gold-hi)}.message-steps li>div{margin-top:auto}.message-steps h3{font-size:35px}.message-steps p{color:var(--muted)}

/* Drawer/menu refinements shared across all pages */
.mobile-reserve>button:first-child{flex:1;display:flex;justify-content:space-between;align-items:center;padding:0 18px;border:0;background:none;color:#090b0a;font-size:10px;text-transform:uppercase;font-weight:700;letter-spacing:.06em;cursor:pointer}
.menu-card button{grid-column:1/-1;border:0;padding:0;background:none;color:var(--gold-hi);font-size:9px;text-align:left;text-transform:uppercase;cursor:pointer}
.cart-empty-links{flex-wrap:wrap}

@media (max-width:1180px){
  .desktop-nav{gap:10px}.desktop-nav a{font-size:7px}.header-inner{gap:18px}
  .page-hero__content h1{font-size:clamp(70px,10vw,118px)}
  .editorial-card{min-height:440px}.result-teasers{min-height:650px}
  .choice-guide__grid,.catalog-criteria__grid{gap:5vw}
  .service-comparison article{min-height:500px}
}

@media (max-width:1020px){
  .desktop-nav,.header-book{display:none}.menu-trigger{display:grid}
  .page-hero__meta{width:100%}.page-hero__ornament{right:6%;top:16%;width:92px}
  .editorial-links{grid-template-columns:1fr 1fr}.editorial-card--featured{grid-column:1/-1}
  .result-teasers{min-height:590px}
  .method-preview,.catalog-preview,.diagnosis-banner__grid,.studio-visit__grid{grid-template-columns:1fr;gap:55px}
  .method-preview__visual,.catalog-preview__image,.diagnosis-banner__image,.studio-visit__map{min-height:500px;height:65vw;max-height:680px}
  .choice-guide__grid,.catalog-criteria__grid,.experience-prologue__grid,.adaptation__grid{grid-template-columns:1fr;gap:50px}
  .service-comparison{grid-template-columns:1fr}.service-comparison article{min-height:0;border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}.service-comparison h3{margin:55px 0 25px}.service-comparison>article>strong{margin-top:35px}
  .catalog-criteria__list{grid-template-columns:repeat(3,1fr)}
  .transformation-grid--portfolio{grid-template-columns:1fr 1fr}.transformation-grid--portfolio .transformation-card:last-child{grid-column:1/-1;display:grid;grid-template-columns:1fr .7fr}.transformation-grid--portfolio .transformation-card:last-child .compare{aspect-ratio:16/10}
  .experience-includes__grid{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:680px){
  .page-hero{min-height:820px;align-items:start}.page-hero::before{background:linear-gradient(0deg,rgba(4,5,5,.99) 0%,rgba(4,5,5,.65) 62%,rgba(4,5,5,.28)),linear-gradient(90deg,rgba(3,4,4,.82),transparent)}
  .page-hero__media img{object-position:65% center}.page-hero--catalog .page-hero__media img{object-position:58% center}.page-hero--experience .page-hero__media img,.page-hero--contact .page-hero__media img{object-position:61% center}
  .page-hero__content{padding-top:145px;padding-bottom:190px}.page-hero__content h1{font-size:clamp(56px,17vw,78px);line-height:.8;margin-bottom:25px}.page-hero__lead{font-size:13px;max-width:95%}.page-hero__actions{display:grid;grid-template-columns:1fr}.page-hero__actions .button{width:100%}.page-hero__ornament{display:none}.page-hero__meta{grid-template-columns:1fr 1fr}.page-hero__meta span{padding:14px 16px}.page-hero__meta span:nth-child(3){display:none}
  .work-hero-collage{transform:translateX(15%);grid-template-columns:1.2fr .8fr;opacity:.56}.work-hero-collage figure:nth-child(3){display:none}
  .editorial-links,.style-guide__grid,.routine-grid,.contact-channel-grid,.experience-includes__grid{grid-template-columns:1fr}.editorial-card--featured{grid-column:auto}.editorial-card{min-height:410px;padding:24px}.editorial-card h3{margin-top:100px}
  .result-teasers{display:grid;grid-template-columns:1fr;min-height:0}.result-teaser{height:112vw;max-height:580px}.result-teaser--large{height:125vw;max-height:630px}.result-teaser span{left:20px;right:20px;bottom:20px;display:block}.result-teaser strong{display:block;margin-top:8px}
  .method-preview__visual,.catalog-preview__image,.diagnosis-banner__image,.studio-visit__map{min-height:400px;height:112vw;max-height:560px}.method-preview__copy h2,.catalog-preview h2,.diagnosis-banner h2,.studio-visit h2{font-size:clamp(53px,15vw,72px)}
  .site-cta__panel{min-height:570px;padding:44px 24px;grid-template-columns:1fr;gap:35px}.site-cta__panel h2{font-size:clamp(53px,15vw,74px)}
  .choice-guide__items article{grid-template-columns:45px 1fr}.choice-guide__items p{grid-column:2}.catalog-criteria__list{grid-template-columns:1fr}.catalog-criteria__list article{min-height:250px;border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}.catalog-criteria__list h3{margin-top:55px}
  .catalog-checkout-bar{align-items:stretch;flex-direction:column}.catalog-checkout-bar .button{width:100%;min-width:0}
  .transformation-grid--portfolio{display:grid!important;grid-template-columns:1fr!important}.transformation-grid--portfolio .transformation-card:last-child{grid-column:auto;display:flex}.transformation-grid--portfolio .transformation-card:last-child .compare{aspect-ratio:4/5}
  .style-guide__grid article,.routine-grid article{min-height:390px}.style-guide__grid h3,.routine-grid h3{margin-top:95px}
  .adaptation__grid>div:last-child>p{font-size:31px}
  .experience-prologue h2{font-size:clamp(55px,15vw,75px)}.prologue-notes{gap:8px}.experience--full .ritual-step{min-height:0!important}.ritual-stage__caption{display:block}.ritual-stage__caption p{text-align:left;margin-top:7px}.experience-includes__grid article{min-height:260px}
  .contact-channel{min-height:340px;padding:24px}.contact-channel h3{font-size:clamp(36px,11vw,50px)}.contact-channel--social>div{flex-wrap:wrap}.studio-visit dl div{grid-template-columns:1fr;gap:7px}.message-steps{grid-template-columns:1fr}.message-steps li{min-height:260px;border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}
  .footer-top nav{grid-template-columns:1fr 1fr}
}

@media (max-width:390px){
  .page-hero{min-height:790px}.page-hero__content{padding-top:130px}.page-hero__content h1{font-size:53px}.page-hero__meta span{font-size:7px}
  .editorial-card{min-height:390px}.contact-channel{min-height:320px}.contact-channel h3{font-size:36px}
  .site-cta__panel{padding-inline:20px}.site-cta__panel h2{font-size:50px}
}

@media (hover:none){
  .editorial-card:hover,.contact-channel:hover{transform:none}.result-teaser:hover img,.catalog-preview__image:hover img{transform:none}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto!important}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .page-veil,.cursor-light{display:none!important}
  .page-hero__media img,.work-hero-collage img,[data-reveal]{opacity:1!important;transform:none!important}
}

/* ========================================================================== */
/* V6 quality pass — motion, editorial variety, contact, compact footer, legal */
/* ========================================================================== */

:root{
  --motion-fast:180ms;
  --motion-ui:280ms;
  --motion-reveal:680ms;
  --motion-hero:620ms;
  --motion-media:820ms;
  --motion-curtain:720ms;
  --ease-premium:cubic-bezier(.22,1,.36,1);
}

/* The brand curtain exists only on the first visit of a session. */
.intro-curtain{display:none;pointer-events:none;transform:translate3d(0,0,0);transition:none;visibility:visible}
.has-brand-intro .intro-curtain{display:grid}
.has-brand-intro.is-ready .intro-curtain{transform:translate3d(0,-101%,0);transition:transform var(--motion-curtain) var(--ease-premium)}
.has-brand-intro .intro-curtain>div{opacity:1;transform:none;transition:opacity 180ms ease,transform 220ms var(--ease-premium)}
.has-brand-intro.is-ready .intro-curtain>div{opacity:0;transform:translateY(-10px)}
.has-brand-intro .intro-mark{opacity:0;transform:scale(.9);animation:intro-mark-v6 360ms 80ms var(--ease-premium) forwards}
.has-brand-intro .intro-curtain strong{opacity:0;transform:translateY(10px);animation:intro-copy-v6 380ms 160ms var(--ease-premium) forwards}
.has-brand-intro .intro-curtain i{transform:scaleX(0);transform-origin:center;animation:intro-line-v6 420ms 220ms var(--ease-premium) forwards}
.has-brand-intro .intro-curtain small{opacity:0;transform:translateY(7px);animation:intro-copy-v6 320ms 310ms var(--ease-premium) forwards}
@keyframes intro-mark-v6{to{opacity:1;transform:none}}
@keyframes intro-copy-v6{to{opacity:1;transform:none}}
@keyframes intro-line-v6{to{transform:scaleX(1)}}

.js .hero-enter{opacity:0;transform:translate3d(0,24px,0);transition:opacity var(--motion-hero) var(--ease-premium),transform var(--motion-hero) var(--ease-premium);transition-delay:var(--hero-delay,120ms)!important}
.js.is-ready .hero-enter{opacity:1;transform:none}
.hero-copy>.eyebrow,.page-hero__content>.eyebrow{--hero-delay:120ms}
.hero-title>.hero-enter:nth-child(1),.page-hero__content h1>.hero-enter:nth-child(1){--hero-delay:180ms}
.hero-title>.hero-enter:nth-child(2),.page-hero__content h1>.hero-enter:nth-child(2){--hero-delay:250ms}
.hero-title>.hero-enter:nth-child(3){--hero-delay:320ms}
.hero-lead,.page-hero__lead{--hero-delay:320ms}
.hero-ctas,.page-hero__actions{--hero-delay:390ms}
.hero-micro,.availability,.hero-proof{--hero-delay:450ms}

.page-veil{opacity:0;transform:translate3d(0,101%,0);transition:none}
.is-page-leaving .page-veil{opacity:1;transform:translate3d(0,0,0);transition:opacity 140ms ease,transform 240ms var(--ease-premium)}
.is-page-arriving .page-veil{opacity:1;transform:translate3d(0,0,0)}
.is-page-arriving.is-ready .page-veil{opacity:1;transform:translate3d(0,-101%,0);transition:transform 360ms var(--ease-premium)}

.js [data-reveal]{transition:opacity 560ms ease,transform var(--motion-reveal) var(--ease-premium);transition-delay:var(--delay,0ms)}
.js [data-reveal="image"],.js [data-reveal="scale"]{transform:translate3d(0,16px,0) scale(.985)}
.js [data-reveal="split"]{transform:translate3d(0,36px,0)}
.js [data-reveal].is-visible{opacity:1;transform:none}

/* Home: services become an editorial index instead of another card grid. */
.page-home .editorial-links{display:block;border-top:1px solid rgba(226,201,140,.22)}
.page-home .editorial-card,.page-home .editorial-card--featured{min-height:0;padding:26px 4px;display:grid;grid-template-columns:110px minmax(240px,.8fr) 1fr auto;gap:24px;align-items:center;border:0;border-bottom:1px solid rgba(255,255,255,.1);background:transparent;box-shadow:none;overflow:visible}
.page-home .editorial-card::before{display:none}
.page-home .editorial-card>span{grid-column:1}.page-home .editorial-card h3{grid-column:2;max-width:none;margin:0;font-size:clamp(34px,3.6vw,56px)}
.page-home .editorial-card p{grid-column:3;margin:0}.page-home .editorial-card strong{grid-column:4;margin:0;padding:0;border:0;white-space:nowrap;font-size:23px}
.page-home .editorial-card i{grid-column:4;margin:4px 0 0;text-align:right}
.page-home .editorial-card:hover{transform:translateX(6px);border-color:rgba(226,201,140,.4)}

/* Services: cards stay selectable, comparison becomes a quiet editorial table. */
.page-services .service-comparison{border:0;border-block:1px solid rgba(226,201,140,.2);background:transparent}
.page-services .service-comparison article{background:transparent;box-shadow:none;border-color:rgba(255,255,255,.08)}
.page-services .service-comparison article:last-child{background:linear-gradient(180deg,rgba(226,201,140,.055),transparent)}
.page-services .choice-guide__items article{background:transparent}

/* Experience: purchase summary is a single continuous band, not six boxes. */
.page-experience .experience-includes__grid{gap:0;border-block:1px solid rgba(226,201,140,.2)}
.page-experience .experience-includes__grid article{min-height:235px;border:0;border-right:1px solid rgba(255,255,255,.08);background:transparent;box-shadow:none}
.page-experience .experience-includes__grid article:nth-child(3n){border-right:0}
.page-experience .experience-includes__price{border:0!important;background:linear-gradient(145deg,rgba(226,201,140,.09),transparent)!important}

/* Contact — guided booking, live routes and stylised map. */
.page-hero--contact .page-hero__media img{object-position:68% center;filter:saturate(.64) contrast(1.06) brightness(.73)}
.guided-booking{background:radial-gradient(circle at 13% 30%,rgba(197,164,100,.08),transparent 28rem),#080a09}
.guided-booking__layout{display:grid;grid-template-columns:minmax(0,1.03fr) minmax(390px,.97fr);gap:clamp(55px,8vw,125px);align-items:start}
.booking-visual{position:sticky;top:100px;height:min(76vh,760px);margin:0;overflow:hidden;border:1px solid rgba(226,201,140,.22);box-shadow:0 36px 110px rgba(0,0,0,.34)}
.booking-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(4,5,5,.92),transparent 52%,rgba(4,5,5,.12));pointer-events:none}
.booking-visual>img{width:100%;height:100%;object-fit:cover;object-position:56% center;filter:saturate(.72) contrast(1.04);transition:transform 900ms var(--ease-premium)}
.booking-visual:hover>img{transform:scale(1.025)}
.booking-visual__copy{position:absolute;z-index:3;left:27px;right:27px;bottom:25px;display:flex;justify-content:space-between;gap:20px;align-items:end}
.booking-visual__copy>span{display:flex;gap:10px;align-items:center;color:var(--gold-hi);font-size:8px;letter-spacing:.12em;text-transform:uppercase}
.booking-visual__copy strong{max-width:310px;text-align:right;font:500 24px/1.05 "Cormorant Garamond"}
.booking-signal{position:absolute;z-index:3;right:25px;top:25px;width:120px;aspect-ratio:1;display:grid;place-items:center;border:1px solid rgba(226,201,140,.22);border-radius:50%}
.booking-signal i{position:absolute;inset:18px;border:1px solid rgba(226,201,140,.14);border-radius:50%}.booking-signal i:nth-child(2){inset:37px}.booking-signal span{color:var(--gold-hi);font:500 30px "Cormorant Garamond"}
.booking-steps h2{font-size:clamp(60px,6.4vw,108px);line-height:.78}
.booking-steps ol{list-style:none;margin:45px 0 32px;padding:0;border-top:1px solid rgba(255,255,255,.09)}
.booking-steps li{position:relative;display:grid;grid-template-columns:66px 1fr;gap:22px;padding:28px 0;border-bottom:1px solid rgba(255,255,255,.09)}
.booking-steps li>span{color:var(--gold-hi);font:500 35px/1 "Cormorant Garamond"}.booking-steps h3{margin:0 0 7px;font-size:30px}.booking-steps p{margin:0;color:var(--muted);font-size:12px;line-height:1.7}

.contact-hub{overflow:hidden;background:linear-gradient(115deg,#111310,#060707 65%)}
.contact-hub__layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:8vw;align-items:center}
.contact-hub__copy h2{font-size:clamp(60px,6vw,100px);line-height:.78}
.contact-lines{margin-top:42px;border-top:1px solid rgba(255,255,255,.09)}
.contact-lines>a,.contact-lines>div{display:grid;grid-template-columns:95px 1fr auto;gap:20px;align-items:center;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.09);transition:padding-left 320ms var(--ease-premium),color 240ms ease}
.contact-lines>a:hover{padding-left:8px;color:var(--gold-hi)}
.contact-lines span{color:var(--gold);font-size:8px;letter-spacing:.11em;text-transform:uppercase}.contact-lines strong{font:500 22px "Cormorant Garamond";overflow-wrap:anywhere}.contact-lines i{font-style:normal}.contact-lines small{grid-column:2/-1;color:var(--muted);font-size:8px}
.contact-map{position:relative;min-height:650px;overflow:hidden;border:1px solid rgba(226,201,140,.2);background:linear-gradient(rgba(255,255,255,.028) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px),radial-gradient(circle at 56% 45%,rgba(197,164,100,.11),transparent 22rem),#090b0a;background-size:56px 56px,56px 56px,auto,auto}
.contact-map::before,.contact-map::after{content:"";position:absolute;left:56%;top:43%;border:1px solid rgba(226,201,140,.12);border-radius:50%;transform:translate(-50%,-50%)}
.contact-map::before{width:390px;height:390px}.contact-map::after{width:250px;height:250px}
.contact-map__radar{position:absolute;left:56%;top:43%;width:130px;aspect-ratio:1;display:grid;place-items:center;border:1px solid rgba(226,201,140,.3);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 60px rgba(197,164,100,.12)}
.contact-map__radar i{position:absolute;inset:18px;border:1px solid rgba(226,201,140,.18);border-radius:50%}.contact-map__radar i:nth-child(2){inset:37px}.contact-map__radar i:nth-child(3){inset:58px;background:var(--gold-hi);box-shadow:0 0 25px var(--gold)}.contact-map__radar span{font:500 34px "Cormorant Garamond";color:var(--gold-hi)}
.contact-map__address{position:absolute;z-index:2;left:28px;right:28px;bottom:28px;padding:24px;border:1px solid rgba(255,255,255,.09);background:rgba(5,6,6,.78);backdrop-filter:blur(14px)}
.contact-map__address small{color:var(--gold);font-size:8px;letter-spacing:.13em}.contact-map__address strong{display:block;margin:10px 0;font:500 28px/1.05 "Cormorant Garamond"}.contact-map__address p{color:var(--muted);font-size:10px}.contact-map__address a{font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-hi)}

.contact-note{padding-block:75px;background:var(--paper);color:var(--ink)}
.contact-note__row{display:grid;grid-template-columns:150px 1.15fr .85fr auto;gap:35px;align-items:center}.contact-note .section-index{margin:0;color:#715938}.contact-note h2{margin:0;font-size:clamp(42px,4.7vw,72px);line-height:.82}.contact-note p{margin:0;color:#4b4a46}.contact-note .text-link{white-space:nowrap;color:var(--ink)}
.faq--contact{background:radial-gradient(circle at 10% 20%,rgba(197,164,100,.07),transparent 25rem),#080a09}
.contact-closing{position:relative;min-height:720px;display:grid;align-items:end;overflow:hidden;background:#050606}
.contact-closing__image{position:absolute;inset:0}.contact-closing__image::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(4,5,5,.97),rgba(4,5,5,.75) 48%,rgba(4,5,5,.2)),linear-gradient(0deg,rgba(4,5,5,.9),transparent 60%)}
.contact-closing__image img{width:100%;height:100%;object-fit:cover;object-position:center;filter:saturate(.65) brightness(.74);transition:transform 1s var(--ease-premium)}
.contact-closing:hover .contact-closing__image img{transform:scale(1.025)}
.contact-closing__content{position:relative;z-index:2;padding-bottom:95px}.contact-closing h2{max-width:980px;font-size:clamp(68px,8vw,130px);line-height:.74}.contact-closing p:not(.section-index){max-width:620px;color:#b9b2a7}.contact-closing__content>div{display:flex;gap:24px;align-items:center;margin-top:28px}

/* Compact footer — informative, never a second hero. */
.site-footer--compact{position:relative;padding:0;background:#050606;border-top:1px solid rgba(226,201,140,.16);overflow:hidden}
.site-footer--compact::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold-hi),transparent);opacity:.32;transform-origin:left}
.footer-main{min-height:190px;padding-block:42px 34px;display:grid;grid-template-columns:1.15fr 1.45fr .75fr;gap:55px;align-items:start}
.footer-brand p{max-width:280px;margin:16px 0 0;color:var(--muted);font-size:10px}.footer-main nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px 24px}.footer-main nav a,.footer-contact a,.footer-contact span{font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:#a9a39a}.footer-main nav a:hover,.footer-contact a:hover{color:var(--gold-hi)}
.footer-contact{display:flex;flex-direction:column;gap:13px;align-items:flex-start}.footer-contact span{color:#706d67}.footer-meta{padding:18px 0 22px;display:flex;justify-content:space-between;gap:25px;border-top:1px solid rgba(255,255,255,.055);font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:#77736d}.footer-meta a:hover{color:var(--gold-hi)}
.site-footer--compact .footer-word,.site-footer--compact .footer-top,.site-footer--compact .footer-bottom{display:none}
.js [data-footer]:not(.is-visible) .footer-main,.js [data-footer]:not(.is-visible) .footer-meta{opacity:0;transform:translateY(15px)}
.js [data-footer].is-visible .footer-main{opacity:1;transform:none;transition:opacity 500ms ease,transform 560ms var(--ease-premium)}
.js [data-footer].is-visible .footer-meta{opacity:1;transform:none;transition:opacity 420ms ease 120ms,transform 480ms var(--ease-premium) 120ms}

/* Legal — sober editorial document with a sticky index. */
.legal-hero{position:relative;min-height:clamp(480px,62svh,650px);display:grid;align-items:end;overflow:hidden;background:radial-gradient(circle at 78% 30%,rgba(197,164,100,.1),transparent 26rem),#070808}
.legal-hero::after{content:"LEGAL";position:absolute;right:-1vw;bottom:-5vw;color:rgba(255,255,255,.025);font:500 24vw/.7 "Cormorant Garamond";letter-spacing:-.06em}
.legal-hero__grid{position:absolute;inset:0;background:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:70px 70px}
.legal-hero__content{position:relative;z-index:2;padding-bottom:80px}.legal-hero h1{max-width:1050px;margin:0;font-size:clamp(70px,9vw,140px);line-height:.75;letter-spacing:-.05em}.legal-hero h1 span{display:block}.legal-hero h1 em{color:var(--gold-hi)}.legal-hero__lead{max-width:700px;margin:28px 0 0;color:#b7b1a6;font-size:15px;line-height:1.7}
.legal-document{background:#0a0c0b}.legal-layout{display:grid;grid-template-columns:260px minmax(0,780px);gap:clamp(60px,9vw,140px);justify-content:center;align-items:start}
.legal-index{position:sticky;top:110px;padding-top:12px}.legal-index>span{display:block;padding-bottom:14px;border-bottom:1px solid rgba(226,201,140,.2);color:var(--gold);font-size:8px;letter-spacing:.14em;text-transform:uppercase}.legal-index nav{display:flex;flex-direction:column;margin-bottom:26px}.legal-index nav a{padding:13px 0;border-bottom:1px solid rgba(255,255,255,.07);font-size:9px;color:#a8a198}.legal-index nav a:hover{color:var(--gold-hi)}
.legal-notice{margin-bottom:85px;padding:24px 26px;border-left:2px solid var(--gold-hi);background:rgba(226,201,140,.07)}.legal-notice strong{font:500 28px "Cormorant Garamond"}.legal-notice p{margin:8px 0 0}
.legal-content article{padding:0 0 90px;margin-bottom:90px;border-bottom:1px solid rgba(255,255,255,.08);scroll-margin-top:110px}.legal-content article:last-child{margin-bottom:0}.legal-content h2{font-size:clamp(52px,6vw,82px);line-height:.8}.legal-content h3{margin:38px 0 15px;font-size:30px}.legal-content p{color:#b7b0a6;line-height:1.9}.legal-data{margin:25px 0 35px}.legal-data div{display:grid;grid-template-columns:210px 1fr;gap:20px;padding:13px 0;border-top:1px solid rgba(255,255,255,.07)}.legal-data dt{color:var(--gold);font-size:8px;letter-spacing:.1em;text-transform:uppercase}.legal-data dd{margin:0;color:#d7d1c7}.legal-table{margin-top:28px;border:1px solid rgba(255,255,255,.08)}.legal-table [role="row"]{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;padding:14px;border-bottom:1px solid rgba(255,255,255,.07)}.legal-table [role="row"]:last-child{grid-template-columns:1fr;border:0}.legal-table strong{font-size:8px;color:var(--gold);text-transform:uppercase}.legal-table span{color:var(--muted)}.legal-updated{padding-top:20px;border-top:1px solid rgba(226,201,140,.2);font-size:10px}

@media (max-width:1020px){
  .guided-booking__layout,.contact-hub__layout{grid-template-columns:1fr;gap:55px}.booking-visual{position:relative;top:auto;height:70vw;max-height:680px;min-height:500px}.contact-map{min-height:600px}
  .contact-note__row{grid-template-columns:1fr 1fr}.contact-note .section-index{grid-column:1/-1}.contact-note .text-link{justify-self:start}
  .footer-main{grid-template-columns:1fr 1fr}.footer-contact{grid-column:1/-1;flex-direction:row;flex-wrap:wrap;gap:20px}
  .legal-layout{grid-template-columns:210px 1fr;gap:55px}
}

@media (max-width:900px) and (min-height:680px){
  .page-experience .ritual-stage{position:sticky;z-index:4;top:68px;padding:0 0 12px;background:#080a09}
  .page-experience .ritual-stage__visual{height:42svh;min-height:280px;max-height:380px;margin-bottom:12px}
  .page-experience .ritual-stage__caption{display:none}.page-experience .ritual-stage>.button{display:none}
  .page-experience .ritual-track{position:relative;z-index:2;padding-top:45px;background:#080a09}
}

@media (max-width:680px){
  .page-home .editorial-card,.page-home .editorial-card--featured{padding:23px 0;grid-template-columns:48px 1fr auto;gap:11px}.page-home .editorial-card>span{grid-column:1}.page-home .editorial-card h3{grid-column:2;font-size:34px}.page-home .editorial-card p{grid-column:2/-1;margin-top:6px}.page-home .editorial-card strong{grid-column:2;font-size:20px}.page-home .editorial-card i{grid-column:3;grid-row:3}.page-home .editorial-card:hover{transform:none}
  .page-experience .experience-includes__grid{grid-template-columns:1fr}.page-experience .experience-includes__grid article{min-height:210px;border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}
  .booking-visual{height:122vw;min-height:420px}.booking-visual__copy{display:block}.booking-visual__copy strong{display:block;margin-top:9px;text-align:left}.booking-signal{width:90px}.booking-steps h2{font-size:clamp(54px,15vw,72px)}.booking-steps li{grid-template-columns:52px 1fr}.booking-steps h3{font-size:27px}
  .contact-hub__copy h2{font-size:clamp(52px,15vw,72px)}.contact-lines>a,.contact-lines>div{grid-template-columns:72px 1fr auto;gap:10px}.contact-lines strong{font-size:18px}.contact-map{min-height:540px}.contact-map::before{width:300px;height:300px}.contact-map::after{width:190px;height:190px}.contact-map__address{left:16px;right:16px;bottom:16px}
  .contact-note{padding-block:55px}.contact-note__row{grid-template-columns:1fr;gap:20px}.contact-note .section-index{grid-column:auto}.contact-note h2{font-size:50px}.contact-note .text-link{white-space:normal}
  .contact-closing{min-height:700px}.contact-closing__image::after{background:linear-gradient(0deg,rgba(4,5,5,.96),rgba(4,5,5,.55) 72%,rgba(4,5,5,.25))}.contact-closing__image img{object-position:68% center}.contact-closing__content{padding-bottom:80px}.contact-closing h2{font-size:clamp(56px,16vw,78px)}.contact-closing__content>div{align-items:flex-start;flex-direction:column}
  .footer-main{min-height:0;padding-block:34px 26px;grid-template-columns:1fr;gap:28px}.footer-main nav{grid-template-columns:repeat(2,1fr)}.footer-contact{grid-column:auto;flex-direction:column;gap:11px}.footer-meta{align-items:flex-start;flex-direction:column;padding-block:15px 82px}
  .legal-hero{min-height:520px}.legal-hero__content{padding-bottom:62px}.legal-hero h1{font-size:clamp(58px,17vw,80px)}.legal-layout{grid-template-columns:1fr}.legal-index{position:relative;top:auto}.legal-index nav{display:grid;grid-template-columns:1fr 1fr}.legal-content article{scroll-margin-top:80px;margin-bottom:65px;padding-bottom:65px}.legal-data div{grid-template-columns:1fr;gap:5px}.legal-table [role="row"]{grid-template-columns:1fr}.legal-table [role="row"] strong{display:none}
}

@media (max-width:900px) and (max-height:679px){
  .page-experience .ritual-stage{position:relative;top:auto}
}

@media (hover:none){.booking-visual:hover>img,.contact-closing:hover .contact-closing__image img{transform:none}}

@media (prefers-reduced-motion:reduce){
  .intro-curtain,.page-veil,.cursor-light{display:none!important}
  .hero-enter,[data-reveal],[data-footer] .footer-main,[data-footer] .footer-meta,.page-hero__media img,.hero-scene img,.ritual-step,.ritual-scene{opacity:1!important;transform:none!important;transition:none!important;animation:none!important}
  .hero-glow,.hero-sweep,.hero-seal svg,.marquee-track{animation:none!important}
}

@media print{
  .intro-curtain,.page-veil,.page-progress,.cursor-light,.mobile-reserve,.site-header,.site-footer,.cart-modal,.mobile-menu{display:none!important}
  [data-reveal],.hero-enter{opacity:1!important;transform:none!important}.legal-hero{min-height:0;padding:40px 0}.legal-index{display:none}.legal-layout{display:block}.legal-content article{break-inside:avoid}
}

/* V7 mobile quality pass — dedicated layouts, not compressed desktop. */
@media screen and (max-width:900px){
  main,.shell,.page-hero__content,.experience-layout,.ritual-track,.guided-booking__layout,.contact-hub__layout,.legal-layout{min-width:0;max-width:100%}

  /* The six-step story becomes a linear mobile timeline. The visual no longer
     sticks over the copy and every step receives its own image cue. */
  .page-experience .experience-layout{display:block!important}
  .page-experience .ritual-stage{position:relative!important;z-index:1;top:auto!important;padding:0!important;background:transparent!important}
  .page-experience .ritual-stage__visual{height:clamp(310px,68vw,500px)!important;min-height:0!important;max-height:none!important;margin:0!important}
  .page-experience .ritual-stage__caption{display:flex!important;margin-top:16px}
  .page-experience .ritual-stage>.button{display:flex!important;width:100%;margin-top:18px}
  .page-experience .ritual-track{position:relative;z-index:1;margin-top:48px;padding:12px 0 18px!important;background:transparent!important}
  .page-experience .ritual-track::before{left:20px!important;top:32px!important;bottom:36px!important;background:linear-gradient(var(--gold-hi),rgba(226,201,140,.22) 72%,rgba(226,201,140,.04))}
  .page-experience .ritual-step{
    min-height:0!important;
    padding:26px 0 44px 58px!important;
    border-bottom:1px solid rgba(255,255,255,.07)!important;
    opacity:.74!important;
    transform:none!important;
  }
  .page-experience .ritual-step:last-child{border-bottom:0!important}
  .page-experience .ritual-step::before{left:15px!important;top:37px!important}
  .page-experience .ritual-step.is-active{opacity:1!important}
  .page-experience .ritual-step>span{margin:0 0 17px!important;font-size:clamp(44px,9vw,58px)!important;line-height:.8!important}
  .page-experience .ritual-step h3{margin:11px 0 14px;font-size:clamp(38px,8vw,56px);line-height:.88}
  .page-experience .ritual-step p{max-width:620px;margin-bottom:0;font-size:14px;line-height:1.7}
  .page-experience .ritual-detail{line-height:1.55}
  .page-experience .ritual-step>div::before{
    content:"";
    display:block;
    width:100%;
    height:clamp(145px,34vw,210px);
    margin:0 0 22px;
    border:1px solid rgba(226,201,140,.16);
    background-color:#111310;
    background-size:cover;
    background-position:center;
    box-shadow:inset 0 0 50px rgba(0,0,0,.18);
    filter:saturate(.7) contrast(1.04) brightness(.82);
  }
  .page-experience .ritual-step:nth-child(1)>div::before{background-image:linear-gradient(90deg,rgba(5,6,6,.2),rgba(5,6,6,.04)),url("assets/gallery-interior.webp");background-position:center 58%}
  .page-experience .ritual-step:nth-child(2)>div::before{background-image:linear-gradient(90deg,rgba(5,6,6,.24),transparent),url("assets/grooming-collection.webp")}
  .page-experience .ritual-step:nth-child(3)>div::before{background-image:linear-gradient(90deg,rgba(5,6,6,.18),transparent),url("assets/gallery-craft.webp")}
  .page-experience .ritual-step:nth-child(4)>div::before{background-image:linear-gradient(90deg,rgba(5,6,6,.2),transparent),url("assets/beard-ritual.webp");background-position:center 43%}
  .page-experience .ritual-step:nth-child(5)>div::before{background-image:linear-gradient(90deg,rgba(5,6,6,.18),transparent),url("assets/transformation-classic.webp");background-position:center 32%}
  .page-experience .ritual-step:nth-child(6)>div::before{background-image:linear-gradient(90deg,rgba(5,6,6,.2),transparent),url("assets/barber-tools.webp");background-position:center 54%}
}

@media screen and (max-width:680px){
  html,body{width:100%;max-width:100%;overflow-x:clip}
  body{padding-bottom:calc(68px + env(safe-area-inset-bottom,0px))}
  img,svg,video{max-width:100%}
  .shell>*{min-width:0}
  .section{padding-block:clamp(72px,21vw,94px)}
  .section-heading h2,.experience-intro h2,.experience-prologue h2,.booking-steps h2,.contact-hub__copy h2,.legal-content h2{overflow-wrap:anywhere;text-wrap:balance}

  /* Interior heroes keep a cinematic crop without oversized type or metadata. */
  .page-hero{min-height:clamp(690px,100svh,790px)}
  .page-hero__content{width:100%;padding-top:clamp(112px,17svh,145px);padding-bottom:156px}
  .page-hero__content h1{max-width:100%;margin-bottom:22px;font-size:clamp(48px,14.5vw,68px);line-height:.82;letter-spacing:-.045em;overflow-wrap:anywhere}
  .page-hero__lead{max-width:34rem;font-size:13px;line-height:1.6}
  .page-hero__actions{gap:8px}
  .page-hero__actions .button{min-width:0;justify-content:space-between;padding-inline:18px;white-space:normal;text-align:left}
  .page-hero__meta{width:100%;grid-template-columns:repeat(2,minmax(0,1fr));backdrop-filter:blur(10px)}
  .page-hero__meta span{min-width:0;padding:13px 18px;line-height:1.45}
  .page-hero__media img{object-position:64% center}
  .page-hero--services .page-hero__media img{object-position:66% center}
  .page-hero--catalog .page-hero__media img{object-position:61% center}
  .page-hero--experience .page-hero__media img{object-position:64% center}
  .page-hero--contact .page-hero__media img{object-position:62% center}
  .work-hero-collage{transform:translateX(22%);opacity:.48}
  .hero-title{font-size:clamp(49px,15.4vw,69px);overflow-wrap:anywhere}

  /* Experience: compact lead visual followed by six readable editorial steps. */
  .page-experience .experience-intro{margin-bottom:38px}
  .page-experience .experience-intro h2{font-size:clamp(50px,14vw,67px)}
  .page-experience .ritual-stage__visual{height:clamp(250px,72vw,380px)!important}
  .page-experience .ritual-stage__hud{inset:auto 16px 16px!important}
  .page-experience .ritual-stage__hud strong{max-width:72%;font-size:clamp(29px,9vw,40px);overflow-wrap:anywhere}
  .page-experience .ritual-stage__caption{display:block!important;padding-bottom:13px}
  .page-experience .ritual-stage__caption p{margin-top:7px;text-align:left}
  .page-experience .ritual-track{margin-top:36px!important}
  .page-experience .ritual-step{padding:22px 0 38px 50px!important}
  .page-experience .ritual-track::before{left:16px!important;top:27px!important}
  .page-experience .ritual-step::before{left:11px!important;top:30px!important}
  .page-experience .ritual-step>div::before{height:clamp(138px,43vw,185px);margin-bottom:18px}
  .page-experience .ritual-step>span{font-size:43px!important}
  .page-experience .ritual-step small{line-height:1.5}
  .page-experience .ritual-step h3{font-size:clamp(36px,11vw,48px)}
  .page-experience .ritual-step p{font-size:13px}
  .page-experience .experience-includes__grid article{min-height:0;padding:25px 4px 28px}
  .page-experience .experience-includes__grid h3{margin:50px 0 12px}

  /* Commerce and portfolio remain single-column before content gets cramped. */
  .shop-layout,.shop-catalog,.products-grid,.product-card,.transformation-grid--portfolio,.style-guide__grid,.routine-grid{min-width:0;max-width:100%}
  .filters{margin-inline:-2px;padding:2px;overscroll-behavior-inline:contain}
  .filter{min-height:44px}
  .catalog-checkout-bar{padding:18px}
  .transformation-info{min-width:0;padding:21px}
  .transformation-info h3,.transformation-info p,.transformation-info a{overflow-wrap:anywhere}
  .compare{touch-action:pan-y}

  /* Contact and legal are rearranged for narrow reading widths. */
  .guided-booking__layout,.contact-hub__layout{gap:42px}
  .booking-visual{height:clamp(380px,112vw,520px);min-height:0}
  .booking-visual__copy{left:19px;right:19px;bottom:18px}
  .booking-steps li{grid-template-columns:43px minmax(0,1fr);gap:14px;padding-block:23px}
  .contact-lines>a,.contact-lines>div{min-width:0}
  .contact-lines strong{min-width:0;overflow-wrap:anywhere}
  .contact-map{min-height:500px}
  .contact-map__address{padding:19px}
  .contact-closing{min-height:620px}
  .contact-closing__content{padding-bottom:72px}
  .contact-closing h2{font-size:clamp(50px,14.5vw,68px);overflow-wrap:anywhere}
  .legal-hero{min-height:470px}
  .legal-hero__content{padding-bottom:48px}
  .legal-hero h1{font-size:clamp(50px,15vw,68px);overflow-wrap:anywhere}
  .legal-hero__lead{font-size:13px}
  .legal-index nav a{min-width:0;overflow-wrap:anywhere}
  .legal-notice{margin-bottom:58px;padding:20px}
  .legal-content article{margin-bottom:54px;padding-bottom:54px}
  .legal-content h2{font-size:clamp(43px,13vw,58px)}
  .legal-content h3{font-size:27px}
  .legal-content p{line-height:1.75;overflow-wrap:anywhere}
  .legal-data dd{overflow-wrap:anywhere}

  /* Navigation/footer reserve enough safe-area space and never force width. */
  .menu-panel{width:100%;padding:20px max(18px,env(safe-area-inset-right)) max(18px,env(safe-area-inset-bottom)) max(18px,env(safe-area-inset-left))}
  .menu-panel nav a{grid-template-columns:22px minmax(0,1fr);font-size:clamp(34px,11.4vw,45px);overflow-wrap:anywhere}
  .menu-card,.menu-meta{min-width:0}.menu-meta{flex-wrap:wrap;row-gap:8px}
  .cart-drawer{width:100%;max-width:100%;height:100dvh}
  .footer-main{padding-top:31px;gap:24px}
  .footer-main nav{gap:11px 18px}
  .footer-meta{gap:8px;padding-bottom:calc(76px + env(safe-area-inset-bottom,0px))}
}

@media screen and (max-width:520px){
  .product-card{display:grid;grid-template-columns:1fr;grid-template-rows:190px auto;min-height:0}
  .product-visual{height:190px;min-height:0}
  .product-info{padding:20px}
  .product-bottom{align-items:stretch}
  .contact-lines>a,.contact-lines>div{grid-template-columns:minmax(0,1fr) auto;gap:7px 12px}
  .contact-lines span{grid-column:1/-1}.contact-lines strong{grid-column:1}.contact-lines i{grid-column:2}.contact-lines small{grid-column:1/-1}
  .legal-index nav{grid-template-columns:1fr}
  .site-cta__panel{min-height:0;padding:40px 20px}
}

@media screen and (max-width:380px){
  :root{--shell:calc(100% - 30px)}
  .page-hero__content h1{font-size:46px}
  .page-hero__meta span{padding-inline:14px}
  .page-experience .ritual-step{padding-left:44px!important}
  .page-experience .ritual-step h3{font-size:36px}
  .booking-signal{width:76px}
  .contact-map::before{width:250px;height:250px}.contact-map::after{width:160px;height:160px}
}

/* V7 cinematic entry — identity (2 s), editorial veil (1.5 s), then hero. */
:root{
  --intro-sweep:500ms;
  --veil-sweep:1000ms;
  --ease-cinematic:cubic-bezier(.76,0,.24,1);
}

.intro-curtain,.page-veil{width:100%;height:100%;height:100dvh;overflow:hidden;contain:paint}
.intro-curtain{display:none;transform:translate3d(0,0,0)!important;visibility:visible!important;background:#050606}
.has-brand-intro:not(.is-ready) .intro-curtain{display:grid}
.has-brand-intro.is-ready .intro-curtain{display:none}
.intro-curtain::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.24;
  background:radial-gradient(circle at 50% 42%,rgba(197,164,100,.09),transparent 28rem),repeating-linear-gradient(90deg,transparent 0,transparent calc(12.5% - 1px),rgba(255,255,255,.018) 12.5%);
}
.intro-curtain::after{
  content:"";position:absolute;inset:auto 0 0;height:1px;pointer-events:none;
  background:linear-gradient(90deg,transparent,var(--gold-hi),transparent);opacity:.7;
}
.has-brand-intro .intro-curtain>div{position:relative;z-index:1;opacity:1;transform:none;transition:opacity 320ms ease,transform 420ms var(--ease-premium)}
.has-brand-intro .intro-mark{opacity:0;transform:scale(.86);animation:intro-mark-v7 520ms 90ms var(--ease-premium) forwards}
.has-brand-intro .intro-curtain strong{max-width:calc(100vw - 48px);opacity:0;transform:translateY(13px);animation:intro-copy-v7 620ms 230ms var(--ease-premium) forwards;text-wrap:balance}
.has-brand-intro .intro-curtain i{transform:scaleX(0);transform-origin:center;animation:intro-line-v7 760ms 380ms var(--ease-premium) forwards}
.has-brand-intro .intro-curtain small{opacity:0;transform:translateY(8px);animation:intro-copy-v7 480ms 520ms var(--ease-premium) forwards}
.has-brand-intro.is-intro-stage-two .intro-curtain{transform:translate3d(0,-101%,0)!important;transition:transform var(--intro-sweep) var(--ease-cinematic)!important}
.has-brand-intro.is-intro-stage-two .intro-curtain>div{opacity:0;transform:translateY(-12px)}
@keyframes intro-mark-v7{to{opacity:1;transform:none}}
@keyframes intro-copy-v7{to{opacity:1;transform:none}}
@keyframes intro-line-v7{to{transform:scaleX(1)}}

.page-veil{
  display:grid;place-items:center;opacity:0;transform:translate3d(0,101%,0);visibility:hidden;pointer-events:none;
  background:radial-gradient(circle at 72% 38%,rgba(197,164,100,.1),transparent 27rem),#080909;
  transition:none;
}
.page-veil::before{
  content:"";position:absolute;inset:0;opacity:.55;
  background:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:72px 72px;
}
.page-veil::after{
  content:"";position:absolute;inset:auto 0 0;height:2px;
  background:linear-gradient(90deg,transparent 4%,var(--gold-hi) 48%,transparent 96%);box-shadow:0 -10px 42px rgba(197,164,100,.24);opacity:.9;
}
.has-brand-intro:not(.is-ready) .page-veil,.is-page-arriving:not(.is-ready) .page-veil{
  opacity:1;visibility:visible;transform:translate3d(0,0,0);
}
.page-veil__brand{position:relative;z-index:1;width:min(720px,calc(100% - 48px));display:grid;place-items:center;text-align:center;opacity:0;transform:translateY(18px);transition:opacity 440ms ease,transform 600ms var(--ease-premium)}
.page-veil__brand>span{width:58px;aspect-ratio:1;display:grid;place-items:center;border:1px solid rgba(226,201,140,.46);border-radius:50%;color:var(--gold-hi);font:500 32px/1 "Cormorant Garamond";box-shadow:0 0 45px rgba(197,164,100,.08)}
.page-veil__title{max-width:100%;margin:20px 0 14px;color:var(--ivory);font:500 clamp(42px,7vw,94px)/.86 "Cormorant Garamond";letter-spacing:.08em;text-wrap:balance}
.page-veil__brand i{width:min(180px,42vw);height:1px;background:var(--metal);transform:scaleX(0);transform-origin:center;transition:transform 760ms 120ms var(--ease-premium)}
.page-veil__brand small{margin-top:13px;color:var(--muted);font-size:8px;letter-spacing:.2em;text-transform:uppercase}
.is-intro-stage-two .page-veil__brand,.is-page-leaving .page-veil__brand{opacity:1;transform:none}
.is-intro-stage-two .page-veil__brand i,.is-page-leaving .page-veil__brand i{transform:scaleX(1)}
.has-brand-intro.is-intro-releasing .page-veil,.is-page-arriving.is-intro-releasing .page-veil{
  opacity:1;visibility:visible;transform:translate3d(0,-101%,0);transition:transform var(--veil-sweep) var(--ease-cinematic);
}
.is-intro-releasing .page-veil__brand{opacity:0;transform:translateY(-16px);transition-duration:300ms}

.is-page-leaving .page-veil{opacity:1;visibility:visible;transform:translate3d(0,0,0);transition:transform 560ms var(--ease-cinematic)}
.is-page-leaving .page-veil__brand{transition-delay:100ms}
.has-brand-intro:not(.is-ready) #site-content,.is-page-arriving:not(.is-ready) #site-content{pointer-events:none}
.has-brand-intro:not(.is-ready) body,.is-page-arriving:not(.is-ready) body{overflow:hidden}

/* Hero motion starts only when app.js marks the complete two-stage sequence. */
.js:not(.is-ready) .hero-enter{opacity:0;transform:translate3d(0,24px,0)}
.js.is-ready .hero-enter{opacity:1;transform:none}

@media screen and (max-width:680px){
  .intro-curtain,.page-veil{height:100%;height:100dvh}
  .intro-mark{width:54px;height:54px;font-size:30px}
  .intro-curtain strong{font-size:clamp(34px,11.5vw,48px)!important;line-height:.94!important;letter-spacing:.11em!important}
  .page-veil__brand{width:calc(100% - 40px)}
  .page-veil__brand>span{width:52px;font-size:29px}
  .page-veil__title{font-size:clamp(34px,11.5vw,52px);line-height:.92;letter-spacing:.08em;overflow-wrap:normal}
  .page-veil::before{background-size:48px 48px}
}

@media (prefers-reduced-motion:reduce){
  .intro-curtain,.page-veil{display:none!important}
  .hero-enter{opacity:1!important;transform:none!important;transition:none!important}
}
