/* ============================================================
   RANCHO TABUÕES — Cachoeira do Campo · Ouro Preto/MG
   Design & code: GMX Digital — v4.0 "Cut Final"
   ============================================================ */

/* ---------- fonts (self-hosted) ---------- */
@font-face{font-family:'Cormorant Garamond';src:url('../fonts/cormorant-garamond-latin-300-normal.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Cormorant Garamond';src:url('../fonts/cormorant-garamond-latin-400-normal.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Cormorant Garamond';src:url('../fonts/cormorant-garamond-latin-500-normal.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Cormorant Garamond';src:url('../fonts/cormorant-garamond-latin-300-italic.woff2') format('woff2');font-weight:300;font-style:italic;font-display:swap}
@font-face{font-family:'Cormorant Garamond';src:url('../fonts/cormorant-garamond-latin-400-italic.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Archivo';src:url('../fonts/archivo-latin-300-normal.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Archivo';src:url('../fonts/archivo-latin-400-normal.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Archivo';src:url('../fonts/archivo-latin-500-normal.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'IBM Plex Mono';src:url('../fonts/ibm-plex-mono-latin-400-normal.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'IBM Plex Mono';src:url('../fonts/ibm-plex-mono-latin-500-normal.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}

/* ---------- tokens ---------- */
:root{
  --ink:#04080A;
  --onyx:#04080A;
  --pine:#07231C;
  --pine-2:#0B3328;
  --emerald:#12BE7F;
  --emerald-deep:#0E4D3A;
  --moss:#3E6B54;
  --sage:#8FB3A0;
  --cream:#F5EFE0;
  --cream-2:#EDE4CE;
  --gold:#DCA84E;
  --gold-soft:#F0CB82;
  --bronze:#A87A32;
  --line:rgba(245,239,224,.16);
  --line-dark:rgba(4,8,10,.15);
  --f-display:'Cormorant Garamond',Georgia,serif;
  --f-body:'Archivo','Helvetica Neue',Arial,sans-serif;
  --f-mono:'IBM Plex Mono','SF Mono',monospace;
  --ease:cubic-bezier(.19,1,.22,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scrollbar-width:thin;scrollbar-color:var(--moss) var(--ink)}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
body{background:var(--onyx);--bg-base:#04080A;color:var(--cream);font-family:var(--f-body);font-weight:300;overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.65;font-size:16px}
/* A1 · fundo fixo que "respira" entre as seções escuras (--bg-base morfada via GSAP) */
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:
  radial-gradient(ellipse 90% 60% at 85% -10%, rgba(14,77,58,.4), transparent 60%),
  radial-gradient(ellipse 70% 50% at 0% 100%, rgba(11,51,40,.35), transparent 60%),
  var(--bg-base)}
::selection{background:var(--gold);color:var(--ink)}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--ink)}::-webkit-scrollbar-thumb{background:var(--moss);border-radius:3px}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}

/* ---------- utilities ---------- */
.wrap{width:min(1560px,92vw);margin:0 auto}
.mono{font-family:var(--f-mono);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;font-weight:400}
.eyebrow{font-family:var(--f-mono);font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:14px}
.eyebrow::before{content:"";width:38px;height:1px;background:var(--gold)}
.eyebrow.center{justify-content:center}
.on-cream .eyebrow{color:var(--bronze)}
.on-cream .eyebrow::before{background:var(--bronze)}
.d-title{font-family:var(--f-display);font-weight:400;line-height:1;letter-spacing:-.005em}
.d-title em{font-style:italic;font-weight:300;color:var(--gold-soft)}
.on-cream .d-title em{color:var(--bronze)}
.lead{font-size:1.02rem;line-height:1.9;color:rgba(245,239,224,.86);max-width:52ch}
.on-cream .lead{color:rgba(12,16,11,.7)}
section{position:relative}
.grain{position:fixed;inset:-100%;width:300%;height:300%;pointer-events:none;z-index:2000;opacity:.02;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 250 250' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.1' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");animation:grain 8s steps(10) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}10%{transform:translate(-5%,-8%)}30%{transform:translate(3%,-5%)}50%{transform:translate(-8%,3%)}70%{transform:translate(6%,6%)}90%{transform:translate(-3%,8%)}}

/* ---------- cursor ---------- */
.cursor{position:fixed;top:0;left:0;width:10px;height:10px;border-radius:50%;background:var(--gold);pointer-events:none;z-index:3000;mix-blend-mode:difference}
.cursor-ring{position:fixed;top:-100px;left:-100px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(201,154,75,.5);pointer-events:none;z-index:2999;transition:width .35s var(--ease),height .35s var(--ease),border-color .35s}
.cursor-ring.is-active{width:82px;height:82px;border-color:var(--gold)}
.cursor-ring .cursor-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-size:.55rem;letter-spacing:.2em;color:var(--gold);opacity:0;transition:opacity .3s}
.cursor-ring.is-active .cursor-label{opacity:1}
@media(hover:none){.cursor,.cursor-ring{display:none}}

/* ---------- preloader ---------- */
#loader{position:fixed;inset:0;z-index:5000;background:var(--cream);color:var(--ink);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:26px}
#loader .l-mark{width:104px;height:104px;border-radius:50%;overflow:hidden;box-shadow:0 20px 60px rgba(12,16,11,.16)}
#loader .l-mark img{width:100%;height:100%;object-fit:cover;transform:scale(1.05)}
#loader .l-word{font-family:var(--f-display);font-size:clamp(1.6rem,3.4vw,2.5rem);letter-spacing:.15em;font-weight:500}
#loader .l-sub{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.34em;color:var(--moss);text-transform:uppercase}
#loader .l-count{position:absolute;bottom:5vh;right:6vw;font-family:var(--f-display);font-size:clamp(4rem,9vw,7rem);font-weight:300;font-style:italic;line-height:1}
#loader .l-bar{position:absolute;bottom:4.5vh;left:6vw;width:min(300px,40vw);height:1px;background:rgba(12,16,11,.15)}
#loader .l-bar i{display:block;height:100%;width:0%;background:var(--ink)}
#curtain{position:fixed;inset:0;z-index:4999;background:var(--pine);transform-origin:top;pointer-events:none}

/* ---------- header ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:900;padding:22px 4vw;display:flex;align-items:center;justify-content:space-between;transition:transform .6s var(--ease),background .5s,padding .5s}
header.is-scrolled{background:linear-gradient(rgba(12,16,11,.86),rgba(12,16,11,0) 170%);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:14px 4vw}
header.is-hidden{transform:translateY(-110%)}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:40px;height:40px;border-radius:50%;overflow:hidden;border:1px solid var(--line);flex-shrink:0}
.brand-mark img{width:100%;height:100%;object-fit:cover;transform:scale(1.08)}
.brand-name{font-family:var(--f-display);font-size:1.12rem;letter-spacing:.16em;font-weight:500;text-transform:uppercase;white-space:nowrap}
.brand-name span{display:block;font-family:var(--f-mono);font-size:.5rem;letter-spacing:.3em;color:var(--sage);margin-top:2px}
nav{display:flex;gap:32px;align-items:center}
nav a.nav-link{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream);opacity:.72;position:relative;padding:6px 0;transition:opacity .3s;white-space:nowrap}
nav a.nav-link::before{content:attr(data-txt);position:absolute;left:0;top:0;padding:6px 0;color:var(--gold);clip-path:inset(0 100% 0 0);transition:clip-path .35s var(--ease);white-space:nowrap}
nav a.nav-link:hover{opacity:1}nav a.nav-link:hover::before{clip-path:inset(0 0 0 0)}
.btn{position:relative;display:inline-flex;align-items:center;gap:12px;border:1px solid var(--gold);color:var(--cream);background:transparent;padding:14px 28px;border-radius:100px;font-family:var(--f-mono);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;overflow:hidden;transition:color .45s var(--ease)}
.btn i{width:6px;height:6px;border-radius:50%;background:var(--gold);transition:background .45s;flex-shrink:0}
.btn::before{content:"";position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .55s var(--ease);z-index:-1;border-radius:100px}
.btn:hover{color:var(--ink)}.btn:hover::before{transform:scaleX(1);transform-origin:left}.btn:hover i{background:var(--ink)}
.btn.solid{background:var(--gold);color:var(--ink)}
.btn.solid i{background:var(--ink)}
.btn.solid::before{background:var(--cream)}
.btn.ghost{border-color:rgba(245,239,224,.35)}
.progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:950;pointer-events:none}
.progress i{display:block;height:100%;background:linear-gradient(90deg,var(--emerald),var(--gold),var(--gold-soft));transform:scaleX(0);transform-origin:left;box-shadow:0 0 12px rgba(18,190,127,.5)}
@media(max-width:1080px){nav .nav-link{display:none}}

/* ---------- hero ---------- */
#hero{height:100svh;min-height:660px;position:relative;overflow:hidden;display:flex;align-items:flex-end}
.hero-media{position:absolute;inset:0}
#hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.08)}
#hero-gl{position:absolute;inset:0;width:100%!important;height:100%!important;opacity:0;transition:opacity 1.4s ease}
#hero .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(4,8,10,.52) 0%,rgba(4,8,10,.02) 30%,rgba(4,8,10,.08) 58%,rgba(4,8,10,.94) 100%);pointer-events:none}
#hero-dust{position:absolute;inset:0;width:100%;height:100%;z-index:4;pointer-events:none;mix-blend-mode:screen}
.hero-inner{position:relative;z-index:5;width:100%;padding:0 4vw 8.5vh}
.hero-eyebrow{margin-bottom:3vh}
.hero-title{font-family:var(--f-display);font-weight:400;line-height:.86;text-transform:uppercase;font-size:clamp(4.6rem,15vw,16.5rem);letter-spacing:.005em}
.hero-title .row{display:block;overflow:hidden;padding-bottom:.04em}
.hero-title .row:nth-child(2){text-align:right;font-style:italic;font-weight:300}
.hero-title .row:nth-child(2) .hchar{color:transparent;-webkit-text-stroke:1.2px rgba(245,239,224,.92)}
.hero-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-top:4vh;flex-wrap:wrap}
.hero-foot .hf-copy{max-width:470px;font-size:1.02rem;color:rgba(245,239,224,.88);line-height:1.8}
.hero-foot .hf-copy strong{font-weight:500;color:var(--gold-soft)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:8.5vh;left:50%;transform:translateX(-50%);z-index:6;display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--f-mono);font-size:.55rem;letter-spacing:.3em;color:rgba(245,239,224,.7);text-transform:uppercase}
.scroll-cue i{width:1px;height:52px;background:linear-gradient(var(--gold),transparent);animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media(max-width:900px){.scroll-cue{display:none}.hero-title{font-size:clamp(4rem,17.5vw,8rem)}}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;overflow:hidden;background:var(--ink);position:relative;z-index:6}
.marquee .track{display:flex;width:max-content;will-change:transform}
.marquee .mi{display:flex;align-items:center;gap:26px;padding:0 26px;font-family:var(--f-display);font-size:1.3rem;font-style:italic;letter-spacing:.08em;color:rgba(245,239,224,.72);white-space:nowrap;text-transform:uppercase}
.marquee .mi::after{content:"✦";font-size:.68rem;color:var(--gold);font-style:normal}

/* ---------- filme ---------- */
#filme{background:
  radial-gradient(ellipse 60% 55% at 50% 42%, rgba(18,190,127,.10), transparent 65%),
  radial-gradient(ellipse 45% 40% at 50% 46%, rgba(220,168,78,.10), transparent 60%),
  linear-gradient(178deg,#04080A 0%,#07231C 42%,#0B3328 78%,#062018 100%);
  padding:15vh 0;overflow:hidden}
#filme::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 34% 42% at 50% 46%,rgba(240,203,130,.13),transparent 70%);filter:blur(10px)}
.fl-head{text-align:center;margin-bottom:8vh;position:relative;z-index:2}
.fl-head .d-title{font-size:clamp(2.8rem,6.4vw,6.4rem);margin-top:20px}
.fl-head p{margin:3vh auto 0;max-width:520px;color:rgba(245,239,224,.72);font-size:.98rem;line-height:1.85}
.fl-stage{display:grid;grid-template-columns:1fr auto 1fr;gap:5vw;align-items:center;position:relative;z-index:2}
.fl-device{position:relative;width:min(400px,84vw);aspect-ratio:9/16;border-radius:22px;overflow:hidden;background:#000;box-shadow:0 70px 150px -40px rgba(0,0,0,.9),0 0 0 1px rgba(240,203,130,.4),0 0 110px -24px rgba(220,168,78,.45),0 0 200px -50px rgba(18,190,127,.35);justify-self:center}
.fl-device video{width:100%;height:100%;object-fit:cover}
.fl-device .fl-ui{position:absolute;left:0;right:0;bottom:0;padding:18px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(transparent,rgba(0,0,0,.72));opacity:1;transition:opacity .4s}
.fl-ctrl{width:46px;height:46px;border-radius:50%;border:1px solid rgba(245,239,224,.5);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);background:rgba(12,16,11,.35);transition:all .35s;flex-shrink:0}
.fl-ctrl:hover{border-color:var(--gold);background:rgba(201,154,75,.22)}
.fl-ctrl svg{width:17px;height:17px;fill:var(--cream)}
.fl-bar{flex:1;height:2px;background:rgba(245,239,224,.22);border-radius:2px;position:relative;cursor:pointer}
.fl-bar i{position:absolute;inset:0;width:0%;background:var(--gold);border-radius:2px}
.fl-caps{display:flex;flex-direction:column;gap:0}
.fl-caps.right{text-align:right;align-items:flex-end}
.fl-cap{border-top:1px solid var(--line);padding:22px 0;cursor:pointer;transition:padding .45s var(--ease);max-width:330px}
.fl-caps .fl-cap:last-child{border-bottom:1px solid var(--line)}
.fl-cap .t{font-family:var(--f-mono);font-size:.56rem;letter-spacing:.24em;color:var(--sage);text-transform:uppercase;display:block;margin-bottom:8px;transition:color .35s}
.fl-cap h4{font-family:var(--f-display);font-size:1.55rem;font-weight:500;letter-spacing:.02em;transition:color .35s}
.fl-cap p{font-size:.85rem;color:rgba(245,239,224,.68);margin-top:7px;line-height:1.7}
.fl-cap:hover h4,.fl-cap.is-live h4{color:var(--gold-soft)}
.fl-cap.is-live .t{color:var(--gold)}
.fl-note{text-align:center;margin-top:6vh;font-family:var(--f-mono);font-size:.56rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(245,239,224,.4);position:relative;z-index:2}
@media(max-width:1080px){.fl-stage{grid-template-columns:1fr}.fl-caps,.fl-caps.right{flex-direction:row;flex-wrap:wrap;gap:0 26px;justify-content:center;text-align:left;align-items:stretch}.fl-cap{border:none!important;max-width:240px}}

/* ---------- manifesto ---------- */
#manifesto{background:var(--cream);color:var(--ink);padding:18vh 0 14vh;overflow:hidden}
#manifesto .topo{position:absolute;right:-6vw;top:7vh;width:46vw;opacity:.5;pointer-events:none}
.mani-text{font-family:var(--f-display);font-weight:400;font-size:clamp(2rem,4.7vw,4.6rem);line-height:1.15;max-width:21ch}
.mani-text .ln{display:block;overflow:hidden;padding-bottom:.06em}
.mani-text .ln>span{display:block}
.mani-text em{font-style:italic;color:var(--bronze)}
.mani-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:4vw;margin-top:9vh}
.mani-col{border-top:1px solid var(--line-dark);padding-top:26px}
.mani-col h5{font-family:var(--f-mono);font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--bronze);margin-bottom:16px}
.mani-col p{font-size:.92rem;line-height:1.85;color:rgba(12,16,11,.7)}
@media(max-width:900px){.mani-cols{grid-template-columns:1fr}}

/* ---------- ouro preto ---------- */
#ouropreto{background:
  radial-gradient(ellipse 70% 60% at 100% 0%, rgba(18,190,127,.08), transparent 55%),
  linear-gradient(165deg,#0B3328 0%,#07231C 45%,#04080A 100%);
  padding:15vh 0;overflow:hidden}
.op-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:6vw;align-items:center}
.op-media{position:relative;overflow:hidden;border-radius:3px;aspect-ratio:4/3.5}
.op-media img{width:100%;height:118%;object-fit:cover}
.op-media .tag{position:absolute;left:18px;bottom:18px;background:rgba(12,16,11,.72);backdrop-filter:blur(8px);padding:10px 16px;border:1px solid var(--line);font-family:var(--f-mono);font-size:.56rem;letter-spacing:.22em;color:var(--gold);text-transform:uppercase}
.op-title{font-size:clamp(2.6rem,5.3vw,5.1rem);margin:22px 0 26px}
.op-list{margin-top:40px;border-top:1px solid var(--line)}
.op-item{display:grid;grid-template-columns:66px 1fr;gap:20px;padding:19px 0;border-bottom:1px solid var(--line);align-items:baseline}
.op-item .n{font-family:var(--f-display);font-style:italic;font-size:1.45rem;color:var(--gold)}
.op-item h4{font-weight:500;font-size:.95rem;letter-spacing:.04em;margin-bottom:4px}
.op-item p{font-size:.86rem;color:rgba(245,239,224,.7)}
.op-nums{display:flex;gap:4vw;margin-top:42px;flex-wrap:wrap}
.op-num .v{font-family:var(--f-display);font-size:clamp(2rem,3.4vw,3.2rem);font-weight:300;line-height:1;color:var(--gold-soft)}
.op-num .k{font-family:var(--f-mono);font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sage);margin-top:8px;display:block}
@media(max-width:960px){.op-grid{grid-template-columns:1fr}}

/* ---------- reserva ---------- */
#reserva{background:
  radial-gradient(ellipse 55% 45% at 15% 8%, rgba(14,77,58,.5), transparent 60%),
  radial-gradient(ellipse 40% 40% at 92% 60%, rgba(220,168,78,.05), transparent 60%);
  padding:15vh 0 0}
