/* ==========================================================================
   VITUS ENGENHARIA — Apresentação Comercial em Slides
   Onyx + Champagne Gold + Vitus Blue
   ========================================================================== */

:root{
  /* Charcoal warm — base neutra */
  --bg: #1a1816;
  --bg-2: #1f1d1b;
  --bg-3: #25221f;
  --surface: #2a2724;
  --surface-2: #312e2a;
  --line: rgba(255,255,255,.07);
  --line-strong: rgba(255,255,255,.14);

  /* Cream / fog */
  --fg: #ebe6dc;
  --fg-soft: #b8b1a5;
  --fg-mute: #847e74;

  /* Taupe / bronze quente — accent neutro */
  --gold: #b89572;
  --gold-light: #d2b394;
  --gold-deep: #8b6e51;
  --gold-glow: rgba(184,149,114,.28);

  --blue: #7a8a95;
  --blue-deep: #5a6770;

  /* Marcellus = display arquitetônico (luxo minimalista, letras romanas)
     Cormorant = serif italic suave para nuances editoriais
     Inter = corpo, neutro e legível */
  --display: "Marcellus", "Cormorant Garamond", "Times New Roman", serif;
  --serif: "Cormorant Garamond", "Times New Roman", serif;
  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;

  --ease: cubic-bezier(.22,.7,.2,1);

  /* deck dims */
  --chrome-h: 56px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--bg);color:var(--fg);font-family:var(--sans);font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}
body.has-cursor{cursor:none}
body.has-cursor a, body.has-cursor button, body.has-cursor [data-magnetic]{cursor:none}
img,video,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{background:none;border:0;cursor:pointer;color:inherit;font:inherit}
ul{list-style:none}
::selection{background:var(--gold);color:#000}

/* ==========================================================================
   FX MODERNOS — Spotlight, cursor, magnetic, clip-reveal, ken-burns, blob
   ========================================================================== */

/* Spotlight (aurora dourada que segue o cursor) */
.spotlight{
  position:fixed;pointer-events:none;z-index:5;
  width:520px;height:520px;border-radius:50%;
  left:0;top:0;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(184,149,114,.18) 0%, rgba(184,149,114,.08) 35%, transparent 70%);
  filter:blur(40px);
  opacity:0;transition:opacity .6s var(--ease);
  mix-blend-mode:screen;
}
.spotlight.is-active{opacity:1}
@media (max-width:900px){.spotlight{display:none}}

/* Custom cursor (ring + dot) */
.cursor-ring,.cursor-dot{
  position:fixed;top:0;left:0;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);will-change:transform,width,height,opacity;
  border-radius:50%;
}
.cursor-ring{
  width:34px;height:34px;border:1px solid var(--gold);
  transition:width .3s var(--ease), height .3s var(--ease), background .3s var(--ease), opacity .3s var(--ease);
  mix-blend-mode:difference;
}
.cursor-dot{
  width:5px;height:5px;background:var(--gold);
  transition:opacity .25s var(--ease), transform .15s linear;
}
.cursor-ring.is-hover{width:62px;height:62px;background:rgba(184,149,114,.06);border-color:var(--gold-light)}
.cursor-ring.is-click{width:24px;height:24px;background:var(--gold)}
@media (max-width:900px), (hover:none){.cursor-ring,.cursor-dot{display:none}}

/* Magnetic wrapper */
[data-magnetic]{display:inline-flex;will-change:transform;transition:transform .35s var(--ease)}

/* Animated gradient blob (fundo dos slides) */
.slide__blob{
  position:absolute;width:60vmin;height:60vmin;border-radius:50%;
  pointer-events:none;z-index:0;
  background:radial-gradient(circle, rgba(184,149,114,.18) 0%, rgba(184,149,114,.06) 50%, transparent 70%);
  filter:blur(50px);
  animation:blobFloat 18s ease-in-out infinite;
  top:-15%;right:-15%;
}
.slide__blob.alt{
  background:radial-gradient(circle, rgba(122,138,149,.14) 0%, rgba(122,138,149,.04) 55%, transparent 75%);
  top:auto;right:auto;bottom:-15%;left:-15%;
  animation-duration:24s;animation-delay:-6s;
}
@keyframes blobFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(40px,-30px) scale(1.08)}
  66%{transform:translate(-30px,40px) scale(.95)}
}

/* Image clip-path reveal (entram como cortina) */
[data-reveal-img]{
  clip-path:inset(0 100% 0 0);
  transition:clip-path 1.4s cubic-bezier(.7,0,.2,1);
}
.slide.is-active [data-reveal-img]{clip-path:inset(0 0 0 0)}
[data-reveal-img="up"]{clip-path:inset(100% 0 0 0)}
.slide.is-active [data-reveal-img="up"]{clip-path:inset(0 0 0 0)}

/* Ken Burns sutil nas imagens do slide ativo */
@keyframes kenBurns{
  0%{transform:scale(1.02) translate(0,0)}
  50%{transform:scale(1.08) translate(-1%, -1%)}
  100%{transform:scale(1.04) translate(1%, 0)}
}
.slide.is-active [data-kenburns]{animation:kenBurns 22s ease-in-out infinite alternate}

/* Number odometer */
.odo{display:inline-flex;overflow:hidden;line-height:1;height:1em;vertical-align:baseline}
.odo__digit{
  display:inline-block;text-align:center;
  transition:transform .9s cubic-bezier(.2,.7,.2,1);
}

/* Animated underline para títulos */
.underline-grow{position:relative;display:inline-block}
.underline-grow::after{
  content:"";position:absolute;left:0;bottom:-.08em;height:1px;width:0;
  background:var(--gold);
  transition:width 1.2s cubic-bezier(.7,0,.2,1);
  transition-delay:.4s;
}
.slide.is-active .underline-grow::after{width:100%}

/* Tilt 3D wrapper */
[data-tilt]{transform-style:preserve-3d;transition:transform .25s var(--ease)}
[data-tilt] > *{transform:translateZ(0)}

