/* =================================================================
   SBS DIGITAL — Sistema visual compartilhado
   Usado por: index (home), vender-mais, atendimento, automacao
   ================================================================= */

/* ===================== TOKENS ===================== */
:root{
  --bg:#070b18;
  --bg-2:#0a1024;
  --bg-3:#0d142e;
  --ink:#eaf0ff;
  --ink-soft:#a9b4d6;
  --ink-dim:#6b779e;
  --blue:#2f6bff;
  --blue-bright:#3d8bff;
  --violet:#7b5cff;
  --violet-soft:#9d7cff;
  --cyan:#34e0e0;
  --wa-green:#25d366;
  --line:rgba(120,140,210,0.14);
  --line-soft:rgba(120,140,210,0.08);
  --glass:rgba(18,26,54,0.55);
  --radius:22px;
  --maxw:1180px;
  --grad-brand:linear-gradient(120deg,#3d8bff 0%,#7b5cff 60%,#9d7cff 100%);
  --grad-text:linear-gradient(110deg,#eaf0ff 0%,#9d7cff 50%,#3d8bff 100%);
  --shadow-glow:0 0 60px rgba(61,139,255,0.35);
  --font-display:"Clash Display","Plus Jakarta Sans",sans-serif;
  --font-body:"Plus Jakarta Sans",system-ui,sans-serif;
  /* tema claro (dobras de respiro) */
  --light-bg:#f4f6fd;
  --light-bg-2:#eef1fb;
  --light-ink:#0d1430;
  --light-ink-soft:#475079;
  --light-ink-dim:#828bb4;
  --light-line:rgba(20,30,80,0.10);
  --light-card:#ffffff;
  /* tom intermediário (azul mais aberto/luminoso) */
  --mid-bg-top:#0f2247;
  --mid-bg-bot:#16315f;
  --mid-ink:#eef3ff;
  --mid-ink-soft:#b9c8ee;
  --mid-ink-dim:#7e92c4;
  --mid-line:rgba(140,170,255,0.20);
  --mid-card:rgba(28,52,100,0.55);
  /* CARDS CONTRASTANTES (card destoa do fundo) */
  --card-on-dark:#e9edfb;        /* fundo escuro  -> card claro/lavanda */
  --card-on-dark-ink:#101936;    /* texto no card claro */
  --card-on-dark-soft:#48527a;
  --card-on-dark-dim:#7b85ad;
  --card-on-light:#0e1733;       /* fundo claro   -> card escuro */
  --card-on-light-ink:#eef2ff;
  --card-on-light-soft:#aeb9e0;
  --card-on-light-dim:#7e89b4;
  --card-on-mid:#ffffff;         /* fundo azul    -> card branco */
  --card-on-mid-ink:#101936;
  --card-on-mid-soft:#48527a;
  --card-on-mid-dim:#7b85ad;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* atmosfera de fundo: meshes de gradiente + grão */
body::before{
  content:"";
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(900px 700px at 80% -8%, rgba(123,92,255,0.26), transparent 58%),
    radial-gradient(800px 650px at 5% 8%, rgba(47,107,255,0.22), transparent 55%),
    radial-gradient(700px 600px at 95% 55%, rgba(52,224,224,0.10), transparent 50%),
    radial-gradient(1000px 800px at 50% 115%, rgba(123,92,255,0.16), transparent 55%),
    linear-gradient(170deg, #070b18 0%, #0a1024 45%, #0b1530 100%);
}
body::after{
  content:"";
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:0.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ===================== NAVBAR ===================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;transition:all .35s ease;
}
.nav.scrolled{
  background:rgba(7,11,24,0.72);backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line-soft);padding:12px 32px;
}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:600;font-size:21px;letter-spacing:-.01em;text-decoration:none;color:var(--ink)}
.logo-mark{
  width:34px;height:34px;border-radius:10px;background:var(--grad-brand);
  display:grid;place-items:center;box-shadow:0 0 22px rgba(123,92,255,0.5);position:relative;flex:none;
}
.logo-mark::after{content:"";position:absolute;inset:7px;border:2px solid rgba(255,255,255,0.92);border-radius:5px;border-right-color:transparent;border-bottom-color:transparent;transform:rotate(45deg)}
.logo span{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:var(--ink-soft);text-decoration:none;font-size:15px;font-weight:500;transition:color .25s ease}
.nav-links a:hover{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:18px}

.btn{
  font-family:var(--font-body);font-weight:700;font-size:15px;border:none;cursor:pointer;
  border-radius:100px;padding:13px 24px;display:inline-flex;align-items:center;gap:9px;
  text-decoration:none;transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
.btn-wa{background:var(--wa-green);color:#04210f;box-shadow:0 8px 28px rgba(37,211,102,0.32)}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(37,211,102,0.5)}
.btn-primary{
  background:var(--grad-brand);color:#fff;font-size:17px;padding:17px 32px;
  box-shadow:0 10px 40px rgba(61,139,255,0.45);position:relative;overflow:hidden;
}
.btn-primary::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,0.35) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .7s ease;
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 52px rgba(123,92,255,0.6)}
.btn-primary:hover::before{transform:translateX(120%)}
.btn-ghost{background:rgba(255,255,255,0.04);color:var(--ink);border:1px solid var(--line);font-size:17px;padding:16px 30px}
.btn-ghost:hover{background:rgba(255,255,255,0.08);transform:translateY(-2px)}

/* ===================== HERO ===================== */
.hero{padding:170px 0 90px;display:grid;grid-template-columns:1.05fr 0.95fr;gap:56px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--violet-soft);
  padding:8px 16px;border-radius:100px;background:rgba(123,92,255,0.10);
  border:1px solid rgba(123,92,255,0.25);margin-bottom:26px;
}
.dot-live{width:8px;height:8px;border-radius:50%;background:var(--wa-green);box-shadow:0 0 0 0 rgba(37,211,102,0.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,0.55)}70%{box-shadow:0 0 0 9px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

h1.hero-title{font-family:var(--font-display);font-weight:600;font-size:clamp(36px,4.6vw,60px);line-height:1.04;letter-spacing:-.02em;margin-bottom:24px}
h1.hero-title .accent{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{font-size:18.5px;color:var(--ink-soft);max-width:560px;margin-bottom:34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.hero-micro{font-size:14.5px;color:var(--ink-dim);display:flex;align-items:center;gap:8px}
.hero-micro svg{flex:none}

/* reveals */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.05s}.d2{transition-delay:.15s}.d3{transition-delay:.25s}.d4{transition-delay:.35s}.d5{transition-delay:.45s}

/* ===================== PHONE MOCKUP ===================== */
.phone-stage{position:relative;display:grid;place-items:center}
.phone-glow{
  position:absolute;width:115%;height:90%;border-radius:50%;
  background:radial-gradient(circle, rgba(61,139,255,0.4), rgba(123,92,255,0.2) 45%, transparent 70%);
  filter:blur(40px);z-index:0;animation:breathe 6s ease-in-out infinite;
}
@keyframes breathe{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}
.phone{
  position:relative;z-index:2;width:330px;max-width:88vw;background:#0b1020;border-radius:42px;
  padding:14px;border:1px solid rgba(150,170,240,0.18);
  box-shadow:0 40px 90px rgba(0,0,0,0.6),0 0 0 1px rgba(123,92,255,0.12), var(--shadow-glow);
  transform:perspective(1400px) rotateY(-11deg) rotateX(3deg);transition:transform .6s ease;
}
.phone:hover{transform:perspective(1400px) rotateY(-4deg) rotateX(1deg)}
.phone-notch{position:absolute;top:22px;left:50%;transform:translateX(-50%);width:120px;height:26px;background:#0b1020;border-radius:0 0 16px 16px;z-index:5}
.screen{background:#0d1424;border-radius:30px;overflow:hidden;height:560px;display:flex;flex-direction:column}
.wa-head{background:linear-gradient(120deg,#13233f,#1a2c52);padding:34px 16px 12px;display:flex;align-items:center;gap:11px;flex:none}
.wa-avatar{width:40px;height:40px;border-radius:50%;background:var(--grad-brand);display:grid;place-items:center;font-weight:800;font-size:15px;color:#fff;box-shadow:0 0 16px rgba(123,92,255,0.5)}
.wa-name{font-weight:700;font-size:15px;line-height:1.2}
.wa-status{font-size:11.5px;color:var(--wa-green);display:flex;align-items:center;gap:5px}
.wa-status::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--wa-green);box-shadow:0 0 8px var(--wa-green)}
.wa-body{flex:1;padding:16px 13px;display:flex;flex-direction:column;gap:9px;overflow:hidden;background:radial-gradient(circle at 20% 10%, rgba(47,107,255,0.06), transparent 40%),#0a1120}
.bubble{max-width:80%;padding:9px 13px;border-radius:15px;font-size:13.5px;line-height:1.45;opacity:0;transform:translateY(12px) scale(.96);animation:popIn .45s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes popIn{to{opacity:1;transform:none}}
.bubble.client{align-self:flex-end;background:#1f3a6e;color:#eaf0ff;border-bottom-right-radius:5px}
.bubble.ai{align-self:flex-start;background:#16213c;color:#dbe4ff;border-bottom-left-radius:5px;border:1px solid rgba(123,92,255,0.18)}
.bubble .meta{display:block;font-size:9.5px;color:var(--ink-dim);margin-top:4px;text-align:right}
.bubble.ai .tag{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--violet-soft);margin-bottom:4px}
.pix-card{align-self:flex-start;max-width:84%;background:linear-gradient(135deg,#0f2d1d,#123a26);border:1px solid rgba(37,211,102,0.4);border-radius:15px;padding:12px;opacity:0;transform:translateY(12px) scale(.96);animation:popIn .45s cubic-bezier(.2,.8,.2,1) forwards}
.pix-card .pix-top{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;color:var(--wa-green);margin-bottom:7px}
.pix-card .pix-val{font-family:var(--font-display);font-size:21px;font-weight:600;color:#eaffe9;line-height:1}
.pix-card .pix-key{font-size:10.5px;color:#8fdcab;margin-top:5px;word-break:break-all}
.pix-card .pix-btn{margin-top:9px;background:var(--wa-green);color:#04210f;text-align:center;font-weight:800;font-size:11.5px;padding:7px;border-radius:8px}
/* card de agendamento (landing atendimento) */
.book-card{align-self:flex-start;max-width:86%;background:linear-gradient(135deg,#13233f,#1a2c52);border:1px solid rgba(61,139,255,0.4);border-radius:15px;padding:12px;opacity:0;transform:translateY(12px) scale(.96);animation:popIn .45s cubic-bezier(.2,.8,.2,1) forwards}
.book-card .bk-top{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;color:var(--blue-bright);margin-bottom:8px}
.book-card .bk-slot{display:flex;align-items:center;justify-content:space-between;background:rgba(61,139,255,0.12);border:1px solid rgba(61,139,255,0.25);border-radius:9px;padding:7px 10px;font-size:12px;margin-bottom:5px}
.book-card .bk-slot .ok{color:var(--wa-green);font-weight:700;font-size:11px}
.book-card .bk-confirm{margin-top:7px;background:var(--blue);color:#fff;text-align:center;font-weight:800;font-size:11.5px;padding:7px;border-radius:8px}
.typing{align-self:flex-start;background:#16213c;border-radius:15px;border-bottom-left-radius:5px;padding:11px 14px;display:flex;gap:4px;opacity:0;animation:popIn .3s forwards;border:1px solid rgba(123,92,255,0.18)}
.typing span{width:6px;height:6px;border-radius:50%;background:var(--violet-soft);animation:typedot 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes typedot{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}

/* mockup de automação (landing automacao) — painel de fluxo */
.flow-panel{position:relative;z-index:2;width:100%;max-width:420px;background:var(--glass);border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:0 40px 90px rgba(0,0,0,0.5),var(--shadow-glow)}
.flow-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.flow-head .ft{font-family:var(--font-display);font-weight:600;font-size:15px}
.flow-head .fstatus{font-size:11px;color:var(--wa-green);display:flex;align-items:center;gap:6px}
.flow-head .fstatus::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--wa-green);box-shadow:0 0 10px var(--wa-green);animation:pulse 2s infinite}
.flow-node{display:flex;align-items:center;gap:13px;background:rgba(13,20,46,0.6);border:1px solid var(--line);border-radius:14px;padding:13px 15px;margin-bottom:0;position:relative;opacity:.4;transition:all .5s ease}
.flow-node.active{opacity:1;border-color:rgba(61,139,255,0.45);box-shadow:0 0 24px rgba(61,139,255,0.2)}
.flow-node .fn-ico{width:38px;height:38px;flex:none;border-radius:11px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(61,139,255,0.18),rgba(123,92,255,0.18));border:1px solid var(--line);color:var(--cyan)}
.flow-node .fn-t{font-weight:700;font-size:14px}
.flow-node .fn-d{font-size:11.5px;color:var(--ink-dim)}
.flow-node .fn-check{margin-left:auto;color:var(--wa-green);opacity:0;transition:opacity .4s ease}
.flow-node.done .fn-check{opacity:1}
.flow-connector{width:2px;height:16px;margin-left:33px;background:linear-gradient(180deg,rgba(61,139,255,0.5),rgba(123,92,255,0.3))}

/* floating stat chips */
.chip{position:absolute;z-index:3;background:var(--glass);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:16px;padding:12px 15px;box-shadow:0 16px 40px rgba(0,0,0,0.4)}
.chip .big{font-family:var(--font-display);font-weight:600;font-size:22px;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.chip .small{font-size:11px;color:var(--ink-soft);margin-top:3px}
.chip-1{top:8%;left:-6%;animation:float1 5s ease-in-out infinite}
.chip-2{bottom:12%;right:-8%;animation:float2 6s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(12px)}}

/* ===================== SECTION SHELL ===================== */
section{position:relative}
.sec{padding:96px 0}
.sec-tag{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-bright);margin-bottom:18px}
.sec-tag::before{content:"";width:26px;height:2px;background:var(--grad-brand);border-radius:2px}
h2.sec-title{font-family:var(--font-display);font-weight:600;font-size:clamp(28px,3.5vw,44px);line-height:1.08;letter-spacing:-.02em;max-width:760px;margin-bottom:20px}
.sec-lead{font-size:18px;color:var(--ink-soft);max-width:720px}
.sec-center{text-align:center}
.sec-center .sec-tag{justify-content:center}
.sec-center h2.sec-title,.sec-center .sec-lead{margin-left:auto;margin-right:auto}

/* ===================== PROBLEMA ===================== */
.problem{background:linear-gradient(180deg,transparent, rgba(10,16,36,0.6), transparent)}
.problem-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.pcard{background:var(--glass);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;position:relative;overflow:hidden;transition:transform .35s ease,border-color .35s ease}
.pcard::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,#ff5470,#ff8a5b);opacity:.7}
.pcard:hover{transform:translateY(-6px);border-color:rgba(255,84,112,0.35)}
.pcard .picon{width:46px;height:46px;border-radius:13px;background:rgba(255,84,112,0.14);border:1px solid rgba(255,84,112,0.35);display:grid;place-items:center;margin-bottom:18px;color:#e63a57}
.pcard h3{font-family:var(--font-display);font-weight:600;font-size:20px;margin-bottom:10px}
.pcard p{font-size:15px;color:var(--ink-soft)}
.transition-line{margin-top:44px;text-align:center;font-size:19px;color:var(--ink);padding:26px;border-radius:var(--radius);background:linear-gradient(120deg,rgba(47,107,255,0.10),rgba(123,92,255,0.10));border:1px solid var(--line)}
.transition-line strong{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:800}

/* ===================== SOLUÇÃO ===================== */
.solution{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.sol-visual{position:relative;background:var(--glass);border:1px solid var(--line);border-radius:28px;padding:30px;box-shadow:0 30px 70px rgba(0,0,0,0.4)}
.sol-row{display:flex;align-items:center;gap:14px;padding:15px 0;border-bottom:1px solid var(--line-soft)}
.sol-row:last-child{border-bottom:none}
.sol-row .si{width:42px;height:42px;flex:none;border-radius:12px;background:rgba(61,139,255,0.12);border:1px solid rgba(61,139,255,0.28);display:grid;place-items:center;color:var(--blue-bright)}
.sol-row .st{font-weight:700;font-size:15.5px}
.sol-row .sd{font-size:13px;color:var(--ink-dim)}
.highlight-box{margin-top:28px;padding:24px;border-radius:var(--radius);background:linear-gradient(120deg,rgba(123,92,255,0.14),rgba(47,107,255,0.10));border:1px solid rgba(123,92,255,0.3);font-size:16.5px}
.highlight-box strong{color:#fff}

/* ===================== COMO FUNCIONA ===================== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:50px;position:relative}
.step{background:var(--glass);border:1px solid var(--line);border-radius:var(--radius);padding:28px 22px;position:relative;transition:transform .35s ease,border-color .35s ease}
.step:hover{transform:translateY(-6px);border-color:rgba(123,92,255,0.35)}
.step .num{font-family:var(--font-display);font-weight:600;font-size:15px;width:38px;height:38px;border-radius:11px;background:var(--grad-brand);display:grid;place-items:center;color:#fff;margin-bottom:18px;box-shadow:0 8px 22px rgba(61,139,255,0.4)}
.step h3{font-family:var(--font-display);font-weight:600;font-size:18px;margin-bottom:9px}
.step p{font-size:14px;color:var(--ink-soft)}

/* ===================== DIFERENCIAIS ===================== */
.diffs{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:50px}
.diff{display:flex;gap:17px;padding:26px;border-radius:var(--radius);background:var(--glass);border:1px solid var(--line);transition:transform .35s ease,border-color .35s ease}
.diff:hover{transform:translateY(-4px);border-color:rgba(52,224,224,0.3)}
.diff .di{width:48px;height:48px;flex:none;border-radius:13px;background:linear-gradient(135deg,rgba(61,139,255,0.18),rgba(123,92,255,0.18));border:1px solid var(--line);display:grid;place-items:center;color:var(--cyan)}
.diff h3{font-family:var(--font-display);font-weight:600;font-size:18.5px;margin-bottom:7px}
.diff p{font-size:14.5px;color:var(--ink-soft)}

/* ===================== HOME: BLOCO DE DIRECIONAMENTO ===================== */
.route-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.rcard{
  display:flex;flex-direction:column;background:var(--glass);border:1px solid var(--line);
  border-radius:var(--radius);padding:32px 28px;text-decoration:none;color:var(--ink);
  position:relative;overflow:hidden;transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease;
}
.rcard::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--grad-brand);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.rcard:hover{transform:translateY(-8px);border-color:rgba(123,92,255,0.4);box-shadow:0 24px 60px rgba(0,0,0,0.4)}
.rcard:hover::before{transform:scaleX(1)}
.rcard .ric{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,rgba(61,139,255,0.18),rgba(123,92,255,0.18));border:1px solid var(--line);display:grid;place-items:center;color:var(--blue-bright);margin-bottom:20px}
.rcard h3{font-family:var(--font-display);font-weight:600;font-size:21px;margin-bottom:11px;line-height:1.2}
.rcard p{font-size:15px;color:var(--ink-soft);flex:1;margin-bottom:20px}
.rcard .rlink{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:15px;color:var(--violet-soft);transition:gap .25s ease}
.rcard:hover .rlink{gap:13px}

/* ===================== HOME: O QUE FAZEMOS ===================== */
.services{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:50px}
.service{display:flex;gap:18px;padding:28px;border-radius:var(--radius);background:var(--glass);border:1px solid var(--line);transition:transform .35s ease,border-color .35s ease}
.service:hover{transform:translateY(-4px);border-color:rgba(61,139,255,0.3)}
.service .svi{width:50px;height:50px;flex:none;border-radius:13px;background:linear-gradient(135deg,rgba(61,139,255,0.18),rgba(123,92,255,0.18));border:1px solid var(--line);display:grid;place-items:center;color:var(--cyan)}
.service h3{font-family:var(--font-display);font-weight:600;font-size:18.5px;margin-bottom:7px}
.service p{font-size:14.5px;color:var(--ink-soft)}

/* ===================== CTA FINAL ===================== */
.cta-final{text-align:center;padding:110px 0}
.cta-box{position:relative;background:linear-gradient(135deg,rgba(47,107,255,0.16),rgba(123,92,255,0.16));border:1px solid rgba(123,92,255,0.3);border-radius:34px;padding:70px 40px;overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,0.45)}
.cta-box::before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(123,92,255,0.4),transparent 70%);top:-200px;left:50%;transform:translateX(-50%);filter:blur(40px);animation:breathe 7s infinite}
.cta-box>*{position:relative;z-index:2}
h2.cta-title{font-family:var(--font-display);font-weight:600;font-size:clamp(26px,3.4vw,40px);line-height:1.1;letter-spacing:-.02em;max-width:680px;margin:0 auto 18px}
.cta-text{font-size:18px;color:var(--ink-soft);max-width:560px;margin:0 auto 34px}
.cta-micro{margin-top:18px;font-size:14px;color:var(--ink-dim)}

/* ===================== FOOTER ===================== */
footer{border-top:1px solid var(--line-soft);padding:54px 0 40px;margin-top:30px}
.foot-grid{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap}
.foot-brand{max-width:360px}
.foot-brand .slogan{font-style:italic;color:var(--violet-soft);margin-top:12px;font-size:15px}
.foot-nav{display:flex;flex-direction:column;gap:10px}
.foot-nav .ftit{font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:4px}
.foot-nav a{color:var(--ink-soft);text-decoration:none;font-size:14.5px;transition:color .25s ease}
.foot-nav a:hover{color:var(--ink)}
.foot-meta{font-size:13.5px;color:var(--ink-dim);line-height:1.9}
.foot-bottom{margin-top:40px;padding-top:24px;border-top:1px solid var(--line-soft);font-size:13px;color:var(--ink-dim);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}

/* ===================== FAB WHATSAPP ===================== */
.fab{position:fixed;bottom:26px;right:26px;z-index:200;width:62px;height:62px;border-radius:50%;background:var(--wa-green);display:grid;place-items:center;box-shadow:0 12px 36px rgba(37,211,102,0.5);transition:transform .3s ease;animation:fabPulse 2.6s infinite}
.fab:hover{transform:scale(1.1)}
@keyframes fabPulse{0%{box-shadow:0 12px 36px rgba(37,211,102,0.5),0 0 0 0 rgba(37,211,102,0.5)}70%{box-shadow:0 12px 36px rgba(37,211,102,0.5),0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 12px 36px rgba(37,211,102,0.5),0 0 0 0 rgba(37,211,102,0)}}

/* ===================== RESPONSIVE ===================== */
@media(max-width:920px){
  .hero{grid-template-columns:1fr;gap:60px;padding:140px 0 60px;text-align:center}
  .hero-cta{justify-content:center}.hero-micro{justify-content:center}.eyebrow{margin-inline:auto}.hero-sub{margin-inline:auto}
  .solution{grid-template-columns:1fr;gap:40px}
  .problem-cards{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .diffs,.services{grid-template-columns:1fr}
  .route-cards{grid-template-columns:1fr}
  .chip-1{left:2%}.chip-2{right:2%}
  .nav-links{display:none}
}
@media(max-width:560px){
  .nav{padding:14px 18px}.nav .btn-wa{padding:10px 16px;font-size:14px}
  .steps{grid-template-columns:1fr}
  .sec{padding:70px 0}
  .cta-box{padding:50px 24px}
  .phone{transform:none}
  .chip{display:none}
}

/* =================================================================
   SISTEMA DE CONTRASTE — o CARD sempre destoa do FUNDO
   - fundo DARK   -> card claro/lavanda  (texto escuro)
   - fundo CLARO  -> card escuro azul    (texto claro)
   - fundo MID    -> card branco         (texto escuro)
   ================================================================= */

/* ---------- CARDS NO FUNDO ESCURO (base) = claro/lavanda ---------- */
.pcard,.step,.diff,.service,.stat,.rcard,.tb-item,.sol-visual{
  background:var(--card-on-dark);
  border-color:rgba(20,30,80,0.10);
}
.pcard,.step,.diff,.service,.stat,.rcard{box-shadow:0 14px 40px rgba(0,0,0,0.35)}
.pcard h3,.step h3,.diff h3,.service h3,.rcard h3{color:var(--card-on-dark-ink)}
.pcard p,.step p,.diff p,.service p,.rcard p,.stat .sl{color:var(--card-on-dark-soft)}
.sol-row .st{color:var(--card-on-dark-ink)}
.sol-row .sd{color:var(--card-on-dark-dim)}
.sol-row{border-color:rgba(20,30,80,0.10)}
.tb-item{color:var(--card-on-dark-soft)}
.tb-item:hover{color:var(--card-on-dark-ink);border-color:rgba(123,92,255,0.4)}
.rcard{color:var(--card-on-dark-ink)}
.rcard .rlink{color:var(--violet)}
.stat .sn{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
/* ícones dos sol-row no card claro */
.sol-row .si{background:rgba(47,107,255,0.10);border-color:rgba(47,107,255,0.22);color:var(--blue)}
.service .svi,.diff .di{background:linear-gradient(135deg,rgba(47,107,255,0.14),rgba(123,92,255,0.14));color:var(--blue)}
.rcard .ric{color:var(--blue)}
.highlight-box{background:linear-gradient(120deg,rgba(123,92,255,0.16),rgba(47,107,255,0.12));border-color:rgba(123,92,255,0.3)}
.highlight-box strong{color:var(--ink)}

/* steps-flow conector */
.steps-flow{position:relative}
.steps-flow::before{content:"";position:absolute;top:47px;left:12%;right:12%;height:2px;background:repeating-linear-gradient(90deg,rgba(150,170,240,0.5) 0 8px,transparent 8px 16px);z-index:0}
.steps-flow .step{z-index:1}

/* =================================================================
   FAIXA DE SEGMENTOS
   ================================================================= */
.trust-band{padding:46px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:rgba(10,16,36,0.4)}
.trust-band .tb-label{text-align:center;font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:26px}
.tb-track{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}
.tb-item{display:inline-flex;align-items:center;gap:9px;padding:11px 20px;border-radius:100px;font-size:14.5px;font-weight:600;transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease}
.tb-item:hover{transform:translateY(-3px);box-shadow:0 10px 26px rgba(0,0,0,0.3)}
.tb-item svg{color:var(--violet);flex:none}

/* =================================================================
   NÚMEROS DE RESULTADO (base = card claro no fundo escuro)
   ================================================================= */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:50px}
.stat{text-align:center;padding:34px 20px;border-radius:var(--radius);position:relative;overflow:hidden}
.stat::after{content:"";position:absolute;bottom:0;left:0;width:100%;height:3px;background:var(--grad-brand);opacity:.6}
.stat .sn{font-family:var(--font-display);font-weight:600;font-size:clamp(30px,4vw,44px);line-height:1}
.stat .sl{font-size:14px;margin-top:10px}

/* =================================================================
   PROVA SOCIAL — depoimentos (base)
   ================================================================= */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:50px}
.testi{display:flex;flex-direction:column;padding:30px 28px;border-radius:var(--radius);position:relative;transition:transform .35s ease,box-shadow .35s ease}
.testi:hover{transform:translateY(-6px)}
.testi .quote-mark{font-family:var(--font-display);font-size:54px;line-height:.6;height:30px}
.testi .stars{display:flex;gap:3px;margin-bottom:14px;color:#ffb13d}
.testi p{font-size:15px;flex:1;line-height:1.6;margin-bottom:22px}
.testi .who{display:flex;align-items:center;gap:13px}
.testi .av{width:46px;height:46px;border-radius:50%;background:var(--grad-brand);display:grid;place-items:center;color:#fff;font-weight:800;font-size:16px;flex:none}
.testi .wn{font-weight:700;font-size:15px}
.testi .wr{font-size:13px}
.placeholder-note{margin-top:26px;text-align:center;font-size:13px;font-style:italic}

/* =================================================================
   DIAGRAMA DE ECOSSISTEMA (institucional)
   ================================================================= */
.eco-stage{position:relative;display:grid;place-items:center;min-height:440px}
.eco-svg{width:100%;max-width:520px;height:auto;overflow:visible}
.eco-line{stroke:url(#ecoGrad);stroke-width:2;fill:none;opacity:.35;stroke-dasharray:6 7}
.eco-pulse{stroke:url(#ecoGrad);stroke-width:2.5;fill:none;stroke-linecap:round}
.eco-node-bg{fill:rgba(18,26,54,0.92);stroke:var(--line);stroke-width:1}
.eco-center-bg{fill:url(#ecoCenter);stroke:rgba(37,211,102,0.5);stroke-width:1.5}
.eco-label{fill:var(--ink-soft);font-family:var(--font-body);font-size:12px;font-weight:600;text-anchor:middle}
.eco-center-label{fill:#fff;font-family:var(--font-display);font-size:13px;font-weight:600;text-anchor:middle}
.eco-node{transform-box:fill-box;transform-origin:center;animation:ecoFloat 5s ease-in-out infinite}
.eco-glow-center{animation:ecoBreathe 4s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
@keyframes ecoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes ecoBreathe{0%,100%{opacity:.9}50%{opacity:1}}
@keyframes dashFlow{to{stroke-dashoffset:-26}}
.eco-line{animation:dashFlow 1.4s linear infinite}

/* =================================================================
   DOBRA CLARA (fundo off-white) -> CARDS ESCUROS
   ================================================================= */
.sec-light{background:linear-gradient(180deg,var(--light-bg),var(--light-bg-2));color:var(--light-ink);position:relative}
.sec-light::before{content:"";position:absolute;top:-1px;left:0;right:0;height:80px;background:linear-gradient(180deg,rgba(11,21,48,0.55),transparent)}
.sec-light > *{position:relative;z-index:1}
.sec-light .sec-tag{color:var(--blue)}
.sec-light h2.sec-title{color:var(--light-ink)}
.sec-light h2.sec-title .accent{background:linear-gradient(110deg,#2f6bff,#7b5cff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sec-light .sec-lead{color:var(--light-ink-soft)}
/* cards escuros no fundo claro */
.sec-light .step,.sec-light .diff,.sec-light .service,.sec-light .stat,.sec-light .testi{
  background:var(--card-on-light);border-color:rgba(255,255,255,0.06);box-shadow:0 16px 44px rgba(13,20,48,0.22)}
.sec-light .step:hover,.sec-light .diff:hover,.sec-light .service:hover{box-shadow:0 24px 56px rgba(13,20,48,0.32)}
.sec-light .step h3,.sec-light .diff h3,.sec-light .service h3{color:var(--card-on-light-ink)}
.sec-light .step p,.sec-light .diff p,.sec-light .service p,.sec-light .stat .sl{color:var(--card-on-light-soft)}
.sec-light .step .num{box-shadow:0 8px 22px rgba(61,139,255,0.5)}
.sec-light .service .svi,.sec-light .diff .di{background:linear-gradient(135deg,rgba(61,139,255,0.25),rgba(123,92,255,0.25));border-color:rgba(150,170,255,0.2);color:var(--cyan)}
.sec-light .stat .sn{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sec-light .steps-flow::before{background:repeating-linear-gradient(90deg,rgba(47,107,255,0.4) 0 8px,transparent 8px 16px)}
/* depoimentos escuros no claro */
.sec-light .testi p{color:var(--card-on-light-soft)}
.sec-light .testi .wn{color:var(--card-on-light-ink)}
.sec-light .testi .wr{color:var(--card-on-light-dim)}
.sec-light .testi .quote-mark{color:rgba(123,92,255,0.5)}
.sec-light .placeholder-note{color:var(--light-ink-dim)}

/* =================================================================
   DOBRA INTERMEDIÁRIA (fundo azul) -> CARDS BRANCOS
   ================================================================= */
.sec-mid{background:linear-gradient(165deg,var(--mid-bg-top),var(--mid-bg-bot));color:var(--mid-ink);position:relative}
.sec-mid::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(700px 400px at 85% 0%, rgba(61,139,255,0.28), transparent 60%),radial-gradient(600px 400px at 10% 100%, rgba(123,92,255,0.20), transparent 60%)}
.sec-mid::after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(140,170,255,0.4),transparent)}
.sec-mid > *{position:relative;z-index:1}
.sec-mid .sec-tag{color:#9fc4ff}
.sec-mid h2.sec-title{color:var(--mid-ink)}
.sec-mid h2.sec-title .accent{background:linear-gradient(110deg,#bda6ff,#5cf0f0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sec-mid .sec-lead{color:var(--mid-ink-soft)}
/* cards brancos no fundo azul */
.sec-mid .step,.sec-mid .service,.sec-mid .diff,.sec-mid .stat,.sec-mid .rcard,.sec-mid .testi,.sec-mid .sol-visual{
  background:var(--card-on-mid);border-color:rgba(255,255,255,0.5);box-shadow:0 18px 48px rgba(5,12,30,0.4);backdrop-filter:none}
.sec-mid .step:hover,.sec-mid .service:hover,.sec-mid .diff:hover,.sec-mid .rcard:hover{box-shadow:0 26px 60px rgba(5,12,30,0.5)}
.sec-mid .step h3,.sec-mid .service h3,.sec-mid .diff h3,.sec-mid .rcard h3{color:var(--card-on-mid-ink)}
.sec-mid .step p,.sec-mid .service p,.sec-mid .diff p,.sec-mid .rcard p,.sec-mid .stat .sl{color:var(--card-on-mid-soft)}
.sec-mid .rcard{color:var(--card-on-mid-ink)}
.sec-mid .rcard .rlink{color:var(--blue)}
.sec-mid .service .svi,.sec-mid .diff .di{background:linear-gradient(135deg,rgba(47,107,255,0.14),rgba(123,92,255,0.14));border-color:rgba(20,30,80,0.1);color:var(--blue)}
.sec-mid .stat .sn{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.sec-mid .steps-flow::before{background:repeating-linear-gradient(90deg,rgba(255,255,255,0.55) 0 8px,transparent 8px 16px)}
/* sol-visual branco no azul */
.sec-mid .sol-row{border-color:rgba(20,30,80,0.1)}
.sec-mid .sol-row .st{color:var(--card-on-mid-ink)}
.sec-mid .sol-row .sd{color:var(--card-on-mid-dim)}
.sec-mid .sol-row .si{background:rgba(47,107,255,0.1);border-color:rgba(47,107,255,0.25);color:var(--blue)}
.sec-mid .highlight-box{background:linear-gradient(120deg,rgba(255,255,255,0.16),rgba(255,255,255,0.06));border-color:rgba(255,255,255,0.4);color:var(--mid-ink)}
.sec-mid .highlight-box strong{color:#fff}
/* depoimentos brancos no azul */
.sec-mid .testi p{color:var(--card-on-mid-soft)}
.sec-mid .testi .wn{color:var(--card-on-mid-ink)}
.sec-mid .testi .wr{color:var(--card-on-mid-dim)}
.sec-mid .testi .quote-mark{color:rgba(123,92,255,0.4)}
.sec-mid .placeholder-note{color:var(--mid-ink-dim)}

/* =================================================================
   RESPONSIVE para os novos blocos
   ================================================================= */
@media(max-width:920px){
  .stats{grid-template-columns:1fr 1fr}
  .testi-grid{grid-template-columns:1fr}
  .steps-flow::before{display:none}
}
@media(max-width:560px){
  .stats{grid-template-columns:1fr 1fr;gap:12px}
  .stat{padding:24px 14px}
  .tb-item{font-size:13px;padding:9px 15px}
}