.rs-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:8vh}
.rs-head .d-title{font-size:clamp(2.8rem,6.4vw,6.4rem)}
.stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.stat{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:42px 34px 38px;position:relative;overflow:hidden;transition:background .5s}
.stat:hover{background:linear-gradient(160deg,rgba(18,190,127,.1),rgba(11,51,40,.5));box-shadow:inset 0 0 0 1px rgba(18,190,127,.28), 0 0 60px -20px rgba(18,190,127,.3)}
.stat::after{content:"";position:absolute;left:34px;right:34px;bottom:0;height:2px;background:linear-gradient(90deg,var(--emerald),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease)}
.stat:hover::after{transform:scaleX(1)}
.stat .k{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.26em;color:var(--sage);text-transform:uppercase;margin-bottom:24px;display:block}
.stat .v{font-family:var(--f-display);font-weight:300;font-size:clamp(2.5rem,4.2vw,4.2rem);line-height:1}
.stat .v small{font-size:.42em;color:var(--gold);font-style:italic;margin-left:6px}
.stat .n{margin-top:15px;font-size:.82rem;color:rgba(245,239,224,.66);line-height:1.65}
@media(max-width:960px){.stats{grid-template-columns:repeat(2,1fr)}.stat{padding:28px 22px}}
@media(max-width:560px){.stats{grid-template-columns:1fr 1fr}}
.ficha{margin-top:10vh;display:grid;grid-template-columns:.9fr 1.1fr;gap:5vw;align-items:start}
.ficha-side h3{font-family:var(--f-display);font-size:clamp(1.9rem,3vw,2.7rem);font-weight:400;line-height:1.15;margin-top:18px}
.ficha-side p{margin-top:20px;font-size:.94rem;color:rgba(245,239,224,.68);line-height:1.85;max-width:44ch}
.ficha-table{border-top:1px solid var(--line)}
.ficha-row{display:grid;grid-template-columns:210px 1fr;gap:20px;padding:17px 0;border-bottom:1px solid var(--line);align-items:baseline}
.ficha-row .k{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sage)}
.ficha-row .v{font-size:.94rem;color:rgba(245,239,224,.92);line-height:1.65}
.ficha-row .v em{color:var(--gold-soft);font-style:italic;font-family:var(--f-display);font-size:1.05em}
@media(max-width:960px){.ficha{grid-template-columns:1fr}.ficha-row{grid-template-columns:150px 1fr}}
.species{padding:24px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;margin-top:10vh}
.species .track{display:flex;width:max-content}
.species .mi{padding:0 30px;display:flex;align-items:center;gap:30px;font-family:var(--f-mono);font-size:.64rem;letter-spacing:.32em;text-transform:uppercase;color:var(--moss);white-space:nowrap}
.species .mi::after{content:"·";color:var(--gold)}
.rs-vale{position:relative;height:84vh;overflow:hidden}
.rs-vale img{width:100%;height:128%;object-fit:cover}
.rs-vale::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,16,11,.4),transparent 34%,rgba(12,16,11,.6) 100%)}
.rs-vale .cap{position:absolute;bottom:6vh;left:4vw;z-index:3}
.rs-vale .cap .big{font-family:var(--f-display);font-style:italic;font-weight:300;font-size:clamp(1.9rem,3.6vw,3.4rem);max-width:18ch;line-height:1.15;text-shadow:0 4px 40px rgba(12,16,11,.6)}

