/* Talamo — Landing de faturamento · dark-luxury editorial
   Newsreader + Geist + Geist Mono · midnight/petróleo + dourado/champanhe + bone.
   Mobile-first · 320 / 768 / 1024 / 1440. */

@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,300;0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,400;1,6..72,500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500&display=swap');

:root {
  --midnight: #16222F; --midnight-2: #0E1822; --midnight-3: #0A131B;
  --petrol: #112433; --petrol-soft: #1B3142;
  --ink-on-dark: #E9E2D2;
  --gold: #D4AF37; --gold-deep: #A68628; --gold-pale: #E8D58A; --champagne: #EBDCA8;
  --bone: #F4F0E8; --bone-deep: #ECE6D8; --ivory: #FAF7F0; --paper: #FFFEFA;
  --ink: #1B2A38; --ink-soft: #44546A; --ink-mute: #6B7785; --ink-faint: #9DA8B4;
  --line: rgba(27,42,56,.12); --line-soft: rgba(27,42,56,.07); --line-strong: rgba(27,42,56,.2);
  --line-d: rgba(233,226,210,.12); --line-d-soft: rgba(233,226,210,.07); --line-d-strong: rgba(233,226,210,.22);
  --celadon: #9CC5B4; --celadon-deep: #5C8A78; --signal: #C0563B;
  --display: 'Newsreader', Georgia, serif;
  --sans: 'Geist', -apple-system, 'Helvetica Neue', sans-serif;
  --mono: 'Geist Mono', 'SF Mono', monospace;
  --r-sm: 6px; --r-md: 10px; --r-lg: 16px; --r-xl: 24px; --r-2xl: 34px;
  --sh-1: 0 1px 2px rgba(10,19,27,.06);
  --sh-2: 0 8px 30px -12px rgba(10,19,27,.18);
  --sh-3: 0 30px 70px -28px rgba(10,19,27,.5);
  --sh-gold: 0 14px 34px -14px rgba(166,134,40,.5);
  --maxw: 1280px;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  margin: 0; font-family: var(--sans); color: var(--ink); background: var(--bone);
  -webkit-font-smoothing: antialiased; font-feature-settings: "ss01","cv11";
  letter-spacing: -.006em; line-height: 1.55; overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
h1,h2,h3,h4 { margin: 0; font-weight: 400; }
p { margin: 0; }
button { font-family: inherit; }
::selection { background: var(--gold-pale); color: var(--midnight); }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; border-radius: 2px; }

.neuron-def { position: absolute; width: 0; height: 0; overflow: hidden; }
.neuron { width: 100%; height: 100%; }

.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 22px; }
@media (min-width: 768px) { .wrap { padding: 0 40px; } }
@media (min-width: 1024px) { .wrap { padding: 0 56px; } }

.display { font-family: var(--display); font-weight: 400; letter-spacing: -.025em; line-height: 1.02; }
.display em { font-style: italic; color: var(--gold-deep); }
.sec-dark .display em, .hero .display em { color: var(--gold); }
.eyebrow {
  font-family: var(--mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--gold-deep); font-weight: 500; display: inline-flex; align-items: center; gap: 10px;
}
.eyebrow::before { content: ""; width: 22px; height: 1px; background: currentColor; opacity: .55; }
.eyebrow.center { justify-content: center; }
.sec-dark .eyebrow { color: var(--gold); }
.mono { font-family: var(--mono); }
.tag-pot {
  display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono);
  font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--gold-deep);
  background: rgba(166,134,40,.1); border: 1px solid rgba(166,134,40,.25);
  padding: 3px 8px; border-radius: 999px;
}
.sec-dark .tag-pot { color: var(--gold-pale); background: rgba(212,175,55,.1); border-color: rgba(212,175,55,.28); }

