/* ============================================================
   FAST MARKETING — marketing.css  (REDESIGN v2)
   Carregado DEPOIS de ../styles.css. Identidade própria:
   VERMELHO lidera, roxo FAST fica de base/marca. Editorial,
   imersivo, pouco texto. Componentes próprios (prefixo .m-),
   NÃO reusa os cards/steps da home.
   Posicionamento: serviço de marketing por GENTE, acelerado por IA.
   ============================================================ */

:root{
  --red:#2b6bff;
  --red-2:#5b8bff;
  --red-deep:#1e4fd6;
  --red-ink:#9db8ff;
  --red-soft:rgba(43,107,255,.13);
  --red-line:rgba(43,107,255,.36);
  --red-glow:rgba(43,107,255,.55);
  --grad-red:linear-gradient(115deg,#5b8bff 0%,#2b6bff 45%,#1e4fd6 100%);
  --grad-rp:linear-gradient(120deg,#5b8bff 0%,#2b6bff 40%,var(--roxo-2) 100%);
  --m-bg:#070009;
  --m-panel:#100410;
}

/* fundo da página puxa um leve quente vermelho/roxo */
body{background:#070009}
::selection{background:var(--red);color:#fff}
::-webkit-scrollbar-thumb{background:var(--red-deep)}
::-webkit-scrollbar-thumb:hover{background:var(--red)}

/* ---------- header da marketing: linha viva vermelha ---------- */
.header.scrolled .nav{
  background:linear-gradient(135deg,rgba(28,4,12,.66) 0%,rgba(12,2,8,.58) 50%,rgba(43,107,255,.16) 100%);
  border-color:rgba(255,255,255,.14);
}
.nav-links a:hover{color:#fff;background:rgba(43,107,255,.14)}
.brand img{filter:drop-shadow(0 0 14px rgba(43,107,255,.5))}

/* ---------- BOTÃO primário VERMELHO ---------- */
.btn-primary{
  background:var(--grad-red);
  box-shadow:0 14px 34px rgba(43,107,255,.42),inset 0 0 0 1px rgba(255,255,255,.10);
}
.btn-primary:hover{box-shadow:0 20px 48px rgba(43,107,255,.6)}
.magnet-dots i{background:var(--red);box-shadow:0 0 10px var(--red-glow)}
.btn-secondary:hover{background:rgba(43,107,255,.12);border-color:var(--red)}

/* eyebrow vermelha de produto */
.eyebrow--prod{color:var(--red-ink);border-color:var(--red-line);background:var(--red-soft)}
.eyebrow--prod::before{background:var(--red);box-shadow:0 0 12px var(--red-glow)}

/* ============================================================
   HERO IMERSIVO
   ============================================================ */
.m-hero{
  position:relative;overflow:hidden;
  min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  padding:128px 0 0;
}
/* malha de gradiente vermelho/roxo que respira */
.m-hero::before{
  content:"";position:absolute;inset:-20%;z-index:0;pointer-events:none;
  background:
    radial-gradient(45% 40% at 18% 22%, rgba(43,107,255,.42), transparent 60%),
    radial-gradient(40% 38% at 82% 30%, rgba(123,22,219,.40), transparent 62%),
    radial-gradient(50% 45% at 60% 88%, rgba(43,107,255,.22), transparent 60%);
  filter:blur(20px);
  animation:mesh-drift 16s ease-in-out infinite alternate;
}
@keyframes mesh-drift{
  0%{transform:translate3d(-2%,-1%,0) scale(1)}
  100%{transform:translate3d(3%,2%,0) scale(1.08)}
}
/* grade técnica sutil */
.m-hero::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(43,107,255,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(43,107,255,.06) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 30% 40%,#000 20%,transparent 78%);
  -webkit-mask-image:radial-gradient(circle at 30% 40%,#000 20%,transparent 78%);
}
.m-hero .container{position:relative;z-index:2;max-width:1080px;flex:1;display:flex;flex-direction:column;justify-content:center}
/* rede de partículas (canvas) atrás do conteúdo do hero */
.m-net{position:absolute;inset:0;z-index:1;opacity:.65;pointer-events:none}

.m-tag{
  display:inline-flex;align-items:center;gap:10px;margin-bottom:26px;
  font-family:var(--f-text);font-weight:700;font-size:12px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--red-ink);
}
.m-tag .pulse{width:9px;height:9px;border-radius:50%;background:var(--red);box-shadow:0 0 0 0 var(--red-glow);animation:pulse-dot 2.2s infinite}
@keyframes pulse-dot{0%{box-shadow:0 0 0 0 rgba(43,107,255,.6)}70%{box-shadow:0 0 0 14px rgba(43,107,255,0)}100%{box-shadow:0 0 0 0 rgba(43,107,255,0)}}

.m-hero h1{
  font-family:var(--f-display);font-weight:600;
  font-size:clamp(40px,8.2vw,104px);line-height:.95;letter-spacing:-.02em;
  margin:0 0 26px;
}
.m-hero h1 .line{display:block;overflow:hidden}
.m-hero h1 em{
  font-style:normal;position:relative;
  background:var(--grad-red);-webkit-background-clip:text;background-clip:text;color:transparent;
}
/* sublinhado vermelho que desenha sob "IA" */
.m-hero h1 em::after{
  content:"";position:absolute;left:0;right:0;bottom:.06em;height:.09em;border-radius:2px;
  background:var(--grad-red);transform:scaleX(0);transform-origin:left;
  animation:draw-line 1.1s .5s cubic-bezier(.7,0,.2,1) forwards;
}
@keyframes draw-line{to{transform:scaleX(1)}}
.js .m-hero h1 .reveal-up{display:inline-block;opacity:0;transform:translateY(110%);animation:rise .9s cubic-bezier(.16,1,.3,1) forwards}
.js .m-hero h1 .d1{animation-delay:.05s}
.js .m-hero h1 .d2{animation-delay:.18s}
@keyframes rise{to{opacity:1;transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){.js .m-hero h1 .reveal-up{opacity:1;transform:none;animation:none}.m-hero h1 em::after{transform:scaleX(1);animation:none}.m-hero::before{animation:none}}

.m-hero .m-sub{
  font-size:clamp(17px,1.9vw,22px);color:var(--text-dim);max-width:620px;line-height:1.45;margin:0 0 36px;
}
.m-hero .m-sub b{color:#fff;font-weight:700}
.m-hero-ctas{display:flex;gap:16px;flex-wrap:wrap;align-items:center}

/* selo discreto de carteira */
.m-hero-note{margin-top:30px;font-size:13px;color:var(--text-mute);display:flex;align-items:center;gap:10px}
.m-hero-note .ln{width:34px;height:1px;background:var(--red-line)}

/* ============================================================
   RIBBON de canais (marquee inclinado)
   ============================================================ */
.m-ribbon{
  position:relative;z-index:3;margin-top:48px;width:100%;
  border-top:1px solid var(--red-line);border-bottom:1px solid var(--red-line);
  background:linear-gradient(90deg,rgba(43,107,255,.08),rgba(123,22,219,.06));
  overflow:hidden;
}
.m-ribbon .track{display:flex;gap:0;width:max-content;animation:ribbon 26s linear infinite}
.m-ribbon:hover .track{animation-play-state:paused}
@keyframes ribbon{to{transform:translateX(-50%)}}
.m-ribbon .it{
  display:inline-flex;align-items:center;gap:18px;padding:18px 30px;
  font-family:var(--f-display);font-weight:500;font-size:clamp(16px,2vw,24px);color:#fff;white-space:nowrap;
}
.m-ribbon .it::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 10px var(--red-glow)}
.m-ribbon .it.dim{color:var(--text-mute)}

/* ============================================================
   MANIFESTO / statement full-bleed
   ============================================================ */
.m-statement{padding:clamp(90px,13vw,160px) 0;position:relative;overflow:hidden}
.m-statement::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 80% at 50% 50%,rgba(43,107,255,.10),transparent 65%);
}
.m-statement .big{
  position:relative;font-family:var(--f-display);font-weight:600;
  font-size:clamp(28px,5.6vw,72px);line-height:1.04;letter-spacing:-.02em;
  max-width:16ch;margin:0 auto;text-align:center;color:#fff;
}
.m-statement .big em{font-style:normal;background:var(--grad-red);-webkit-background-clip:text;background-clip:text;color:transparent}
.m-statement .sub{margin:28px auto 0;text-align:center;max-width:60ch;color:var(--text-dim);font-size:clamp(16px,1.7vw,19px)}

/* manifesto com foto real (gente) */
.m-statement-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(32px,5vw,68px);align-items:center;position:relative;z-index:2}
@media(max-width:840px){.m-statement-grid{grid-template-columns:1fr;gap:32px}}
.m-statement-media{position:relative;border-radius:26px;overflow:hidden;aspect-ratio:4/5;
  border:1px solid var(--red-line);box-shadow:0 34px 80px rgba(43,107,255,.20),var(--shadow-roxo)}
@media(max-width:840px){.m-statement-media{aspect-ratio:16/12;max-width:480px}}
.m-statement-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 14%}
.m-statement-media::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 38%,rgba(7,0,9,.5) 100%),linear-gradient(125deg,rgba(43,107,255,.18),transparent 52%)}
.m-badge{position:absolute;left:16px;bottom:16px;z-index:2;display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;font-size:12px;font-weight:700;color:#fff;
  background:rgba(7,0,9,.55);border:1px solid var(--red-line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.m-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 10px var(--red-glow)}
.m-statement-grid .big{margin:0;text-align:left;max-width:18ch}
.m-statement-grid .sub{margin:24px 0 0;text-align:left;max-width:52ch}

/* ============================================================
   GENTE + IA  (pilares do como-entregamos)
   ============================================================ */
.m-deliver{padding:clamp(72px,10vw,120px) 0;position:relative;overflow:hidden}
.m-deliver::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(50% 50% at 85% 10%,rgba(123,22,219,.18),transparent 60%)}
.m-deliver .container{position:relative;z-index:2}
.m-head{max-width:720px;margin:0 0 56px}
.m-head .k{font-size:12px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--red-ink);display:inline-block;margin-bottom:16px}
.m-head h2{font-family:var(--f-display);font-weight:600;font-size:clamp(28px,4.4vw,54px);line-height:1.04;letter-spacing:-.02em;color:#fff;margin:0}
.m-head h2 em{font-style:normal;background:var(--grad-red);-webkit-background-clip:text;background-clip:text;color:transparent}
.m-head p{margin-top:18px;color:var(--text-dim);font-size:clamp(16px,1.7vw,19px);max-width:60ch}

.m-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.m-pillars{grid-template-columns:1fr}}
.m-pillar{
  position:relative;padding:34px 30px 30px;border-radius:22px;overflow:hidden;
  background:linear-gradient(165deg,rgba(43,107,255,.07),rgba(10,3,12,.6));
  border:1px solid var(--red-line);
}
.m-pillar:nth-child(2){background:linear-gradient(165deg,rgba(123,22,219,.10),rgba(10,3,12,.6));border-color:var(--border-2)}
.m-pillar .pic{font-family:var(--f-display);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--red-ink)}
.m-pillar:nth-child(2) .pic{color:var(--roxo-2)}
.m-pillar h3{font-family:var(--f-display);font-weight:500;font-size:clamp(20px,2.4vw,26px);color:#fff;margin:14px 0 10px;line-height:1.12}
.m-pillar p{color:var(--text-dim);font-size:15px;line-height:1.55}
.m-pillar .big-n{position:absolute;right:18px;top:6px;font-family:var(--f-display);font-size:90px;line-height:1;color:rgba(255,255,255,.04);font-weight:700}

/* ============================================================
   SERVIÇOS — bento assimétrico
   ============================================================ */
.m-services{padding:clamp(72px,10vw,120px) 0;position:relative;overflow:hidden}
.m-services::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(55% 60% at 12% 80%,rgba(43,107,255,.12),transparent 62%)}
.m-services .container{position:relative;z-index:2}
.m-bento{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
@media(max-width:860px){.m-bento{grid-template-columns:1fr}}
.m-cell{
  position:relative;overflow:hidden;border-radius:22px;padding:30px;
  background:linear-gradient(160deg,rgba(20,4,16,.9),rgba(7,0,9,.92));
  border:1px solid rgba(255,255,255,.08);
  transition:transform .35s cubic-bezier(.2,.7,.2,1),border-color .35s,box-shadow .35s;
  display:flex;flex-direction:column;min-height:230px;
}
.m-cell.lg{grid-column:span 4}
.m-cell.sm{grid-column:span 2}
@media(max-width:860px){.m-cell.lg,.m-cell.sm{grid-column:span 1}}
.m-cell::after{
  content:"";position:absolute;right:-80px;bottom:-80px;width:220px;height:220px;border-radius:50%;
  background:radial-gradient(closest-side,var(--red-glow),transparent 70%);opacity:.18;transition:opacity .35s;
}
.m-cell:hover{transform:translateY(-6px);border-color:var(--red);box-shadow:0 26px 60px rgba(43,107,255,.20)}
.m-cell:hover::after{opacity:.5}
.m-cell .num{font-family:var(--f-display);font-size:13px;color:var(--red-ink);letter-spacing:.14em}
.m-cell h3{font-family:var(--f-display);font-weight:500;font-size:clamp(22px,2.6vw,30px);color:#fff;margin:auto 0 10px;line-height:1.08}
.m-cell p{color:var(--text-dim);font-size:15px;line-height:1.5;max-width:46ch}
.m-cell .chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.m-cell .chips span{font-size:12px;padding:5px 11px;border-radius:999px;background:var(--red-soft);border:1px solid var(--red-line);color:var(--red-ink)}
.m-cell .spot{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .3s;
  background:radial-gradient(380px circle at var(--mx,50%) var(--my,50%),rgba(43,107,255,.16),transparent 60%)}
.m-cell:hover .spot{opacity:1}

/* ============================================================
   PROCESSO IMERSIVO — espinha vermelha + nós em zig-zag
   ============================================================ */
.m-flow{padding:clamp(80px,11vw,140px) 0;position:relative;overflow:hidden}
.m-flow::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(40% 50% at 80% 20%,rgba(43,107,255,.14),transparent 60%),
    radial-gradient(40% 50% at 15% 85%,rgba(123,22,219,.18),transparent 62%)}
.m-flow .container{position:relative;z-index:2}
.m-track{position:relative;margin-top:64px;padding-left:0}
/* espinha central */
.m-track::before{
  content:"";position:absolute;left:30px;top:0;bottom:0;width:3px;border-radius:3px;
  background:linear-gradient(180deg,var(--red) 0%,var(--roxo-2) 100%);
  box-shadow:0 0 18px var(--red-glow);opacity:.55;
}
@media(min-width:861px){.m-track::before{left:50%;transform:translateX(-50%)}}
.m-node{position:relative;padding:0 0 54px 70px}
@media(min-width:861px){
  .m-node{width:50%;padding:0 56px 64px 56px}
  .m-node:nth-child(odd){left:0;text-align:right}
  .m-node:nth-child(even){left:50%;text-align:left}
}
.m-node .dot{
  position:absolute;top:2px;left:18px;width:26px;height:26px;border-radius:50%;
  background:var(--m-bg);border:3px solid var(--red);box-shadow:0 0 0 6px rgba(43,107,255,.12),0 0 22px var(--red-glow);
  display:grid;place-items:center;
}
.m-node .dot::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--red)}
@media(min-width:861px){
  .m-node:nth-child(odd) .dot{left:auto;right:-13px}
  .m-node:nth-child(even) .dot{left:-13px}
}
.m-node .n{font-family:var(--f-display);font-weight:700;font-size:clamp(40px,6vw,72px);line-height:.9;
  background:var(--grad-red);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;margin-bottom:6px}