/* ---------- compare (hoje / amanhã) ---------- */
#visao{background:var(--cream);color:var(--ink);padding:15vh 0}
.cp-head{display:flex;justify-content:space-between;align-items:flex-end;gap:26px;flex-wrap:wrap;margin-bottom:7vh}
.cp-head .d-title{font-size:clamp(2.8rem,6vw,6rem)}
.compare{position:relative;aspect-ratio:16/9.4;overflow:hidden;border-radius:3px;box-shadow:0 50px 110px -30px rgba(12,16,11,.4);cursor:ew-resize;user-select:none;touch-action:none}
.compare img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.cmp-top{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.cmp-top img{width:100%;height:100%}
.cmp-handle{position:absolute;top:0;bottom:0;width:1px;background:var(--cream);pointer-events:none;box-shadow:0 0 30px rgba(0,0,0,.5)}
.cmp-handle::after{content:"◂ ▸";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--cream);color:var(--ink);width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;letter-spacing:.06em;box-shadow:0 14px 40px rgba(12,16,11,.4)}
.cmp-label{position:absolute;bottom:22px;font-family:var(--f-mono);font-size:.58rem;letter-spacing:.26em;text-transform:uppercase;padding:11px 18px;backdrop-filter:blur(8px);pointer-events:none}
.cmp-label.hoje{left:22px;background:rgba(12,16,11,.66);color:var(--cream)}
.cmp-label.amanha{right:22px;background:rgba(245,239,224,.82);color:var(--ink)}
.cp-foot{margin-top:3.5vh;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-family:var(--f-mono);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(12,16,11,.5)}

