/* =========================================================================
   SOLARIUM MANTIQUEIRA — "A casa que coleciona luz"
   Bioma: montanha/serra · hora dourada · esmeralda do azulejo · refúgio-design
   ========================================================================= */
/* ---- Fontes self-hosted (zero render-block externo / anti-CLS) ---- */
@font-face{font-family:"Cormorant Garamond";font-style:normal;font-weight:500;font-display:swap;src:url("/assets/fonts/cormorant-500.woff2") format("woff2")}
@font-face{font-family:"Cormorant Garamond";font-style:normal;font-weight:600;font-display:swap;src:url("/assets/fonts/cormorant-600.woff2") format("woff2")}
@font-face{font-family:"Cormorant Garamond";font-style:normal;font-weight:700;font-display:swap;src:url("/assets/fonts/cormorant-700.woff2") format("woff2")}
@font-face{font-family:"Cormorant Garamond";font-style:italic;font-weight:500;font-display:swap;src:url("/assets/fonts/cormorant-500i.woff2") format("woff2")}
@font-face{font-family:"Cormorant Garamond";font-style:italic;font-weight:600;font-display:swap;src:url("/assets/fonts/cormorant-600i.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:400;font-display:swap;src:url("/assets/fonts/inter-400.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:500;font-display:swap;src:url("/assets/fonts/inter-500.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:600;font-display:swap;src:url("/assets/fonts/inter-600.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:700;font-display:swap;src:url("/assets/fonts/inter-700.woff2") format("woff2")}
/* fallbacks ajustados por métrica (neutralizam o swap → anti-CLS) */
@font-face{font-family:"Cormorant Fallback";src:local("Georgia"),local("Times New Roman");ascent-override:108%;descent-override:28%;line-gap-override:0%;size-adjust:90%}
@font-face{font-family:"Inter Fallback";src:local("Arial");ascent-override:90%;descent-override:22.43%;line-gap-override:0%;size-adjust:107%}
:root{
  --espresso:#15120E;        /* base cinema (preto-café quente) */
  --espresso-2:#1d1813;
  --bone:#F4EDE2;            /* luz editorial */
  --bone-2:#EDE3D3;
  --gold:#E0913B;           /* o sol (acento em fundo escuro) */
  --gold-2:#F2B765;
  --gold-ink:#A6571A;       /* âmbar escuro (acento em fundo claro — passa AA) */
  --emerald:#2F6F63;        /* material assinatura (azulejo vidrado) */
  --emerald-2:#3C8B7C;
  --mist:#9DB1B3;           /* neblina */
  --ink:#231d17;            /* texto sobre bone */
  --ink-soft:#5c5044;
  --line-d:rgba(244,237,226,.14);
  --line-l:rgba(35,29,23,.14);
  --serif:"Cormorant Garamond","Cormorant Fallback",Georgia,"Times New Roman",serif;
  --sans:"Inter","Inter Fallback",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --ease:cubic-bezier(.76,0,.24,1);
  --ease-out:cubic-bezier(.2,.7,.2,1);
  --sig:cubic-bezier(.22,1,.36,1);   /* curva da assinatura (cumeeira/sol) */
  --maxw:1280px;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:#0c0a08;color:var(--bone);
  font-family:var(--sans);font-size:17px;line-height:1.65;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* ====== O DIA VIVO — o sol que percorre o arco do dia (assinatura global) ====== */
.daysky{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden;
  background:radial-gradient(150% 120% at 50% -10%, #241d15 0%, #15110c 50%, #0a0807 100%)}
.daysun{position:absolute;left:0;top:0;width:82vmax;height:82vmax;border-radius:50%;
  will-change:transform,opacity,filter;
  transform:translate(calc(50vw - 41vmax),calc(58vh - 41vmax));
  background:radial-gradient(circle, rgba(255,206,138,.92) 0%, rgba(240,156,70,.52) 20%, rgba(196,98,44,.22) 40%, rgba(120,60,30,.06) 56%, transparent 70%)}
.filmgrain{position:fixed;inset:0;z-index:6000;pointer-events:none;opacity:.05;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='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
/* dark sections ficam transparentes → o céu vivo (sol que viaja) É o fundo delas */
.proof,.divider,.design,.gallery,.book,.foot{background:transparent}
.manifesto,.homes,.exp,.where,.faq{background:rgba(244,237,226,.95)}
.reviews{background:rgba(239,229,213,.95)}

/* ====== PROGRESSIVE ENHANCEMENT (sem JS, nada fica escondido) ====== */
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3{margin:0;font-weight:600;letter-spacing:-.01em}
p{margin:0}
::selection{background:var(--gold);color:var(--espresso)}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip{position:fixed;left:12px;top:-60px;z-index:10001;background:var(--gold);color:var(--espresso);
  padding:10px 16px;border-radius:8px;font-weight:600;transition:top .25s}
.skip:focus{top:12px}

/* ---------- tipografia utilitária ---------- */
.eyebrow{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;font-weight:600;
  color:var(--emerald-2);margin:0 0 1.1rem}
.eyebrow--light{color:var(--gold-2)}
.sec-head{max-width:var(--maxw);margin:0 auto;padding:0 6vw 3rem}
.sec-head--center{text-align:center}
.sec-title{font-family:var(--serif);font-weight:600;line-height:1.0;letter-spacing:-.015em;
  font-size:clamp(2.5rem,6.4vw,5.2rem)}
.sec-title em,.manifesto__big em,.home__name em{font-style:italic;color:var(--gold-ink);font-weight:600}
.hero__title em,.foot__name em,.nav__name em,.intro__word em,
.design .sec-title em,.book .sec-title em,.gallery .sec-title em{font-style:italic;color:var(--gold);font-weight:600}
.sec-title--light{color:var(--bone)}
.sec-lead{max-width:46ch;margin-top:1.2rem;color:var(--ink-soft);font-size:1.08rem}
.book .sec-lead,.arc .sec-lead{color:var(--mist)}

/* ---------- botões ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  background:var(--gold);color:#1a1308;font-weight:600;font-size:.98rem;
  padding:.92em 1.5em;border:1px solid var(--gold);border-radius:100px;
  transition:transform .3s var(--ease-out),background .3s,box-shadow .3s,color .3s;
  letter-spacing:.01em;line-height:1;white-space:nowrap}
.btn:hover{background:var(--gold-2);border-color:var(--gold-2);transform:translateY(-2px);
  box-shadow:0 12px 30px -10px rgba(224,145,59,.6)}
.btn:focus-visible{outline:2px solid var(--gold-2);outline-offset:3px}
.btn--ghost{background:transparent;color:var(--bone);border-color:var(--line-d)}
.btn--ghost:hover{background:rgba(244,237,226,.07);border-color:var(--bone);color:var(--bone);box-shadow:none}
.btn--link{background:transparent;border-color:transparent;color:var(--ink);padding:.92em .4em;
  text-decoration:underline;text-underline-offset:5px;text-decoration-color:var(--line-l)}
.btn--link:hover{background:transparent;color:var(--emerald);transform:none;box-shadow:none;text-decoration-color:var(--emerald)}
.btn--lg{font-size:1.05rem;padding:1.05em 1.9em}
.btn--sm{padding:.7em 1.2em;font-size:.9rem}
.btn--block{width:100%}

/* ---------- progresso + cursor ---------- */
.prog{position:fixed;top:0;left:0;right:0;height:2px;z-index:9000;pointer-events:none}
.prog i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-2));transition:width .1s linear}
.cursor{position:fixed;top:0;left:0;width:34px;height:34px;border:1px solid var(--gold-2);border-radius:50%;
  transform:translate(-50%,-50%);pointer-events:none;z-index:9500;mix-blend-mode:difference;
  transition:width .25s var(--ease-out),height .25s var(--ease-out),opacity .3s;opacity:0;will-change:transform}
.cursor.on{opacity:1}
.cursor.grow{width:64px;height:64px;background:rgba(242,183,101,.12)}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* ---------- INTRO / cortina ---------- */
/* intro 100% CSS-driven (não depende do timing do JS → não atrasa o LCP) */
.intro{position:fixed;inset:0;z-index:10000;background:var(--espresso);
  display:flex;align-items:center;justify-content:center;text-align:center;
  will-change:transform;animation:introLift 1.15s var(--ease) forwards}
@keyframes introLift{0%,52%{transform:translateY(0)}100%{transform:translateY(-101%);visibility:hidden}}
.intro__in{padding:0 8vw}
.intro__ridge{width:min(560px,72vw);height:auto;margin:0 auto .4rem;display:block}
.intro__ridge path{stroke-dasharray:1;stroke-dashoffset:1;animation:draw .6s var(--sig) .05s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.intro__word{font-family:var(--serif);font-size:clamp(2rem,7vw,4rem);font-weight:600;
  font-variant:small-caps;letter-spacing:.06em;color:var(--bone);margin:.2rem 0 .4rem;
  opacity:0;transform:translateY(12px);animation:introWord .5s var(--ease) .15s forwards}
@keyframes introWord{to{opacity:1;transform:none}}
.intro__sub{font-size:.75rem;letter-spacing:.32em;text-transform:uppercase;color:var(--mist);
  opacity:0;animation:introSub .45s ease .32s forwards}
@keyframes introSub{to{opacity:.9}}

/* ---------- HEADER ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:7000;display:flex;align-items:center;
  justify-content:space-between;gap:1rem;padding:1.1rem 6vw;
  transition:background .4s,padding .4s,border-color .4s;border-bottom:1px solid transparent}
.nav.solid{background:rgba(21,18,14,.82);backdrop-filter:blur(14px);border-bottom-color:var(--line-d);padding:.7rem 6vw}
.nav__brand{display:flex;align-items:center;gap:.6rem}
.nav__mark{width:38px;height:auto;color:var(--gold-2);flex:none}
.nav__name{font-family:var(--serif);font-size:1.3rem;font-weight:600;font-variant:small-caps;letter-spacing:.05em;color:var(--bone)}
.nav__links{display:flex;gap:1.8rem}
.nav__links a{font-size:.86rem;letter-spacing:.04em;color:var(--bone);opacity:.8;position:relative;padding:.3rem 0}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold-2);transition:width .3s var(--ease-out)}
.nav__links a:hover{opacity:1}.nav__links a:hover::after{width:100%}
@media (max-width:880px){.nav__links{display:none}}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  overflow:hidden;background:var(--espresso);isolation:isolate}
.hero__media{position:absolute;inset:0;z-index:-3}
.hero__img{width:100%;height:100%;object-fit:cover;object-position:center 42%;
  animation:ken 30s var(--ease-out) infinite alternate;will-change:transform}
@keyframes ken{from{transform:scale(1.04)}to{transform:scale(1.16)}}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 48%;
  opacity:0;transition:opacity 1.4s ease;will-change:opacity}
.hero__video.on{opacity:1}
.hero__sun{position:absolute;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(60% 50% at 50% 78%,rgba(242,183,101,.42),rgba(224,145,59,.12) 38%,transparent 66%);
  mix-blend-mode:screen;opacity:.9;will-change:transform,opacity}
.hero__veil{position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,rgba(21,18,14,.55) 0%,rgba(21,18,14,.05) 32%,rgba(21,18,14,.35) 64%,rgba(21,18,14,.92) 100%)}
.hero__grain{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto;
  padding:0 6vw 12vh}
.hero__title{font-family:var(--serif);font-weight:600;
  font-size:clamp(3rem,11.5vw,9.5rem);line-height:.92;letter-spacing:-.02em;
  margin:.4rem 0 1.4rem;text-shadow:0 2px 40px rgba(21,18,14,.5)}
.ln{display:block;overflow:hidden}
.ln>span{display:block;transform:translateY(112%);will-change:transform;
  animation:lnUp 1.05s var(--ease) .2s both}
.ln:nth-child(2)>span{animation-delay:.29s}
.ln:nth-child(3)>span{animation-delay:.38s}
@keyframes lnUp{to{transform:translateY(0)}}
/* entrada do conteúdo do hero via CSS (independe do JS → LCP estável) */
.hero .reveal{animation:heroIn .9s var(--ease-out) both}
.hero .eyebrow{animation-delay:.1s}
.hero__sub{animation-delay:.5s}
.hero__cta{animation-delay:.66s}
@keyframes heroIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.hero__sub{max-width:50ch;font-size:1.12rem;color:rgba(244,237,226,.94);margin-bottom:2rem;text-shadow:0 1px 20px rgba(21,18,14,.55)}
.hero .eyebrow--light{text-shadow:0 1px 16px rgba(21,18,14,.6)}
.hero__cta{display:flex;gap:.9rem;flex-wrap:wrap}
.hero__cue{position:absolute;left:50%;bottom:2.4rem;z-index:3;transform:translateX(-50%);
  width:26px;height:42px;border:1px solid rgba(244,237,226,.5);border-radius:14px;display:grid;place-items:start center}
.hero__cue span{width:3px;height:8px;margin-top:7px;border-radius:3px;background:var(--gold-2);animation:cue 1.8s var(--ease-out) infinite}
@keyframes cue{0%{opacity:0;transform:translateY(0)}30%{opacity:1}80%{opacity:0;transform:translateY(13px)}100%{opacity:0}}

/* reveal genérico */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:none}

/* ---------- PROVA / marquee ---------- */
.proof{background:var(--espresso-2);border-top:1px solid var(--line-d);border-bottom:1px solid var(--line-d);
  padding:1.4rem 0;overflow:hidden}
.marquee{display:flex;width:100%;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__t{display:flex;gap:1.4rem;align-items:center;white-space:nowrap;flex:none;
  animation:scroll 34s linear infinite;font-family:var(--serif);font-size:1.5rem;color:var(--bone)}
.marquee__t .dot{color:var(--gold);opacity:.7}
.marquee__t span{opacity:.92}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- MANIFESTO ---------- */
.manifesto{background:var(--bone);color:var(--ink);padding:clamp(5rem,12vw,9rem) 6vw}
.manifesto .eyebrow{color:var(--emerald)}
.manifesto__big{max-width:18ch;margin:0;font-family:var(--serif);font-weight:500;
  font-size:clamp(2rem,5.4vw,4.2rem);line-height:1.12;letter-spacing:-.01em}
.manifesto__big .w{display:inline-block;opacity:.16;transition:opacity .5s var(--ease-out)}
.manifesto__big .w.lit{opacity:1}
.manifesto__big em{font-style:italic;color:var(--gold)}

/* ---------- ARC (capítulo pinned) ---------- */
.arc{height:400vh;position:relative;background:var(--espresso)}
.arc__pin{position:sticky;top:0;height:100svh;overflow:hidden}
.arc__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;will-change:opacity}
.arc__img[data-i="0"]{opacity:1}
.arc__veil{position:absolute;inset:0;background:linear-gradient(90deg,rgba(21,18,14,.75),rgba(21,18,14,.15) 55%,transparent);z-index:1}
.arc__caps{position:absolute;left:6vw;bottom:12vh;z-index:2;max-width:34ch;min-height:clamp(150px,24vh,250px)}
.arc__cap{position:absolute;left:0;bottom:0;font-family:var(--serif);font-weight:500;
  font-size:clamp(1.8rem,4.6vw,3.4rem);line-height:1.05;color:var(--bone);opacity:0;will-change:transform,opacity}
.arc__cap[data-i="0"]{opacity:1}
.arc__h{display:block;font-family:var(--sans);font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-2);margin-bottom:.7rem;font-weight:600}
.arc__bar{position:absolute;left:6vw;right:6vw;bottom:7vh;height:2px;background:var(--line-d);z-index:2}
.arc__bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-2))}

