/* ============================================================
   ZOIO — Apresentação de marca · styles
   Irezumi · Dallas · dark & gold
   ============================================================ */

:root{
  --ink:        #100E0A;   /* sumi quente — substituto do preto puro */
  --ink-deep:   #16120C;
  --char:       #1F1A12;   /* carvão quente */
  --char-soft:  #2A241A;
  --leather:    #4A3728;
  --gold:       #C8973A;
  --gold-soft:  #E0B860;
  --gold-glow:  #F0D38A;
  --red:        #8B1A1A;
  --red-soft:   #A83232;
  --cream:      #F5F0E8;
  --cream-dim:  #D8CFC0;
  --cream-mute: #A59B8B;

  --paper:      #F5F0E8;
  --paper-warm: #EDE5D6;

  --line:       rgba(245,240,232,0.13);
  --line-gold:  rgba(200,151,58,0.30);
  --line-dark:  rgba(26,20,12,0.14);

  --display: 'Cormorant Garamond', Georgia, serif;
  --sans:    'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Arial, sans-serif;

  --ease-cinema: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-slow:   cubic-bezier(0.65, 0.05, 0.36, 1);
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  background:var(--ink);
  color:var(--cream);
  font-family:var(--sans);
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
em{ font-style:italic; }
strong{ font-weight:500; color:var(--gold-soft); }

/* ====== TIPOGRAFIA UTIL ====== */
.display-l{ font-family:var(--display); font-weight:500; font-size:clamp(44px,6.4vw,96px); line-height:1.02; letter-spacing:-0.01em; }
.display-m{ font-family:var(--display); font-weight:500; font-size:clamp(32px,4.6vw,68px); line-height:1.05; letter-spacing:-0.008em; }
.display-l em, .display-m em{ color:var(--gold); }

.plate-no{
  font-family:var(--sans); font-weight:500; font-size:11px;
  letter-spacing:0.4em; text-transform:uppercase; color:var(--gold);
  margin-bottom:26px;
}
.plate-no.center{ text-align:center; }
.kicker{
  font-family:var(--sans); font-weight:500; font-size:12px;
  letter-spacing:0.32em; text-transform:uppercase; color:var(--cream-mute);
  margin-bottom:22px;
}

.frame{ max-width:1240px; margin:0 auto; padding:140px 56px; }

/* ====== PROGRESS ====== */
.progress{ position:fixed; top:0; left:0; right:0; height:2px; background:rgba(245,240,232,0.06); z-index:120; }
.progress .bar{ height:100%; width:0%; background:linear-gradient(90deg,var(--red),var(--gold)); }

/* ====== NAV ====== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 40px;
  background:linear-gradient(180deg, rgba(16,14,10,0.82) 0%, rgba(16,14,10,0) 100%);
  backdrop-filter:blur(2px);
}
.nav-brand{ display:flex; align-items:center; gap:11px; text-decoration:none; }
.nav-eye{ width:30px; height:30px; }
.nav-word{ font-family:var(--display); font-weight:600; font-size:22px; letter-spacing:0.18em; color:var(--cream); }
.nav-meta{ display:flex; align-items:center; gap:10px; font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--cream-mute); }
.nav-sep{ color:var(--gold); }

/* ====== BLEED / BG / VEIL ====== */
.bleed{ position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; }
.bg{
  position:absolute; inset:-6% -2%; z-index:0;
  background-size:cover; background-position:center;
  will-change:transform;
}
.veil{ position:absolute; inset:0; z-index:1; }

/* ====== HERO ====== */
.hero .bg{ background-position:center 22%; }
.hero .veil{
  background:
    linear-gradient(180deg, rgba(16,14,10,0.55) 0%, rgba(16,14,10,0.18) 35%, rgba(16,14,10,0.85) 100%),
    radial-gradient(120% 90% at 75% 40%, rgba(200,151,58,0.10), transparent 55%);
}
.hero-frame{ position:relative; z-index:2; width:100%; padding-top:120px; padding-bottom:80px; }
.top-line{ display:flex; justify-content:space-between; align-items:flex-start; gap:20px; }
.crest{ font-family:var(--display); font-size:19px; color:var(--cream-dim); }
.crest em{ color:var(--gold); }
.meta{ text-align:right; font-size:11px; letter-spacing:0.22em; text-transform:uppercase; color:var(--cream-mute); line-height:1.7; }
.hero-h1{
  font-family:var(--display); font-weight:500;
  font-size:clamp(48px,9vw,140px); line-height:0.98; letter-spacing:-0.015em;
  margin:clamp(60px,14vh,150px) 0;
  text-shadow:0 2px 40px rgba(0,0,0,0.5);
}
.hero-h1 em{ color:var(--gold); }
.bottom-line{ display:flex; justify-content:space-between; align-items:flex-end; gap:20px; }
.signature{ font-family:var(--display); font-style:italic; font-size:21px; color:var(--cream-dim); line-height:1.5; }
.scroll-cue{ font-size:10px; letter-spacing:0.3em; text-transform:uppercase; color:var(--cream-mute); }
.scroll-cue span{ position:relative; padding-bottom:24px; }
.scroll-cue span::after{ content:''; position:absolute; bottom:0; left:50%; width:1px; height:18px; background:var(--gold); animation:cue 2s var(--ease-slow) infinite; }
@keyframes cue{ 0%,100%{ transform:scaleY(0.4); opacity:0.3; transform-origin:top; } 50%{ transform:scaleY(1); opacity:1; } }

/* hero text reveal */
.top-line, .hero-h1, .bottom-line{ opacity:0; transform:translateY(26px); animation:heroIn 1.4s var(--ease-cinema) forwards; }
.top-line{ animation-delay:0.5s; }
.hero-h1{ animation-delay:0.9s; }
.bottom-line{ animation-delay:1.5s; }
@keyframes heroIn{ to{ opacity:1; transform:none; } }

/* ====== REVEAL ====== */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1.3s var(--ease-cinema), transform 1.3s var(--ease-cinema); }
.reveal.in{ opacity:1; transform:none; }