/* Word/letter split */
.split-word{display:inline-block;overflow:hidden;vertical-align:bottom;line-height:1.05;padding:0 .04em}
.split-word > span{
  display:inline-block;transform:translateY(110%);opacity:0;
  transition:transform 1s cubic-bezier(.2,.7,.2,1), opacity 1s var(--ease);
}
.slide.is-active .split-word > span{transform:translateY(0);opacity:1}

/* Image blur-in */
[data-blur-in]{filter:blur(20px);opacity:0;transition:filter 1.4s var(--ease), opacity 1.4s var(--ease)}
.slide.is-active [data-blur-in]{filter:blur(0);opacity:1}

/* film grain */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9998;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.05;mix-blend-mode:overlay;
}

/* ==========================================================================
   LOADER
   ========================================================================== */
.loader{position:fixed;inset:0;background:var(--bg);z-index:10000;display:flex;align-items:center;justify-content:center;transition:opacity .8s var(--ease), visibility .8s var(--ease)}
.loader.is-hidden{opacity:0;visibility:hidden}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:24px}
.loader__logo{width:110px;height:110px;fill:var(--gold);animation:logoPulse 2s ease-in-out infinite}
@keyframes logoPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05);filter:drop-shadow(0 0 20px var(--gold-glow))}}
.loader__bar{width:200px;height:1px;background:rgba(255,255,255,.12);overflow:hidden;position:relative}
.loader__bar span{display:block;height:100%;background:linear-gradient(90deg,transparent,var(--gold),transparent);width:40%;animation:loadBar 1.4s ease-in-out infinite}
@keyframes loadBar{0%{transform:translateX(-100%)}100%{transform:translateX(450%)}}
.loader__text{font-family:var(--display);letter-spacing:.32em;font-size:10.5px;color:var(--gold-light);font-weight:400;text-transform:uppercase}

/* ==========================================================================
   CHROME (top + bottom)
   ========================================================================== */
.chrome{
  position:fixed;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;height:var(--chrome-h);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  background:rgba(10,10,12,.55);
}
.chrome--top{top:0;border-bottom:1px solid var(--line)}
.chrome--bottom{bottom:0;border-top:1px solid var(--line);gap:24px;justify-content:center}

.chrome__brand{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.chrome__logo{height:24px;width:auto;fill:var(--fg)}
.chrome__title{
  flex:1;text-align:center;font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--fg-mute);
}
.chrome__actions{display:flex;align-items:center;gap:10px}
.chrome__btn{
  width:36px;height:36px;border:1px solid var(--line-strong);border-radius:8px;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--fg-soft);transition:all .25s var(--ease);
}
.chrome__btn svg{width:16px;height:16px}
.chrome__btn:hover{border-color:var(--gold);color:var(--gold-light);background:rgba(184,149,114,.08)}

.nav-arrow{
  width:42px;height:42px;border:1px solid var(--line-strong);border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;color:var(--fg-soft);
  transition:all .25s var(--ease);
}
.nav-arrow svg{width:18px;height:18px}
.nav-arrow:hover{border-color:var(--gold);color:var(--gold-light);background:rgba(184,149,114,.1);transform:scale(1.05)}
.nav-arrow:disabled{opacity:.25;cursor:not-allowed;transform:none}

.counter{display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:13px;color:var(--fg);min-width:80px;justify-content:center;letter-spacing:.05em}
.counter i{display:inline-block;width:28px;height:1px;background:var(--gold)}
.counter span{font-variant-numeric:tabular-nums}
#current{color:var(--gold-light);font-size:15px;font-weight:500}

.dots{display:flex;align-items:center;gap:8px;flex-wrap:wrap;max-width:380px;justify-content:center}
.dot-btn{
  width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.18);
  transition:all .3s var(--ease);
}
.dot-btn.is-active{background:var(--gold);box-shadow:0 0 10px var(--gold-glow);width:22px;border-radius:4px}
.dot-btn:hover{background:rgba(255,255,255,.4)}

/* progress bar (under top chrome) */
.progress{
  position:fixed;top:var(--chrome-h);left:0;height:2px;width:0%;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  z-index:99;transition:width .5s var(--ease);
  box-shadow:0 0 10px var(--gold-glow);
}

/* hint */
.hint{
  position:fixed;bottom:calc(var(--chrome-h) + 16px);left:50%;transform:translateX(-50%);
  font-size:11px;letter-spacing:.06em;color:var(--fg-mute);z-index:90;
  background:rgba(10,10,12,.7);backdrop-filter:blur(8px);
  padding:8px 16px;border:1px solid var(--line);border-radius:999px;
  opacity:0;transition:opacity .6s var(--ease);
  pointer-events:none;
}
.hint.is-visible{opacity:1}
.hint kbd{
  font-family:var(--mono);font-size:10px;
  background:var(--surface-2);border:1px solid var(--line-strong);border-radius:4px;
  padding:2px 6px;margin:0 1px;color:var(--gold-light);
}

/* ==========================================================================
   DECK & SLIDES
   ========================================================================== */
.deck{
  position:fixed;
  top:var(--chrome-h);
  bottom:var(--chrome-h);
  left:0;right:0;
  overflow:hidden;
}
.slide{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  padding:48px 64px;
  opacity:0;visibility:hidden;
  transform:translateX(40px) scale(.985);
  transition:opacity .7s var(--ease), transform .9s var(--ease), visibility 0s linear .9s;
  overflow:hidden;
}
.slide.is-active{
  opacity:1;visibility:visible;
  transform:translateX(0) scale(1);
  transition:opacity .7s var(--ease), transform .9s var(--ease), visibility 0s linear 0s;
  z-index:2;
}
.slide.is-prev{transform:translateX(-40px) scale(.985)}

.slide__inner{
  width:100%;max-width:1280px;height:100%;
  display:flex;flex-direction:column;justify-content:center;
  gap:28px;
  position:relative;z-index:2;
}

.slide__head{margin-bottom:8px;text-align:center;max-width:880px;margin-left:auto;margin-right:auto}