/* ---------- DIVISOR ASSINATURA ---------- */
.divider{background:var(--espresso);padding:2.5rem 6vw;color:var(--emerald-2)}
.divider svg{width:100%;height:54px;display:block;opacity:.5}
.divider__path{stroke-dasharray:1;stroke-dashoffset:1}
.divider.in .divider__path{animation:draw 1.6s var(--sig) forwards}

/* ---------- HOMES ---------- */
.homes{background:var(--bone);color:var(--ink);padding:clamp(4.5rem,10vw,8rem) 0 clamp(3rem,6vw,5rem)}
.home{max-width:var(--maxw);margin:0 auto clamp(3.5rem,7vw,6rem);padding:0 6vw;
  display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.home--rev{direction:rtl}.home--rev>*{direction:ltr}
.home__media{overflow:hidden;border-radius:4px;clip-path:inset(0 0 100% 0);transition:clip-path 1.1s var(--ease)}
.home.in .home__media{clip-path:inset(0)}
.home__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;transition:transform 1.2s var(--ease-out)}
.home:hover .home__media img{transform:scale(1.05)}
.home__tag{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--emerald);font-weight:600;margin-bottom:.8rem}
.home__name{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.8rem);font-weight:600;line-height:1;margin-bottom:1rem}
.home__desc{color:var(--ink-soft);font-size:1.06rem;margin-bottom:1.4rem;max-width:44ch}
.home__feat{list-style:none;padding:0;margin:0 0 1.8rem;display:grid;gap:.6rem}
.home__feat li{position:relative;padding-left:1.5rem;color:var(--ink);font-size:.98rem}
.home__feat li::before{content:"";position:absolute;left:0;top:.62em;width:8px;height:8px;border-radius:50%;
  background:var(--emerald-2)}
