/* ====================================================================
   API-Next — Landing (Premium / claro · refino editorial)
   Marca: azul #005ff9 · verde #00ff99 · escuro #15161b
   Sistema: tokens de tipo/spacing/motion, hierarquia real, assimetria
   intencional, motion com propósito. Stack vanilla, sem build.
   ==================================================================== */

:root{
  /* ---- superfícies / cor ---- */
  --paper:#ffffff;
  --bg:#fbfbfd;
  --tint:#f3f7ff;
  --ink:#16181d;
  --muted:#5e6675;
  --faint:#9aa1ad;        /* só decorativo (linhas, ícones leves) */
  --faint-text:#67707f;   /* ≥4.5:1 sobre #fff — para TEXTO cinza */
  --line:#ebedf2;
  --line-2:#e0e3ea;
  --blue:#005ff9;
  --blue-deep:#0046c4;
  --blue-soft:#eef4ff;
  --green:#00ff99;
  --green-deep:#097a4d;   /* ≥4.5:1 inclusive sobre célula .us #f6faff */
  --green-soft:#e8fff6;
  --dark:#15161b;
  --dark-2:#1e2027;
  --dark-3:#191b21;
  --dark-line:#2c2e37;
  --dark-muted:#a8aeba;

  /* ---- famílias (honestas: só o que carrega) ---- */
  --display:'Montserrat',system-ui,-apple-system,sans-serif;
  --body:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;

  /* ---- escala tipográfica (razão ~1.25, base 17px) ---- */
  --fs-eyebrow:.75rem;
  --fs-sm:.875rem;
  --fs-base:1rem;
  --fs-md:1.125rem;
  --fs-lg:1.375rem;
  --fs-xl:1.75rem;
  --fs-2xl:2.25rem;
  --fs-h2:clamp(2.1rem,4vw,2.85rem);
  --fs-hero:clamp(2.5rem,5.2vw,4.15rem);
  --fs-stat:clamp(2.4rem,3.4vw,3rem);
  --fs-hero-num:clamp(3rem,6vw,4.4rem);

  /* ---- ritmo vertical / line-height ---- */
  --lh-tight:1.12;
  --lh-snug:1.4;
  --lh-body:1.65;

  /* ---- spacing 8pt ---- */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px;
  --s6:32px; --s7:48px; --s8:64px; --s9:96px;

  /* ---- sombras ---- */
  --sh-sm:0 1px 2px rgba(18,24,40,.04);
  --sh:0 10px 30px -10px rgba(18,24,40,.12), 0 2px 8px -2px rgba(18,24,40,.05);
  --sh-lg:0 34px 70px -22px rgba(18,24,40,.22), 0 8px 24px -8px rgba(18,24,40,.07);
  --sh-blue:0 14px 36px -10px rgba(0,95,249,.32);

  /* ---- raios ---- */
  --r:12px;
  --r-lg:18px;
  --r-xl:26px;

  /* ---- motion (uma "mão" só) ---- */
  --dur-fast:180ms;
  --dur:300ms;
  --dur-space:460ms;
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-std:cubic-bezier(.2,.7,.3,1);

  --wrap:1140px;
  --pad:48px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;font-family:var(--body);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:var(--lh-body);overflow-wrap:break-word;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg,video,canvas{max-width:100%;}
h1,h2,h3,h4{font-family:var(--display);margin:0;line-height:var(--lh-tight);letter-spacing:-.025em;font-weight:800;color:var(--ink);}
h2{font-size:var(--fs-h2);letter-spacing:-.03em;}
p{margin:0;}
ul{margin:0;padding:0;list-style:none;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--blue);color:#fff;}

/* foco visível global */
a:focus-visible,button:focus-visible,input:focus-visible,[tabindex]:focus-visible{
  outline:2.5px solid var(--blue);outline-offset:2px;border-radius:3px;
}

/* utilitário acessível */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.skip{position:fixed;left:-999px;top:8px;z-index:100;}
.skip:focus{left:8px;background:var(--blue);color:#fff;padding:10px 16px;border-radius:var(--r);box-shadow:var(--sh);}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:30px;}
.sec{padding-block:var(--pad);scroll-margin-top:74px;}
.sec--bg{background:var(--bg);}
.sec--tint{background:var(--tint);}

.eyebrow{display:inline-flex;align-items:center;gap:.55em;width:max-content;max-width:100%;font-family:var(--body);font-weight:600;font-size:var(--fs-eyebrow);letter-spacing:.12em;text-transform:uppercase;color:var(--blue);background:var(--blue-soft);border:1px solid #dbe8ff;padding:7px 14px;border-radius:999px;margin-bottom:20px;}
.eyebrow i{color:var(--faint);font-variant-numeric:tabular-nums;font-style:normal;}
.sec-head{max-width:680px;margin-bottom:clamp(32px,4vw,44px);}
.sec-head.center{margin-inline:auto;text-align:center;}
.sec-head.center .eyebrow{margin-inline:auto;}
.sec-head p{color:var(--muted);font-size:var(--fs-md);margin-top:var(--s4);line-height:var(--lh-snug);}

/* ---------- botões ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--body);font-weight:600;font-size:var(--fs-base);line-height:1;padding:15px 26px;border-radius:var(--r);border:1.5px solid transparent;cursor:pointer;transition:transform var(--dur-fast) var(--ease-std),box-shadow var(--dur-fast) ease,background var(--dur-fast) ease,border-color var(--dur-fast) ease,color var(--dur-fast) ease;}
.btn-primary{background:var(--blue);color:#fff;box-shadow:var(--sh-blue);}
.btn-primary:hover{background:var(--blue-deep);transform:translateY(-2px);box-shadow:0 20px 44px -12px rgba(0,95,249,.42);}
.btn-outline{background:var(--paper);color:var(--ink);border-color:var(--line-2);box-shadow:var(--sh-sm);}
.btn-outline:hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:var(--sh);}
.btn-light{background:#fff;color:var(--ink);}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 18px 40px -12px rgba(0,0,0,.35);}
.btn-lg{padding:17px 30px;font-size:1.04rem;}
.btn-block{width:100%;}
.btn:active{transform:translateY(0) scale(.985);transition-duration:90ms;}

/* ícone de check reutilizável */
.chk{color:var(--green-deep);flex:none;}

/* ====================================================================
   HEADER
   ==================================================================== */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.8);backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid transparent;transition:border-color var(--dur) ease;}
.header.scrolled{border-color:var(--line);}
.nav{display:flex;align-items:center;gap:32px;height:74px;}
.brand{font-family:var(--display);font-weight:800;font-size:1.3rem;letter-spacing:-.02em;color:var(--ink);}
.brand .dot{color:var(--blue);}
.nav-links{display:flex;gap:28px;margin-left:10px;}
.nav-links a{font-size:.95rem;color:var(--muted);font-weight:500;transition:color .15s;}
.nav-links a:hover{color:var(--ink);}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:20px;}
.nav-cta .login{font-size:.95rem;color:var(--muted);font-weight:500;}
.nav-cta .login:hover{color:var(--ink);}
.nav-cta .btn{padding:10px 18px;font-size:.92rem;border-radius:10px;}
.burger{display:none;background:none;border:0;cursor:pointer;width:48px;height:48px;align-items:center;justify-content:center;flex-direction:column;padding:0;}
.burger span{display:block;width:20px;height:2px;background:var(--ink);margin:3px auto;border-radius:2px;}
/* menu mobile escondido por padrão (só aparece via .show no breakpoint do burger) */
.nav-mobile{display:none;flex-direction:column;padding:8px 30px 20px;border-top:1px solid var(--line);}
.nav-mobile.show{display:flex;}
.nav-mobile a{padding:14px 4px;color:var(--ink);font-weight:500;border-bottom:1px solid var(--bg);}
.nav-mobile .btn{margin-top:14px;padding:15px 26px;color:#fff;border-bottom:0;justify-content:center;font-weight:600;}

/* ====================================================================
   HERO
   ==================================================================== */
.hero{padding-block:48px;position:relative;overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 70% at 82% 38%, rgba(0,95,249,.07), transparent 60%);pointer-events:none;}
.hero-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:72px;align-items:center;position:relative;z-index:1;}
.hero-grid>*{min-width:0;}
.hero-tag{display:inline-block;font-size:.82rem;font-weight:500;color:var(--muted);background:var(--paper);border:1px solid var(--line-2);border-radius:999px;padding:7px 16px;margin-bottom:30px;box-shadow:var(--sh-sm);}
.hero-tag b{color:var(--ink);font-weight:600;}
.hero h1{font-size:var(--fs-hero);letter-spacing:-.035em;line-height:1.02;}
.hero h1 .accent{color:var(--blue);}
.hero-sub{font-size:var(--fs-md);color:var(--muted);margin-top:26px;max-width:520px;line-height:1.6;}
.hero-sub b{color:var(--ink);font-weight:600;}
.hero-actions{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;}
.hero-trust{display:flex;align-items:center;flex-wrap:wrap;gap:12px 18px;margin-top:34px;color:var(--faint-text);font-size:.92rem;}
.hero-trust b{color:var(--ink);font-weight:700;}
.hero-trust .sep{width:3px;height:3px;border-radius:50%;background:var(--faint);}