.slide__overlay{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(184,149,114,.14), transparent 55%),
    radial-gradient(ellipse at 80% 70%, rgba(122,138,149,.08), transparent 60%),
    linear-gradient(180deg, rgba(26,24,22,.55) 0%, rgba(26,24,22,.88) 100%);
}
.slide__video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  filter:brightness(.45) saturate(.85) contrast(1.05);
}
.slide__grid-bg{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center, black 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, black 30%, transparent 75%);
}
.slide__bg-glow{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse at center, rgba(184,149,114,.12) 0%, transparent 55%),
    radial-gradient(ellipse at 20% 80%, rgba(122,138,149,.07) 0%, transparent 55%);
}

/* ==========================================================================
   TIPOGRAFIA / ELEMENTOS
   ========================================================================== */
.eyebrow{
  display:inline-block;font-size:10.5px;letter-spacing:.26em;
  text-transform:uppercase;color:var(--gold);
  font-family:var(--mono);font-weight:500;
}

.badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border:1px solid var(--line-strong);
  border-radius:999px;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--fg-soft);
  background:rgba(255,255,255,.02);backdrop-filter:blur(8px);
}
.badge .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 12px var(--gold-glow);animation:pulseDot 2s infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.4}}

.title-xl{
  font-family:var(--display);font-weight:400;
  font-size:clamp(40px, 5.4vw, 84px);line-height:1.02;letter-spacing:-.005em;
}
.title-lg{
  font-family:var(--display);font-weight:400;
  font-size:clamp(34px, 4.4vw, 62px);line-height:1.08;letter-spacing:-.005em;
}
.title-xl em, .title-lg em{
  font-family:var(--serif);font-style:italic;color:var(--gold-light);font-weight:300;
}
.center{text-align:center}

.lead{font-size:clamp(15px, 1.2vw, 18px);color:var(--fg-soft);line-height:1.65;max-width:60ch}

.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;border-radius:999px;
  font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  position:relative;overflow:hidden;
  transition:transform .3s var(--ease), color .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
}
.btn svg{width:16px;height:16px;transition:transform .3s var(--ease)}
.btn--gold{
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-light) 100%);
  color:#101010;
  box-shadow:0 12px 40px -12px var(--gold-glow), inset 0 1px 0 rgba(255,255,255,.4);
}
.btn--gold:hover{box-shadow:0 18px 56px -12px var(--gold-glow);transform:translateY(-2px)}
.btn--gold:hover svg{transform:translateX(4px)}
.btn--ghost{border:1px solid var(--line-strong);color:var(--fg);background:rgba(255,255,255,.02)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold-light);transform:translateY(-2px)}
.btn--lg{padding:20px 36px;font-size:13.5px}

/* ==========================================================================
   COVER (slide 1)
   ========================================================================== */
.slide--cover .slide__inner.cover{
  align-items:flex-start;justify-content:center;text-align:left;
  max-width:1280px;
}
.cover__top{margin-bottom:40px}
.cover__logo{width:240px;fill:var(--fg);margin-bottom:48px}
.cover__title{
  font-family:var(--display);font-weight:400;
  font-size:clamp(56px, 7.6vw, 124px);line-height:1;letter-spacing:-.005em;
  margin-bottom:32px;
}
.cover__title em{font-family:var(--serif);font-style:italic;color:var(--gold-light);font-weight:300}
.cover__sub{
  font-size:clamp(16px,1.4vw,20px);color:var(--fg-soft);
  max-width:600px;margin-bottom:60px;line-height:1.6;
}
.cover__meta{
  display:grid;grid-template-columns:repeat(3, max-content);gap:48px;
  padding-top:32px;border-top:1px solid var(--line);
}
.cover__meta > div{display:flex;flex-direction:column;gap:6px}
.cover__meta span{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.cover__meta strong{font-family:var(--display);font-size:18px;font-weight:400;color:var(--fg);letter-spacing:.005em}

/* ==========================================================================
   TWO COLUMN LAYOUTS
   ========================================================================== */
.two-col{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;height:100%}
.two-col--rev{grid-template-columns:1fr 1.1fr}
.two-col__left{display:flex;flex-direction:column;gap:20px;justify-content:center}
.two-col__right{display:flex;align-items:center;justify-content:center;height:100%}
.two-col__right--lg{justify-content:center}

@media (max-width:980px){
  .two-col, .two-col--rev{grid-template-columns:1fr;gap:24px}
  .two-col--rev .two-col__right{order:-1}
}

/* FRAME (renders) */
.frame{
  position:relative;border-radius:18px;overflow:hidden;
  box-shadow:0 40px 80px -20px rgba(0,0,0,.6), 0 0 0 1px var(--line);
  width:100%;aspect-ratio:4/5;max-height:70vh;
}
.frame--tall{aspect-ratio:3/4;max-height:75vh}
.frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.slide.is-active .frame img{transform:scale(1.04)}
.frame__corner{
  position:absolute;width:24px;height:24px;border:1px solid var(--gold);z-index:2;
}
.frame__corner.tl{top:14px;left:14px;border-right:0;border-bottom:0}
.frame__corner.tr{top:14px;right:14px;border-left:0;border-bottom:0}
.frame__corner.bl{bottom:14px;left:14px;border-right:0;border-top:0}
.frame__corner.br{bottom:14px;right:14px;border-left:0;border-top:0}
.frame__badge{
  position:absolute;bottom:24px;right:24px;
  background:rgba(10,10,12,.85);backdrop-filter:blur(12px);
  border:1px solid var(--gold);padding:14px 18px;border-radius:12px;
  display:flex;flex-direction:column;align-items:center;
}
.frame__badge strong{font-family:var(--display);color:var(--gold);font-size:14px;letter-spacing:.16em;font-weight:500;text-transform:uppercase}
.frame__badge small{font-size:10px;letter-spacing:.18em;color:var(--fg-mute);text-transform:uppercase;margin-top:2px}
.frame__count{
  position:absolute;bottom:18px;left:18px;
  background:rgba(26,24,22,.85);backdrop-filter:blur(12px);
  border:1px solid var(--gold);padding:8px 14px;border-radius:999px;
  font-family:var(--mono);
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-light);font-weight:500;
  z-index:3;
}