.home__foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  border-top:1px solid var(--line-l);padding-top:1.4rem}
.price{display:flex;align-items:baseline;gap:.4rem;color:var(--ink-soft);font-size:.85rem}
.price strong{font-family:var(--serif);font-size:1.9rem;color:var(--ink);font-weight:600}
.home__cta{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}

/* ---------- DESIGN ---------- */
.design{background:var(--espresso);color:var(--bone);padding:clamp(5rem,11vw,8rem) 0}
.design .sec-lead{color:var(--mist)}
.grid--design{max-width:var(--maxw);margin:0 auto;padding:0 6vw;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-d);
  border:1px solid var(--line-d)}
.feat{background:var(--espresso);padding:2.2rem}
.feat--wide{grid-column:span 3;display:grid;grid-template-columns:1.3fr 1fr;gap:0;padding:0;overflow:hidden}
.feat--wide .feat__media{overflow:hidden}
.feat--wide .feat__media img{width:100%;height:100%;object-fit:cover;min-height:300px;transition:transform 1.2s var(--ease-out)}
.feat--wide:hover .feat__media img{transform:scale(1.05)}
.feat--wide .feat__txt{padding:2.6rem;align-self:center}
.feat__icon{width:46px;height:46px;color:var(--gold-2);margin-bottom:1.2rem}
.feat__icon svg{width:100%;height:100%}
.feat h3{font-family:var(--serif);font-size:1.6rem;font-weight:600;margin-bottom:.6rem}
.feat--wide .feat__txt h3{font-size:2rem}
.feat p{color:var(--mist);font-size:1rem}