/* ============ BUTTONS ============ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  height: 54px; padding: 0 26px; border-radius: 999px;
  font: 600 15.5px/1 var(--sans); letter-spacing: -.01em; cursor: pointer;
  border: 1px solid transparent; transition: background .16s, color .16s, border-color .16s, transform .12s, box-shadow .16s;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn .ic { width: 17px; height: 17px; transition: transform .16s; }
.btn:hover .ic { transform: translateX(3px); }
.btn-gold { background: var(--gold); color: var(--midnight); box-shadow: var(--sh-gold); }
.btn-gold:hover { background: var(--champagne); }
.btn-dark { background: var(--midnight); color: var(--bone); }
.btn-dark:hover { background: var(--midnight-2); }
.btn-outline { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn-outline:hover { background: rgba(27,42,56,.04); border-color: var(--midnight); }
.btn-outline.on-dark { color: var(--bone); border-color: var(--line-d-strong); }
.btn-outline.on-dark:hover { background: rgba(233,226,210,.07); border-color: var(--bone); }
.btn-lg { height: 60px; padding: 0 32px; font-size: 16.5px; }
.btn-sm { height: 44px; padding: 0 18px; font-size: 14px; }
.btn-block { width: 100%; }

/* ============ NAV ============ */
.nav {
  position: sticky; top: 0; z-index: 60;
  background: rgba(244,240,232,.82); backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line); transition: box-shadow .2s, background .2s;
}
.nav.scrolled { box-shadow: var(--sh-1); }
.nav-in { display: flex; align-items: center; justify-content: space-between; height: 70px; gap: 18px; }
.brand { display: flex; align-items: center; gap: 11px; color: var(--midnight); }
.brand .mk { width: 34px; height: 34px; color: var(--gold-deep); flex: 0 0 auto; }
.brand .wm { font-family: var(--display); font-size: 27px; letter-spacing: -.02em; color: var(--midnight); line-height: 1; }
.nav-links { display: none; }
@media (min-width: 1024px) { .nav-links { display: flex; align-items: center; gap: 4px; } }
.nav-links a { font-size: 13.5px; color: var(--ink-soft); padding: 9px 13px; border-radius: 8px; font-weight: 500; transition: background .14s, color .14s; }
.nav-links a:hover { background: rgba(27,42,56,.05); color: var(--ink); }
.nav-cta { display: flex; align-items: center; gap: 10px; }
.nav-cta .ghost-link { display: none; font-size: 13.5px; color: var(--midnight); font-weight: 500; }
@media (min-width: 768px) { .nav-cta .ghost-link { display: inline; } }
.nav-burger { display: inline-grid; place-items: center; width: 44px; height: 44px; border: 1px solid var(--line-strong); border-radius: 10px; background: var(--paper); cursor: pointer; }
@media (min-width: 1024px) { .nav-burger { display: none; } }
.nav-burger svg { width: 20px; height: 20px; color: var(--midnight); }
.mobile-menu { display: none; position: fixed; inset: 70px 0 0; z-index: 55; background: var(--bone); padding: 24px 22px; flex-direction: column; gap: 4px; }
.mobile-menu.open { display: flex; }
.mobile-menu a { font-family: var(--display); font-size: 26px; color: var(--midnight); padding: 14px 0; border-bottom: 1px solid var(--line); }
.mobile-menu .btn { margin-top: 18px; }