/* Frame com PDF embutido */
.frame--pdf{background:#fff}
.frame--pdf > iframe{
  position:absolute;inset:0;width:100%;height:100%;
  border:0;display:block;background:#f4efe7;
}
.frame__open{
  position:absolute;bottom:18px;right:18px;z-index:3;
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:999px;
  background:rgba(26,24,22,.92);backdrop-filter:blur(12px);
  border:1px solid var(--gold);color:var(--gold-light);
  font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;font-weight:500;
  transition:background .25s var(--ease), transform .25s var(--ease), color .25s var(--ease);
}
.frame__open svg{width:13px;height:13px;transition:transform .25s var(--ease)}
.frame__open:hover{background:var(--gold);color:#1a1816;transform:translateY(-2px)}
.frame__open:hover svg{transform:translate(2px,-2px)}

/* Nota de case */
.case-note{
  margin-top:8px;padding-top:14px;border-top:1px solid var(--line);
  font-size:13px;color:var(--fg-mute);line-height:1.5;max-width:50ch;
}
.case-note span{
  font-family:var(--mono);color:var(--gold);font-size:10px;
  letter-spacing:.2em;text-transform:uppercase;font-weight:500;
  margin-right:6px;
}

/* STATS */
.stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  padding-top:24px;border-top:1px solid var(--line);margin-top:12px;
}
.stat{display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.stat > strong, .stat > .stat__plus{display:inline-block}
.stat__row{display:flex;align-items:baseline;gap:2px}
.stat strong{
  font-family:var(--display);font-weight:400;font-size:clamp(36px,3.6vw,58px);line-height:1;letter-spacing:0;
  background:linear-gradient(135deg, var(--gold-light), var(--gold-deep));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat .stat__plus{
  font-family:var(--display);font-style:normal;font-weight:400;
  font-size:clamp(24px,2.4vw,36px);line-height:1;
  background:linear-gradient(135deg, var(--gold-light), var(--gold-deep));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat span{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-mute);width:100%}

/* CHECK LIST */
.check-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 28px}
.check-list li{
  padding-left:20px;position:relative;line-height:1.45;
}
.check-list li::before{
  content:"";position:absolute;left:0;top:.55em;
  width:10px;height:1px;background:var(--gold);
}
.check-list strong{display:block;font-size:13.5px;font-weight:500;color:var(--fg);margin-bottom:2px}
.check-list span{font-size:12.5px;color:var(--fg-mute);line-height:1.5}

@media (max-width:680px){.check-list{grid-template-columns:1fr}}

/* ==========================================================================
   PILLARS (slide 03)
   ========================================================================== */
.grid-4{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  margin-top:24px;
}
.pillar-card{
  background:linear-gradient(180deg, var(--surface) 0%, var(--bg-2) 100%);
  border:1px solid var(--line);border-radius:18px;padding:32px 26px;
  position:relative;overflow:hidden;
  transition:transform .4s var(--ease), border-color .4s var(--ease);
  display:flex;flex-direction:column;gap:14px;
}
.pillar-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at top, rgba(184,149,114,.1), transparent 60%);
  opacity:0;transition:opacity .5s var(--ease);
}
.pillar-card:hover{transform:translateY(-6px);border-color:rgba(184,149,114,.32)}
.pillar-card:hover::before{opacity:1}
.pillar-card__num{
  font-family:var(--mono);color:var(--gold);font-size:11px;letter-spacing:.2em;font-weight:500;
}
.pillar-card__icon{
  width:44px;height:44px;border-radius:10px;
  border:1px solid var(--gold);color:var(--gold);
  display:flex;align-items:center;justify-content:center;
}
.pillar-card__icon svg{width:20px;height:20px}
.pillar-card h3{font-family:var(--display);font-size:22px;font-weight:400;line-height:1.2;letter-spacing:0}
.pillar-card p{font-size:13px;color:var(--fg-soft);line-height:1.55}

@media (max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid-4{grid-template-columns:1fr}}

/* ==========================================================================
   MEMBROS
   ========================================================================== */
.slide--member .two-col{gap:80px}
.member-photo{
  position:relative;width:100%;max-width:480px;aspect-ratio:4/5;
  border-radius:18px;overflow:hidden;
  box-shadow:0 40px 80px -20px rgba(0,0,0,.6), 0 0 0 1px var(--line);
}
.member-photo img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.4) contrast(1.05);
  transition:filter .8s var(--ease), transform 1.4s var(--ease);
}
.slide.is-active .member-photo img{filter:grayscale(0) contrast(1);transform:scale(1.03)}
.member-tag{
  position:absolute;top:18px;left:18px;
  background:rgba(10,10,12,.85);backdrop-filter:blur(8px);
  border:1px solid var(--gold);
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-light);
  padding:6px 12px;border-radius:999px;
}

.member-role{
  font-size:13px;letter-spacing:.06em;color:var(--gold);
  text-transform:uppercase;
}
.member-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.member-list li{
  font-size:14.5px;color:var(--fg-soft);line-height:1.5;
  padding-left:20px;position:relative;
}
.member-list li::before{content:"+";position:absolute;left:0;top:0;color:var(--gold);font-weight:300}
.member-list em{color:var(--gold-light);font-style:normal;font-size:13px}
.quote{
  font-family:var(--serif);font-size:21px;line-height:1.4;font-weight:300;letter-spacing:0;
  border-left:1px solid var(--gold);padding-left:20px;margin-top:12px;color:var(--fg-soft);
}
.quote em{font-family:var(--serif);color:var(--gold-light);font-style:italic;font-weight:400}

/* ==========================================================================
   GALERIA (slide 10)
   ========================================================================== */
.gallery{
  display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);
  gap:14px;height:100%;max-height:62vh;
}
.gallery__item{
  position:relative;overflow:hidden;border-radius:14px;border:1px solid var(--line);
  cursor:pointer;
}
.gallery__item--lg{grid-column:span 2;grid-row:span 2}
.gallery__item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease), filter .5s var(--ease);
  filter:brightness(.85);
}
.gallery__item:hover img{transform:scale(1.06);filter:brightness(1)}
.gallery__item figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:16px;color:#fff;
  background:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.85) 100%);
  transform:translateY(20%);opacity:0;
  transition:transform .4s var(--ease), opacity .4s var(--ease);
}
.gallery__item:hover figcaption{transform:translateY(0);opacity:1}
.gallery__item span{font-family:var(--mono);color:var(--gold);font-size:11px;letter-spacing:.2em;font-weight:500}
.gallery__item strong{display:block;font-family:var(--display);font-size:18px;font-weight:400;margin-top:4px;letter-spacing:0}