/* ====== SECTION BG TONES ====== */
section.light{ background:var(--paper); color:var(--ink); }
section.light .plate-no{ color:var(--red); }
section.light .display-m em, section.light .display-l em{ color:var(--red); }
section.light strong{ color:var(--red); }

/* ====== OPENER ====== */
.opener{ background:linear-gradient(180deg, var(--ink) 0%, var(--ink-deep) 100%); }
.opener .reveal-text{ font-family:var(--display); font-weight:400; font-size:clamp(26px,3.6vw,52px); line-height:1.32; max-width:18ch; }
.opener .line{ display:block; overflow:hidden; }
.opener .line > span{ display:inline-block; transform:translateY(110%); transition:transform 1.3s var(--ease-cinema); }
.opener.in .line > span{ transform:translateY(0); }
.opener.in .line:nth-child(1) > span{ transition-delay:0.05s; }
.opener.in .line:nth-child(2) > span{ transition-delay:0.18s; }
.opener.in .line:nth-child(3) > span{ transition-delay:0.34s; }
.opener.in .line:nth-child(4) > span{ transition-delay:0.50s; }
.opener.in .line:nth-child(5) > span{ transition-delay:0.64s; }
.opener .reveal-text em{ color:var(--gold); }

/* ====== CHAPTER ====== */
.chapter{ background:var(--ink-deep); }
.chapter-grid{ max-width:1240px; margin:0 auto; padding:150px 56px; display:grid; grid-template-columns:1fr 1fr; gap:80px; }
.col-left{ position:sticky; top:120px; align-self:start; }
.col-right p{ font-size:18px; line-height:1.75; color:var(--cream-dim); margin-bottom:24px; max-width:46ch; }
.col-right .sig{ font-family:var(--display); font-style:italic; color:var(--gold); font-size:18px; margin-top:36px; }

/* ====== PLATE ====== */
.plate{ min-height:92vh; }
.plate-veil{ background:linear-gradient(90deg, rgba(16,14,10,0.88) 0%, rgba(16,14,10,0.45) 50%, rgba(16,14,10,0.2) 100%); }
.plate-frame{ position:relative; z-index:2; }
.plate-frame.right{ text-align:right; margin-left:auto; }
.plate-frame.right .plate-quote, .plate-frame.right .plate-cap{ margin-left:auto; }
.plate-quote{ font-family:var(--display); font-weight:400; font-size:clamp(34px,5.4vw,84px); line-height:1.08; max-width:16ch; color:var(--cream); }
.plate-quote em{ color:var(--gold); font-style:italic; }
.plate-cap{ margin-top:34px; font-size:11px; letter-spacing:0.28em; text-transform:uppercase; color:var(--cream-mute); }