/* ============ HERO ============ */
.hero { position: relative; background: radial-gradient(120% 90% at 80% 0%, var(--petrol) 0%, var(--midnight) 45%, var(--midnight-2) 100%); color: var(--ink-on-dark); overflow: hidden; }
.hero::after { content: ""; position: absolute; inset: 0; background-image: radial-gradient(rgba(233,226,210,.045) 1px, transparent 1px); background-size: 30px 30px; mask-image: linear-gradient(180deg, #000 0%, transparent 75%); pointer-events: none; }
.hero-in { position: relative; z-index: 2; padding: 56px 0 0; }
@media (min-width: 1024px) { .hero-in { padding: 84px 0 0; } }
.hero-top { display: grid; grid-template-columns: 1fr; gap: 30px; align-items: end; }
@media (min-width: 1024px) { .hero-top { grid-template-columns: 1.15fr .85fr; gap: 56px; } }
.hero h1 { font-size: clamp(38px, 7vw, 76px); color: var(--bone); margin-top: 22px; letter-spacing: -.035em; }
.hero h1 em { color: var(--gold); font-style: italic; }
.hero h1 .u { background: linear-gradient(180deg, transparent 62%, rgba(212,175,55,.4) 62%, rgba(212,175,55,.4) 92%, transparent 92%); }
.hero-sub { margin-top: 24px; font-family: var(--display); font-size: clamp(18px, 2.5vw, 23px); line-height: 1.5; color: var(--ink-on-dark); opacity: .82; max-width: 36ch; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 13px; margin-top: 32px; }
.hero-aside { padding-bottom: 4px; }
.hero-kpis { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1px; background: var(--line-d); border: 1px solid var(--line-d); border-radius: var(--r-md); overflow: hidden; }
@media (min-width: 1024px) { .hero-kpis { grid-template-columns: 1fr; gap: 1px; } }
.hero-kpis .k { background: rgba(233,226,210,.03); padding: 18px 20px; }
.hero-kpis .k b { font-family: var(--mono); font-size: clamp(22px,3vw,30px); color: var(--gold-pale); letter-spacing: -.02em; font-variant-numeric: tabular-nums; display: block; }
.hero-kpis .k span { font-size: 12px; color: var(--ink-on-dark); opacity: .66; margin-top: 3px; display: block; line-height: 1.35; }
.hero-trustline { margin-top: 26px; font-family: var(--mono); font-size: 11px; letter-spacing: .08em; color: var(--ink-on-dark); opacity: .55; text-transform: uppercase; }

/* hero product mock */
.mock-wrap { margin-top: 44px; position: relative; padding-bottom: 56px; }
@media (min-width: 1024px) { .mock-wrap { margin-top: 60px; padding-bottom: 76px; } }
.mock {
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg);
  box-shadow: var(--sh-3); overflow: hidden;
  display: grid; grid-template-columns: 1fr;
}
@media (min-width: 860px) { .mock { grid-template-columns: 200px 1fr 280px; } }
.mock-bar { display: flex; align-items: center; gap: 7px; padding: 12px 16px; border-bottom: 1px solid var(--line); grid-column: 1 / -1; background: var(--ivory); }
.mock-bar .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--line-strong); }
.mock-bar .ttl { margin-left: 10px; font-family: var(--mono); font-size: 10.5px; letter-spacing: .08em; color: var(--ink-mute); text-transform: uppercase; }
.mock-side { background: var(--bone-deep); border-right: 1px solid var(--line); padding: 14px 12px; display: none; }
@media (min-width: 860px) { .mock-side { display: block; } }
.mock-nav { display: flex; flex-direction: column; gap: 2px; }
.mock-nav .it { display: flex; align-items: center; gap: 9px; padding: 9px 11px; border-radius: 6px; font-size: 12.5px; color: var(--ink-soft); position: relative; }
.mock-nav .it svg { width: 15px; height: 15px; opacity: .7; }
.mock-nav .it.on { background: var(--paper); color: var(--midnight); font-weight: 500; box-shadow: var(--sh-1); }
.mock-nav .it.on::before { content: ""; position: absolute; left: -12px; top: 7px; bottom: 7px; width: 2px; background: var(--gold-deep); border-radius: 2px; }
.mock-main { padding: 22px 24px; min-width: 0; }
.mock-eyebrow { font-family: var(--mono); font-size: 10px; letter-spacing: .12em; color: var(--gold-deep); text-transform: uppercase; }
.mock-h { font-family: var(--display); font-size: clamp(22px,3vw,30px); color: var(--midnight); letter-spacing: -.025em; margin-top: 4px; line-height: 1.05; }
.mock-metrics { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; margin-top: 20px; padding-bottom: 18px; border-bottom: 1px solid var(--line); }
.mock-metrics .m { padding-left: 16px; border-left: 1px solid var(--line); }
.mock-metrics .m:first-child { padding-left: 0; border-left: 0; }
.mock-metrics .m .l { font-family: var(--mono); font-size: 8.5px; letter-spacing: .08em; color: var(--ink-mute); text-transform: uppercase; }
.mock-metrics .m .v { font-family: var(--mono); font-size: clamp(18px,2.4vw,24px); color: var(--midnight); letter-spacing: -.02em; margin-top: 6px; }
.mock-metrics .m .d { font-family: var(--mono); font-size: 9.5px; color: var(--celadon-deep); margin-top: 4px; }
.mock-bars { margin-top: 20px; display: flex; align-items: flex-end; gap: 8px; height: 96px; }
.mock-bars .bar { flex: 1; background: linear-gradient(180deg, var(--gold-pale), var(--gold)); border-radius: 4px 4px 0 0; opacity: .9; position: relative; }
.mock-bars .bar:last-child { background: linear-gradient(180deg, var(--midnight-soft, #44546A), var(--midnight)); }
.mock-bars .bar::after { content: attr(data-m); position: absolute; bottom: -18px; left: 0; right: 0; text-align: center; font-family: var(--mono); font-size: 8px; color: var(--ink-mute); }
.mock-aside { background: var(--ivory); border-top: 1px solid var(--line); padding: 18px 16px; }
@media (min-width: 860px) { .mock-aside { border-top: 0; border-left: 1px solid var(--line); } }
.mock-aside .lbl { font-family: var(--mono); font-size: 10px; letter-spacing: .12em; color: var(--gold-deep); text-transform: uppercase; }
.mock-card { margin-top: 12px; background: var(--midnight); color: var(--bone); border-radius: 8px; padding: 14px; }
.mock-card .t { font-family: var(--display); font-size: 18px; letter-spacing: -.02em; }
.mock-card .t b { color: var(--gold); }
.mock-card .row { display: flex; justify-content: space-between; margin-top: 10px; font-size: 11.5px; }
.mock-card .row span:first-child { color: var(--ink-on-dark); opacity: .6; font-family: var(--mono); font-size: 9px; letter-spacing: .08em; text-transform: uppercase; }
.mock-task { display: flex; gap: 9px; align-items: flex-start; padding: 11px 0; border-bottom: 1px solid var(--line-soft); }
.mock-task .pin { width: 8px; height: 8px; border-radius: 50%; margin-top: 4px; flex: 0 0 auto; }
.mock-task .pin.gold { background: var(--gold); } .mock-task .pin.cel { background: var(--celadon-deep); } .mock-task .pin.sig { background: var(--signal); }
.mock-task .tx b { font-size: 12.5px; color: var(--midnight); display: block; font-weight: 500; }
.mock-task .tx span { font-size: 11px; color: var(--ink-mute); }
.mock-float { position: absolute; background: var(--paper); border: 1px solid var(--line); border-radius: 12px; padding: 13px 16px; box-shadow: var(--sh-3); display: flex; align-items: center; gap: 11px; }
.mock-float.br { right: -6px; bottom: 18px; }
.mock-float .fi { width: 38px; height: 38px; border-radius: 10px; background: rgba(166,134,40,.12); color: var(--gold-deep); display: grid; place-items: center; flex: 0 0 auto; }
.mock-float .fi svg { width: 20px; height: 20px; }
.mock-float b { font-family: var(--mono); font-size: 17px; color: var(--midnight); display: block; letter-spacing: -.02em; }
.mock-float span { font-size: 11px; color: var(--ink-mute); }
@media (max-width: 600px) { .mock-float.br { display: none; } }

/* ============ SECTION SCAFFOLD ============ */
.sec { padding: 72px 0; }
@media (min-width: 768px) { .sec { padding: 104px 0; } }
.sec-dark { background: var(--midnight); color: var(--ink-on-dark); }
.sec-dark-2 { background: var(--midnight-2); color: var(--ink-on-dark); }
.sec-ivory { background: var(--ivory); }
.sec-head { max-width: 42ch; }
.sec-head.center { margin: 0 auto; text-align: center; }
.sec-head h2 { font-size: clamp(30px, 5vw, 52px); color: var(--midnight); margin-top: 16px; }
.sec-dark .sec-head h2, .sec-dark-2 .sec-head h2 { color: var(--bone); }
.sec-head p { margin-top: 18px; font-family: var(--display); font-size: clamp(17px,2.2vw,20px); line-height: 1.55; color: var(--ink-mute); }
.sec-dark .sec-head p, .sec-dark-2 .sec-head p { color: var(--ink-on-dark); opacity: .76; }

/* ============ CREDIBILITY ============ */
.cred { border-top: 1px solid var(--line-d); border-bottom: 1px solid var(--line-d); }
.cred-in { display: grid; grid-template-columns: 1fr; gap: 30px; padding: 30px 0; align-items: center; }
@media (min-width: 900px) { .cred-in { grid-template-columns: auto 1fr; gap: 48px; } }
.cred-logos { display: flex; flex-wrap: wrap; align-items: center; gap: 22px 30px; }
.cred-logos .lg { font-family: var(--display); font-size: 19px; color: var(--ink-on-dark); opacity: .6; letter-spacing: -.01em; white-space: nowrap; }
.cred-nums { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--line-d); border-radius: var(--r-md); overflow: hidden; }
.cred-nums .n { background: var(--midnight-2); padding: 18px 16px; text-align: center; }
.cred-nums .n b { font-family: var(--mono); font-size: clamp(22px,3.4vw,32px); color: var(--gold-pale); letter-spacing: -.02em; display: block; }
.cred-nums .n span { font-size: 11px; color: var(--ink-on-dark); opacity: .6; margin-top: 4px; display: block; line-height: 1.3; }

/* ============ DOR ============ */
.dor-grid { display: grid; grid-template-columns: 1fr; gap: 14px; margin-top: 48px; }
@media (min-width: 640px) { .dor-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .dor-grid { grid-template-columns: repeat(4,1fr); gap: 16px; } }
.dor-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 26px 22px; box-shadow: var(--sh-1); display: flex; flex-direction: column; gap: 12px; }
.dor-card .ico { width: 44px; height: 44px; border-radius: 12px; background: rgba(192,86,59,.1); color: var(--signal); display: grid; place-items: center; }
.dor-card .ico svg { width: 23px; height: 23px; }
.dor-card h3 { font-family: var(--display); font-size: 22px; color: var(--midnight); letter-spacing: -.02em; line-height: 1.1; }
.dor-card p { font-size: 13.5px; color: var(--ink-mute); line-height: 1.55; }
.dor-card .cost { margin-top: auto; font-family: var(--mono); font-size: 11px; letter-spacing: .04em; color: var(--signal); padding-top: 10px; border-top: 1px solid var(--line-soft); }

/* ============ ALAVANCAS (bento) ============ */
.alav { display: grid; grid-template-columns: 1fr; gap: 16px; margin-top: 52px; }
@media (min-width: 860px) { .alav { grid-template-columns: 1fr 1fr; gap: 18px; } }
.alav-card { position: relative; background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-xl); padding: 30px; overflow: hidden; box-shadow: var(--sh-1); display: flex; flex-direction: column; gap: 16px; transition: box-shadow .2s, transform .2s, border-color .2s; }
.alav-card:hover { box-shadow: var(--sh-2); transform: translateY(-3px); border-color: var(--line-strong); }
.alav-card.wide { grid-column: 1 / -1; }
@media (min-width: 860px) { .alav-card.wide { display: grid; grid-template-columns: 1.1fr .9fr; gap: 36px; align-items: center; } }
.alav-num { font-family: var(--mono); font-size: 11px; letter-spacing: .14em; color: var(--gold-deep); }
.alav-card h3 { font-family: var(--display); font-size: clamp(24px,3vw,30px); color: var(--midnight); letter-spacing: -.025em; line-height: 1.04; }
.alav-card .sup { font-size: 14.5px; color: var(--ink-soft); line-height: 1.6; }
.alav-feat { display: flex; flex-direction: column; gap: 8px; }
.alav-feat li { list-style: none; display: flex; gap: 9px; align-items: flex-start; font-size: 13px; color: var(--ink-soft); }
.alav-feat li svg { width: 16px; height: 16px; color: var(--gold-deep); flex: 0 0 auto; margin-top: 2px; }
.alav-card ul { margin: 0; padding: 0; }
.alav-result { margin-top: auto; display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid var(--line-soft); }
.alav-result .big { font-family: var(--mono); font-size: 26px; color: var(--midnight); letter-spacing: -.02em; }
.alav-result .lbl { font-size: 12px; color: var(--ink-mute); line-height: 1.35; }
.alav-viz { background: var(--ivory); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 18px; }