@media (max-width:980px){
  .gallery{grid-template-columns:repeat(2,1fr);max-height:none}
  .gallery__item--lg{grid-column:span 2;grid-row:span 1}
}

/* ==========================================================================
   VIDEO SLIDE
   ========================================================================== */
.slide--video .slide__inner{justify-content:flex-start;padding-top:20px}
.video-frame{
  width:100%;max-width:1100px;margin:0 auto;
  border-radius:18px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 40px 100px -30px rgba(0,0,0,.7);
  background:#000;
}
.video-frame video{width:100%;height:auto;display:block;max-height:62vh}

/* ==========================================================================
   PROCESSO
   ========================================================================== */
.process{
  position:relative;display:grid;grid-template-columns:repeat(6,1fr);gap:14px;
  margin-top:32px;
}
.process__line{
  position:absolute;top:30px;left:5%;right:5%;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);opacity:.5;
}
.process__step{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:20px 18px;display:flex;flex-direction:column;gap:8px;
  transition:transform .4s var(--ease), border-color .4s var(--ease);
}
.process__step:hover{transform:translateY(-4px);border-color:var(--gold)}
.process__step span{font-family:var(--display);color:var(--gold);font-size:28px;line-height:1;font-weight:400;letter-spacing:0}
.process__step h4{font-family:var(--display);font-size:17px;font-weight:400;letter-spacing:0}
.process__step p{font-size:12.5px;color:var(--fg-mute);line-height:1.5}

@media (max-width:1024px){.process{grid-template-columns:repeat(3,1fr)}.process__line{display:none}}
@media (max-width:600px){.process{grid-template-columns:repeat(2,1fr)}}

/* ==========================================================================
   QUOTE SLIDE
   ========================================================================== */
.slide--quote .slide__inner{align-items:center;text-align:center}
.quote-wrap{display:flex;flex-direction:column;align-items:center;gap:32px}
.big-quote{
  font-family:var(--display);font-weight:400;
  font-size:clamp(32px, 4.4vw, 64px);line-height:1.22;letter-spacing:0;
  max-width:1100px;color:var(--fg);position:relative;
}
.big-quote span{
  font-family:var(--serif);font-weight:300;font-size:1.6em;color:var(--gold);
  position:absolute;line-height:.6;font-style:italic;
}
.big-quote span:first-child{top:-.1em;left:-.5em}
.big-quote span.close{bottom:-.5em;right:-.5em}
.big-quote em{font-family:var(--serif);font-style:italic;color:var(--gold-light);font-weight:300}
.quote-author{font-size:13px;letter-spacing:.2em;color:var(--gold);text-transform:uppercase}

/* ==========================================================================
   CTA FINAL SLIDE
   ========================================================================== */
.slide--cta .slide__inner.cta-wrap{
  align-items:center;text-align:center;gap:24px;
  max-width:1000px;margin:0 auto;
}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.contacts{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  width:100%;max-width:820px;margin:24px auto 0;
  padding-top:32px;border-top:1px solid var(--line);text-align:left;
}
.contacts > div{display:flex;flex-direction:column;gap:4px}
.contacts span{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.contacts strong{font-family:var(--display);font-size:18px;font-weight:400;color:var(--fg);letter-spacing:0}
.cta-thanks{
  font-family:var(--serif);font-style:italic;font-size:36px;color:var(--gold-light);
  margin-top:16px;font-weight:300;letter-spacing:0;
}

@media (max-width:768px){.contacts{grid-template-columns:1fr;text-align:center}.contacts > div{align-items:center}}

/* ==========================================================================
   OVERVIEW (mode O)
   ========================================================================== */
.overview{
  position:fixed;inset:0;z-index:200;
  background:rgba(8,8,10,.96);backdrop-filter:blur(20px);
  display:none;flex-direction:column;
  padding:32px 48px;
}
.overview.is-open{display:flex;animation:fadeIn .4s var(--ease)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.overview__head{display:flex;justify-content:space-between;align-items:center;padding:0 0 24px;border-bottom:1px solid var(--line)}
.overview__head h3{font-family:var(--display);font-size:24px;font-weight:400;color:var(--gold-light);letter-spacing:0}
.overview__head button{font-size:32px;color:var(--fg-soft);width:40px;height:40px;border-radius:50%;border:1px solid var(--line-strong)}
.overview__head button:hover{color:var(--fg);border-color:var(--gold)}
.overview__grid{
  display:grid;grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));gap:18px;
  padding:24px 0 32px;overflow-y:auto;flex:1;
}
.over-card{
  aspect-ratio:16/9;border-radius:10px;border:1px solid var(--line);
  background:var(--surface);overflow:hidden;cursor:pointer;
  position:relative;transition:transform .3s var(--ease), border-color .3s var(--ease);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:14px;color:var(--fg);
}
.over-card:hover{transform:translateY(-4px);border-color:var(--gold)}
.over-card span{
  position:absolute;top:12px;left:14px;
  font-family:var(--mono);font-weight:500;
  font-size:10px;letter-spacing:.2em;color:var(--gold);
}
.over-card strong{font-family:var(--display);font-size:17px;font-weight:400;line-height:1.3;letter-spacing:0}

/* ==========================================================================
   ANIMAÇÕES DOS ELEMENTOS [data-anim]
   ========================================================================== */
