/* ============================================================
   HubCore — Design System
   Base extraída do layout aprovado (Journey) e generalizada
   para todo o ecossistema HubCore.
   ============================================================ */

:root {
  /* Backgrounds */
  --bg-dark: #020918;
  --bg-deep: #061226;
  --bg-blue: #081a34;

  /* Brand / accents */
  --primary: #1477ff;
  --primary-2: #39a7ff;
  --cyan: #35d4ff;
  --purple: #8f36ff;
  --teal: #0fc7b7;
  --green: #16c172;
  --orange: #ff7a1a;
  --indigo: #6a5cff;

  /* Text */
  --text-dark: #071226;
  --text: #ffffff;
  --muted: #aab8cc;
  --muted-dark: #5a6475;

  /* Lines / surfaces */
  --line: rgba(255,255,255,.12);
  --line-dark: rgba(10,34,70,.10);
  --card: rgba(255,255,255,.07);
  --glass: rgba(7, 20, 42, .72);
  --white: #ffffff;
  --soft: #f4f8ff;

  --shadow: 0 30px 80px rgba(0,0,0,.35);
  --radius-xl: 28px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--bg-dark);
  color: var(--text);
  line-height: 1.5;
}

body.edit-mode [contenteditable="true"] {
  outline: 1px dashed rgba(20,119,255,.55);
  outline-offset: 4px;
  border-radius: 8px;
  cursor: text;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; }