/* mini-viz pieces */
.viz-funnel { display: flex; flex-direction: column; gap: 7px; }
.viz-funnel .stage { height: 30px; border-radius: 5px; display: flex; align-items: center; padding: 0 12px; font-family: var(--mono); font-size: 10.5px; color: var(--midnight); background: var(--gold-pale); }
.viz-funnel .stage span { margin-left: auto; opacity: .7; }
.viz-bars2 { display: flex; align-items: flex-end; gap: 7px; height: 90px; }
.viz-bars2 .b { flex: 1; background: var(--bone-deep); border-radius: 4px 4px 0 0; position: relative; }
.viz-bars2 .b.hi { background: linear-gradient(180deg, var(--gold-pale), var(--gold)); }
.viz-ring { display: flex; align-items: center; gap: 14px; }
.viz-ring .donut { width: 76px; height: 76px; border-radius: 50%; background: conic-gradient(var(--gold) 0 72%, var(--bone-deep) 72% 100%); display: grid; place-items: center; flex: 0 0 auto; }
.viz-ring .donut::after { content: ""; width: 52px; height: 52px; border-radius: 50%; background: var(--ivory); }
.viz-ring .donut .val { position: absolute; font-family: var(--mono); font-size: 16px; color: var(--midnight); }
.viz-list { display: flex; flex-direction: column; gap: 8px; }
.viz-row { display: flex; align-items: center; gap: 10px; padding: 9px 11px; background: var(--paper); border: 1px solid var(--line); border-radius: 6px; font-size: 12px; color: var(--midnight); }
.viz-row .d { width: 7px; height: 7px; border-radius: 50%; flex: 0 0 auto; }
.viz-row .tag { margin-left: auto; font-family: var(--mono); font-size: 10px; color: var(--ink-mute); }