/* ---------- masterplan ---------- */
#plano{background:var(--cream);color:var(--ink);padding:0 0 15vh}
.pl-head{margin-bottom:7vh;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:26px}
.pl-head .d-title{font-size:clamp(2.8rem,6vw,6rem)}
.pl-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:5vw;align-items:start}
.pl-media{position:relative;border-radius:3px;overflow:hidden;box-shadow:0 40px 90px -30px rgba(12,16,11,.35)}
.pl-media img{width:100%}
.pl-media .stamp{position:absolute;top:16px;right:16px;background:var(--ink);color:var(--cream);font-family:var(--f-mono);font-size:.54rem;letter-spacing:.24em;padding:9px 14px;text-transform:uppercase}
.pl-side{position:sticky;top:110px}
.pl-side h3{font-family:var(--f-display);font-size:1.9rem;font-weight:500;margin-bottom:8px}
.pl-side>p{font-size:.92rem;color:rgba(12,16,11,.68);line-height:1.8;margin-bottom:32px}
.pl-item{border-top:1px solid var(--line-dark);padding:17px 0;display:flex;justify-content:space-between;gap:18px;align-items:baseline}
.pl-item:last-of-type{border-bottom:1px solid var(--line-dark)}
.pl-item .k{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(12,16,11,.55)}
.pl-item .v{font-family:var(--f-display);font-size:1.38rem;font-weight:500;text-align:right;white-space:nowrap}
.pl-item .v small{font-size:.6em;font-style:italic;color:var(--bronze)}
.pl-note{margin-top:24px;font-size:.72rem;color:rgba(12,16,11,.5);line-height:1.7;border-left:2px solid var(--gold);padding-left:14px}
.hot{position:absolute;width:18px;height:18px;margin:-9px 0 0 -9px;cursor:pointer;z-index:4}
.hot::before{content:"";position:absolute;inset:4px;border-radius:50%;background:var(--gold)}
.hot::after{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid var(--gold);animation:hotp 2.4s var(--ease) infinite}
@keyframes hotp{0%{transform:scale(.6);opacity:1}100%{transform:scale(2.6);opacity:0}}
.hot .tip{position:absolute;bottom:26px;left:50%;transform:translate(-50%,8px);background:var(--ink);color:var(--cream);padding:12px 16px;width:max-content;max-width:230px;border:1px solid rgba(201,154,75,.4);opacity:0;pointer-events:none;transition:all .4s var(--ease);z-index:5}
.hot .tip b{display:block;font-family:var(--f-display);font-size:1.05rem;font-weight:500;margin-bottom:3px}
.hot .tip span{font-family:var(--f-mono);font-size:.54rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage);line-height:1.7;display:block}
.hot:hover .tip,.hot.is-open .tip{opacity:1;transform:translate(-50%,0)}
@media(max-width:960px){.pl-grid{grid-template-columns:1fr}.pl-side{position:static}}