[data-anim]{
  opacity:0;transform:translateY(28px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
}
.slide.is-active [data-anim]{opacity:1;transform:translateY(0)}
.slide.is-active [data-anim]:nth-child(1){transition-delay:.15s}
.slide.is-active [data-anim]:nth-child(2){transition-delay:.28s}
.slide.is-active [data-anim]:nth-child(3){transition-delay:.4s}
.slide.is-active [data-anim]:nth-child(4){transition-delay:.5s}
.slide.is-active [data-anim]:nth-child(5){transition-delay:.6s}
.slide.is-active [data-anim]:nth-child(6){transition-delay:.7s}
.slide.is-active [data-anim]:nth-child(7){transition-delay:.8s}
.slide.is-active [data-anim]:nth-child(8){transition-delay:.9s}

/* pillar/member/process delay cascade for grids */
.slide.is-active .grid-4 .pillar-card[data-anim]:nth-child(1){transition-delay:.3s}
.slide.is-active .grid-4 .pillar-card[data-anim]:nth-child(2){transition-delay:.4s}
.slide.is-active .grid-4 .pillar-card[data-anim]:nth-child(3){transition-delay:.5s}
.slide.is-active .grid-4 .pillar-card[data-anim]:nth-child(4){transition-delay:.6s}

.slide.is-active .process .process__step[data-anim]:nth-child(1){transition-delay:.3s}
.slide.is-active .process .process__step[data-anim]:nth-child(2){transition-delay:.4s}
.slide.is-active .process .process__step[data-anim]:nth-child(3){transition-delay:.5s}
.slide.is-active .process .process__step[data-anim]:nth-child(4){transition-delay:.6s}
.slide.is-active .process .process__step[data-anim]:nth-child(5){transition-delay:.7s}
.slide.is-active .process .process__step[data-anim]:nth-child(6){transition-delay:.8s}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important}
  [data-anim]{opacity:1 !important;transform:none !important}
}

/* ==========================================================================
   RESPONSIVE — Otimização completa
   Breakpoints: 1280 (laptop), 1024 (tablet land), 768 (tablet port), 560 (mobile L), 380 (mobile S)
   ========================================================================== */

/* Laptop pequeno */
@media (max-width:1280px){
  .slide{padding:40px 48px}
  .slide__inner{gap:22px}
  .two-col, .two-col--rev{gap:48px}
  .check-list{gap:12px 22px}
  .pillar-card{padding:26px 22px}
}

/* Desktop/laptop com pouca altura: preserva o deck sem cortar barras ou CTA */
@media (min-width:981px) and (max-height:820px){
  .slide{padding:30px 64px}
  .slide__inner{gap:18px}
  .title-xl{font-size:clamp(38px,4.8vw,66px);line-height:1.05}
  .title-lg{font-size:clamp(32px,4vw,52px)}
  .lead{font-size:clamp(14px,1vw,16px);line-height:1.55}

  .cover__top{margin-bottom:20px}
  .cover__logo{width:170px;margin-bottom:28px}
  .cover__title{font-size:clamp(52px,6.4vw,92px);line-height:.98;margin-bottom:22px}
  .cover__sub{font-size:17px;line-height:1.5;margin-bottom:34px;max-width:580px}
  .cover__meta{padding-top:22px;gap:40px}
  .cover__meta strong{font-size:16px}

  .grid-4{margin-top:18px}
  .pillar-card{padding:24px 22px}
  .pillar-card h3{font-size:20px}

  .frame{max-height:62vh}
  .frame--tall{max-height:66vh}
  .member-photo{max-width:420px}
  .slide--member .two-col{gap:56px}
  .member-list{gap:6px}
  .quote{font-size:19px;margin-top:8px}

  .gallery{max-height:58vh}
  .slide--video .slide__inner{padding-top:0}
  .video-frame video{max-height:56vh}
  .process{margin-top:22px}
  .process__step{padding:16px 16px}
  .big-quote{font-size:clamp(30px,4vw,54px)}

  .slide--cta .slide__inner.cta-wrap{gap:16px}
  .slide--cta .lead{max-width:760px}
  .contacts{margin-top:16px;padding-top:24px}
  .cta-thanks{font-size:30px;margin-top:8px}
  .btn--lg{padding:17px 30px}
}

/* Tablet landscape */
@media (max-width:1024px){
  .slide{padding:32px 28px}
  .chrome{padding:0 16px}
  .chrome__title{display:none}
  .slide__inner{gap:18px}
  .two-col, .two-col--rev{gap:36px}
  .stats{gap:16px}
  .grid-4{grid-template-columns:repeat(2,1fr);gap:16px}
  .process{grid-template-columns:repeat(3,1fr)}
  .process__line{display:none}
  .gallery{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr)}
  .gallery__item--lg{grid-column:span 2;grid-row:span 2}
}

/* Tablet portrait — ponto crítico onde colunas viram empilhadas */
@media (max-width:980px){
  .deck{
    overflow-y:auto;overflow-x:hidden;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:y proximity;
    scroll-behavior:smooth;
  }
  .slide{
    position:relative;inset:auto;
    min-height:calc(100vh - var(--chrome-h) * 2);
    height:auto;
    opacity:1 !important;visibility:visible !important;transform:none !important;
    padding:60px 28px;
    overflow:visible;
    scroll-snap-align:start;
    page-break-after:always;
  }
  .slide.is-active, .slide.is-prev{transform:none !important}
  /* Em mobile, a "navegação" vira scroll vertical natural — esconde dots/nav-arrow extra controles ficam */
  .chrome--bottom{justify-content:space-between}
  .counter{min-width:auto}
  .dots{display:none}
  .progress{display:none}
  .hint{display:none}

  .slide__inner{height:auto;min-height:auto}
  .two-col, .two-col--rev{
    grid-template-columns:1fr;
    gap:32px;
  }
  .two-col--rev .two-col__right{order:-1}
  .two-col__right{justify-content:center}

  /* Reduz tamanho das imagens quando empilhadas */
  .frame, .frame--tall{
    aspect-ratio:4/3;max-height:50vh;width:100%;max-width:540px;margin:0 auto;
  }
  .member-photo{
    aspect-ratio:1/1;max-width:340px;max-height:50vh;margin:0 auto;
  }

  /* Cover */
  .cover__logo{width:180px;margin-bottom:32px}
  .cover__top{margin-bottom:24px}
  .cover__sub{margin-bottom:36px}
  .cover__meta{gap:24px;grid-template-columns:repeat(2,max-content)}

  /* Stats */
  .stats{grid-template-columns:repeat(3,1fr);gap:14px}

  /* Service lists */
  .check-list{grid-template-columns:1fr 1fr;gap:14px 20px}
  .pillars{grid-template-columns:1fr 1fr}
}