/* ============ COMO FUNCIONA ============ */
.steps { display: grid; grid-template-columns: 1fr; gap: 18px; margin-top: 52px; }
@media (min-width: 860px) { .steps { grid-template-columns: repeat(3,1fr); gap: 0; } }
.step { padding: 30px; position: relative; }
@media (min-width: 860px) { .step + .step { border-left: 1px solid var(--line-d); } }
.step .sn { font-family: var(--mono); font-size: 12px; letter-spacing: .12em; color: var(--gold); }
.step h3 { font-family: var(--display); font-size: 28px; color: var(--bone); letter-spacing: -.02em; margin-top: 12px; }
.step p { font-size: 14px; color: var(--ink-on-dark); opacity: .74; margin-top: 12px; line-height: 1.6; }
.step .ar { margin-top: 18px; color: var(--gold); }

/* ============ DIFERENCIAIS ============ */
.difs { display: grid; grid-template-columns: 1fr; gap: 14px; margin-top: 48px; }
@media (min-width: 640px) { .difs { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .difs { grid-template-columns: repeat(4,1fr); } }
.dif { padding: 26px; background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--sh-1); }
.dif .di { width: 46px; height: 46px; border-radius: 12px; background: var(--midnight); color: var(--gold); display: grid; place-items: center; margin-bottom: 16px; }
.dif .di svg { width: 23px; height: 23px; }
.dif h3 { font-family: var(--display); font-size: 21px; color: var(--midnight); letter-spacing: -.02em; }
.dif p { font-size: 13px; color: var(--ink-mute); margin-top: 8px; line-height: 1.55; }