/* ---------- viver (renders editorial) ---------- */
#viver{background:
  radial-gradient(ellipse 60% 40% at 50% 0%, rgba(14,77,58,.45), transparent 60%);
  padding:15vh 0}
.vv-head{text-align:center;margin-bottom:9vh}
.vv-head .d-title{font-size:clamp(2.8rem,6.4vw,6.4rem);margin-top:20px}
.vv-head p{margin:3vh auto 0;max-width:540px;color:rgba(245,239,224,.7);font-size:.98rem;line-height:1.85}
.vv-item{display:grid;grid-template-columns:1.1fr .9fr;gap:5vw;align-items:center;margin-bottom:11vh}
.vv-item:nth-child(even){grid-template-columns:.9fr 1.1fr}
.vv-item:nth-child(even) .vv-media{order:2}
.vv-media{position:relative;overflow:hidden;border-radius:3px;aspect-ratio:16/10}
.vv-media img{width:100%;height:114%;object-fit:cover}
.vv-media .idx{position:absolute;top:16px;left:16px;font-family:var(--f-mono);font-size:.56rem;letter-spacing:.24em;color:var(--cream);background:rgba(12,16,11,.6);backdrop-filter:blur(6px);padding:8px 13px;text-transform:uppercase}
.vv-copy .eyebrow{margin-bottom:18px}
.vv-copy h3{font-family:var(--f-display);font-size:clamp(2rem,3.6vw,3.4rem);font-weight:400;line-height:1.06}
.vv-copy h3 em{font-style:italic;color:var(--gold-soft)}
.vv-copy p{margin-top:22px;font-size:.98rem;line-height:1.9;color:rgba(245,239,224,.84);max-width:46ch}
.vv-mosaic{display:grid;grid-template-columns:repeat(12,1fr);gap:2vw;margin-top:2vh}
.vv-mosaic .m-it{overflow:hidden;border-radius:3px;position:relative}
.vv-mosaic .m-it img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);transition:transform 1.2s var(--ease)}
.vv-mosaic .m-it:hover img{transform:scale(1.13)}
.vv-mosaic .m-it .tag{position:absolute;left:14px;bottom:14px;font-family:var(--f-mono);font-size:.52rem;letter-spacing:.22em;color:var(--cream);text-transform:uppercase;background:rgba(12,16,11,.6);backdrop-filter:blur(6px);padding:7px 12px;opacity:0;transform:translateY(8px);transition:all .45s var(--ease)}
.vv-mosaic .m-it:hover .tag{opacity:1;transform:none}
.vv-mosaic .m-1{grid-column:1/8;aspect-ratio:16/9}
.vv-mosaic .m-2{grid-column:8/13;aspect-ratio:4/3.2;margin-top:7vh}
.vv-mosaic .m-3{grid-column:1/6;aspect-ratio:4/3.2;margin-top:-2vh}
.vv-mosaic .m-4{grid-column:6/13;aspect-ratio:16/9;margin-top:5vh}
@media(max-width:900px){.vv-mosaic>div{grid-column:1/13!important;margin-top:0!important;aspect-ratio:16/10!important}}
.vv-disc{text-align:center;font-family:var(--f-mono);font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,239,224,.38);margin-top:2vh}
@media(max-width:960px){.vv-item,.vv-item:nth-child(even){grid-template-columns:1fr}.vv-item:nth-child(even) .vv-media{order:0}}

/* ---------- experiencias rail ---------- */
#exp{background:
  radial-gradient(ellipse 60% 60% at 0% 100%, rgba(18,190,127,.07), transparent 55%),
  linear-gradient(170deg,#04080A 0%,#07231C 55%,#0B3328 100%);
  overflow:hidden}