/* ---------- EXPERIÊNCIAS ---------- */
.exp{background:var(--bone);color:var(--ink);padding:clamp(5rem,11vw,8rem) 0}
.exp__track{display:flex;gap:1.4rem;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:0 6vw 1.5rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.exp__track::-webkit-scrollbar{height:6px}
.exp__track::-webkit-scrollbar-thumb{background:var(--line-l);border-radius:3px}
.card{flex:0 0 clamp(260px,30vw,360px);scroll-snap-align:start}
.card__media{overflow:hidden;border-radius:4px;margin-bottom:1.1rem;aspect-ratio:4/3}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease-out)}
.card:hover .card__media img{transform:scale(1.06)}
.card h3{font-family:var(--serif);font-size:1.55rem;font-weight:600;margin-bottom:.4rem}
.card p{color:var(--ink-soft);font-size:.98rem}

/* ---------- REVIEWS ---------- */
.reviews{background:#efe5d5;color:var(--ink);padding:clamp(5rem,11vw,8rem) 0}
.bigquote{max-width:1040px;margin:0 auto;padding:0 6vw;text-align:center;position:relative}
.bigquote__mark{display:block;font-family:var(--serif);font-size:clamp(5rem,12vw,9rem);line-height:.5;
  color:var(--gold-ink);opacity:.32;height:.5em;margin-bottom:.2em}
.bigquote__q{margin:0;font-family:var(--serif);font-weight:500;font-style:italic;
  font-size:clamp(1.9rem,5vw,3.6rem);line-height:1.16;letter-spacing:-.01em;color:var(--ink);
  min-height:2.5em;transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}
.bigquote.swap .bigquote__q{opacity:0;transform:translateY(10px)}
.bigquote__who{display:block;margin-top:1.6rem;font-size:.92rem;letter-spacing:.04em;color:var(--ink-soft);
  transition:opacity .5s}
.bigquote.swap .bigquote__who{opacity:0}
.bigquote__stars{color:var(--gold-ink);letter-spacing:.1em;margin-right:.4rem}
.reviews__rail{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1.3rem;
  max-width:760px;margin:2.6rem auto 0;padding:0 6vw}
.reviews__rail li{font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:#6a5f50;
  transition:color .4s,opacity .4s;cursor:default}
.reviews__rail li.on{color:#8a4612;font-weight:600}
.reviews__note{text-align:center;color:var(--ink-soft);font-size:.82rem;margin-top:2.4rem;font-style:italic;padding:0 6vw}

/* ---------- GALERIA ---------- */
.gallery{background:var(--espresso);color:var(--bone);padding:clamp(5rem,11vw,8rem) 0}
.gallery__track{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:0 6vw 1.5rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.gallery__track::-webkit-scrollbar{height:6px}
.gallery__track::-webkit-scrollbar-thumb{background:var(--line-d);border-radius:3px}
.shot{flex:0 0 auto;height:clamp(280px,42vh,460px);padding:0;border:0;background:none;overflow:hidden;
  border-radius:4px;scroll-snap-align:center}
.shot img{height:100%;width:auto;object-fit:cover;transition:transform 1s var(--ease-out),filter .5s;filter:saturate(.96)}
.shot:hover img{transform:scale(1.05);filter:saturate(1.05)}
.shot:focus-visible{outline:2px solid var(--gold-2);outline-offset:3px}

/* ---------- ONDE ESTAMOS ---------- */
.where{background:var(--bone);color:var(--ink);padding:clamp(5rem,11vw,8rem) 6vw}
.where__in{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.times{list-style:none;padding:0;margin:2rem 0 0;display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.times li{border-top:1px solid var(--line-l);padding-top:1rem}
.times strong{display:block;font-family:var(--serif);font-size:2.2rem;font-weight:600;color:var(--ink);line-height:1}
.times span{font-size:.9rem;color:var(--ink-soft)}
.where__map{border-radius:6px;overflow:hidden;border:1px solid var(--line-l);aspect-ratio:4/3;min-height:300px}
.where__map iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.85) contrast(.97)}

/* ---------- RESERVAR ---------- */
.book{background:var(--espresso);color:var(--bone);padding:clamp(5rem,11vw,8rem) 6vw;position:relative;isolation:isolate}
.book::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(70% 60% at 18% 22%,rgba(47,111,99,.22),transparent 60%),
             radial-gradient(60% 60% at 90% 90%,rgba(224,145,59,.16),transparent 60%)}
.book__in{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.book__why{list-style:none;padding:0;margin:1.8rem 0 0;display:grid;gap:.9rem}
.book__why li{position:relative;padding-left:1.8rem;color:var(--bone);font-size:1.02rem}
.book__why li::before{content:"";position:absolute;left:0;top:.5em;width:11px;height:11px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,var(--gold-2),var(--gold))}
.book__form{background:rgba(244,237,226,.04);border:1px solid var(--line-d);border-radius:12px;
  padding:clamp(1.6rem,3vw,2.4rem);display:grid;gap:1rem;backdrop-filter:blur(6px)}
.field{display:grid;gap:.4rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field label{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mist);font-weight:600}
.field input,.field select{font-family:inherit;font-size:16px;color:var(--bone);background:rgba(21,18,14,.6);
  border:1px solid var(--line-d);border-radius:8px;padding:.85em 1em;width:100%;
  -webkit-appearance:none;appearance:none}
.field input::-webkit-calendar-picker-indicator{filter:invert(.8) sepia(1) saturate(3) hue-rotate(2deg)}
.field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' stroke='%23F2B765' stroke-width='2'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1em center;padding-right:2.4em}
.field input:focus,.field select:focus{outline:none;border-color:var(--gold-2);background:rgba(21,18,14,.85)}
.book__fine{font-size:.82rem;color:var(--mist);text-align:center;margin-top:.2rem}

/* ---------- FAQ ---------- */
.faq{background:var(--bone);color:var(--ink);padding:clamp(5rem,11vw,8rem) 0}
.faq__list{max-width:780px;margin:0 auto;padding:0 6vw}
.qa{border-bottom:1px solid var(--line-l)}
.qa summary{list-style:none;cursor:pointer;padding:1.4rem 0;font-family:var(--serif);font-size:1.4rem;
  font-weight:600;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";color:var(--gold);font-family:var(--sans);font-weight:400;font-size:1.6rem;transition:transform .3s}
.qa[open] summary::after{transform:rotate(45deg)}
.qa>div{padding:0 0 1.4rem;color:var(--ink-soft);font-size:1.02rem;max-width:64ch}

/* ---------- RODAPÉ ---------- */
.foot{background:var(--espresso);color:var(--bone);padding:clamp(4rem,8vw,6rem) 6vw 2rem;position:relative;overflow:hidden}
.foot__top{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;position:relative;z-index:2}
.foot__name{font-family:var(--serif);font-size:clamp(2.2rem,6vw,3.4rem);font-weight:600;font-variant:small-caps;letter-spacing:.04em}
.foot__addr{color:var(--mist);margin-top:.5rem;font-size:.95rem}
.foot__nav{display:flex;gap:1.6rem;flex-wrap:wrap;align-items:center}
.foot__nav a{font-size:.9rem;opacity:.85;position:relative}
.foot__nav a:hover{opacity:1;color:var(--gold-2)}
.foot__ridge{position:absolute;left:0;right:0;bottom:38px;width:100%;height:120px;color:var(--emerald);opacity:.28;z-index:0}
.foot__bot{max-width:var(--maxw);margin:3.5rem auto 0;padding-top:1.4rem;border-top:1px solid var(--line-d);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.8rem;color:var(--mist);position:relative;z-index:2}
.foot__credit a{color:var(--gold-2)}

/* ---------- BOOKBAR (mobile) ---------- */
.bookbar{position:fixed;left:0;right:0;bottom:0;z-index:6500;display:flex;align-items:center;justify-content:space-between;
  gap:.8rem;padding:.7rem 1rem;padding-bottom:calc(.7rem + env(safe-area-inset-bottom));
  background:rgba(21,18,14,.92);backdrop-filter:blur(12px);border-top:1px solid var(--line-d);
  transform:translateY(120%);transition:transform .4s var(--ease-out)}
.bookbar.show{transform:translateY(0)}
.bookbar__txt{font-family:var(--serif);font-size:1.05rem;color:var(--bone)}
@media (min-width:881px){.bookbar{display:none}}

/* ---------- LIGHTBOX ---------- */
.lb{position:fixed;inset:0;z-index:11000;background:rgba(10,8,6,.96);display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .35s}
.lb.open{opacity:1}
.lb[hidden]{display:none}
.lb__img{max-width:92vw;max-height:86vh;object-fit:contain;border-radius:4px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8)}
.lb__close{position:absolute;top:1.2rem;right:1.4rem;width:48px;height:48px;border-radius:50%;border:1px solid var(--line-d);
  background:rgba(244,237,226,.06);color:var(--bone);font-size:1.2rem}
.lb__nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;
  border:1px solid var(--line-d);background:rgba(244,237,226,.06);color:var(--bone);font-size:2rem;line-height:1}
.lb__prev{left:1.4rem}.lb__next{right:1.4rem}
.lb__close:hover,.lb__nav:hover{background:rgba(242,183,101,.18);border-color:var(--gold-2)}
.lb button:focus-visible{outline:2px solid var(--gold-2);outline-offset:2px}

/* ---------- RESPONSIVO ---------- */
@media (max-width:880px){
  body{font-size:16px}
  .home,.where__in,.book__in,.feat--wide{grid-template-columns:1fr}
  .home--rev{direction:ltr}
  .home__media{clip-path:none}
  .grid--design{grid-template-columns:1fr 1fr}
  .feat--wide{grid-column:span 2}
  .feat--wide .feat__media{min-height:240px}
  .reviews__grid{grid-template-columns:1fr}
  .nav{padding:.9rem 6vw}
  .hero__inner{padding-bottom:15vh}
  .arc__caps{max-width:80vw}
}
@media (max-width:560px){
  .grid--design{grid-template-columns:1fr}
  .feat--wide{grid-column:span 1}
  .times{grid-template-columns:1fr 1fr}
  .home__foot{flex-direction:column;align-items:flex-start}
  .foot__ridge{bottom:54px}
}

/* ---------- PROGRESSIVE ENHANCEMENT (sem JS, nada fica escondido) ---------- */
html:not(.js) .intro{display:none}
html:not(.js) .ln>span{transform:none}
html:not(.js) .reveal{opacity:1;transform:none}
html:not(.js) .home__media{clip-path:none}
html:not(.js) .manifesto__big .w{opacity:1}
html:not(.js) .divider__path{stroke-dashoffset:0}
html:not(.js) .cursor{display:none}
html:not(.js) .arc{height:auto}
html:not(.js) .arc__pin{position:static;height:auto}
html:not(.js) .arc__img{position:relative;opacity:1!important;height:auto;aspect-ratio:16/9;margin-bottom:1px}
html:not(.js) .arc__veil{display:none}
html:not(.js) .arc__caps{position:relative;left:auto;bottom:auto;margin:1.5rem 6vw;max-width:none}
html:not(.js) .arc__cap{position:relative;opacity:1!important;transform:none!important;margin-bottom:1rem}
html:not(.js) .arc__bar{display:none}

/* ---------- REDUCED MOTION: desliga TUDO ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .intro{display:none}
  .hero__img{animation:none;transform:none}
  .hero__sun{animation:none}
  .ln>span{transform:none}
  .reveal{opacity:1;transform:none}
  .home__media{clip-path:none}
  .marquee__t{animation:none;transform:none}
  .marquee{-webkit-mask-image:none;mask-image:none;overflow-x:auto}
  .manifesto__big .w{opacity:1}
  .arc{height:auto}
  .arc__pin{position:static;height:auto}
  .arc__img{position:relative;opacity:1!important;height:auto;aspect-ratio:16/9;margin-bottom:1px}
  .arc__veil{display:none}
  .arc__caps{position:relative;left:auto;bottom:auto;margin:1.5rem 6vw;max-width:none}
  .arc__cap{position:relative;opacity:1!important;transform:none!important;margin-bottom:1rem}
  .arc__bar{display:none}
  .divider__path{stroke-dashoffset:0}
  .intro__ridge path{stroke-dashoffset:0}
  .cursor{display:none}
  .hero__cue span{animation:none}
}