/* ============ COMPARATIVO ============ */
.vs { display: grid; grid-template-columns: 1fr; gap: 16px; margin-top: 48px; }
@media (min-width: 820px) { .vs { grid-template-columns: 1fr 1fr; gap: 20px; } }
.vs-col { border-radius: var(--r-xl); padding: 32px 28px; }
.vs-before { background: var(--paper); border: 1px solid var(--line); }
.vs-after { background: linear-gradient(160deg, var(--midnight), var(--midnight-2)); color: var(--ink-on-dark); box-shadow: var(--sh-3); position: relative; overflow: hidden; }
.vs-after::before { content: ""; position: absolute; right: -40px; top: -40px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(212,175,55,.14), transparent 65%); }
.vs-col .hd { font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 6px; }
.vs-before .hd { color: var(--ink-mute); }
.vs-after .hd { color: var(--gold); }
.vs-col .big { font-family: var(--display); font-size: 26px; letter-spacing: -.02em; margin-bottom: 22px; }
.vs-before .big { color: var(--midnight); }
.vs-after .big { color: var(--bone); }
.vs-row { display: flex; gap: 12px; align-items: flex-start; padding: 12px 0; font-size: 14px; line-height: 1.45; }
.vs-row + .vs-row { border-top: 1px solid var(--line-soft); }
.vs-after .vs-row + .vs-row { border-top-color: var(--line-d-soft); }
.vs-row svg { width: 19px; height: 19px; flex: 0 0 auto; margin-top: 1px; }
.vs-before .vs-row { color: var(--ink-soft); } .vs-before .vs-row svg { color: var(--signal); }
.vs-after .vs-row { color: var(--ink-on-dark); } .vs-after .vs-row svg { color: var(--gold); }

/* ============ DEPOIMENTOS ============ */
.depo { display: grid; grid-template-columns: 1fr; gap: 16px; margin-top: 48px; }
@media (min-width: 768px) { .depo { grid-template-columns: repeat(3,1fr); } }
.depo-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-xl); padding: 30px 28px; box-shadow: var(--sh-1); display: flex; flex-direction: column; }
.depo-card .mk { font-family: var(--display); font-style: italic; font-size: 58px; line-height: .5; color: var(--gold-deep); height: 30px; }
.depo-card blockquote { margin: 6px 0 0; font-family: var(--display); font-size: 19px; line-height: 1.45; color: var(--midnight); letter-spacing: -.01em; flex: 1; }
.depo-card .who { margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--line-soft); display: flex; align-items: center; gap: 12px; }
.depo-card .av { width: 46px; height: 46px; border-radius: 50%; background: var(--bone-deep); display: grid; place-items: center; color: var(--ink-mute); flex: 0 0 auto; overflow: hidden; }
.depo-card .av svg { width: 22px; height: 22px; }
.depo-card .who b { font-size: 14px; color: var(--midnight); display: block; }
.depo-card .who span { font-family: var(--mono); font-size: 10px; letter-spacing: .06em; color: var(--ink-mute); text-transform: uppercase; }
.depo-pending { font-family: var(--mono); font-size: 9.5px; letter-spacing: .08em; color: var(--ink-faint); text-transform: uppercase; margin-top: 14px; }