.exp-pin{height:100svh;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.exp-head{padding:0 4vw;margin-bottom:5vh;display:flex;justify-content:space-between;align-items:flex-end;gap:20px}
.exp-head .d-title{font-size:clamp(2.6rem,5.6vw,5.6rem)}
.rail-progress{width:min(260px,30vw);height:1px;background:var(--line);position:relative;margin-top:14px}
.rail-progress i{position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left}
.rail{position:relative;display:flex;gap:2.4vw;padding:0 4vw;width:max-content;will-change:transform;align-items:stretch}
.card{position:relative;z-index:1;width:clamp(300px,30vw,470px);flex-shrink:0;overflow:hidden;border-radius:3px;background:var(--ink)}
.card.tall{width:clamp(250px,22vw,340px)}
.card .c-media{aspect-ratio:3/3.6;overflow:hidden;position:relative}
.card.wide .c-media{aspect-ratio:4/3.4}
.card .c-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);transition:transform 1.1s var(--ease)}
.card:hover .c-media img{transform:scale(1.12)}
.card .c-cap{position:absolute;left:0;right:0;bottom:0;padding:22px;background:linear-gradient(transparent,rgba(12,16,11,.9));display:flex;flex-direction:column;gap:6px}
.card .c-cap .n{font-family:var(--f-mono);font-size:.55rem;letter-spacing:.26em;color:var(--gold);text-transform:uppercase}
.card .c-cap h4{font-family:var(--f-display);font-weight:500;font-size:1.5rem;letter-spacing:.02em}
.rail-end{display:flex;align-items:center;padding:0 6vw 0 3vw}
.rail-end .re{font-family:var(--f-display);font-style:italic;font-size:clamp(1.8rem,3vw,3rem);color:var(--gold-soft);white-space:nowrap}
@media(max-width:900px){.exp-pin{height:auto;padding:13vh 0}.rail{width:auto;overflow-x:auto;padding-bottom:20px;-webkit-overflow-scrolling:touch}}

/* ---------- localizacao ---------- */
#local{background:var(--cream);color:var(--ink);padding:15vh 0;overflow:hidden}
.lo-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:7vh}
.lo-head .d-title{font-size:clamp(2.8rem,6vw,6rem)}
.lo-head p{max-width:400px;font-size:.94rem;line-height:1.85;color:rgba(12,16,11,.65)}
.dest{border-top:1px solid var(--line-dark)}
.dest-row{position:relative;display:grid;grid-template-columns:56px 1.2fr .5fr .5fr 30px;gap:2.5vw;align-items:center;padding:30px 26px;border-bottom:1px solid var(--line-dark);transition:padding .5s var(--ease);overflow:hidden;cursor:pointer}
.dest-row .row-bg{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:0;transition:opacity .55s var(--ease)}
.dest-row .row-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);transition:transform 1.4s var(--ease)}
.dest-row .row-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(4,8,10,.88) 0%,rgba(4,8,10,.55) 45%,rgba(4,8,10,.75) 100%)}
.dest-row>*{position:relative;z-index:2}
.dest-row:hover{padding-left:40px}
.dest-row:hover .row-bg{opacity:1}
.dest-row:hover .row-bg img{transform:scale(1)}
.dest-row:hover .i{color:var(--gold-soft)}
.dest-row:hover h3 span{color:rgba(245,239,224,.8)}
.dest-row:hover .km,.dest-row:hover .min{color:var(--cream)}
.dest-row:hover .km small,.dest-row:hover .min small{color:rgba(245,239,224,.65)}
.dest-row .i{font-family:var(--f-mono);font-size:.6rem;color:var(--bronze);letter-spacing:.2em}
.dest-row h3{font-family:var(--f-display);font-weight:500;font-size:clamp(1.5rem,2.7vw,2.4rem);letter-spacing:.01em;transition:color .4s}
.dest-row h3 span{display:block;font-family:var(--f-body);font-weight:300;font-size:.8rem;color:rgba(12,16,11,.55);margin-top:5px;letter-spacing:0}
.dest-row:hover h3{color:var(--gold-soft)}
.dest-row .km,.dest-row .min{font-family:var(--f-display);font-size:clamp(1.3rem,2vw,1.9rem);font-weight:400;white-space:nowrap}
.dest-row .km small,.dest-row .min small{font-family:var(--f-mono);font-size:.52rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(12,16,11,.5);display:block;margin-top:4px}
.dest-row .a{font-family:var(--f-display);font-size:1.6rem;color:var(--bronze);transform:rotate(-45deg);transition:transform .4s var(--ease)}
.dest-row:hover .a{transform:rotate(0);color:var(--gold-soft)}
.lo-infra{margin-top:11vh;display:grid;grid-template-columns:.85fr 1.15fr;gap:5vw;align-items:center}
.lo-infra-media{overflow:hidden;border-radius:3px;aspect-ratio:4/4.4;position:relative}
.lo-infra-media img{width:100%;height:116%;object-fit:cover}
.lo-infra h3{font-family:var(--f-display);font-size:clamp(2rem,3.8vw,3.6rem);font-weight:400;line-height:1.08;margin-top:18px}
.lo-infra h3 em{font-style:italic;color:var(--bronze)}
.infra-list{margin-top:36px;border-top:1px solid var(--line-dark)}
.infra-item{display:grid;grid-template-columns:56px 1fr;gap:18px;padding:19px 0;border-bottom:1px solid var(--line-dark);align-items:baseline}
.infra-item .n{font-family:var(--f-display);font-style:italic;font-size:1.35rem;color:var(--bronze)}
.infra-item h4{font-weight:500;font-size:.95rem;margin-bottom:4px}
.infra-item p{font-size:.86rem;color:rgba(12,16,11,.6);line-height:1.7}
@media(max-width:960px){.lo-infra{grid-template-columns:1fr}.dest-row{grid-template-columns:34px 1fr auto 24px}.dest-row .min{display:none}.dest-preview{display:none}}

/* ---------- pousada ---------- */
#pousada{background:
  radial-gradient(ellipse 55% 45% at 88% 10%, rgba(14,77,58,.45), transparent 60%);
  padding:15vh 0}
.po-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:6vw;align-items:center}
.po-media{position:relative;overflow:hidden;aspect-ratio:4/4.5;border-radius:3px}
.po-media img{width:100%;height:118%;object-fit:cover}
.po-media .frame{position:absolute;inset:14px;border:1px solid rgba(245,239,224,.35);pointer-events:none}
.po-media .tag{position:absolute;left:26px;bottom:26px;font-family:var(--f-mono);font-size:.54rem;letter-spacing:.22em;color:var(--cream);background:rgba(12,16,11,.6);backdrop-filter:blur(6px);padding:8px 13px;text-transform:uppercase;z-index:2}
.po-title{font-size:clamp(2.6rem,5.4vw,5.2rem);margin:22px 0 24px}
.po-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:34px}
.po-tags span{border:1px solid var(--line);padding:9px 16px;border-radius:100px;font-family:var(--f-mono);font-size:.56rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sage);transition:all .4s}
.po-tags span:hover{border-color:var(--gold);color:var(--gold)}
.po-sub{margin-top:9vh;position:relative;overflow:hidden;border-radius:3px;aspect-ratio:21/8}
.po-sub img{width:100%;height:120%;object-fit:cover}
.po-sub .cap{position:absolute;left:26px;bottom:22px;z-index:2;font-family:var(--f-display);font-style:italic;font-size:clamp(1.3rem,2.4vw,2.1rem);text-shadow:0 4px 30px rgba(12,16,11,.6)}
.po-sub::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(12,16,11,.55))}
@media(max-width:960px){.po-grid{grid-template-columns:1fr}}