/* Tablet portrait pequeno / mobile landscape */
@media (max-width:768px){
  :root{--chrome-h:52px}
  .slide{padding:48px 22px}
  .slide__inner{gap:16px}

  .chrome{padding:0 12px;gap:8px}
  .chrome__brand{flex:0 0 auto}
  .chrome__logo{height:20px}
  .chrome__btn{width:34px;height:34px;border-radius:6px}
  .chrome__btn svg{width:14px;height:14px}
  .chrome__actions{gap:6px}

  .nav-arrow{width:38px;height:38px}
  .nav-arrow svg{width:15px;height:15px}
  .counter{font-size:12px;gap:8px}
  .counter i{width:16px}
  #current{font-size:13px}

  /* Cover */
  .cover__logo{width:140px;margin-bottom:24px}
  .cover__title{font-size:clamp(40px, 11vw, 72px);margin-bottom:24px;line-height:.98}
  .cover__sub{font-size:15px;margin-bottom:28px}
  .cover__meta{
    grid-template-columns:1fr 1fr;gap:16px 20px;
    padding-top:20px;
  }
  .cover__meta strong{font-size:14px}
  .cover__meta span{font-size:9px}

  /* Tipografia */
  .title-xl{font-size:clamp(34px, 9vw, 54px);line-height:1.05}
  .title-lg{font-size:clamp(28px, 7vw, 44px);line-height:1.1}
  .lead{font-size:15px;line-height:1.6}
  .eyebrow{font-size:9.5px;letter-spacing:.22em}

  /* Stats — uma linha 3 itens menor */
  .stats{padding-top:18px;margin-top:8px;gap:12px}
  .stat strong{font-size:32px}
  .stat .stat__plus{font-size:18px}
  .stat span{font-size:9px;letter-spacing:.12em}
  .stat__row{gap:0}

  /* Service / Check list */
  .check-list{grid-template-columns:1fr;gap:10px}
  .check-list strong{font-size:14px}
  .check-list span{font-size:12.5px}

  /* Pillars */
  .pillars{grid-template-columns:1fr;gap:18px}
  .grid-4{grid-template-columns:1fr 1fr;gap:12px}
  .pillar-card{padding:20px 18px;gap:10px}
  .pillar-card h3{font-size:18px}
  .pillar-card p{font-size:12.5px}
  .pillar-card__icon{width:38px;height:38px}

  /* Member */
  .member-photo{max-width:280px;aspect-ratio:1/1}
  .member-tag{font-size:9px;padding:5px 10px;top:12px;left:12px}
  .slide--member .two-col{gap:28px}
  .member-role{font-size:12px}
  .member-list li{font-size:13px}
  .quote{font-size:17px;padding-left:16px;line-height:1.4}

  /* Frames */
  .frame, .frame--tall{aspect-ratio:4/3;max-height:42vh;max-width:480px}
  .frame__corner{width:18px;height:18px}
  .frame__corner.tl,.frame__corner.tr,.frame__corner.bl,.frame__corner.br{top:auto;bottom:auto;left:auto;right:auto}
  .frame__corner.tl{top:10px;left:10px}
  .frame__corner.tr{top:10px;right:10px}
  .frame__corner.bl{bottom:10px;left:10px}
  .frame__corner.br{bottom:10px;right:10px}
  .frame__badge{padding:10px 14px;bottom:14px;right:14px}
  .frame__badge strong{font-size:12px}
  .frame__badge small{font-size:9px}
  .frame__count{font-size:9px;padding:6px 10px;bottom:14px;left:14px}
  .frame--pdf{aspect-ratio:3/4;max-height:50vh}
  .frame__open{font-size:9.5px;padding:7px 12px;bottom:14px;right:14px}
  .case-note{font-size:12.5px;padding-top:12px}

  /* Gallery */
  .gallery{grid-template-columns:repeat(2,1fr);grid-template-rows:auto;gap:8px}
  .gallery__item, .gallery__item--lg{grid-column:span 1;grid-row:span 1;aspect-ratio:4/3}
  .gallery__item--lg{grid-column:span 2;aspect-ratio:16/9}
  .gallery__item figcaption{padding:10px;transform:translateY(0);opacity:1;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.85) 100%)}
  .gallery__item span{font-size:9px}
  .gallery__item strong{font-size:14px}

  /* Video */
  .video-frame video{max-height:55vh}

  /* Processo */
  .process{grid-template-columns:1fr 1fr;gap:10px}
  .process__step{padding:16px 14px;gap:6px}
  .process__step span{font-size:24px}
  .process__step h4{font-size:14px}
  .process__step p{font-size:11.5px;line-height:1.45}

  /* Quote */
  .big-quote{font-size:clamp(24px, 6vw, 38px);line-height:1.25;padding:0 .3em}
  .big-quote span{font-size:1.4em}
  .big-quote span:first-child{left:-.2em}
  .big-quote span.close{right:-.2em}

  /* CTA */
  .slide--cta .slide__inner.cta-wrap{gap:18px}
  .cta-actions{flex-direction:column;width:100%;gap:10px}
  .cta-actions .btn{width:100%;justify-content:center}
  .btn{padding:16px 22px;font-size:11.5px;letter-spacing:.1em}
  .btn--lg{padding:18px 24px;font-size:12px}
  .contacts{
    grid-template-columns:1fr;text-align:center;gap:18px;
    padding-top:24px;margin-top:14px;
  }
  .contacts > div{align-items:center}
  .contacts strong{font-size:16px}
  .contacts span{font-size:9px}
  .cta-thanks{font-size:26px;margin-top:8px}

  /* Overview */
  .overview{padding:20px 18px}
  .overview__head h3{font-size:18px}
  .overview__head button{width:34px;height:34px;font-size:24px}
  .overview__grid{
    grid-template-columns:repeat(auto-fill, minmax(160px,1fr));
    gap:10px;
  }
  .over-card{padding:10px}
  .over-card span{font-size:9px;top:8px;left:10px}
  .over-card strong{font-size:13px}
}