/* ============ FAQ ============ */
.faq { max-width: 860px; margin: 44px auto 0; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 18px; padding: 24px 0; background: none; border: 0; cursor: pointer; text-align: left; color: var(--midnight); font-family: var(--display); font-size: clamp(19px,2.4vw,23px); letter-spacing: -.015em; }
.faq-q .pl { flex: 0 0 auto; width: 28px; height: 28px; border-radius: 8px; background: var(--ivory); display: grid; place-items: center; color: var(--gold-deep); transition: transform .2s, background .2s, color .2s; }
.faq-q .pl svg { width: 15px; height: 15px; }
.faq-item.open .faq-q .pl { background: var(--gold-deep); color: var(--bone); transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.faq-a-in { padding: 0 0 24px; font-size: 15px; color: var(--ink-soft); line-height: 1.65; max-width: 70ch; }
.faq-item.open .faq-a { max-height: 320px; }

/* ============ CTA FINAL + FORM ============ */
.cta-final { position: relative; overflow: hidden; }
.cta-final::before { content: ""; position: absolute; right: -10%; top: -20%; width: 50%; height: 140%; background: radial-gradient(circle, rgba(212,175,55,.12), transparent 62%); pointer-events: none; }
.cta-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr; gap: 40px; align-items: center; }
@media (min-width: 940px) { .cta-grid { grid-template-columns: 1.05fr .95fr; gap: 64px; } }
.cta-final h2 { font-size: clamp(32px,5.5vw,58px); color: var(--bone); }
.cta-final h2 em { color: var(--gold); font-style: italic; }
.cta-final .lede { margin-top: 20px; font-family: var(--display); font-size: 20px; line-height: 1.5; color: var(--ink-on-dark); opacity: .8; max-width: 44ch; }
.cta-final .reassure { margin-top: 26px; display: flex; flex-direction: column; gap: 10px; }
.cta-final .reassure div { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--ink-on-dark); opacity: .82; }
.cta-final .reassure svg { width: 17px; height: 17px; color: var(--gold); flex: 0 0 auto; }
.form-card { background: var(--paper); border-radius: var(--r-xl); padding: 32px; box-shadow: var(--sh-3); }
@media (min-width: 768px) { .form-card { padding: 38px; } }
.form-card .fh { font-family: var(--display); font-size: 26px; color: var(--midnight); letter-spacing: -.02em; }
.form-card .fsub { font-size: 13.5px; color: var(--ink-mute); margin-top: 6px; }
.field { margin-top: 18px; }
.field label { display: block; font-family: var(--mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 8px; }
.field label .req { color: var(--gold-deep); }
.input { width: 100%; height: 52px; padding: 0 15px; border: 1px solid var(--line-strong); border-radius: var(--r-md); background: var(--paper); font: 400 15px var(--sans); color: var(--ink); outline: none; transition: border-color .15s, box-shadow .15s; }
.input::placeholder { color: var(--ink-faint); }
.input:focus { border-color: var(--gold-deep); box-shadow: 0 0 0 3px rgba(166,134,40,.16); }
.input.err { border-color: var(--signal); box-shadow: 0 0 0 3px rgba(192,86,59,.14); }
.field-err { font-size: 12px; color: var(--signal); margin-top: 6px; display: none; }
.field-err.show { display: block; }
.form-card .btn { margin-top: 24px; }
.form-note { margin-top: 14px; font-size: 11.5px; color: var(--ink-mute); text-align: center; line-height: 1.5; }
.form-success { display: none; text-align: center; padding: 20px 0; }
.form-success.show { display: block; animation: fadeUp .5s ease both; }
.form-success .ck { width: 60px; height: 60px; border-radius: 50%; background: var(--celadon-deep); color: var(--paper); display: grid; place-items: center; margin: 0 auto 18px; }
.form-success .ck svg { width: 30px; height: 30px; }
.form-success h3 { font-family: var(--display); font-size: 28px; color: var(--midnight); letter-spacing: -.02em; }
.form-success p { font-size: 14px; color: var(--ink-mute); margin-top: 10px; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

/* ============ FOOTER ============ */
.footer { background: var(--midnight-3); color: var(--ink-on-dark); padding: 60px 0 30px; }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: 32px; padding-bottom: 40px; border-bottom: 1px solid var(--line-d); }
@media (min-width: 768px) { .footer-grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; } }
.footer .brand .wm { color: var(--bone); }
.footer .brand .mk { color: var(--gold); }
.footer-about { margin-top: 18px; font-family: var(--display); font-size: 16px; line-height: 1.5; color: var(--ink-on-dark); opacity: .66; max-width: 34ch; }
.footer h4 { font-family: var(--mono); font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; }
.footer-list { display: flex; flex-direction: column; gap: 10px; }
.footer-list a { font-size: 14px; color: var(--ink-on-dark); opacity: .76; }
.footer-list a:hover { opacity: 1; color: var(--bone); }
.footer-bot { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 12px; padding-top: 22px; }
.footer-bot span { font-family: var(--mono); font-size: 10.5px; letter-spacing: .06em; color: var(--ink-on-dark); opacity: .5; }