/* ---------- galeria ---------- */
#galeria{background:transparent;padding:0 0 15vh}
.ga-head{margin-bottom:7vh}
.ga-head .d-title{font-size:clamp(2.6rem,5.6vw,5.6rem)}
.ga-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:2vw;align-items:start}
.ga-it{overflow:hidden;border-radius:3px;position:relative}
.ga-it img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);transition:transform 1.2s var(--ease)}
.ga-it:hover img{transform:scale(1.14)}
.ga-it .tag{position:absolute;left:14px;bottom:14px;font-family:var(--f-mono);font-size:.52rem;letter-spacing:.24em;color:var(--cream);text-transform:uppercase;background:rgba(12,16,11,.6);backdrop-filter:blur(6px);padding:7px 12px;opacity:0;transform:translateY(8px);transition:all .45s var(--ease)}
.ga-it:hover .tag{opacity:1;transform:none}
.ga-1{grid-column:1/7;aspect-ratio:4/3}
.ga-2{grid-column:7/13;aspect-ratio:4/3;margin-top:8vh}
.ga-3{grid-column:1/5;aspect-ratio:4/4.4;margin-top:-3vh}
.ga-4{grid-column:5/10;aspect-ratio:4/3;margin-top:6vh}
.ga-5{grid-column:10/13;aspect-ratio:3/4;margin-top:1vh}
@media(max-width:900px){.ga-grid>div{grid-column:1/13!important;margin-top:0!important;aspect-ratio:4/3!important}}

/* ---------- cta ---------- */
#cta{padding:22vh 0 15vh;text-align:center;overflow:hidden;position:relative;background:var(--onyx)}
#cta .cta-bg{position:absolute;inset:0;z-index:0}
#cta .cta-bg img{width:100%;height:112%;object-fit:cover}
#cta .cta-bg::after{content:"";position:absolute;inset:0;background:
  radial-gradient(ellipse 70% 80% at 50% 60%, rgba(4,8,10,.28), rgba(4,8,10,.9)),
  linear-gradient(180deg, rgba(4,8,10,.92) 0%, rgba(4,8,10,.25) 30%, rgba(4,8,10,.3) 65%, rgba(4,8,10,.96) 100%)}
#cta .wrap{position:relative;z-index:3}
#cta .topo{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(1200px,120vw);opacity:.3;pointer-events:none;z-index:2}
.cta-title{font-size:clamp(3.2rem,9.4vw,9.4rem);text-transform:uppercase;line-height:.94;position:relative;z-index:3;text-shadow:0 8px 60px rgba(4,8,10,.7)}
.cta-title em{display:block}
#cta .lead{margin:4.5vh auto 6vh;max-width:460px;text-align:center;position:relative;z-index:2}
#cta .btn{font-size:.68rem;padding:20px 42px;position:relative;z-index:2}
.cta-meta{margin-top:9vh;display:flex;justify-content:center;gap:5vw;flex-wrap:wrap;position:relative;z-index:2}
.cta-meta div{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sage);line-height:2.1}
.cta-meta b{color:var(--gold);font-weight:400;display:block}

/* ---------- footer ---------- */
footer{background:var(--ink);border-top:1px solid var(--line);padding:0 4vw 4vh}
.ft-marquee{overflow:hidden;padding:6vh 0 4vh;border-bottom:1px solid var(--line);margin-bottom:6vh}
.ft-marquee .track{display:flex;width:max-content;will-change:transform}
.ft-marquee span{font-family:var(--f-display);font-size:clamp(4.5rem,11vw,11rem);line-height:1;text-transform:uppercase;white-space:nowrap;padding-right:6vw;color:transparent;-webkit-text-stroke:1px rgba(245,239,224,.34);transition:color .5s}
.ft-marquee:hover span{color:rgba(18,190,127,.12)}
.ft-top{display:flex;justify-content:space-between;align-items:center;gap:26px;flex-wrap:wrap;margin-bottom:6vh}
.ft-brand{display:flex;align-items:center;gap:18px}
.ft-brand .brand-mark{width:62px;height:62px}
.ft-brand h4{font-family:var(--f-display);font-size:1.5rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500}
.ft-brand p{font-family:var(--f-mono);font-size:.53rem;letter-spacing:.28em;color:var(--sage);text-transform:uppercase;margin-top:4px}
.ft-links{display:flex;gap:28px;flex-wrap:wrap}
.ft-links a{font-family:var(--f-mono);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,239,224,.6);transition:color .3s}
.ft-links a:hover{color:var(--gold)}
.ft-bottom{border-top:1px solid var(--line);padding-top:26px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-family:var(--f-mono);font-size:.54rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,239,224,.42)}
.ft-bottom .gmx b{color:var(--gold);font-weight:400}
.ft-disclaimer{margin-top:20px;font-size:.62rem;color:rgba(245,239,224,.35);max-width:900px;line-height:1.8}

/* ============================================================
   v4.0 · LAPIDAÇÃO FINAL
   ============================================================ */

/* A2 · curtain wipe nos títulos */
.d-title{position:relative}
.d-title .ti{display:block}
.d-title .wipe{position:absolute;inset:-3% -1.5%;background:var(--emerald-deep);transform:scaleX(0);transform-origin:0 50%;pointer-events:none;z-index:2}

/* A3 · bordas vivas escuro→cream */
.sec-divider{position:absolute;top:-1px;left:0;right:0;height:2px;z-index:5;pointer-events:none}
.sec-divider svg{display:block;width:100%;height:2px}