.m-node h4{font-family:var(--f-display);font-weight:500;font-size:clamp(19px,2.2vw,24px);color:#fff;margin:0 0 8px}
.m-node p{color:var(--text-dim);font-size:15px;line-height:1.5;max-width:42ch}
@media(min-width:861px){.m-node:nth-child(odd) p{margin-left:auto}}

/* ============================================================
   RESULTADOS — números editoriais gigantes + clientes + quote
   ============================================================ */
.m-proof{padding:clamp(72px,10vw,120px) 0;position:relative;overflow:hidden}
.m-proof::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 60% at 50% 0%,rgba(43,107,255,.12),transparent 60%)}
.m-proof .container{position:relative;z-index:2}
.m-nums{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:18px}
@media(max-width:760px){.m-nums{grid-template-columns:1fr}}
.m-num{padding:18px 0;border-top:1px solid var(--red-line)}
.m-num .v{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,8vw,96px);line-height:.9;letter-spacing:-.02em;
  background:var(--grad-rp);-webkit-background-clip:text;background-clip:text;color:transparent;transform:skewX(-5deg);display:inline-block}
.m-num .l{display:block;margin-top:12px;color:var(--text-dim);font-size:14px;max-width:30ch}
.m-num .l b{color:#fff;font-weight:700}

.m-quote{margin:48px 0 8px;max-width:880px}
.m-quote p{font-family:var(--f-display);font-weight:400;font-size:clamp(20px,2.8vw,32px);line-height:1.25;color:#fff;letter-spacing:-.01em}
.m-quote p .hl{background:var(--grad-red);-webkit-background-clip:text;background-clip:text;color:transparent}
.m-quote .who{margin-top:18px;color:var(--text-mute);font-size:14px;letter-spacing:.04em}

/* marquee de clientes: logos SEM quadros, direto na seção clara */
.m-clients{margin-top:56px;overflow:hidden;padding:6px 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.m-clients .lbl{display:block;text-align:center;margin-bottom:24px;color:var(--ink-mute);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:700}
.m-clients .track{display:flex;gap:60px;width:max-content;align-items:center;animation:ribbon 40s linear infinite}
.m-clients:hover .track{animation-play-state:paused}
.m-clients .lg{flex-shrink:0;height:60px;display:grid;place-items:center;padding:0 8px}
.m-clients .lg img{max-height:40px;max-width:150px;width:auto;object-fit:contain;display:block;filter:saturate(1.05)}
.m-clients .lg img.tall{max-height:54px}

/* ============================================================
   SEÇÕES CLARAS  —  ritmo claro/escuro (operador pediu mais claro)
   Aplicar .m-light na <section>. Roxo/vermelho viram accent escuro
   legível sobre o creme.
   ============================================================ */
.m-light{
  background:linear-gradient(180deg,#f6f3fc 0%,#fcfbff 100%);
  color:var(--ink-2);
}
.m-light::before{
  content:"";position:absolute;left:0;right:0;top:-1px;height:2px;pointer-events:none;z-index:3;
  background:linear-gradient(90deg,transparent 8%,var(--red) 50%,transparent 92%);
  box-shadow:0 0 26px var(--red-glow);
}
/* cancela os glows escuros internos quando a seção é clara */
.m-light.m-deliver::before,
.m-light.m-services::before,
.m-light.m-proof::before{background:linear-gradient(90deg,transparent 8%,var(--red) 50%,transparent 92%)}
.m-light .m-head .k{color:var(--red-deep)}
.m-light .m-head h2{color:var(--ink)}
.m-light .m-head h2 em{background:linear-gradient(115deg,var(--red) 0%,var(--red-deep) 70%,var(--roxo) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.m-light .m-head p{color:var(--ink-2)}

/* pilares no claro */
.m-light .m-pillar{background:linear-gradient(165deg,rgba(43,107,255,.06),#ffffff);border-color:rgba(43,107,255,.18);box-shadow:0 14px 34px rgba(74,10,138,.08)}
.m-light .m-pillar:nth-child(2){background:linear-gradient(165deg,rgba(123,22,219,.08),#ffffff);border-color:rgba(123,22,219,.20)}
.m-light .m-pillar .pic{color:var(--red-deep)}
.m-light .m-pillar:nth-child(2) .pic{color:var(--roxo)}
.m-light .m-pillar h3{color:var(--ink)}
.m-light .m-pillar p{color:var(--ink-2)}
.m-light .m-pillar .big-n{color:rgba(22,16,46,.05)}

/* bento no claro */
.m-light .m-cell{background:#ffffff;border-color:rgba(123,22,219,.12);box-shadow:0 14px 34px rgba(74,10,138,.08)}
.m-light .m-cell h3{color:var(--ink)}
.m-light .m-cell p{color:var(--ink-2)}
.m-light .m-cell .num{color:var(--red-deep)}
.m-light .m-cell .chips span{background:rgba(43,107,255,.08);border-color:rgba(43,107,255,.24);color:var(--red-deep)}
.m-light .m-cell:hover{border-color:var(--red);box-shadow:0 24px 54px rgba(43,107,255,.18)}
.m-light .m-cell::after{opacity:.08}
.m-light .m-cell:hover::after{opacity:.22}
.m-light .m-cell .spot{background:radial-gradient(380px circle at var(--mx,50%) var(--my,50%),rgba(43,107,255,.10),transparent 60%)}

/* resultados no claro */
.m-light .m-num{border-top-color:rgba(43,107,255,.32)}
.m-light .m-num .v{background:linear-gradient(115deg,var(--red) 0%,var(--red-deep) 65%,var(--roxo) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.m-light .m-num .l{color:var(--ink-2)}
.m-light .m-num .l b{color:var(--ink)}
.m-light .m-quote p{color:var(--ink)}
.m-light .m-quote p .hl{background:linear-gradient(115deg,var(--red),var(--red-deep));-webkit-background-clip:text;background-clip:text;color:transparent}
.m-light .m-quote .who{color:var(--ink-mute)}

/* ============================================================
   IMAGENS (banco livre, temas que casam)
   ============================================================ */
/* card de serviço com imagem de fundo (Tráfego Pago) */
.m-cell.img{overflow:hidden}
.m-light .m-cell.img{background:#0a0410;border-color:var(--red-line)}
.m-cell.img .bgimg{position:absolute;inset:0;z-index:0}
.m-cell.img .bgimg img{width:100%;height:100%;object-fit:cover;opacity:.92}
.m-cell.img::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(150deg,rgba(20,4,16,.42) 0%,rgba(7,0,9,.88) 78%)}
.m-cell.img::after{display:none}
.m-cell.img > *{position:relative;z-index:2}
.m-light .m-cell.img .num{color:var(--red-ink)}
.m-light .m-cell.img h3{color:#fff}
.m-light .m-cell.img p{color:var(--text-dim)}
.m-light .m-cell.img .chips span{background:rgba(43,107,255,.18);border-color:var(--red-line);color:#dbe6ff}
.m-cell.img:hover{border-color:var(--red);box-shadow:0 24px 54px rgba(43,107,255,.30)}

/* resultados: imagem do painel + depoimento lado a lado */
.m-proof-feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:center;margin-top:52px}
@media(max-width:840px){.m-proof-feature{grid-template-columns:1fr;gap:28px}}
.m-proof-media{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:16/11;
  border:1px solid var(--red-line);box-shadow:0 26px 60px rgba(74,10,138,.16)}
.m-proof-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.m-proof-media::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(120deg,rgba(43,107,255,.12),transparent 58%)}
.m-proof .m-quote{margin:0}
.m-light .m-proof-media .m-badge{color:#fff}

/* ============================================================
   CTA FINAL — bloco vermelho
   ============================================================ */
.m-cta{padding:clamp(80px,11vw,140px) 0;position:relative;overflow:hidden}
.m-cta-card{
  position:relative;overflow:hidden;border-radius:30px;text-align:center;
  padding:clamp(44px,7vw,84px) clamp(24px,5vw,64px);
  background:
    radial-gradient(60% 90% at 0% 0%,rgba(43,107,255,.5),transparent 60%),
    radial-gradient(70% 90% at 100% 100%,rgba(123,22,219,.45),transparent 60%),
    linear-gradient(160deg,#02122e,#070009);
  border:1px solid var(--red-line);
  box-shadow:0 0 80px rgba(43,107,255,.22);
}
.m-cta-card::after{content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:overlay;opacity:.5;
  background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,.10) 50%,transparent 60%);background-size:240% 100%;
  animation:glass-sheen 7s ease-in-out infinite}
.m-cta-card .k{font-size:12px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--red-ink)}
.m-cta-card h2{font-family:var(--f-display);font-weight:600;font-size:clamp(30px,5.4vw,64px);line-height:1.02;letter-spacing:-.02em;color:#fff;margin:16px auto 18px;max-width:14ch}
.m-cta-card h2 em{font-style:normal;background:var(--grad-red);-webkit-background-clip:text;background-clip:text;color:transparent}
.m-cta-card p{color:var(--text-dim);max-width:54ch;margin:0 auto 30px;font-size:clamp(16px,1.7vw,19px)}
.m-cta-card .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;z-index:2}

/* footer: laço vermelho */
.footer::before{filter:hue-rotate(280deg) saturate(1.4)}
.f-col a:hover{color:var(--red-ink)}
.socials a:hover{background:var(--red);border-color:var(--red)}
.f-brand p{max-width:360px}

/* reveal helpers reaproveitam .reveal de script.js */
.reveal.delay-4{animation-delay:.32s}
.reveal.delay-5{animation-delay:.40s}

/* números de resultados: alinhados, sem quebra (evita o "14 dias" torto) */
.m-nums{align-items:start}
.m-num{display:flex;flex-direction:column}
.m-num .v{white-space:nowrap;font-size:clamp(46px,7vw,88px)}
.m-num .l{min-height:2.6em}

/* ============================================================
   HERO 2 COLUNAS + CARD DE BUILD (exclusivo da Fábrica)
   ============================================================ */
.f-hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(32px,5vw,60px);align-items:center;width:100%}
@media(max-width:960px){.f-hero-grid{grid-template-columns:1fr}.f-hero-grid .hero-visual{display:none}}
.f-hero-grid .hero-card{
  border-color:var(--red-line);
  box-shadow:0 0 60px rgba(43,107,255,.4),0 0 120px rgba(43,107,255,.16);
  background:linear-gradient(160deg,#0b1030 0%,#060714 62%);
}
.f-hero-grid .hero-card .chip{background:rgba(43,107,255,.18);border-color:var(--red-line);color:#dbe6ff}
.f-hero-grid .hero-card .stat b{background:linear-gradient(135deg,#fff,#5b8bff);-webkit-background-clip:text;background-clip:text;color:transparent}
.f-hero-grid .hero-card .progress .fill{background:linear-gradient(90deg,#2b6bff,#5b8bff)}
.f-hero-grid .hero-card .code-line{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:#8fb0ff;
  background:rgba(43,107,255,.08);border:1px solid var(--red-line);border-radius:8px;padding:8px 12px;margin:2px 0 14px}
.f-hero-grid .hero-card .code-line b{color:#5b8bff}

/* ============================================================
   PIPELINE / TERMINAL DE BUILD (substitui a timeline)
   ============================================================ */
.f-pipeline{padding:clamp(80px,11vw,140px) 0;position:relative;overflow:hidden}
.f-pipeline::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(42% 50% at 82% 16%,rgba(43,107,255,.16),transparent 60%),
    radial-gradient(42% 52% at 14% 88%,rgba(123,22,219,.20),transparent 62%)}
.f-pipeline .container{position:relative;z-index:2}
.f-term{max-width:860px;margin:56px auto 0;border-radius:16px;overflow:hidden;
  background:linear-gradient(160deg,#0a1024 0%,#05060f 70%);
  border:1px solid var(--red-line);
  box-shadow:0 46px 110px rgba(0,0,0,.55),0 0 70px rgba(43,107,255,.16)}
.f-term .bar{display:flex;align-items:center;gap:8px;padding:13px 16px;background:rgba(255,255,255,.035);border-bottom:1px solid rgba(255,255,255,.06)}
.f-term .bar i{width:12px;height:12px;border-radius:50%;display:inline-block}
.f-term .bar .r{background:#ff5f56}.f-term .bar .y{background:#ffbd2e}.f-term .bar .g{background:#27c93f}
.f-term .bar .title{margin-left:12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;color:var(--text-mute);letter-spacing:.03em}
.f-term .body{padding:24px 24px 26px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px}
.f-term .cmd{color:#8fb0ff;margin-bottom:16px}
.f-term .cmd .p{color:#5b8bff;font-weight:700}
.f-term .cmd .fl{color:var(--text-mute)}
.f-step{display:grid;grid-template-columns:22px auto 1fr;gap:14px;align-items:baseline;padding:9px 0;border-bottom:1px dashed rgba(255,255,255,.06)}
.f-step:last-child{border-bottom:0}
.f-step .ck{color:#3ad17a;font-weight:700}
.f-step .lead{color:#fff}
.f-step .lead b{color:#5b8bff;font-weight:700;margin-right:8px}
.f-step .desc{color:var(--text-mute);font-size:12.5px;text-align:right}
.f-step.run .ck{color:#5b8bff}
.f-step.run .cursor{display:inline-block;width:9px;height:15px;background:#5b8bff;margin-left:6px;transform:translateY(2px);animation:blink 1.1s steps(1) infinite}
.f-term .status{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-mute)}
.f-term .status .badge{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:999px;background:rgba(58,209,122,.12);border:1px solid rgba(58,209,122,.32);color:#7af0a8;font-weight:700;font-size:12px}
@media(max-width:640px){
  .f-term .body{font-size:12.5px}
  .f-step{grid-template-columns:20px 1fr;gap:10px}
  .f-step .desc{grid-column:2;text-align:left;margin-top:2px}
}