/* ============ JORNADA KANBAN ============ */
.jornada-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.jornada-total { text-align: right; flex: 0 0 auto; }
.jornada-total .lbl { font-family: var(--mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); opacity: .8; }
.jornada-total b { font-family: var(--mono); font-size: clamp(30px,4vw,42px); color: var(--gold-pale); letter-spacing: -.03em; display: block; line-height: 1; margin-top: 4px; font-variant-numeric: tabular-nums; }
.kanban {
  display: grid; grid-auto-flow: column; grid-auto-columns: 78%;
  gap: 14px; margin-top: 44px; overflow-x: auto; padding: 4px 4px 18px;
  scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch;
}
.kanban::-webkit-scrollbar { height: 6px; }
.kanban::-webkit-scrollbar-thumb { background: var(--line-d-strong); border-radius: 999px; }
@media (min-width: 640px) { .kanban { grid-auto-columns: 40%; } }
@media (min-width: 1024px) { .kanban { grid-template-columns: repeat(6,1fr); grid-auto-flow: row; gap: 12px; overflow: visible; } }
.kcol {
  scroll-snap-align: start; position: relative;
  background: rgba(233,226,210,.04); border: 1px solid var(--line-d);
  border-radius: var(--r-lg); padding: 20px 18px 18px;
  display: flex; flex-direction: column; gap: 14px; min-width: 0;
  transition: border-color .2s, transform .2s, background .2s;
}
.kcol:hover { transform: translateY(-3px); border-color: var(--line-d-strong); background: rgba(233,226,210,.06); }
.kcol.acquire { background: rgba(233,226,210,.05); }
.kcol.gold { background: rgba(212,175,55,.1); border-color: rgba(212,175,55,.28); }
.kcol.cel { background: rgba(156,197,180,.12); border-color: rgba(156,197,180,.28); }
.kcol.featured { background: var(--midnight-2); border-color: var(--gold-deep); box-shadow: var(--sh-2); }
.kcol-top { display: flex; align-items: center; justify-content: space-between; }
.kcol-ic { width: 38px; height: 38px; border-radius: 10px; background: rgba(233,226,210,.08); color: var(--gold-pale); display: grid; place-items: center; }
.kcol.gold .kcol-ic { background: rgba(166,134,40,.22); color: var(--gold-deep); }
.kcol.cel .kcol-ic { background: rgba(92,138,120,.22); color: var(--celadon-deep); }
.kcol.featured .kcol-ic { background: rgba(212,175,55,.18); color: var(--gold); }
.kcol-ic svg { width: 19px; height: 19px; }
.kcol-n { font-family: var(--mono); font-size: 11px; color: var(--ink-on-dark); opacity: .5; letter-spacing: .06em; }
.kcol.gold .kcol-n, .kcol.cel .kcol-n { color: var(--midnight); opacity: .5; }
.kcol h3 { font-family: var(--display); font-size: 21px; letter-spacing: -.02em; color: var(--bone); line-height: 1; }
.kcol.gold h3, .kcol.cel h3 { color: var(--midnight); }
.kcol .flow { font-family: var(--mono); font-size: 10px; letter-spacing: .04em; color: var(--ink-on-dark); opacity: .56; margin-top: 5px; text-transform: uppercase; }
.kcol.gold .flow, .kcol.cel .flow { color: var(--midnight); opacity: .6; }
.kcol .count { display: flex; align-items: baseline; gap: 7px; padding: 6px 0 2px; border-top: 1px solid var(--line-d-soft); }
.kcol.gold .count, .kcol.cel .count { border-top-color: rgba(27,42,56,.12); }
.kcol .count b { font-family: var(--mono); font-size: 30px; letter-spacing: -.03em; color: var(--gold-pale); line-height: 1; font-variant-numeric: tabular-nums; }
.kcol.gold .count b { color: var(--gold-deep); } .kcol.cel .count b { color: var(--celadon-deep); } .kcol.featured .count b { color: var(--gold); }
.kcol .count span { font-family: var(--mono); font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-on-dark); opacity: .5; }
.kcol.gold .count span, .kcol.cel .count span { color: var(--midnight); opacity: .55; }
.kcol .desc { font-size: 12.5px; line-height: 1.5; color: var(--ink-on-dark); opacity: .72; }
.kcol.gold .desc, .kcol.cel .desc { color: var(--midnight); opacity: .82; }
.kcol .ex { margin-top: auto; font-family: var(--mono); font-size: 8.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-on-dark); opacity: .4; }
.kcol.gold .ex, .kcol.cel .ex { color: var(--midnight); opacity: .5; }
.kanban-foot { margin-top: 22px; display: flex; align-items: flex-start; gap: 12px; padding: 18px 20px; background: rgba(233,226,210,.04); border: 1px solid var(--line-d); border-radius: var(--r-lg); }
.kanban-foot svg { width: 18px; height: 18px; color: var(--gold); flex: 0 0 auto; margin-top: 2px; }
.kanban-foot p { font-size: 13.5px; color: var(--ink-on-dark); opacity: .78; line-height: 1.55; }
.kanban-foot p b { color: var(--bone); opacity: 1; font-weight: 500; }
.kanban-hint { display: none; font-family: var(--mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-on-dark); opacity: .5; margin-top: 14px; align-items: center; gap: 7px; }
.kanban-hint svg { width: 14px; height: 14px; }
@media (max-width: 1023px) { .kanban-hint { display: flex; } }

/* ============ REVEAL ============ */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }
.reveal.shown { opacity: 1 !important; transform: none !important; transition: none !important; }
.reveal[data-d="1"] { transition-delay: .08s; } .reveal[data-d="2"] { transition-delay: .16s; } .reveal[data-d="3"] { transition-delay: .24s; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* sticky mobile cta */
.mcta { position: fixed; left: 0; right: 0; bottom: 0; z-index: 50; padding: 10px 16px calc(10px + env(safe-area-inset-bottom)); background: rgba(22,34,47,.95); backdrop-filter: blur(10px); border-top: 1px solid var(--line-d); transform: translateY(120%); transition: transform .3s ease; }
.mcta.show { transform: none; }
.mcta .btn { width: 100%; }
@media (min-width: 1024px) { .mcta { display: none; } }