/* ====== TRAJETÓRIA ====== */
.path{ background:linear-gradient(180deg, var(--ink-deep), var(--ink)); }
.path-title{ text-align:center; margin-top:14px; }
.path-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:34px; margin-top:80px; }
.path-col{ padding:38px 30px; border:1px solid var(--line); border-top:2px solid var(--line-gold); background:rgba(255,255,255,0.012); }
.path-era{ font-size:10px; letter-spacing:0.24em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.path-col h4{ font-family:var(--display); font-weight:500; font-size:34px; color:var(--cream); margin-bottom:16px; }
.path-col p{ font-size:15.5px; line-height:1.7; color:var(--cream-mute); }

/* ====== DNA ====== */
.dna{ background:var(--ink); }
.dna-title{ margin-bottom:64px; }
.dna .grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.dna .card{ background:var(--ink); padding:36px 28px; opacity:0; transform:translateY(24px); transition:opacity 1s var(--ease-cinema), transform 1s var(--ease-cinema); transition-delay:0s; min-height:230px; }
.dna.in .card{ opacity:1; transform:none; }
.dna.in .card:nth-child(1){ transition-delay:0.05s; } .dna.in .card:nth-child(2){ transition-delay:0.12s; }
.dna.in .card:nth-child(3){ transition-delay:0.19s; } .dna.in .card:nth-child(4){ transition-delay:0.26s; }
.dna.in .card:nth-child(5){ transition-delay:0.33s; } .dna.in .card:nth-child(6){ transition-delay:0.40s; }
.dna.in .card:nth-child(7){ transition-delay:0.47s; } .dna.in .card:nth-child(8){ transition-delay:0.54s; }
.dna .card .label{ font-size:10px; letter-spacing:0.22em; text-transform:uppercase; color:var(--gold); margin-bottom:22px; }
.dna .card h4{ font-family:var(--display); font-weight:500; font-size:27px; color:var(--cream); margin-bottom:14px; }
.dna .card p{ font-size:14.5px; line-height:1.62; color:var(--cream-mute); }

/* ====== DIAGNÓSTICO ====== */
.diag{ background:var(--ink-deep); }
.diag-title{ margin-bottom:60px; }
.diag-grid{ display:flex; flex-direction:column; }
.diag-row{ display:grid; grid-template-columns:1.1fr 1.6fr 0.3fr 1.6fr; gap:24px; align-items:center; padding:26px 0; border-top:1px solid var(--line); }
.diag-row:last-child{ border-bottom:1px solid var(--line); }
.diag-dim{ font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--gold); }
.diag-now{ font-size:16px; color:var(--cream-mute); font-style:italic; font-family:var(--display); }
.diag-arrow{ color:var(--red-soft); font-size:20px; text-align:center; }
.diag-next{ font-size:16.5px; color:var(--cream); line-height:1.5; }