/* B1 · split por palavra */
.w{display:inline-block;overflow:hidden;vertical-align:bottom;padding-bottom:.1em;margin-bottom:-.1em}
.w>span{display:inline-block}
html.no-motion .w>span{transform:none!important}

/* B2 · itálicos dourados com shimmer (sutil) */
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .d-title em,.vv-copy h3 em,.lo-infra h3 em{
    background-image:linear-gradient(100deg,var(--gold) 0%,var(--gold-soft) 42%,#FFF0CE 50%,var(--gold-soft) 58%,var(--gold) 100%);
    background-size:280% 100%;background-position:120% 50%;
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
    animation:shimmer 6s linear infinite}
  .on-cream .d-title em,.on-cream h3 em,.lo-infra h3 em{
    background-image:linear-gradient(100deg,var(--bronze) 0%,#C99A4B 42%,#E8BD6E 50%,#C99A4B 58%,var(--bronze) 100%)}
  html.no-motion .d-title em,html.no-motion h3 em{animation:none}
}
@keyframes shimmer{0%{background-position:120% 50%}100%{background-position:-160% 50%}}

/* D1 · glow ambiente reativo atrás do device */
.fl-stage{perspective:950px}
.fl-glow{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(430px,88vw);aspect-ratio:9/16;border-radius:40px;filter:blur(64px);opacity:.55;pointer-events:none;z-index:0;transition:background 1s ease;background:radial-gradient(ellipse 60% 55% at 50% 45%,rgba(220,168,78,.4),transparent 70%)}
.fl-device{position:relative;z-index:2}
.fl-caps{position:relative;z-index:2}

/* D2 · progress ring no play */
.fl-ctrl{position:relative}
#filmPlay .ring{position:absolute;inset:-3px;width:auto;height:auto;transform:rotate(-90deg);pointer-events:none}
#filmPlay .ring circle{fill:none;stroke:var(--gold);stroke-width:1.6;stroke-linecap:round;stroke-dasharray:141.4;stroke-dashoffset:141.4;transition:stroke-dashoffset .25s linear}

/* D3 · legenda do capítulo ativo */
.fl-chapter{position:absolute;left:18px;bottom:84px;z-index:3;font-family:var(--f-mono);font-size:.56rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-soft);background:rgba(4,8,10,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:8px 13px;opacity:0;transform:translateY(6px);transition:opacity .4s ease,transform .4s var(--ease);pointer-events:none;max-width:70%}
.fl-chapter.show{opacity:1;transform:translateY(0)}
.fl-chapter:empty{opacity:0}

/* E1–E3 · slider Hoje/Amanhã */
.cmp-handle{background:linear-gradient(180deg,var(--gold-soft),var(--cream) 40%,var(--cream) 60%,var(--gold-soft))}
.cmp-handle::after{animation:handlepulse 2.6s var(--ease) infinite}
@keyframes handlepulse{0%,100%{box-shadow:0 14px 40px rgba(12,16,11,.4),0 0 0 0 rgba(220,168,78,.45)}50%{box-shadow:0 14px 40px rgba(12,16,11,.4),0 0 0 12px rgba(220,168,78,0)}}
html.no-motion .cmp-handle::after{animation:none}
.cmp-label{transition:background .45s,color .45s,box-shadow .45s}
.cmp-label.is-on{background:var(--gold);color:var(--ink);box-shadow:0 8px 30px -8px rgba(220,168,78,.6)}
.cmp-flash{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:6}

/* F2 · numerais fantasma do rail */
.ghost-layer{position:absolute;inset:0;z-index:0;pointer-events:none}
.ghost-n{position:absolute;top:50%;transform:translateY(-58%);font-family:var(--f-display);font-weight:300;font-style:italic;font-size:clamp(10rem,17vw,17rem);line-height:1;color:transparent;-webkit-text-stroke:1px rgba(245,239,224,.08);white-space:nowrap}

/* G2 · botões dual-label */
.btn .bl{position:relative;display:inline-block;overflow:hidden;line-height:1.4}
.btn .bl .a{display:inline-block;transition:transform .45s var(--ease)}
.btn .bl .b{position:absolute;left:0;top:0;display:inline-block;transform:translateY(115%);transition:transform .45s var(--ease)}
.btn:hover .bl .a{transform:translateY(-115%)}
.btn:hover .bl .b{transform:translateY(0)}

/* G4 · header volta com blur animado */
header{transition:transform .6s var(--ease),background .5s,padding .5s,backdrop-filter .6s ease,-webkit-backdrop-filter .6s ease}
header.is-returning{backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);transition:transform .6s var(--ease),background .5s,padding .5s}

/* H5 · contraste defensivo do mono sobre cream */
.on-cream .mono{color:#4A6B5B}

/* I2 · easter egg — o cavalo do logo galopa pela tela (assinatura GMX) */
.gmx-horse{position:fixed;bottom:7vh;left:0;z-index:4000;pointer-events:none;display:flex;align-items:center;gap:6px}
.gmx-horse .gh-mark{width:74px;height:74px;border-radius:50%;overflow:hidden;border:1px solid var(--gold);box-shadow:0 14px 44px -8px rgba(220,168,78,.55),0 0 0 6px rgba(220,168,78,.08);background:var(--cream)}
.gmx-horse .gh-mark img{width:100%;height:100%;object-fit:cover;transform:scale(1.08)}
.gmx-horse .gh-trail{width:10px;height:10px;border-radius:50%;background:var(--gold-soft);order:-1}
.gmx-horse .gh-trail.t2{width:7px;height:7px;opacity:.7}
.gmx-horse .gh-trail.t3{width:4px;height:4px;opacity:.5}

/* ---------- reveal primitives ---------- */
[data-reveal]{opacity:0;transform:translateY(44px)}
.clip-reveal{clip-path:inset(0 0 100% 0)}
.clip-reveal img{transform:scale(1.16)}
html.no-motion [data-reveal]{opacity:1;transform:none}
html.no-motion .clip-reveal{clip-path:inset(0 0 0 0)}
html.no-motion .clip-reveal img{transform:none}
html.no-motion .mani-text .ln>span{transform:none!important}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}