/* ---------- painel de status ---------- */
.panel{background:var(--paper);border-radius:var(--r-xl);box-shadow:var(--sh-lg);padding:32px 32px 16px;}
.panel-top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:24px;border-bottom:1px solid var(--line);}
.panel-label{font-size:.92rem;font-weight:600;color:var(--ink);}
.panel-state{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:600;color:var(--green-deep);background:var(--green-soft);padding:6px 12px;border-radius:999px;}
.panel-state .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(0,255,153,.18);animation:pulse-dot 2.4s ease-in-out infinite;}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 3px rgba(0,255,153,.20);}50%{box-shadow:0 0 0 7px rgba(0,255,153,0);}}
.panel-uptime{display:flex;align-items:baseline;flex-wrap:wrap;gap:6px 14px;padding:28px 0 8px;}
.panel-uptime .num{font-family:var(--display);font-weight:800;font-size:var(--fs-stat);letter-spacing:-.04em;font-variant-numeric:tabular-nums;}
.panel-uptime .lab{font-size:.9rem;color:var(--faint-text);}
.bars{display:flex;gap:3px;height:34px;align-items:flex-end;margin:8px 0 10px;overflow-x:auto;overflow-y:hidden;}
.bars i{flex:1 0 4px;height:100%;border-radius:2px;background:var(--green-deep);opacity:.78;transform-origin:bottom;}
.bars i.w{background:#c47f12;}
.js .bars i{transform:scaleY(.06);}
.js .bars.in i{transform:scaleY(1);transition:transform var(--dur-space) var(--ease-out);}
.bars-cap{display:flex;justify-content:space-between;font-size:.74rem;color:var(--faint-text);}
.status-list{margin-top:10px;}
.status-list li{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:15px 0;border-top:1px solid var(--line);font-size:.95rem;}
.status-list li .k{color:var(--ink);}
.status-list li .ok{color:var(--green-deep);font-weight:600;font-size:.86rem;white-space:nowrap;}

/* ====================================================================
   ESTABILIDADE — sumário editorial numerado 01–04
   ==================================================================== */
.mech-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.mech{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;transition:transform var(--dur-fast) var(--ease-std),box-shadow var(--dur-fast) ease,border-color var(--dur-fast) ease;}
.mech-ico{width:46px;height:46px;border-radius:13px;display:inline-flex;align-items:center;justify-content:center;background:var(--blue-soft);color:var(--blue);margin-bottom:16px;}
.mech-ico svg{width:24px;height:24px;}
.mech:hover{transform:translateY(-4px);border-color:var(--blue);box-shadow:var(--sh-lg);}
.mech h3{font-size:1.24rem;font-weight:700;margin-bottom:12px;}
.mech p{color:var(--muted);font-size:.99rem;line-height:1.6;}
.mech .mech-note{display:block;margin-top:20px;padding-top:18px;border-top:1px solid var(--line);font-size:.84rem;color:var(--faint-text);}
.mech .mech-note b{color:var(--muted);font-weight:600;}
/* 1º card dominante — âncora tintada do bento */
.mech--lead{grid-column:1/-1;display:grid;grid-template-columns:1.5fr .8fr;gap:36px;align-items:center;background:var(--blue-soft);border-color:#cfe0ff;box-shadow:none;}
.mech--lead .mech-ico{background:var(--blue);color:#fff;}
.mech--lead h3{font-size:var(--fs-lg);}
.mech--lead .mech-body{align-self:center;}
.mech--lead .mech-note{margin-top:0;border-top:0;padding-top:0;align-self:center;border-left:2px solid #cfe0ff;padding-left:36px;}

/* ====================================================================
   CUSTO-BENEFÍCIO
   ==================================================================== */
.cost-top{display:grid;grid-template-columns:.8fr 1.2fr;gap:44px;align-items:center;margin-bottom:40px;}
.cost-top>*{min-width:0;}
.save{background:var(--paper);border-radius:var(--r-lg);box-shadow:var(--sh);padding:30px;}
.save-row{display:flex;align-items:baseline;flex-wrap:wrap;gap:8px 16px;}
.save-row .ours{font-family:var(--display);font-weight:800;font-size:var(--fs-stat);color:var(--ink);letter-spacing:-.04em;font-variant-numeric:tabular-nums;}
.save-row .theirs{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--faint-text);text-decoration:line-through;font-variant-numeric:tabular-nums;}
.save-meta{font-size:.94rem;color:var(--muted);margin-top:10px;}
.save-econ{margin-top:22px;padding-top:20px;border-top:1px solid var(--line);font-size:1rem;color:var(--ink);}
.save-econ b{color:var(--green-deep);font-weight:700;}
.cost-note{font-size:var(--fs-md);color:var(--ink);font-weight:500;line-height:1.62;}
.cost-note b{font-weight:700;}

.cmp-wrap{background:var(--paper);border-radius:var(--r-lg);box-shadow:var(--sh);}
.cmp-scroll{overflow-x:auto;border-radius:var(--r-lg);padding-top:12px;}
table.cmp{width:100%;border-collapse:collapse;font-size:.96rem;min-width:560px;}
table.cmp th,table.cmp td{padding:17px 22px;text-align:left;border-bottom:1px solid var(--line);font-weight:400;}
table.cmp thead th{font-weight:600;color:var(--muted);font-size:.79rem;text-transform:uppercase;letter-spacing:.08em;}
table.cmp tbody th[scope=row]{color:var(--muted);font-weight:400;font-size:.96rem;}
/* coluna API-Next como pódio */
table.cmp .us{background:#f6faff;}
table.cmp thead th.us{color:var(--blue);border-top-left-radius:var(--r);border-top-right-radius:var(--r);transform:translateY(-8px);padding-top:25px;box-shadow:inset 1px 0 var(--blue-soft),inset -1px 0 var(--blue-soft);}
table.cmp tbody td.us{color:var(--ink);font-weight:600;box-shadow:inset 1px 0 var(--blue-soft),inset -1px 0 var(--blue-soft);font-variant-numeric:tabular-nums;}
table.cmp tbody tr:last-child td.us,table.cmp tbody tr:last-child th{border-bottom:0;}
table.cmp tbody tr:last-child td.us{box-shadow:inset 1px 0 var(--blue-soft),inset -1px 0 var(--blue-soft),inset 0 -1px var(--blue-soft);border-bottom-left-radius:var(--r);border-bottom-right-radius:var(--r);}
.yes,.no{display:inline-flex;align-items:center;gap:7px;}
.yes{color:var(--green-deep);font-weight:600;}
.no{color:var(--faint-text);}
.cmp-foot{font-size:.81rem;color:var(--faint-text);margin-top:16px;}

/* ====================================================================
   SIMPLICIDADE
   ==================================================================== */
.simple-grid{display:grid;grid-template-columns:1fr .82fr;gap:64px;align-items:start;}
.simple-grid>*{min-width:0;}
.simple-head p{color:var(--muted);font-size:var(--fs-md);margin-top:var(--s4);line-height:var(--lh-snug);}
.points{margin-top:36px;}
.point{padding:24px 0;border-top:1px solid var(--line);}
.point:first-child{border-top:0;padding-top:0;}
.point h3{font-size:1.1rem;font-weight:700;margin-bottom:6px;}
.point p{color:var(--muted);font-size:.98rem;line-height:1.55;}
.feats{background:var(--paper);border-radius:var(--r-lg);box-shadow:var(--sh);padding:10px 26px;}
.feats div{display:flex;align-items:center;gap:13px;padding:17px 0;border-bottom:1px solid var(--line);font-size:.97rem;font-weight:500;}
.feats div:last-child{border-bottom:0;}
.feats .chk{color:var(--blue);}

/* ====================================================================
   PARCEIROS (momento escuro)
   ==================================================================== */
.partner{background:var(--dark);color:#fff;position:relative;overflow:hidden;}
.partner::before{content:"";position:absolute;top:-200px;right:-120px;width:560px;height:560px;background:radial-gradient(closest-side, rgba(0,255,153,.12), transparent 72%);pointer-events:none;}
.partner .wrap{position:relative;z-index:1;}
.partner .eyebrow{color:var(--green);background:rgba(0,255,153,.10);border-color:rgba(0,255,153,.22);}
.partner .eyebrow i{color:var(--dark-muted);}
.partner h2{color:#fff;}
.partner .lead{color:var(--dark-muted);font-size:var(--fs-md);margin-top:var(--s4);max-width:600px;line-height:1.6;}
.partner-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;margin-top:44px;align-items:center;}
.partner-grid>*{min-width:0;}

.calc{background:var(--dark-2);border:1px solid var(--dark-line);border-radius:var(--r-xl);padding:30px;box-shadow:0 30px 60px -24px rgba(0,0,0,.6);}
.calc-title{font-size:.76rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--dark-muted);margin-bottom:26px;}
.calc-field label{display:flex;justify-content:space-between;align-items:baseline;gap:10px;font-size:.94rem;color:var(--dark-muted);margin-bottom:16px;}
.calc-field label .val{font-family:var(--display);font-weight:800;color:#fff;font-size:1.2rem;font-variant-numeric:tabular-nums;}
input[type=range]{width:100%;accent-color:var(--green);height:6px;cursor:pointer;background:transparent;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:var(--green);border:3px solid var(--dark-2);box-shadow:0 2px 8px rgba(0,0,0,.4);cursor:pointer;margin-top:-9px;}
input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--green);border:3px solid var(--dark-2);cursor:pointer;}
input[type=range]::-webkit-slider-runnable-track{height:6px;border-radius:3px;background:var(--dark-line);}
input[type=range]::-moz-range-track{height:6px;border-radius:3px;background:var(--dark-line);}
.calc-out{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:28px;}
.calc-box{background:var(--dark-3);border:1px solid var(--dark-line);border-radius:var(--r);padding:20px;}
.calc-box.you{border-color:rgba(0,255,153,.5);}
.calc-box .ck{font-size:.78rem;color:var(--dark-muted);margin-bottom:10px;}
.calc-box .cv{font-family:var(--display);font-weight:800;font-size:1.7rem;letter-spacing:-.02em;font-variant-numeric:tabular-nums;}
.calc-box.you .cv{color:var(--green);}
.calc-box .cs{font-size:.76rem;color:var(--dark-muted);margin-top:6px;}
.calc-verdict{margin-top:22px;font-size:.97rem;color:var(--dark-muted);}
.calc-verdict b{color:var(--green);font-weight:700;}

.partner-copy h3{color:#fff;font-size:var(--fs-lg);margin-bottom:24px;letter-spacing:-.02em;}
.partner-points{margin-bottom:32px;}
.pp{padding:18px 0;border-top:1px solid var(--dark-line);color:var(--dark-muted);font-size:.99rem;line-height:1.55;}
.pp:first-child{border-top:0;padding-top:0;}
.pp b{color:#fff;font-weight:600;}

/* ====================================================================
   DEV
   ==================================================================== */
.dev-grid{display:grid;grid-template-columns:.78fr 1.22fr;gap:48px;align-items:center;}
.dev-grid>*{min-width:0;}
.dev-head p{color:var(--muted);font-size:var(--fs-md);margin-top:var(--s4);line-height:1.6;}
.code-card{background:#16171c;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);}
.code-tabs{display:flex;border-bottom:1px solid #2a2c34;}
.code-tab{font-family:var(--mono);font-size:.82rem;color:#8b93a7;background:none;border:0;border-bottom:2px solid transparent;padding:15px 20px;cursor:pointer;transition:color var(--dur-fast) ease;}
.code-tab[aria-selected=true]{color:#fff;border-bottom-color:var(--blue);}
.code-body{padding:24px;overflow-x:auto;}
.code-body pre{margin:0;font-family:var(--mono);font-size:.83rem;line-height:1.75;color:#e6e8ee;}
.code-body pre[hidden]{display:none;}
.code-body pre.swap{animation:code-in var(--dur) var(--ease-out);}
@keyframes code-in{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.code-body .cm{color:#7e879b;}
.code-body .st{color:#7ee2b8;}
.code-body .kw{color:#6db1ff;}
.code-body .fn{color:#e6c07b;}

/* ====================================================================
   NÚMEROS — placar editorial com número-herói
   ==================================================================== */
.stats{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:36px;align-items:end;}
.stat{padding-left:36px;border-left:1px solid var(--line);}
.stat:first-child{padding-left:0;border-left:0;}
.stat .n{font-family:var(--display);font-weight:800;font-size:var(--fs-stat);letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums;}
.stat:first-child .n{font-size:var(--fs-hero-num);}
.stat .n .u{color:var(--blue);font-weight:500;}
.stat .l{color:var(--muted);font-size:.95rem;margin-top:12px;}

/* ====================================================================
   PREÇOS
   ==================================================================== */
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:880px;margin-inline:auto;align-items:start;}
.price{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--sh);padding:38px;display:flex;flex-direction:column;}
.price.rec{box-shadow:var(--sh-lg);outline:1.5px solid var(--blue);transform:translateY(-12px);}
/* Parceiro (não-recomendado): um pouco menor e centralizado, para ceder destaque ao Cliente */
.price:not(.rec){transform:scale(.95);transform-origin:center;align-self:center;box-shadow:var(--sh-sm);}
.price-tag{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:16px;}
.price.rec .price-tag{position:absolute;top:-14px;left:38px;margin:0;background:var(--blue);color:#fff;padding:7px 15px;border-radius:999px;box-shadow:var(--sh-blue);}
.price .pname{font-family:var(--display);font-weight:800;font-size:1.28rem;}
.price.rec .pname{margin-top:8px;}
.price .pdesc{color:var(--muted);font-size:.94rem;margin-top:8px;min-height:46px;line-height:1.5;}
.price .pval{font-family:var(--display);font-weight:800;font-size:var(--fs-2xl);letter-spacing:-.04em;margin-top:16px;font-variant-numeric:tabular-nums;}
.price .pval small{font-size:.95rem;color:var(--faint-text);font-weight:600;}
.price .pval .per{display:block;margin-top:4px;}
.price .prange{font-size:.9rem;color:var(--muted);margin-top:6px;}
.price ul{margin:28px 0 32px;display:grid;gap:14px;}
.price li{display:flex;gap:12px;align-items:flex-start;font-size:.96rem;color:var(--ink);line-height:1.45;}
.price li .chk{margin-top:2px;}
.price .btn{margin-top:auto;}

/* ====================================================================
   FAQ
   ==================================================================== */
.faq{max-width:780px;margin-inline:auto;border-top:1px solid var(--line);}
.qa{border-bottom:1px solid var(--line);}
.qa button{width:100%;background:none;border:0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:26px 4px;text-align:left;font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--ink);letter-spacing:-.01em;}
.qa .sign{flex:none;font-size:1.4rem;color:var(--blue);line-height:1;transition:transform var(--dur) var(--ease-out);}
.qa.open .sign{transform:rotate(45deg);}
.qa .ans{max-height:0;overflow:hidden;visibility:hidden;transition:max-height var(--dur) var(--ease-out),visibility var(--dur);}
.qa.open .ans{visibility:visible;}
.qa .ans p{color:var(--muted);font-size:1.02rem;padding:0 42px 28px 4px;line-height:1.6;}

/* ====================================================================
   CTA FINAL (momento escuro)
   ==================================================================== */
.final-wrap{padding-block:var(--pad);}
.final{background:var(--dark);border-radius:var(--r-xl);padding:clamp(48px,7vw,84px) clamp(32px,5vw,64px);text-align:center;position:relative;overflow:hidden;}
.final::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 120% at 50% -10%, rgba(0,95,249,.12), transparent 50%);pointer-events:none;}
.final-inner{position:relative;z-index:1;}
.final h2{color:#fff;max-width:680px;margin-inline:auto;}
.final p{color:var(--dark-muted);font-size:var(--fs-md);margin-top:18px;}
.final .btn{margin-top:34px;}
.final .fnote{margin-top:22px;color:#8b93a7;font-size:.88rem;}

/* ====================================================================
   FOOTER
   ==================================================================== */
.footer{background:var(--paper);border-top:1px solid var(--line);padding-block:48px;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:44px;}
.footer .brand{display:inline-block;margin-bottom:16px;}
.footer .fdesc{color:var(--muted);font-size:.94rem;max-width:280px;line-height:1.6;}
.footer h5{font-size:.76rem;text-transform:uppercase;letter-spacing:.12em;color:var(--faint-text);margin:0 0 18px;font-family:var(--body);font-weight:700;}
.footer ul{display:grid;gap:12px;}
.footer ul a{color:var(--muted);font-size:.94rem;transition:color .15s;}
.footer ul a:hover{color:var(--blue);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-top:52px;padding-top:28px;border-top:1px solid var(--line);color:var(--faint-text);font-size:.85rem;}

/* ====================================================================
   MOTION — scroll reveal (só com JS ativo)
   ==================================================================== */
.js .reveal{opacity:0;transform:translateY(16px);}
.js .reveal.in{opacity:1;transform:none;transition:opacity var(--dur-space) var(--ease-out),transform var(--dur-space) var(--ease-out);}

/* ====================================================================
   RESPONSIVO
   ==================================================================== */
@media (max-width:980px){
  .hero-grid,.cost-top,.simple-grid,.partner-grid,.dev-grid{grid-template-columns:1fr;gap:48px;align-items:stretch;}
  .panel{max-width:500px;}
  .mech-grid{grid-template-columns:1fr 1fr;}
  .mech--lead{grid-template-columns:1.1fr .9fr;}
  .stats{grid-template-columns:1fr 1fr;gap:44px 36px;}
  .stat{padding-left:0;border-left:0;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px;}
}
@media (max-width:900px){
  .nav-links,.nav-cta{display:none;}
  .burger{display:flex;margin-left:auto;}
}
@media (max-width:680px){
  .mech-grid{grid-template-columns:1fr;}
  .mech--lead{grid-column:auto;grid-template-columns:1fr;gap:20px;}
  .mech--lead .mech-note{margin-top:18px;padding-top:18px;border-top:1px solid var(--line);border-left:0;padding-left:0;}
  .price-grid{grid-template-columns:1fr;max-width:440px;}
  .price{padding:28px 24px;}
  .price .pval{font-size:1.9rem;}
  .price.rec{transform:none;margin-top:18px;}
  .price:not(.rec){transform:none;align-self:auto;box-shadow:var(--sh);}
  .calc-out{grid-template-columns:1fr;}
  body{font-size:16px;}

  /* tabela comparativa -> cards por critério (sem scroll horizontal) */
  .cmp-wrap{background:transparent;box-shadow:none;}
  .cmp-scroll{overflow-x:visible;padding-top:0;border-radius:0;}
  table.cmp{min-width:0;display:block;}
  table.cmp thead{display:none;}
  table.cmp tbody{display:block;}
  table.cmp tbody tr{display:block;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:4px 16px 12px;margin-bottom:14px;box-shadow:var(--sh-sm);}
  table.cmp tbody th[scope=row]{display:block;font-family:var(--display);font-weight:700;font-size:1.05rem;color:var(--ink);padding:14px 2px 12px;border-bottom:1px solid var(--line);}
  table.cmp tbody td{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:11px 2px;border-bottom:1px solid var(--line);text-align:right;transform:none!important;box-shadow:none!important;border-radius:0;}
  table.cmp tbody td::before{content:attr(data-label);color:var(--faint-text);font-weight:500;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;text-align:left;flex:none;}
  table.cmp tbody td:last-child{border-bottom:0;}
  table.cmp tbody td.us{background:var(--blue-soft);margin:8px -16px;padding:12px 16px;border-radius:10px!important;border-bottom:0;font-weight:700;color:var(--ink);}
  table.cmp tbody td.us::before{color:var(--blue);}

  /* code-card: quebrar linhas longas em vez de cortar/rolar */
  .code-body{padding:18px 16px;}
  .code-body pre{white-space:pre-wrap;overflow-wrap:anywhere;font-size:.78rem;line-height:1.7;}
  .code-tab{padding:13px 16px;}

  /* números: 3 blocos individuais, centralizados */
  .stats{grid-template-columns:1fr;gap:14px;}
  .stat{text-align:center;padding:28px 20px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-sm);}
  .stat:first-child .n{font-size:clamp(2.8rem,11vw,3.4rem);}
  .stat .l{margin-top:8px;}
}
@media (max-width:480px){
  .footer-grid{grid-template-columns:1fr;}
  .calc-field label{flex-direction:column;align-items:flex-start;gap:8px;}
  .footer ul a{display:inline-flex;align-items:center;min-height:44px;}
}

/* --------------------------------------------------------------------
   ESCALA INTERMEDIÁRIA — laptop + tablet (shrink proporcional)
   Motor: redefinir o TETO dos clamps em :root reescala todo o sistema
   tokenizado; overrides explícitos cobrem o hero hardcoded; a guarda de
   altura (por último) aperta só o vertical em laptops baixos.
   -------------------------------------------------------------------- */

/* LAPTOP por largura — notebooks 1366/1440/1536 e 1920 @125–150% (=1536/1280 CSS) */
@media (min-width:981px) and (max-width:1536px){
  :root{
    --fs-hero:clamp(2.3rem,4.4vw,3.2rem);
    --fs-h2:clamp(2.05rem,3.4vw,2.4rem);
    --fs-stat:clamp(2rem,3vw,2.5rem);
    --fs-hero-num:clamp(2.6rem,4.6vw,3.4rem);
    --fs-2xl:2rem; --fs-lg:1.25rem; --fs-md:1.06rem;
    --pad:34px;
  }
  body{font-size:16px;}
  .nav{height:64px;} .sec{scroll-margin-top:64px;}
  .hero{padding-block:32px;}
  .hero-grid{gap:40px;}                 /* mantém 1.35fr .85fr — não re-empilhar */
  .hero-tag{margin-bottom:18px;}
  .hero-sub{margin-top:16px;}
  .hero-actions{margin-top:22px;}
  .hero-trust{margin-top:20px;}
  .panel{padding:22px 22px 12px;}
  .panel-top{padding-bottom:16px;}
  .panel-uptime{padding:16px 0 6px;}
  .bars{height:26px;margin:6px 0 8px;}
  .status-list li{padding:10px 0;}
  .mech{padding:24px;} .mech--lead{gap:24px;}
  .save,.calc{padding:24px;} .price{padding:30px;}
  .feats{padding:8px 22px;} .code-body{padding:20px;}
}

/* TABLET 681–980 — acima do mobile (≤680), sem vazar. Layout já empilha no bloco 980 */
@media (min-width:681px) and (max-width:980px){
  :root{
    --fs-hero:clamp(2.2rem,6vw,2.9rem);
    --fs-h2:clamp(1.9rem,4.4vw,2.2rem);
    --fs-stat:clamp(1.9rem,4vw,2.3rem);
    --fs-hero-num:clamp(2.4rem,7vw,3.2rem);
    --fs-2xl:1.9rem; --fs-lg:1.18rem; --fs-md:1rem;
    --pad:28px;
  }
  body{font-size:16px;}
  .nav{height:60px;} .sec{scroll-margin-top:60px;}
  .hero{padding-block:22px;}
  .hero-grid{gap:32px;}                 /* sobrescreve o gap:48px do bloco 980 */
  .hero-tag{margin-bottom:16px;}
  .hero-sub{margin-top:14px;}
  .hero-actions{margin-top:20px;}
  .hero-trust{margin-top:18px;}
  .panel{padding:20px 20px 10px;}       /* mantém o max-width:500px do bloco 980 */
  .panel-top{padding-bottom:14px;}
  .panel-uptime{padding:14px 0 6px;}
  .bars{height:24px;margin:6px 0 6px;}
  .status-list li{padding:9px 0;}
  .mech{padding:22px;} .save,.calc{padding:22px;} .feats{padding:8px 20px;}
}

/* GUARDA DE ALTURA — laptops baixos (1366×768, 1280×720, 1536×864).
   Aperta só o vertical do hero, nunca a tipografia. Por ÚLTIMO na cascata. */
@media (min-width:981px) and (max-height:820px){
  .hero{padding-block:24px;padding-block:clamp(16px,3svh,28px);}
  .hero-grid{gap:40px;}
  .panel{padding:20px 22px 10px;}
  .panel-top{padding-bottom:16px;}
  .panel-uptime{padding:16px 0 6px;}
  .bars{height:24px;margin:6px 0 8px;}
  .status-list li{padding:11px 0;padding:clamp(9px,1.3svh,12px) 0;}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important;animation:none!important;}
  .js .reveal{opacity:1!important;transform:none!important;}
  .js .bars i{transform:scaleY(1)!important;}
}