/* ====== PALETA ====== */
.pal-title{ margin-bottom:18px; }
.pal-sub{ font-size:17px; line-height:1.7; color:#6a5f4e; max-width:54ch; margin-bottom:60px; }
.swatches{ display:grid; grid-template-columns:repeat(7,1fr); gap:16px; }
.sw{ transition:transform 0.5s var(--ease-cinema); }
.sw:hover{ transform:translateY(-8px); }
.chip{ aspect-ratio:1/1.4; border-radius:3px; box-shadow:0 8px 24px rgba(0,0,0,0.12); }
.sw-name{ font-size:13px; font-weight:500; color:var(--ink); margin-top:14px; }
.sw-hex{ font-size:11px; letter-spacing:0.08em; color:#998c77; margin-top:3px; }

/* ====== TIPOGRAFIA ====== */
.typo-title{ margin-bottom:60px; }
.typo-demos{ display:grid; grid-template-columns:1fr 1fr; gap:54px 60px; }
.typo-tag{ font-size:10px; letter-spacing:0.26em; text-transform:uppercase; color:var(--red); margin-bottom:18px; padding-bottom:14px; border-bottom:1px solid var(--line-dark); }
.typo-big{ font-family:var(--display); font-weight:500; font-size:clamp(44px,6vw,84px); line-height:1; color:var(--ink); }
.typo-big.italic{ font-style:italic; color:var(--red); }
.typo-body{ font-size:18px; line-height:1.7; color:#4a4034; max-width:42ch; }
.typo-label{ font-size:15px; font-weight:600; letter-spacing:0.3em; color:var(--ink); }

/* ====== LOGO SYSTEM ====== */
.logo-sys{ background:linear-gradient(180deg, var(--ink), var(--ink-deep)); }
.logo-title{ margin-bottom:24px; }
.logo-sub{ font-size:17px; line-height:1.75; color:var(--cream-dim); max-width:56ch; margin-bottom:70px; }
.logo-main{ display:flex; align-items:center; gap:50px; padding:70px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); justify-content:center; flex-wrap:wrap; }
.logo-big-eye{ width:140px; height:140px; }
.logo-lockup{ text-align:left; }
.logo-word{ font-family:var(--display); font-weight:600; font-size:clamp(56px,9vw,120px); letter-spacing:0.16em; line-height:1; color:var(--cream); }
.logo-tagline{ font-size:12px; letter-spacing:0.34em; color:var(--gold); margin-top:14px; }
.logo-apps{ display:grid; grid-template-columns:repeat(5,1fr); gap:24px; margin-top:60px; }
.app{ display:flex; flex-direction:column; align-items:center; gap:16px; padding:34px 14px; border:1px solid var(--line); }
.app > span{ font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--cream-mute); }
.app img{ width:38px; height:38px; }
.app-rounded{ width:54px !important; height:54px !important; border-radius:13px; }
.app-avatar{ width:54px; height:54px; border-radius:50%; background:var(--char); display:flex; align-items:center; justify-content:center; border:1px solid var(--line-gold); }
.app-avatar img{ width:34px; height:34px; }
.app-stamp{ width:54px; height:54px; display:flex; align-items:center; justify-content:center; opacity:0.55; }
.app-btn{ display:flex; align-items:center; gap:8px; padding:10px 16px; border:1px solid var(--gold); border-radius:30px; }
.app-btn img{ width:20px; height:20px; }
.app-btn span{ font-size:12px; letter-spacing:0.1em; color:var(--gold); }

/* ====== ÍCONE REDUZIDO ====== */
.icon-title{ margin-bottom:20px; }
.icon-sub{ font-size:17px; line-height:1.7; color:#6a5f4e; max-width:52ch; margin-bottom:60px; }
.mockups{ display:grid; grid-template-columns:repeat(3,1fr); gap:34px; }
.mock{ display:flex; flex-direction:column; align-items:center; gap:20px; }
.mock-cap{ font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:#998c77; }
.mock-browser{ width:100%; max-width:300px; background:#fff; border-radius:10px 10px 6px 6px; box-shadow:0 14px 40px rgba(0,0,0,0.14); overflow:hidden; }
.mb-tab{ display:flex; align-items:center; gap:8px; padding:11px 14px; background:#ece5d8; font-size:12px; color:#3a3228; }
.mb-tab img{ width:15px; height:15px; }
.mb-tab span{ flex:1; }
.mb-tab i{ font-style:normal; color:#998c77; }
.mb-url{ padding:9px 14px; background:#fff; }
.mb-url span{ font-size:12px; color:#6a5f4e; background:#f1ece2; padding:5px 12px; border-radius:20px; display:inline-block; }
.mock-phone{ width:170px; height:200px; background:linear-gradient(160deg,#2a241a,#100e0a); border-radius:26px; padding:24px; border:5px solid #0a0907; }
.mp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; height:100%; }
.mp-grid span{ border-radius:9px; background:rgba(245,240,232,0.07); aspect-ratio:1; }
.mp-app{ background:none !important; }
.mp-app img{ width:100%; border-radius:11px; }
.mock-share{ width:100%; max-width:300px; display:flex; flex-direction:column; gap:12px; }
.ms-row{ display:flex; align-items:center; gap:13px; background:#fff; padding:13px; border-radius:11px; box-shadow:0 8px 24px rgba(0,0,0,0.08); }
.ms-row img{ width:42px; height:42px; border-radius:10px; }
.ms-row b{ display:block; font-size:14px; color:var(--ink); }
.ms-row span{ font-size:12px; color:#998c77; }

/* ====== PREVIEW SITE ====== */
.preview{ background:var(--ink); }
.prev-title{ margin-bottom:18px; }
.prev-sub{ font-size:18px; line-height:1.7; color:var(--cream-dim); max-width:50ch; margin-bottom:54px; }
.browser{ border-radius:12px; overflow:hidden; box-shadow:0 30px 80px rgba(0,0,0,0.5); border:1px solid var(--line); }
.br-bar{ display:flex; align-items:center; gap:8px; padding:13px 18px; background:#1a1610; border-bottom:1px solid var(--line); }
.br-dot{ width:11px; height:11px; border-radius:50%; background:#3a342a; }
.br-dot:nth-child(1){ background:#8B1A1A; } .br-dot:nth-child(2){ background:#C8973A; } .br-dot:nth-child(3){ background:#5C7547; }
.br-url{ margin-left:14px; display:flex; align-items:center; gap:8px; font-size:12px; color:var(--cream-mute); background:rgba(255,255,255,0.04); padding:6px 16px; border-radius:20px; }
.br-url img{ width:14px; height:14px; }
.br-screen{ background:var(--ink); }
.site-hero{ position:relative; min-height:480px; background-size:cover; background-position:center 20%; display:flex; flex-direction:column; }
.sh-veil{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(16,14,10,0.7) 0%, rgba(16,14,10,0.25) 40%, rgba(16,14,10,0.8) 100%); }
.sh-nav{ position:relative; z-index:2; display:flex; align-items:center; justify-content:space-between; padding:24px 38px; }
.sh-brand{ display:flex; align-items:center; gap:9px; font-family:var(--display); font-weight:600; font-size:20px; letter-spacing:0.16em; color:var(--cream); }
.sh-brand img{ width:26px; height:26px; }
.sh-links{ display:flex; align-items:center; gap:26px; font-size:13px; letter-spacing:0.06em; color:var(--cream-dim); }
.sh-cta{ padding:9px 20px; border:1px solid var(--gold); border-radius:30px; color:var(--gold); font-size:12px; letter-spacing:0.08em; cursor:default; }
.sh-cta.big{ padding:14px 30px; font-size:14px; background:var(--gold); color:var(--ink); border:none; margin-top:8px; }
.sh-center{ position:relative; z-index:2; margin-top:auto; padding:40px 38px 54px; }
.sh-kicker{ font-size:11px; letter-spacing:0.32em; color:var(--gold); margin-bottom:20px; }
.sh-center h3{ font-family:var(--display); font-weight:500; font-size:clamp(34px,5vw,60px); line-height:1.02; color:var(--cream); margin-bottom:28px; }
.sh-center h3 em{ color:var(--gold); }
.sh-center .sh-cta.big{ display:inline-block; }

.prev-block{ margin-top:54px; }
.prev-lbl{ font-size:11px; letter-spacing:0.26em; text-transform:uppercase; color:var(--gold); margin-bottom:24px; padding-bottom:14px; border-bottom:1px solid var(--line); }
.gal-filters{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:22px; }
.gf{ font-size:12px; letter-spacing:0.1em; padding:8px 18px; border:1px solid var(--line); border-radius:30px; color:var(--cream-mute); }
.gf.active{ background:var(--cream); color:var(--ink); border-color:var(--cream); }
.gal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.gal-item{ aspect-ratio:3/4; background-size:cover; background-position:center; border-radius:5px; }
.gal-item.tall{ grid-row:span 1; }

.booking{ display:grid; grid-template-columns:0.8fr 1.2fr; gap:40px; background:var(--ink-deep); border:1px solid var(--line); border-radius:10px; padding:44px; align-items:center; }
.bk-left h4{ font-family:var(--display); font-weight:500; font-size:34px; color:var(--cream); margin-bottom:18px; }
.bk-left p{ font-size:15px; line-height:1.7; color:var(--cream-mute); font-style:italic; font-family:var(--display); }
.bk-form{ display:flex; flex-direction:column; gap:16px; }
.bk-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.bk-field label{ display:block; font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold); margin-bottom:8px; }
.bk-input{ padding:13px 16px; background:rgba(255,255,255,0.03); border:1px solid var(--line); border-radius:6px; font-size:14px; color:var(--cream-dim); }
.bk-upload{ color:var(--cream-mute); }
.bk-submit{ margin-top:8px; padding:15px; text-align:center; background:var(--gold); color:var(--ink); font-size:14px; font-weight:500; letter-spacing:0.06em; border-radius:6px; }
.prev-note{ margin-top:34px; font-size:13px; color:var(--cream-mute); font-style:italic; text-align:center; }

/* ====== ESTRATÉGIA ====== */
.strat-title{ margin-bottom:60px; }
.strat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); }
.strat-card{ background:var(--paper); padding:40px 32px; }
.sc-num{ font-family:var(--display); font-size:30px; color:var(--red); margin-bottom:18px; }
.strat-card h4{ font-family:var(--display); font-weight:500; font-size:25px; color:var(--ink); margin-bottom:14px; }
.strat-card p{ font-size:15px; line-height:1.65; color:#5a5042; }

/* ====== GEO / IA ====== */
.geo{ background:var(--ink-deep); }
.geo-title{ margin-bottom:24px; }
.geo-sub{ font-size:18px; line-height:1.7; color:var(--cream-dim); max-width:56ch; margin-bottom:56px; }
.conversation{ display:flex; flex-direction:column; gap:18px; max-width:760px; margin:0 auto 70px; }
.bubble{ padding:24px 28px; border-radius:18px; }
.bubble .who{ display:flex; align-items:center; gap:9px; font-size:10px; letter-spacing:0.22em; text-transform:uppercase; margin-bottom:14px; }
.bubble .who img{ width:18px; height:18px; }
.bubble.user{ align-self:flex-end; max-width:78%; background:rgba(245,240,232,0.05); border:1px solid var(--line); border-bottom-right-radius:4px; }
.bubble.user .who{ color:var(--cream-mute); justify-content:flex-end; }
.bubble.user .msg{ font-size:18px; color:var(--cream); text-align:right; }
.bubble.assist{ align-self:flex-start; max-width:88%; background:linear-gradient(135deg, rgba(200,151,58,0.10), rgba(139,26,26,0.06)); border:1px solid var(--line-gold); border-bottom-left-radius:4px; }
.bubble.assist .who{ color:var(--gold); }
.bubble.assist .msg{ font-family:var(--display); font-size:21px; line-height:1.5; color:var(--cream); }
.bubble.assist .msg em{ color:var(--gold-soft); font-style:italic; }
.geo-pillars{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.geo-card{ background:var(--ink-deep); padding:36px 26px; }
.geo-num{ font-family:var(--display); font-size:30px; color:var(--gold); margin-bottom:18px; }
.geo-card h4{ font-family:var(--display); font-weight:500; font-size:23px; color:var(--cream); margin-bottom:13px; line-height:1.1; }
.geo-card p{ font-size:14px; line-height:1.62; color:var(--cream-mute); }
.geo-note{ margin-top:40px; text-align:center; font-family:var(--display); font-style:italic; font-size:20px; line-height:1.5; color:var(--cream-dim); max-width:60ch; margin-left:auto; margin-right:auto; }

/* ====== FUTURO ====== */
.future{ background:linear-gradient(180deg, var(--ink-deep), var(--ink)); }
.fut-title{ text-align:center; margin-bottom:70px; }
.fut-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:40px; }
.fut-col{ text-align:center; padding:0 18px; }
.fut-when{ font-size:11px; letter-spacing:0.26em; text-transform:uppercase; color:var(--gold); margin-bottom:26px; }
.fut-col p{ font-family:var(--display); font-style:italic; font-size:23px; line-height:1.5; color:var(--cream-dim); }

/* ====== CLOSING ====== */
.closing{ min-height:96vh; text-align:center; }
.close-veil{ background:linear-gradient(180deg, rgba(16,14,10,0.85), rgba(16,14,10,0.7) 50%, rgba(16,14,10,0.95)); }
.close-frame{ position:relative; z-index:2; margin:0 auto; text-align:center; }
.close-eye{ width:64px; height:64px; margin:0 auto 36px; }
.close-h{ font-family:var(--display); font-weight:500; font-size:clamp(40px,7vw,104px); line-height:1.02; color:var(--cream); }
.close-h em{ color:var(--gold); }
.close-sub{ font-size:18px; color:var(--cream-dim); margin:34px auto 44px; max-width:42ch; line-height:1.6; }
.close-cta{ display:inline-block; padding:18px 44px; background:var(--gold); color:var(--ink); font-size:15px; font-weight:500; letter-spacing:0.06em; border-radius:34px; text-decoration:none; transition:transform 0.4s var(--ease-cinema), box-shadow 0.4s; }
.close-cta:hover{ transform:translateY(-3px); box-shadow:0 16px 40px rgba(200,151,58,0.3); }

/* ====== FOOTER ====== */
.footer{ background:var(--ink); border-top:1px solid var(--line); }
.foot-frame{ display:flex; align-items:center; justify-content:space-between; gap:30px; padding:60px 56px; flex-wrap:wrap; }
.foot-brand{ display:flex; align-items:center; gap:11px; font-family:var(--display); font-weight:600; font-size:24px; letter-spacing:0.16em; color:var(--cream); }
.foot-brand img{ width:30px; height:30px; }
.foot-info{ display:flex; flex-direction:column; gap:6px; font-size:12px; letter-spacing:0.12em; color:var(--cream-mute); text-transform:uppercase; }
.foot-credit{ font-size:12px; line-height:1.7; color:var(--cream-mute); text-align:right; }
.foot-credit strong{ color:var(--gold); }

/* ====== RESPONSIVE ====== */
@media (max-width:1024px){
  .frame{ padding:110px 40px; }
  .chapter-grid{ grid-template-columns:1fr; gap:44px; padding:110px 40px; }
  .col-left{ position:static; }
  .dna .grid{ grid-template-columns:repeat(2,1fr); }
  .swatches{ grid-template-columns:repeat(4,1fr); }
  .typo-demos{ grid-template-columns:1fr; gap:44px; }
  .strat-grid{ grid-template-columns:repeat(2,1fr); }
  .geo-pillars{ grid-template-columns:repeat(2,1fr); }
  .logo-apps{ grid-template-columns:repeat(3,1fr); }
  .mockups{ grid-template-columns:1fr; gap:50px; max-width:420px; margin:0 auto; }
  .booking{ grid-template-columns:1fr; gap:30px; }
}
@media (max-width:640px){
  .frame{ padding:84px 22px; }
  .nav{ padding:14px 22px; }
  .nav-meta span:last-child{ display:none; }
  .top-line{ flex-direction:column; gap:14px; }
  .meta{ text-align:left; }
  .path-grid{ grid-template-columns:1fr; gap:18px; }
  .dna .grid{ grid-template-columns:1fr; }
  .dna .card{ min-height:auto; }
  .diag-row{ grid-template-columns:1fr; gap:8px; padding:22px 0; }
  .diag-arrow{ display:none; }
  .diag-now::before{ content:'hoje — '; color:var(--gold); }
  .diag-next::before{ content:'amanhã — '; color:var(--red-soft); }
  .swatches{ grid-template-columns:repeat(2,1fr); }
  .strat-grid{ grid-template-columns:1fr; }
  .geo-pillars{ grid-template-columns:1fr; }
  .bubble.user, .bubble.assist{ max-width:100%; }
  .logo-apps{ grid-template-columns:repeat(2,1fr); }
  .logo-main{ flex-direction:column; gap:30px; text-align:center; }
  .logo-lockup{ text-align:center; }
  .fut-grid{ grid-template-columns:1fr; gap:50px; }
  .gal-grid{ grid-template-columns:1fr 1fr; }
  .sh-links span, .sh-cta:not(.big){ display:none; }
  .bk-row{ grid-template-columns:1fr; }
  .foot-frame{ flex-direction:column; align-items:flex-start; text-align:left; }
  .foot-credit{ text-align:left; }
}