/* Mobile médio */
@media (max-width:560px){
  .slide{padding:40px 18px}

  .chrome--bottom{padding:0 12px}

  /* Stats em 3 colunas ainda, mas compacto */
  .stats{
    grid-template-columns:repeat(3,1fr);
    gap:8px;padding-top:14px;
  }
  .stat strong{font-size:26px}
  .stat .stat__plus{font-size:15px}
  .stat span{font-size:8.5px;letter-spacing:.1em}

  /* Diferenciais 1 col */
  .grid-4{grid-template-columns:1fr;gap:10px}

  /* Process 1 col */
  .process{grid-template-columns:1fr;gap:8px}

  /* Cover meta — 1 col */
  .cover__meta{grid-template-columns:1fr;gap:14px}

  /* Member photo um pouco menor */
  .member-photo{max-width:240px}

  /* Frame max menor */
  .frame, .frame--tall{max-height:38vh}
  .frame--pdf{max-height:46vh}

  /* Gallery 1 col com lg ocupando 1 row */
  .gallery{grid-template-columns:1fr}
  .gallery__item, .gallery__item--lg{grid-column:span 1;aspect-ratio:16/10}

  /* Counter em letras menores */
  .counter{font-size:11px;gap:6px}
  .nav-arrow{width:36px;height:36px}
}

/* Mobile pequeno (320-380px) */
@media (max-width:380px){
  .slide{padding:36px 14px}
  .cover__logo{width:120px}
  .cover__title{font-size:38px;margin-bottom:18px}
  .cover__sub{font-size:14px;margin-bottom:24px}
  .title-xl{font-size:32px}
  .title-lg{font-size:26px}
  .lead{font-size:14px}
  .stats{gap:6px}
  .stat strong{font-size:22px}
  .stat .stat__plus{font-size:13px}
  .quote{font-size:15px}
  .member-list li{font-size:12.5px}
  .check-list strong{font-size:13.5px}
  .check-list span{font-size:12px}
  .chrome__logo{height:18px}
  .chrome__btn{width:32px;height:32px}
}

/* Mobile polish: safe-area, tap targets and lighter rendering */
@media (max-width:980px){
  html,body{
    height:100%;
    overscroll-behavior:none;
  }

  .deck{
    top:calc(var(--chrome-h) + env(safe-area-inset-top));
    bottom:calc(var(--chrome-h) + env(safe-area-inset-bottom));
    scroll-snap-type:y proximity;
    scroll-padding-block:0;
    overscroll-behavior-y:contain;
  }

  .slide{
    min-height:calc(100svh - (var(--chrome-h) * 2) - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    padding-block:clamp(28px, 5svh, 44px);
  }

  .slide__inner{
    width:100%;
    max-width:560px;
    margin-inline:auto;
  }

  .chrome{
    padding-left:calc(12px + env(safe-area-inset-left));
    padding-right:calc(12px + env(safe-area-inset-right));
  }

  .chrome--top{
    height:calc(var(--chrome-h) + env(safe-area-inset-top));
    padding-top:env(safe-area-inset-top);
  }

  .chrome--bottom{
    height:calc(var(--chrome-h) + env(safe-area-inset-bottom));
    padding-bottom:env(safe-area-inset-bottom);
  }

  .chrome__btn,
  .nav-arrow{
    width:44px;
    height:44px;
    min-width:44px;
    min-height:44px;
  }

  .chrome__logo{max-width:96px}

  .badge{
    max-width:100%;
    white-space:normal;
    text-align:center;
    line-height:1.35;
  }

  .title-xl,
  .title-lg,
  .cover__title,
  .big-quote{
    text-wrap:balance;
  }

  .lead,
  .cover__sub{
    text-wrap:pretty;
  }

  .cover__meta,
  .contacts{
    width:100%;
  }

  .cover__meta strong,
  .contacts strong,
  .btn{
    overflow-wrap:anywhere;
  }

  .frame,
  .member-photo,
  .video-frame,
  .gallery__item,
  .pillar-card,
  .process__step{
    border-radius:14px;
  }

  [data-anim],
  [data-blur-in]{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
  }

  [data-reveal-img]{
    clip-path:inset(0) !important;
  }

  [data-kenburns],
  .slide.is-active [data-kenburns]{
    animation:none !important;
  }

  .slide.is-active .frame img,
  .slide.is-active .member-photo img{
    transform:none;
  }

  .slide__blob{
    filter:blur(36px);
    opacity:.72;
  }
}

@supports (height:100dvh){
  @media (max-width:980px){
    .slide{
      min-height:calc(100dvh - (var(--chrome-h) * 2) - env(safe-area-inset-top) - env(safe-area-inset-bottom));
      padding-block:clamp(28px, 5dvh, 44px);
    }
  }
}

@media (max-width:560px){
  .pillar-card{padding:18px 16px}
  .process__step{padding:15px 14px}
  .gallery{gap:10px}
  .member-tag{
    max-width:calc(100% - 24px);
    white-space:normal;
    line-height:1.2;
  }
}

@media (max-width:380px){
  .badge{
    padding:7px 10px;
    font-size:8.5px;
    letter-spacing:.1em;
  }

  .btn,
  .btn--lg{
    gap:8px;
    padding:14px 14px;
    font-size:10px;
    letter-spacing:.06em;
  }

  .btn svg{width:14px;height:14px;flex:0 0 auto}
  .cover__meta strong{font-size:13px}
  .contacts strong{font-size:14.5px}
}

/* Landscape em phones (altura curta) */
@media (max-height:520px) and (orientation:landscape){
  .slide{padding:32px 28px}
  .cover__logo{width:120px;margin-bottom:14px}
  .cover__title{font-size:clamp(32px,6vw,52px);margin-bottom:14px}
  .cover__sub{margin-bottom:18px;font-size:14px}
  .cover__meta{padding-top:14px}
  .frame, .frame--tall, .member-photo{max-height:65vh}
  .stats{padding-top:12px;margin-top:6px}
  .slide__inner{gap:14px}
}

/* Quando o usuário prefere movimento reduzido + mobile */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important}
  [data-anim]{opacity:1 !important;transform:none !important}
  .slide{opacity:1 !important;visibility:visible !important;transform:none !important}
  .slide__blob{display:none}
  [data-kenburns]{animation:none !important}
}