/* ---------- Edit toolbar ---------- */
.edit-toolbar {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 999;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 999px;
  background: rgba(2,9,24,.82);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 18px 50px rgba(0,0,0,.35);
  backdrop-filter: blur(18px);
}
.toolbar-label { color: #c9d8ee; font-size: 12px; padding-left: 8px; white-space: nowrap; }
.toggle-btn {
  border: 0; border-radius: 999px; padding: 10px 14px; color: #fff;
  background: rgba(255,255,255,.08); cursor: pointer; font-weight: 700; font-size: 12px;
}
.toggle-btn.active {
  background: linear-gradient(135deg, var(--primary), #0756d6);
  box-shadow: 0 10px 22px rgba(20,119,255,.35);
}

/* ---------- Top bar / nav ---------- */
.topbar {
  position: absolute;
  inset: 0 0 auto 0;
  z-index: 20;
  height: 86px;
  display: flex;
  align-items: center;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
/* On non-hero (white) pages, use a solid dark bar */
.topbar.solid {
  position: sticky;
  top: 0;
  background: rgba(2,9,24,.92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.nav {
  width: min(var(--max), calc(100% - 48px));
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

/* ---------- Brand / wordmark ---------- */
.brand {
  display: flex;
  align-items: center;
  gap: 11px;
  font-size: 25px;
  font-weight: 900;
  letter-spacing: -.03em;
}
.brand-logo { display: block; width: 188px; height: auto; object-fit: contain; }
footer .brand-logo { width: 168px; }
/* CSS wordmark fallback (shown when logo image is missing) */
.brand-mark {
  width: 38px; height: 38px; border-radius: 12px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--primary), #0756d6);
  box-shadow: 0 12px 26px rgba(20,119,255,.30);
  color: #fff;
}
.brand-word { font-size: 24px; font-weight: 900; letter-spacing: -.04em; color: #fff; }

.menu {
  display: flex; align-items: center; gap: 30px;
  color: rgba(255,255,255,.86); font-size: 14px; font-weight: 600;
}
.menu a { opacity: .92; transition: .2s ease; }
.menu a:hover, .menu a.active { color: var(--primary-2); opacity: 1; }

.nav-cta {
  border: 1px solid rgba(58,161,255,.62);
  color: #eaf4ff;
  padding: 13px 18px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 700;
  background: rgba(20,119,255,.06);
  transition: .2s ease;
}
.nav-cta:hover { background: rgba(20,119,255,.16); border-color: rgba(57,167,255,.9); }

.hamb { display: none; }

/* ---------- Dropdown "Soluções" ---------- */
.has-sub { position: relative; }
.has-sub > .sol-toggle {
  display: inline-flex; align-items: center; gap: 6px; cursor: pointer; opacity: .92;
}
.has-sub > .sol-toggle i { width: 16px; height: 16px; transition: transform .2s ease; }
.has-sub.active > .sol-toggle { color: var(--primary-2); opacity: 1; }
.has-sub:hover > .sol-toggle { color: var(--primary-2); opacity: 1; }
.has-sub:hover > .sol-toggle i { transform: rotate(180deg); }

.submenu {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  padding-top: 16px; z-index: 40;
  opacity: 0; visibility: hidden; transform: translateX(-50%) translateY(8px);
  transition: opacity .18s ease, transform .18s ease;
}
.has-sub:hover .submenu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.submenu-inner {
  width: 560px;
  background: rgba(7,16,34,.97); backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.12); border-radius: 18px;
  padding: 12px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px;
  box-shadow: 0 30px 70px rgba(0,0,0,.5);
}
.submenu-inner > a { display: flex; gap: 12px; align-items: center; padding: 12px; border-radius: 12px; transition: .18s ease; }
.submenu-inner > a:hover { background: rgba(255,255,255,.07); }
.submenu-inner strong { display: block; color: #fff; font-size: 14px; letter-spacing: -.02em; }
.submenu-inner small { display: block; color: #9fb0c8; font-size: 12px; font-weight: 500; }
.submenu-inner small.sm-name { color: var(--primary-2); font-weight: 800; letter-spacing: .04em; }
.mobile-menu a.mm-sub .mm-name { color: #7f93ad; font-weight: 600; }
.sm-ic { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; color: #fff; flex: 0 0 auto; }
.submenu-all {
  grid-column: 1 / -1; justify-content: center; color: var(--primary-2);
  font-weight: 800; font-size: 13px; margin-top: 4px;
  border-top: 1px solid rgba(255,255,255,.08); border-radius: 0;
}

/* Accent background helpers (badges / submenu icons) */
.bg-blue   { background: var(--primary); }
.bg-purple { background: var(--purple); }
.bg-orange { background: var(--orange); }
.bg-teal   { background: var(--green); }
.bg-cyan   { background: var(--cyan); color: #03263a; }
.bg-indigo { background: var(--indigo); }

/* Mobile menu group */
.mm-group {
  margin: 18px 4px 2px; font-size: 12px; font-weight: 900;
  letter-spacing: .14em; text-transform: uppercase; color: var(--primary-2);
}
.mobile-menu a.mm-sub { font-size: 16px; font-weight: 600; padding: 13px 4px; color: #c9d8ee; }

/* ---------- Solution page badge ---------- */
.sol-badge {
  width: 58px; height: 58px; border-radius: 16px; display: grid; place-items: center;
  color: #fff; margin-bottom: 22px; box-shadow: 0 16px 32px rgba(0,0,0,.30);
}
.sol-hero-name {
  font-size: clamp(16px, 2vw, 22px); font-weight: 900;
  letter-spacing: .12em; text-transform: uppercase; margin: -8px 0 20px;
}
.tone-blue   { color: #5fb0ff; }
.tone-purple { color: #b18cff; }
.tone-orange { color: #ff9d5c; }
.tone-teal   { color: #46e3a0; }
.tone-cyan   { color: #7fe6ff; }
.tone-indigo { color: #9a8dff; }

/* Mobile drawer */
.mobile-menu {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 60;
  background: rgba(2,9,24,.96);
  backdrop-filter: blur(16px);
  padding: 96px 30px 30px;
}
.mobile-menu.open { display: block; }
.mobile-menu a {
  display: block;
  padding: 16px 4px;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -.02em;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.mobile-menu .mm-close {
  position: absolute; top: 26px; right: 26px;
  width: 44px; height: 44px; border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04); color: #fff;
  display: grid; place-items: center; cursor: pointer;
}

/* ---------- Hero ---------- */
.hero {
  position: relative;
  min-height: 760px;
  overflow: hidden;
  background:
    radial-gradient(circle at 78% 45%, rgba(20,119,255,.35), transparent 28%),
    radial-gradient(circle at 56% 10%, rgba(57,167,255,.16), transparent 34%),
    linear-gradient(135deg, #020918 0%, #061226 54%, #071936 100%);
}
.hero:before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(2,9,24,.98) 0%, rgba(2,9,24,.86) 34%, rgba(2,9,24,.48) 57%, rgba(2,9,24,.78) 100%),
    url('https://images.unsplash.com/photo-1552664730-d307ca884978?q=80&w=2400&auto=format&fit=crop') center right / cover no-repeat;
  opacity: .93;
}
.hero:after {
  content: "";
  position: absolute;
  inset: auto -15% -28% -15%;
  height: 430px;
  background: radial-gradient(ellipse at center, rgba(20,119,255,.35), transparent 58%);
  filter: blur(12px);
  pointer-events: none;
}
/* Hero da TrueMind com imagem própria */
.hero-truemind:before {
  background:
    linear-gradient(90deg, rgba(2,9,24,.97) 0%, rgba(2,9,24,.84) 38%, rgba(2,9,24,.5) 62%, rgba(2,9,24,.78) 100%),
    url('truemind.jpg') center center / cover no-repeat;
  opacity: 1;
}

/* Hero da QuickCreate com imagem própria */
.hero-quickcreate:before {
  background:
    linear-gradient(90deg, rgba(2,9,24,.97) 0%, rgba(2,9,24,.84) 38%, rgba(2,9,24,.5) 62%, rgba(2,9,24,.78) 100%),
    url('QuickCreate.jpg') center center / cover no-repeat;
  opacity: 1;
}

/* Compact hero variant for internal pages */
.hero.compact { min-height: 520px; }
.hero.compact .hero-grid { padding: 150px 0 70px; }

.hero-grid {
  position: relative;
  z-index: 2;
  width: min(var(--max), calc(100% - 48px));
  margin: 0 auto;
  padding: 170px 0 92px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  align-items: center;
}
.hero-copy { max-width: 720px; }
.hero-grid.two { grid-template-columns: 1.05fr .95fr; align-items: center; gap: 54px; }
@media (max-width: 1040px) { .hero-grid.two { grid-template-columns: 1fr; } }

/* Stat cards (números de mercado) */
.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.stat-card {
  background: linear-gradient(180deg, #fff, #f6f9ff);
  border: 1px solid rgba(10,34,70,.09); border-radius: 20px; padding: 26px 24px;
  box-shadow: 0 18px 46px rgba(13,41,81,.07);
}
.stat-card .num {
  display: block; font-size: 46px; line-height: 1; letter-spacing: -.05em; font-weight: 900; margin-bottom: 10px;
  background: linear-gradient(135deg, #1b7cff, #47d2ff); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.stat-card small { color: #58677d; font-size: 14px; line-height: 1.5; display: block; }
.stat-card.has-src { min-height: 200px; display: flex; flex-direction: column; transition: .2s ease; }
.stat-card.has-src:hover { transform: translateY(-4px); box-shadow: 0 26px 60px rgba(13,41,81,.12); }
.stat-card .stat-src { margin-top: auto; padding-top: 14px; color: #8190a6; font-size: 12px; }
@media (max-width: 1040px) { .stat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 680px)  { .stat-grid { grid-template-columns: 1fr; } }

/* Check-list em 2 colunas */
.check-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 32px; }
@media (max-width: 680px) { .check-2col { grid-template-columns: 1fr; } }

/* Grade de chips (jornadas) */
.chip-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 900px) { .chip-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .chip-grid { grid-template-columns: 1fr; } }
.chip {
  display: flex; align-items: center; gap: 13px;
  padding: 16px 18px; border-radius: 14px;
  background: #fff; border: 1px solid rgba(10,34,70,.10);
  box-shadow: 0 14px 34px rgba(13,41,81,.06);
  color: #2a3a52; font-weight: 700; font-size: 15px;
}
.chip .ic {
  width: 28px; height: 28px; flex: 0 0 auto; border-radius: 9px;
  display: grid; place-items: center; background: rgba(20,119,255,.12); color: var(--primary);
}
.chip .ic svg { width: 16px; height: 16px; }
.chip-grid.acc-teal .chip .ic { background: rgba(22,193,114,.14); color: var(--green); }
.chip-grid.acc-purple .chip .ic { background: rgba(143,54,255,.12); color: var(--purple); }
.chip-grid.acc-orange .chip .ic { background: rgba(255,122,26,.12); color: #e95d00; }
.chip-grid.acc-cyan .chip .ic { background: rgba(53,212,255,.16); color: #0a8fc0; }
.chip-grid.acc-indigo .chip .ic { background: rgba(106,92,255,.12); color: #5547e0; }

/* Cabeçalho em 2 colunas (título + texto de defesa) */
.head-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: end; margin-bottom: 40px; }
.head-2col h2 { margin: 0; }
.head-2col p { margin: 0; }
@media (max-width: 900px) { .head-2col { grid-template-columns: 1fr; gap: 16px; align-items: start; } }

/* Tópicos com ícone em destaque (grade de funcionalidades) */
.feature-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 1040px) { .feature-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px)  { .feature-grid { grid-template-columns: 1fr; } }
.feature-item {
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px; padding: 22px; transition: .2s ease;
}
.feature-item:hover { background: rgba(255,255,255,.07); transform: translateY(-3px); }
.feature-item .fi-ic {
  width: 48px; height: 48px; border-radius: 14px; display: grid; place-items: center;
  margin-bottom: 16px; background: rgba(20,119,255,.16); color: #5fb0ff;
}
.feature-item .fi-ic svg { width: 22px; height: 22px; }
.feature-item strong { display: block; color: #fff; font-size: 16px; letter-spacing: -.02em; margin-bottom: 6px; line-height: 1.25; }
.feature-item small { color: #9fb0c8; font-size: 13px; line-height: 1.5; }
.feature-grid.acc-indigo .fi-ic { background: rgba(106,92,255,.20); color: #9a8dff; }
.feature-grid.acc-purple .fi-ic { background: rgba(143,54,255,.20); color: #b18cff; }
.feature-grid.acc-orange .fi-ic { background: rgba(255,122,26,.20); color: #ff9d5c; }
.feature-grid.acc-teal .fi-ic   { background: rgba(22,193,114,.20); color: #46e3a0; }
.feature-grid.acc-cyan .fi-ic   { background: rgba(53,212,255,.22); color: #7fe6ff; }
.feature-item:hover .fi-ic { transform: scale(1.05); }

/* FAQ (accordion nativo, sem JS) */
.faq { display: grid; gap: 12px; max-width: 860px; margin: 0 auto; }
.faq details {
  background: #fff; border: 1px solid rgba(10,34,70,.10); border-radius: 16px;
  padding: 0 22px; box-shadow: 0 14px 34px rgba(13,41,81,.06);
}
.faq summary {
  list-style: none; cursor: pointer; padding: 20px 0; font-weight: 800; color: #071226;
  font-size: 17px; display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary:after { content: "+"; font-size: 26px; line-height: 1; color: var(--primary); font-weight: 400; flex: 0 0 auto; }
.faq details[open] summary:after { content: "\2013"; }
.faq details p { margin: 0 0 20px; color: #51627b; font-size: 15px; line-height: 1.7; }

/* Faixa de fatos (obrigação) */
.fact-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 28px; }
@media (max-width: 760px) { .fact-row { grid-template-columns: 1fr; } }
.fact { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.10); border-radius: 16px; padding: 22px; }
.fact i, .fact svg { color: var(--primary-2); margin-bottom: 12px; }
.fact strong { display: block; color: #fff; font-size: 15px; margin-bottom: 6px; }
.fact small { color: #aebdd2; font-size: 13.5px; line-height: 1.5; }

/* Callout (destaque) */
.callout {
  border-left: 4px solid var(--primary); background: rgba(20,119,255,.10);
  border-radius: 14px; padding: 22px 24px; color: #dbe8fa; font-size: 17px; line-height: 1.65;
}

.eyebrow {
  color: var(--primary-2);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 12px;
  font-weight: 900;
  margin: 0 0 22px;
}

h1, h2, h3, p { margin-top: 0; }

.hero h1 {
  font-size: clamp(44px, 6vw, 78px);
  line-height: .99;
  letter-spacing: -.07em;
  margin-bottom: 24px;
  max-width: 760px;
}
.hero.compact h1 { font-size: clamp(40px, 5vw, 64px); }

.blue-text {
  background: linear-gradient(135deg, #1b7cff, #47d2ff);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero-lead {
  max-width: 720px;
  color: #eaf2ff;
  font-size: clamp(22px, 2.6vw, 32px);
  line-height: 1.25;
  letter-spacing: -.03em;
  font-weight: 800;
  margin: 0 0 22px;
}
.hero-sub {
  max-width: 620px;
  color: #cbd6e8;
  font-size: 18px;
  line-height: 1.7;
  margin-bottom: 30px;
}
.hero-sub + .hero-sub { margin-top: -16px; }

/* 2-column body copy */
.copy-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.copy-2col p { color: #51627b; font-size: 16px; line-height: 1.7; margin: 0; }
.dark-band .copy-2col p { color: #aebdd2; }

.hero-actions {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 14px; margin-bottom: 58px;
}
.hero.compact .hero-actions { margin-bottom: 12px; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 22px; border-radius: 12px;
  font-size: 15px; font-weight: 800;
  transition: .2s ease; border: 1px solid transparent;
}
.btn-primary {
  background: linear-gradient(135deg, #157bff, #075ce8);
  color: #fff; box-shadow: 0 18px 45px rgba(20,119,255,.32);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 22px 55px rgba(20,119,255,.42); }
.btn-ghost {
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.04); color: #fff;
}
.btn-ghost:hover { border-color: rgba(57,167,255,.65); background: rgba(20,119,255,.10); }
.btn-dark { background: #071226; color: #fff; border-color: rgba(10,34,70,.16); }
.btn-dark:hover { transform: translateY(-2px); }

/* ---------- Hero points ---------- */
.hero-points {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  grid-column: 1 / -1;
  margin-top: 6px;
}
.point {
  display: flex; gap: 13px; min-width: 0;
  color: #dbe8fa; padding-right: 14px;
  border-right: 1px solid rgba(255,255,255,.12);
}
.point:last-child { border-right: 0; }
.point i { color: var(--primary-2); flex: 0 0 auto; }
.point strong { display: block; color: #fff; font-size: 14px; margin-bottom: 4px; }
.point small { color: #9fb0c8; font-size: 13px; line-height: 1.45; display: block; }

/* ---------- Trust strip ---------- */
.trust {
  position: relative; z-index: 2;
  background: linear-gradient(180deg, rgba(5,15,32,.96), rgba(10,24,46,.98));
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.trust-inner { width: min(var(--max), calc(100% - 48px)); margin: 0 auto; padding: 34px 0; }
.trust-label { color: var(--primary-2); font-size: 11px; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; margin-bottom: 20px; }

/* ---------- Flow steps (Comunicar → Engajar → ...) ---------- */
.flow {
  display: flex; flex-wrap: wrap; align-items: stretch; gap: 12px;
}
.flow-step {
  flex: 1 1 140px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  border-radius: 16px;
  padding: 18px 16px;
  position: relative;
  min-width: 0;
}
.flow-step i { color: var(--primary-2); margin-bottom: 12px; }
.flow-step strong { display: block; font-size: 16px; letter-spacing: -.02em; color: #fff; margin-bottom: 6px; }
.flow-step small { color: #9fb0c8; font-size: 13px; line-height: 1.45; }
.flow-step span.num { position: absolute; top: 14px; right: 16px; font-size: 12px; font-weight: 900; color: rgba(255,255,255,.35); }

/* ---------- Market / stat cards ---------- */
.market-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.market-card {
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.055);
  border-radius: 18px; padding: 20px; min-height: 150px;
}
.market-card strong { display: block; font-size: 34px; line-height: 1; letter-spacing: -.06em; margin-bottom: 10px; color: #fff; }
.market-card p { color: #c4d1e4; font-size: 14px; margin-bottom: 12px; }
.market-card small { color: #7fbfff; font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }

/* ---------- Faixa de clientes ---------- */
.clients { background: #ffffff; padding: 42px 0; border-bottom: 1px solid rgba(10,34,70,.08); }
.clients-label {
  text-align: center; color: #7a8aa3; font-size: 12px; font-weight: 800;
  letter-spacing: .16em; text-transform: uppercase; margin: 0 0 28px;
}
.client-logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 34px 56px; }
.client-logo {
  height: 60px; max-width: 210px; object-fit: contain;
  filter: grayscale(1); opacity: .58; transition: .25s ease;
}
.client-logo:hover { filter: grayscale(0); opacity: 1; }
.client-name {
  color: #9aa7ba; font-weight: 800; font-size: 26px; letter-spacing: -.02em;
  filter: grayscale(1); transition: .25s ease;
}
.client-name:hover { color: #46587a; }
.clients-more { color: #aab6c8; font-weight: 800; font-size: 15px; }

@media (max-width: 680px) {
  .client-logos { gap: 26px 36px; }
  .client-logo { height: 42px; max-width: 150px; }
  .client-name { font-size: 20px; }
}

/* ---------- White section ---------- */
.white-section { background: linear-gradient(180deg, #fff, #f7faff); color: var(--text-dark); padding: 78px 0; }
.section-inner { width: min(var(--max), calc(100% - 48px)); margin: 0 auto; }
.center { text-align: center; }
.section-kicker { color: #136eff; text-transform: uppercase; letter-spacing: .16em; font-size: 12px; font-weight: 900; margin-bottom: 12px; }
.section-title { font-size: clamp(32px, 4vw, 48px); line-height: 1.08; letter-spacing: -.055em; margin-bottom: 16px; }
.section-sub { color: #506079; font-size: 17px; max-width: 720px; margin: 0 auto 48px; }
.center .section-sub { margin-left: auto; margin-right: auto; }

/* ---------- Solution / frente cards ---------- */
.solution-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.solution-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.solution-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }

.solution-card {
  min-height: 420px;
  border-radius: 22px;
  background: #fff;
  border: 1px solid rgba(10,34,70,.10);
  box-shadow: 0 24px 60px rgba(13,41,81,.08);
  padding: 24px;
  position: relative;
  overflow: hidden;
  transition: .25s ease;
  display: flex;
  flex-direction: column;
}
.solution-card:hover { transform: translateY(-7px); box-shadow: 0 32px 80px rgba(13,41,81,.13); }
.solution-card:before { content: ""; position: absolute; inset: 0 0 auto; height: 4px; background: var(--primary); }

/* Accent variants (top bar + icon + pill + list bullets) */
.f-blue:before    { background: var(--primary); }
.f-purple:before  { background: var(--purple); }
.f-orange:before  { background: var(--orange); }
.f-teal:before    { background: var(--green); }
.f-cyan:before    { background: var(--cyan); }
.f-indigo:before  { background: var(--indigo); }

.solution-visual {
  height: 118px; border-radius: 20px; margin: 0 0 24px;
  display: flex; align-items: center; justify-content: space-between;
  background: linear-gradient(135deg, rgba(20,119,255,.11), rgba(20,119,255,.02));
  padding: 18px;
}
.f-purple .solution-visual { background: linear-gradient(135deg, rgba(143,54,255,.12), rgba(143,54,255,.02)); }
.f-orange .solution-visual { background: linear-gradient(135deg, rgba(255,122,26,.13), rgba(255,122,26,.02)); }
.f-teal .solution-visual   { background: linear-gradient(135deg, rgba(22,193,114,.13), rgba(22,193,114,.02)); }
.f-cyan .solution-visual   { background: linear-gradient(135deg, rgba(53,212,255,.14), rgba(53,212,255,.02)); }
.f-indigo .solution-visual { background: linear-gradient(135deg, rgba(106,92,255,.14), rgba(106,92,255,.02)); }

.solution-icon {
  width: 54px; height: 54px; border-radius: 16px; display: grid; place-items: center;
  color: #fff; background: var(--primary); box-shadow: 0 16px 32px rgba(20,119,255,.25);
}
.f-purple .solution-icon { background: var(--purple); }
.f-orange .solution-icon { background: var(--orange); }
.f-teal .solution-icon   { background: var(--green); }
.f-cyan .solution-icon   { background: var(--cyan); color: #03263a; }
.f-indigo .solution-icon { background: var(--indigo); }

.iso-shape {
  width: 88px; height: 72px; border-radius: 20px; opacity: .72;
  background: linear-gradient(135deg, rgba(255,255,255,.7), rgba(20,119,255,.22));
  transform: skew(-12deg) rotate(-4deg);
}

.pill {
  display: inline-block; padding: 6px 9px; border-radius: 999px;
  color: var(--primary); background: rgba(20,119,255,.09);
  text-transform: uppercase; letter-spacing: .06em;
  font-size: 10px; font-weight: 900; margin-bottom: 12px;
}
.f-purple .pill { color: var(--purple); background: rgba(143,54,255,.09); }
.f-orange .pill { color: #e95d00; background: rgba(255,122,26,.10); }
.f-teal .pill   { color: #0a9a5c; background: rgba(22,193,114,.12); }
.f-cyan .pill   { color: #0a8fc0; background: rgba(53,212,255,.14); }
.f-indigo .pill { color: #5547e0; background: rgba(106,92,255,.12); }

.solution-card h3 { font-size: 24px; letter-spacing: -.04em; margin-bottom: 12px; }
/* Categoria em destaque + nome da plataforma menor (segundo) */
.solution-card .sol-cat { font-size: 23px; letter-spacing: -.035em; line-height: 1.12; margin: 0 0 6px; color: #071226; }
.solution-card .sol-name {
  display: inline-block; font-size: 12px; font-weight: 900; letter-spacing: .10em;
  text-transform: uppercase; color: var(--primary); margin-bottom: 14px;
}
.f-purple .sol-name { color: var(--purple); }
.f-orange .sol-name { color: #e95d00; }
.f-teal .sol-name   { color: #0a9a5c; }
.f-cyan .sol-name   { color: #0a8fc0; }
.f-indigo .sol-name { color: #5547e0; }
.solution-card p { color: #526079; font-size: 15px; min-height: 68px; }
.solution-card .card-desc { color: #67768d; font-size: 13.5px; line-height: 1.55; min-height: 0; margin: -4px 0 0; }
.solution-card .ideal {
  font-size: 12.5px; line-height: 1.5; color: #40516a; min-height: 0;
  background: rgba(20,119,255,.06); border-radius: 12px; padding: 12px 14px; margin: 14px 0 0;
}
.solution-card .ideal strong { color: #136eff; }
.f-purple .ideal strong { color: var(--purple); }
.f-orange .ideal strong { color: #e95d00; }
.f-teal .ideal strong   { color: #0a9a5c; }
.f-cyan .ideal strong   { color: #0a8fc0; }
.f-indigo .ideal strong { color: #5547e0; }
.solution-card ul { list-style: none; padding: 0; margin: 20px 0 22px; display: grid; gap: 10px; color: #40516a; font-size: 13px; }
.solution-card li:before { content: "✦"; color: var(--primary); margin-right: 8px; }
.f-purple li:before { color: var(--purple); }
.f-orange li:before { color: var(--orange); }
.f-teal li:before   { color: var(--green); }
.f-cyan li:before   { color: #0a8fc0; }
.f-indigo li:before { color: var(--indigo); }
/* Card largo (ocupa todas as colunas) — layout horizontal */
.solution-card.wide { grid-column: 1 / -1; flex-direction: row; align-items: center; gap: 30px; min-height: auto; }
.solution-card.wide .solution-visual { width: 240px; flex: 0 0 240px; height: 150px; margin: 0; }
.solution-card.wide .wide-body { flex: 1 1 auto; }
.solution-card.wide .wide-body p { min-height: 0; }
.solution-card.wide .wide-body .ideal { margin-top: 12px; }
@media (max-width: 680px) {
  .solution-card.wide { flex-direction: column; align-items: stretch; gap: 0; }
  .solution-card.wide .solution-visual { width: 100%; flex: none; }
}

.learn { color: var(--primary); font-size: 13px; font-weight: 900; cursor: pointer; margin-top: auto; }
.f-purple .learn { color: var(--purple); }
.f-orange .learn { color: #e95d00; }
.f-teal .learn   { color: #0a9a5c; }
.f-cyan .learn   { color: #0a8fc0; }
.f-indigo .learn { color: #5547e0; }

/* ---------- Product modal ---------- */
.product-modal-overlay {
  position: fixed; inset: 0; z-index: 1200; display: none;
  align-items: center; justify-content: center; padding: 24px;
  background: rgba(2, 9, 24, .72); backdrop-filter: blur(14px);
}
.product-modal-overlay.open { display: flex; }
.product-modal {
  width: min(760px, 100%); max-height: 88vh; overflow: auto;
  border-radius: 28px; background: linear-gradient(180deg, #ffffff, #f6f9ff);
  color: #071226; border: 1px solid rgba(10,34,70,.12);
  box-shadow: 0 34px 100px rgba(0,0,0,.38); padding: 34px; position: relative;
}
.modal-close {
  position: absolute; right: 22px; top: 20px;
  width: 42px; height: 42px; border-radius: 50%;
  border: 1px solid rgba(10,34,70,.12); background: #fff; color: #071226;
  cursor: pointer; display: grid; place-items: center;
}
.modal-kicker {
  display: inline-block; padding: 7px 11px; border-radius: 999px;
  color: #1477ff; background: rgba(20,119,255,.09);
  text-transform: uppercase; letter-spacing: .08em;
  font-size: 11px; font-weight: 900; margin-bottom: 16px;
}
.product-modal h3 { font-size: clamp(30px, 4vw, 44px); line-height: 1.05; letter-spacing: -.055em; margin: 0 48px 16px 0; }
.modal-description { color: #4f5f78; font-size: 17px; line-height: 1.7; margin-bottom: 24px; }
.modal-topic-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-bottom: 28px; }
.modal-topic { border-radius: 18px; background: #fff; border: 1px solid rgba(10,34,70,.09); padding: 16px; box-shadow: 0 14px 34px rgba(13,41,81,.07); }
.modal-topic strong { display: block; font-size: 15px; margin-bottom: 6px; color: #071226; }
.modal-topic span { display: block; color: #5b6b82; font-size: 13px; line-height: 1.45; }
.modal-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* ---------- Dark band ---------- */
.dark-band {
  background:
    radial-gradient(circle at 70% 40%, rgba(20,119,255,.18), transparent 34%),
    linear-gradient(180deg, #020918, #061226);
  padding: 82px 0; color: #fff;
}
.impact-grid { display: grid; grid-template-columns: 1fr 1.55fr; gap: 50px; align-items: center; }
.impact-copy h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.05; letter-spacing: -.06em; margin-bottom: 18px; }
.impact-copy p { color: #aebdd2; font-size: 17px; max-width: 460px; }

.metric-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.metric-card {
  border-radius: 22px; background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.09);
  padding: 28px 20px; min-height: 205px;
  display: grid; align-content: center; text-align: center;
}
.metric-card i { color: var(--primary-2); margin: 0 auto 20px; }
.metric-card strong { font-size: 46px; letter-spacing: -.06em; display: block; margin-bottom: 8px; }
.metric-card span { color: #d8e4f4; font-weight: 800; display: block; margin-bottom: 4px; }
.metric-card small { color: #9fb0c8; }

/* ---------- Benefits / pillars ---------- */
.benefits { background: #fff; color: var(--text-dark); padding: 74px 0 82px; }
.benefit-header { display: grid; grid-template-columns: .9fr 1.1fr; gap: 42px; align-items: end; margin-bottom: 34px; }
.benefit-header h2 { font-size: clamp(32px, 4vw, 48px); line-height: 1.05; letter-spacing: -.055em; margin: 0; }
.benefit-header p { color: #51627b; font-size: 17px; margin: 0; max-width: 560px; }
.benefit-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.benefit-row.cols-2 { grid-template-columns: repeat(2, 1fr); }
.benefit-item {
  display: flex; gap: 16px; align-items: flex-start; color: #34445d;
  background: linear-gradient(180deg, #ffffff, #f6f9ff);
  border: 1px solid rgba(10,34,70,.09);
  box-shadow: 0 18px 46px rgba(13,41,81,.07);
  border-radius: 20px; padding: 22px; min-height: 150px;
}
.benefit-item i, .benefit-item svg { color: #0f61db; flex: 0 0 auto; margin-top: 3px; }
.benefit-item strong { display: block; color: #071226; margin-bottom: 8px; font-size: 16px; letter-spacing: -.02em; }
.benefit-item small { color: #58677d; line-height: 1.55; font-size: 14px; }

/* Variante "pilares": fila única de 4, ícone maior e azul, corpo de texto bem menor */
.benefit-row.pilares { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1040px) { .benefit-row.pilares { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 680px)  { .benefit-row.pilares { grid-template-columns: 1fr; } }
.benefit-row.pilares .benefit-item { flex-direction: column; gap: 14px; min-height: 0; }
.benefit-row.pilares .benefit-item > svg,
.benefit-row.pilares .benefit-item > i {
  width: 40px; height: 40px; margin-top: 0;
  color: var(--primary); stroke: var(--primary);
}
.benefit-row.pilares .benefit-item strong { font-size: 18px; margin-bottom: 6px; }
.benefit-row.pilares .benefit-item small { font-size: 12px; line-height: 1.5; }

/* ---------- Intelligence ---------- */
.intelligence { background: #f7faff; color: var(--text-dark); padding: 78px 0; }
.intel-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 44px; align-items: center; }
.intel-grid.reverse { grid-template-columns: 1.15fr .85fr; }
.intel-panel {
  border-radius: 30px; background: #061226; color: #fff; padding: 22px;
  box-shadow: 0 28px 70px rgba(9, 29, 61, .22); border: 1px solid rgba(255,255,255,.08);
}
.intel-video {
  border-radius: 24px; overflow: hidden; line-height: 0;
  box-shadow: 0 28px 70px rgba(9,29,61,.22); border: 1px solid rgba(10,34,70,.10); background: #061226;
}
.intel-video video { width: 100%; height: auto; display: block; }
.panel-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.panel-card { background: rgba(255,255,255,.07); border-radius: 17px; padding: 18px; border: 1px solid rgba(255,255,255,.08); }
.panel-card small { color: #9fb0c8; display: block; margin-bottom: 8px; }
.panel-card strong { font-size: 30px; letter-spacing: -.05em; }
.panel-card .up { color: #46e3a0; font-size: 12px; font-weight: 800; display: block; margin-top: 6px; }
.bar-list { display: grid; gap: 10px; margin-top: 10px; }
.bar { height: 8px; background: rgba(255,255,255,.1); border-radius: 99px; overflow: hidden; }
.bar span { display: block; height: 100%; background: linear-gradient(90deg, #1477ff, #35d4ff); border-radius: 99px; }
.intel-copy h2 { font-size: clamp(34px, 4vw, 48px); line-height: 1.08; letter-spacing: -.055em; }
.intel-copy p { color: #51627b; font-size: 17px; }
.check-list { list-style: none; padding: 0; margin: 24px 0 0; display: grid; gap: 14px; }
.check-list li { display: flex; gap: 12px; color: #34445d; font-weight: 700; }
.check-list li:before { content: "✓"; width: 22px; height: 22px; display: inline-grid; place-items: center; border-radius: 50%; background: rgba(20,119,255,.12); color: #1477ff; font-size: 13px; flex: 0 0 auto; }

/* ---------- Tag list (casos / indicadores) ---------- */
.tag-cloud { display: flex; flex-wrap: wrap; gap: 12px; }
.tag-cloud.center { justify-content: center; }
.tag {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 13px 18px; border-radius: 14px;
  background: #fff; border: 1px solid rgba(10,34,70,.10);
  box-shadow: 0 14px 34px rgba(13,41,81,.06);
  color: #2a3a52; font-weight: 700; font-size: 15px;
}
.tag i { color: var(--primary); }
/* dark tag variant */
.dark-band .tag, .final-cta .tag, .hero .tag {
  background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.10); color: #dbe8fa;
}
.dark-band .tag i, .final-cta .tag i { color: var(--primary-2); }

/* ---------- Steps / logic list ---------- */
.logic-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; max-width: 560px; }
.logic-list li { display: flex; gap: 16px; align-items: center; font-size: 19px; font-weight: 800; letter-spacing: -.02em; }
.logic-list li .n {
  width: 38px; height: 38px; flex: 0 0 auto; border-radius: 12px;
  display: grid; place-items: center; font-size: 15px;
  background: rgba(20,119,255,.14); color: #2b86ff;
}
.dark-band .logic-list li { color: #eaf2ff; }
.dark-band .logic-list li .n { background: rgba(57,167,255,.16); color: #7fc0ff; }

/* ---------- Final CTA ---------- */
/* ---------- Carrossel de soluções ---------- */
.carousel { position: relative; }
.carousel-nav { display: flex; gap: 10px; justify-content: flex-end; margin-bottom: 18px; }
.carousel-btn {
  width: 46px; height: 46px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.06);
  color: #fff; cursor: pointer; display: grid; place-items: center; transition: .18s ease;
}
.carousel-btn:hover { background: rgba(20,119,255,.22); border-color: var(--primary-2); }
.carousel-track {
  display: flex; gap: 20px; overflow-x: auto; scroll-snap-type: x mandatory;
  scroll-behavior: smooth; padding: 6px 2px 18px;
}
.carousel-track::-webkit-scrollbar { height: 8px; }
.carousel-track::-webkit-scrollbar-thumb { background: rgba(255,255,255,.16); border-radius: 99px; }
.carousel-track::-webkit-scrollbar-track { background: rgba(255,255,255,.05); border-radius: 99px; }
.carousel-card {
  flex: 0 0 312px; scroll-snap-align: start;
  background: #fff; color: #071226; border-radius: 22px; padding: 24px;
  border: 1px solid rgba(255,255,255,.08); box-shadow: 0 24px 60px rgba(0,0,0,.28);
  display: flex; flex-direction: column; min-height: 318px; position: relative; overflow: hidden;
  transition: transform .22s ease, box-shadow .22s ease;
}
.carousel-card:hover { transform: translateY(-6px); box-shadow: 0 32px 80px rgba(0,0,0,.4); }
.carousel-card:before { content: ""; position: absolute; inset: 0 0 auto; height: 4px; background: var(--primary); }
.carousel-card.acc-purple:before { background: var(--purple); }
.carousel-card.acc-orange:before { background: var(--orange); }
.carousel-card.acc-teal:before   { background: var(--green); }
.carousel-card.acc-cyan:before   { background: var(--cyan); }
.carousel-card.acc-indigo:before { background: var(--indigo); }
/* Cards azuis (segmentos no carrossel) */
.carousel-card.seg-blue {
  background: linear-gradient(160deg, #1f63dd 0%, #0a2e6e 100%);
  color: #fff; border: 1px solid rgba(255,255,255,.14); min-height: 250px;
  box-shadow: 0 24px 60px rgba(8,26,60,.45);
}
.carousel-card.seg-blue:before { display: none; }
.carousel-card.seg-blue:hover { box-shadow: 0 32px 80px rgba(8,26,60,.6); }
.carousel-card.seg-blue .seg-ic {
  width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center;
  background: rgba(255,255,255,.16); color: #fff; margin-bottom: 18px;
}
.carousel-card.seg-blue .seg-ic svg { width: 24px; height: 24px; }
.carousel-card.seg-blue h3 { font-size: 21px; letter-spacing: -.03em; margin: 0 0 10px; color: #fff; }
.carousel-card.seg-blue p { color: rgba(255,255,255,.82); font-size: 14px; line-height: 1.55; margin: 0; }
.carousel-card.seg-purple {
  background: linear-gradient(160deg, #8f36ff 0%, #4b1693 100%);
  color: #fff; border: 1px solid rgba(255,255,255,.14); min-height: 250px;
  box-shadow: 0 24px 60px rgba(45,12,90,.45);
}
.carousel-card.seg-purple:before { display: none; }
.carousel-card.seg-purple:hover { box-shadow: 0 32px 80px rgba(45,12,90,.6); }
.carousel-card.seg-purple .seg-ic { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center; background: rgba(255,255,255,.16); color: #fff; margin-bottom: 18px; }
.carousel-card.seg-purple .seg-ic svg { width: 24px; height: 24px; }
.carousel-card.seg-purple h3 { font-size: 21px; letter-spacing: -.03em; margin: 0 0 10px; color: #fff; }
.carousel-card.seg-purple p { color: rgba(255,255,255,.82); font-size: 14px; line-height: 1.55; margin: 0; }
.carousel-card.seg-indigo {
  background: linear-gradient(160deg, #6a5cff 0%, #2a2080 100%);
  color: #fff; border: 1px solid rgba(255,255,255,.14); min-height: 250px;
  box-shadow: 0 24px 60px rgba(28,20,90,.45);
}
.carousel-card.seg-indigo:before { display: none; }
.carousel-card.seg-indigo:hover { box-shadow: 0 32px 80px rgba(28,20,90,.6); }
.carousel-card.seg-indigo .seg-ic { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center; background: rgba(255,255,255,.16); color: #fff; margin-bottom: 18px; }
.carousel-card.seg-indigo .seg-ic svg { width: 24px; height: 24px; }
.carousel-card.seg-indigo h3 { font-size: 21px; letter-spacing: -.03em; margin: 0 0 10px; color: #fff; }
.carousel-card.seg-indigo p { color: rgba(255,255,255,.82); font-size: 14px; line-height: 1.55; margin: 0; }
.carousel-card.seg-orange {
  background: linear-gradient(160deg, #ff7a1a 0%, #9c3d00 100%);
  color: #fff; border: 1px solid rgba(255,255,255,.16); min-height: 250px;
  box-shadow: 0 24px 60px rgba(90,38,5,.45);
}
.carousel-card.seg-orange:before { display: none; }
.carousel-card.seg-orange:hover { box-shadow: 0 32px 80px rgba(90,38,5,.6); }
.carousel-card.seg-orange .seg-ic { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center; background: rgba(255,255,255,.18); color: #fff; margin-bottom: 18px; }
.carousel-card.seg-orange .seg-ic svg { width: 24px; height: 24px; }
.carousel-card.seg-orange h3 { font-size: 21px; letter-spacing: -.03em; margin: 0 0 10px; color: #fff; }
.carousel-card.seg-orange p { color: rgba(255,255,255,.85); font-size: 14px; line-height: 1.55; margin: 0; }

.cc-cat { font-size: 21px; letter-spacing: -.035em; line-height: 1.15; margin: 0 0 6px; }
.cc-name { display: inline-block; font-size: 12px; font-weight: 900; letter-spacing: .10em; text-transform: uppercase; color: var(--primary); margin-bottom: 14px; }
.acc-purple .cc-name { color: var(--purple); }
.acc-orange .cc-name { color: #e95d00; }
.acc-teal .cc-name   { color: #0a9a5c; }
.acc-cyan .cc-name   { color: #0a8fc0; }
.acc-indigo .cc-name { color: #5547e0; }
.cc-desc { color: #526079; font-size: 14px; line-height: 1.55; margin: 0 0 18px; }
.cc-link { margin-top: auto; font-size: 13px; font-weight: 900; color: var(--primary); }
.acc-purple .cc-link { color: var(--purple); }
.acc-orange .cc-link { color: #e95d00; }
.acc-teal .cc-link   { color: #0a9a5c; }
.acc-cyan .cc-link   { color: #0a8fc0; }
.acc-indigo .cc-link { color: #5547e0; }

.final-cta {
  background:
    radial-gradient(circle at 15% 55%, rgba(20,119,255,.28), transparent 30%),
    radial-gradient(circle at 86% 28%, rgba(57,212,255,.14), transparent 28%),
    linear-gradient(135deg, #020918, #071b36);
  padding: 90px 0; color: #fff;
}
.cta-box {
  border: 1px solid rgba(57,167,255,.25);
  background: rgba(255,255,255,.045);
  border-radius: 30px; padding: 44px;
  display: grid; grid-template-columns: 1fr auto; gap: 34px; align-items: center;
  box-shadow: 0 30px 90px rgba(0,0,0,.24);
}
.cta-box h2 { font-size: clamp(34px, 5vw, 58px); line-height: 1.02; letter-spacing: -.065em; margin-bottom: 16px; }
.cta-box p { color: #b7c6da; font-size: 17px; max-width: 660px; margin-bottom: 0; }
.cta-list { list-style: none; padding: 0; margin: 18px 0 0; display: grid; gap: 10px; color: #c9d8ee; }
.cta-list li:before { content: "✓"; color: #35d4ff; margin-right: 9px; }

/* CTA rotativo */
.cta-rotator { display: grid; }
.cta-rotator .cta-box { grid-area: 1 / 1; opacity: 0; visibility: hidden; transition: opacity .55s ease; pointer-events: none; }
.cta-rotator .cta-box.active { opacity: 1; visibility: visible; pointer-events: auto; }
.cta-dots { display: flex; gap: 9px; justify-content: center; margin-top: 24px; }
.cta-dot { width: 9px; height: 9px; border-radius: 50%; border: 0; background: rgba(255,255,255,.25); cursor: pointer; padding: 0; transition: .25s ease; }
.cta-dot.active { background: var(--primary-2); width: 26px; border-radius: 6px; }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 44px; align-items: start; }
.contact-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 24px; padding: 30px;
}
.contact-card h3 { font-size: 22px; letter-spacing: -.03em; margin-bottom: 6px; }
.field { display: grid; gap: 8px; margin-bottom: 16px; }
.field label { font-size: 13px; font-weight: 700; color: #c9d8ee; }
.field input, .field textarea, .field select {
  width: 100%; padding: 14px 16px; border-radius: 12px;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.14);
  color: #fff; font-family: inherit; font-size: 15px;
}
.field input::placeholder, .field textarea::placeholder { color: #6f7f96; }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--primary-2); }
.field select option { color: #071226; }
.contact-channels { display: grid; gap: 14px; }
.channel {
  display: flex; align-items: center; gap: 16px;
  padding: 18px; border-radius: 16px;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.10);
  transition: .2s ease;
}
.channel:hover { border-color: rgba(57,167,255,.6); background: rgba(20,119,255,.10); transform: translateY(-2px); }
.channel .ic { width: 48px; height: 48px; flex: 0 0 auto; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(135deg, var(--primary), #0756d6); color: #fff; }
.channel strong { display: block; font-size: 16px; }
.channel small { color: #9fb0c8; font-size: 13px; }

/* ---------- Blog (índice) ---------- */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
@media (max-width: 1040px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 680px) { .blog-grid { grid-template-columns: 1fr; } }
.blog-card {
  display: flex; flex-direction: column; background: #fff;
  border: 1px solid rgba(10,34,70,.10); border-radius: 22px; overflow: hidden;
  box-shadow: 0 24px 60px rgba(13,41,81,.08); transition: .25s ease; color: inherit;
}
.blog-card:hover { transform: translateY(-6px); box-shadow: 0 32px 80px rgba(13,41,81,.14); }
.blog-thumb { aspect-ratio: 16 / 10; width: 100%; object-fit: cover; display: block; background: #e7eefb; }
.blog-body { padding: 24px; display: flex; flex-direction: column; flex: 1; }
.blog-cat {
  align-self: flex-start; font-size: 11px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase;
  color: var(--primary); background: rgba(20,119,255,.09); padding: 6px 10px; border-radius: 999px; margin-bottom: 14px;
}
.blog-card h3 { font-size: 21px; letter-spacing: -.03em; line-height: 1.2; margin: 0 0 10px; color: #071226; }
.blog-card p { color: #526079; font-size: 14.5px; line-height: 1.6; margin: 0 0 18px; }
.blog-meta { margin-top: auto; display: flex; align-items: center; gap: 10px; font-size: 13px; color: #7a8aa3; }
.blog-readmore { color: var(--primary); font-weight: 800; font-size: 13px; }

/* ---------- Blog (artigo) ---------- */
/* Página de artigo: fundo branco (texto escuro legível) */
main:has(.post-hero) { background: #fff; }
body.is-post { background: #fff; }
.post-hero { position: relative; }
.post-hero:after { content: ""; position: absolute; inset: 0 0 auto 0; height: 130px; background: linear-gradient(180deg, rgba(2,9,24,.6), transparent); pointer-events: none; }
.post-hero-img { width: 100%; height: min(46vw, 460px); object-fit: cover; display: block; background: #0a1f3d; }
.post-head {
  width: min(760px, calc(100% - 48px)); margin: -90px auto 0; position: relative; z-index: 2;
  background: #fff; border-radius: 22px; padding: 34px; box-shadow: 0 30px 80px rgba(13,41,81,.14);
  border: 1px solid rgba(10,34,70,.08);
}
.post-head h1 { font-size: clamp(28px, 4vw, 44px); line-height: 1.1; letter-spacing: -.045em; margin: 0 0 14px; color: #071226; }
.post-head .post-meta { display: flex; flex-wrap: wrap; gap: 12px; color: #7a8aa3; font-size: 14px; }
.post-wrap { width: min(760px, calc(100% - 48px)); margin: 0 auto; }
.post-body { color: #2a3a52; font-size: 18.5px; line-height: 1.9; padding: 44px 0 20px; }
.post-body h2 { font-size: 28px; letter-spacing: -.03em; color: #071226; margin: 38px 0 14px; line-height: 1.2; }
.post-body p { margin: 0 0 22px; }
.post-body ul { margin: 0 0 24px; padding-left: 0; list-style: none; display: grid; gap: 11px; }
.post-body ul li { display: flex; gap: 12px; }
.post-body ul li:before { content: "✦"; color: var(--primary); flex: 0 0 auto; }
.post-figure { margin: 30px 0; }
.post-figure img { width: 100%; border-radius: 18px; display: block; background: #e7eefb; }
.post-figure figcaption { color: #8190a6; font-size: 13px; margin-top: 10px; text-align: center; }
.post-quote { border-left: 4px solid var(--primary); background: #f4f8ff; padding: 22px 24px; border-radius: 14px; font-size: 19px; font-weight: 600; color: #0d2951; margin: 30px 0; }
.post-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 30px 0; }
@media (max-width: 560px) { .post-stats { grid-template-columns: 1fr; } }
.post-stat { background: linear-gradient(180deg,#fff,#f6f9ff); border: 1px solid rgba(10,34,70,.09); border-radius: 16px; padding: 20px; }
.post-stat strong { display: block; font-size: 34px; letter-spacing: -.05em; color: #1477ff; }
.post-stat small { color: #58677d; font-size: 13px; }
.post-chart { background: #061226; border-radius: 22px; padding: 30px; color: #fff; margin: 34px 0; }
.post-chart h4 { margin: 0 0 6px; font-size: 18px; }
.post-chart .pc-sub { color: #cdd9ec; font-size: 14px; margin-bottom: 22px; }
.pc-bars { display: grid; gap: 16px; }
.pc-bar .pc-label { display: flex; justify-content: space-between; font-size: 14px; color: #eaf2ff; margin-bottom: 7px; }
.pc-track { height: 12px; background: rgba(255,255,255,.1); border-radius: 99px; overflow: hidden; }
.pc-fill { height: 100%; border-radius: 99px; background: linear-gradient(90deg,#1477ff,#35d4ff); }
.post-back { display: inline-flex; align-items: center; gap: 8px; color: var(--primary); font-weight: 800; }

/* ---------- Footer ---------- */
footer { background: #020918; color: #8ea0b9; border-top: 1px solid rgba(255,255,255,.08); }
.footer-inner {
  width: min(var(--max), calc(100% - 48px)); margin: 0 auto;
  display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; font-size: 13px;
}
.footer-grid {
  display: grid; grid-template-columns: 1.7fr 1fr 1fr 1.1fr; gap: 40px;
  padding: 58px 0 42px; align-items: start;
}
.footer-brand .footer-tag { max-width: 340px; color: #aebdd2; font-size: 14px; line-height: 1.7; margin: 0 0 22px; }
.footer-social { display: flex; gap: 12px; }
.footer-social a {
  width: 40px; height: 40px; border-radius: 11px; display: grid; place-items: center;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.10); color: #cdd9ec; transition: .2s ease;
}
.footer-social a:hover { background: rgba(20,119,255,.20); border-color: var(--primary-2); color: #fff; transform: translateY(-2px); }
.footer-social svg { width: 18px; height: 18px; fill: currentColor; }
.footer-col h4 { color: #fff; font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; margin: 0 0 14px; }
.footer-col a { display: flex; align-items: center; gap: 9px; color: #9fb0c8; font-size: 14px; padding: 7px 0; transition: .18s ease; }
.footer-col a:hover { color: var(--primary-2); }
.footer-col svg { width: 16px; height: 16px; flex: 0 0 auto; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.08); }
.footer-bottom-inner { display: flex; align-items: center; justify-content: space-between; padding: 20px 0; font-size: 13px; color: #6f7f96; }
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 560px) { .footer-grid { grid-template-columns: 1fr; } .footer-bottom-inner { flex-direction: column; gap: 8px; align-items: flex-start; } }

/* ---------- Responsive ---------- */
@media (max-width: 1040px) {
  .menu { display: none; }
  .hamb { display: grid; place-items: center; width: 44px; height: 44px; border-radius: 12px; border: 1px solid rgba(255,255,255,.14); color: #fff; background: rgba(255,255,255,.04); }
  .hero-grid { grid-template-columns: 1fr; padding-top: 140px; }
  .hero-points, .solution-grid, .solution-grid.cols-3, .metric-grid { grid-template-columns: repeat(2, 1fr); }
  .benefit-header, .impact-grid, .intel-grid, .intel-grid.reverse, .cta-box, .contact-grid { grid-template-columns: 1fr; }
  .benefit-row, .market-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 680px) {
  .nav { width: min(100% - 30px, var(--max)); }
  .nav-cta { display: none; }
  .hero-grid, .section-inner, .trust-inner, .footer-inner { width: min(100% - 30px, var(--max)); }
  .hero { min-height: auto; }
  .hero-grid { padding: 126px 0 62px; }
  .hero h1 { font-size: 42px; }
  .hero-sub { font-size: 16px; }
  .hero-points, .solution-grid, .solution-grid.cols-3, .solution-grid.cols-2, .metric-grid, .benefit-row, .benefit-row.cols-2, .market-grid, .panel-grid { grid-template-columns: 1fr; }
  .point { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.10); padding-bottom: 14px; }
  .white-section, .dark-band, .intelligence, .final-cta, .benefits { padding: 56px 0; }
  .solution-card { min-height: auto; }
  .cta-box { padding: 28px; }
  .footer-inner { flex-direction: column; align-items: flex-start; }
  .edit-toolbar { left: 12px; right: 12px; justify-content: center; }
  .toolbar-label { display: none; }
  .flow-step { flex: 1 1 calc(50% - 6px); }
  .intel-grid { grid-template-columns: 1fr !important; }
  .copy-2col { grid-template-columns: 1fr; }
  /* boxes compactos em 2 colunas no mobile */
  .metric-grid, .stat-grid, .market-grid, .panel-grid, .feature-grid { grid-template-columns: 1fr 1fr; }
  .metric-card { min-height: 0; padding: 20px 13px; }
  .metric-card strong { font-size: 28px; }
  .metric-card i, .metric-card svg { margin-bottom: 10px; }
  .stat-card { min-height: 0; padding: 20px 15px; }
  .stat-card .num { font-size: 28px; }
  .market-card strong { font-size: 26px; }
}
