/* =========================================================
   SHIRO TECNOLOGIA — Design System
   Dark corporate / premium / tecnológico
   ========================================================= */

:root {
  /* Paleta oficial — SHIRO design tokens (shiro-tokens.css) */
  --bg:            #0a0f1c;   /* navy-900 — fundo página */
  --bg-2:          #0f1524;   /* navy-850 — faixas alternadas */
  --bg-base:       #060a13;   /* navy-950 — header/footer */
  --card:          #141c30;   /* navy-800 — cards */
  --blue:          #1f6feb;   /* blue-500 — cor da marca */
  --blue-2:        #3a82ff;   /* blue-400 — acento/links */
  --blue-hover:    #5e98ff;   /* blue-300 — hover */
  --text:          #f4f7fb;   /* navy-50 */
  --text-2:        #aeb9cc;   /* navy-200 */

  /* Derivados */
  --line:          rgba(255,255,255,.07);
  --line-strong:   rgba(58,130,255,.35);
  --card-grad:     linear-gradient(160deg,#141c30 0%,#0f1524 100%);
  --glow:          0 0 0 1px rgba(31,111,235,.15), 0 18px 40px -18px rgba(31,111,235,.55);
  --shadow:        0 24px 60px -30px rgba(0,0,0,.7);

  --radius:        14px;
  --radius-lg:     20px;
  --maxw:          1200px;
  --header-h:      72px;

  --ff-title: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --ff-body:  'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --ff-mono:  'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

/* ---------------- Reset ---------------- */
*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--ff-body);
  background: var(--bg);
  color: var(--text-2);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
h1,h2,h3,h4,h5 { font-family: var(--ff-title); color: var(--text); line-height: 1.15; margin: 0; font-weight: 700; }

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.text-blue { color: var(--blue-2); }
.center { text-align: center; }

/* gradient background helpers */
.bg-2 { background: var(--bg-2); }
.section { padding: 84px 0; position: relative; }
.section.tight { padding: 56px 0; }

.eyebrow {
  font-family: var(--ff-title);
  font-size: 13px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--blue-2); font-weight: 600; margin: 0 0 14px;
}
.section-title { font-size: clamp(26px,3.4vw,38px); margin: 0 0 14px; letter-spacing: -.01em; line-height: 1.14; }
.section-sub { color: var(--text-2); max-width: 720px; margin: 0 auto; font-size: 17px; }
.center .section-sub { margin: 0 auto; }

/* ---------------- Buttons ---------------- */
.btn {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 13px 22px; border-radius: 11px;
  font-family: var(--ff-title); font-weight: 600; font-size: 15px;
  border: 1px solid transparent; transition: .22s ease; white-space: nowrap;
}
.btn svg { width: 17px; height: 17px; }
.btn-primary { background: linear-gradient(135deg,var(--blue) 0%,var(--blue-2) 100%); color: #fff; box-shadow: 0 12px 30px -12px rgba(37,99,235,.8); }
.btn-primary:hover { background: linear-gradient(135deg,var(--blue-2) 0%,var(--blue-hover) 100%); transform: translateY(-2px); }
.btn-ghost { background: rgba(255,255,255,.04); color: var(--text); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--line-strong); background: rgba(59,130,246,.08); color:#fff; }
.btn-outline { background: transparent; color: var(--text); border-color: var(--line); }
.btn-outline:hover { border-color: var(--blue-2); color: var(--blue-hover); }
.btn-lg { padding: 16px 30px; font-size: 16px; }

.link-arrow { color: var(--blue-2); font-family: var(--ff-title); font-weight: 600; font-size: 14px; display: inline-flex; align-items: center; gap: 7px; transition: .2s; }
.link-arrow:hover { color: var(--blue-hover); gap: 11px; }
.link-arrow svg { width: 15px; height: 15px; flex: none; }

/* ---------------- Top bar ---------------- */
.topbar { background: var(--bg-base); border-bottom: 1px solid var(--line); font-size: 13px; color: var(--text-2); }
.topbar .container { display: flex; align-items: center; justify-content: space-between; min-height: 40px; gap: 18px; }
.topbar .slogan { color: #93a4bd; }
.topbar .tb-right { display: flex; align-items: center; gap: 20px; }
.topbar .tb-item { display: inline-flex; align-items: center; gap: 7px; }
.topbar .tb-item svg { width: 14px; height: 14px; color: var(--blue-2); }
.topbar .tb-social { display: flex; gap: 12px; }
.topbar .tb-social a { color: #93a4bd; transition: .2s; }
.topbar .tb-social a:hover { color: var(--blue-hover); }
.topbar .tb-social svg { width: 15px; height: 15px; }

/* ---------------- Header ---------------- */
.site-header { position: sticky; top: 0; z-index: 100; background: rgba(6,10,19,.88); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.site-header .bar { display: flex; flex-wrap: nowrap; align-items: center; justify-content: space-between; height: var(--header-h); gap: 12px; max-width: 1340px; }

.logo { display: flex; align-items: center; gap: 10px; flex: none; }
.logo .mark { width: 36px; height: 36px; flex: none; }
.logo .name { font-family: var(--ff-title); font-weight: 800; font-size: 20px; color: #fff; letter-spacing: .04em; line-height: 1; white-space: nowrap; }
.logo .name small { display: block; font-size: 8.5px; letter-spacing: .4em; color: var(--blue-2); font-weight: 600; margin-top: 3px; }

.nav { display: flex; align-items: center; gap: 1px; flex-wrap: nowrap; }
.nav > a, .nav .has-sub > a { position: relative; padding: 9px 9px; font-family: var(--ff-title); font-weight: 500; font-size: 13.5px; color: var(--text-2); border-radius: 8px; transition: .2s; display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; }
/* botões do menu mobile: escondidos no desktop (só aparecem no drawer) */
.mobile-cta { display: none; }
.nav > a:hover, .nav .has-sub:hover > a { color: #fff; }
.nav > a.active { color: #fff; }
.nav > a.active::after { content: ""; position: absolute; left: 13px; right: 13px; bottom: 2px; height: 2px; background: var(--blue-2); border-radius: 2px; }
.nav .caret { width: 10px; height: 10px; opacity: .7; }

.has-sub { position: relative; }
.submenu { position: absolute; top: calc(100% + 6px); left: 0; min-width: 248px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px; padding: 8px; box-shadow: var(--shadow); opacity: 0; visibility: hidden; transform: translateY(8px); transition: .2s; }
.has-sub:hover .submenu { opacity: 1; visibility: visible; transform: translateY(0); }
.submenu a { display: block; padding: 10px 12px; border-radius: 8px; font-size: 14px; color: var(--text-2); }
.submenu a:hover { background: rgba(59,130,246,.1); color: #fff; }
.submenu-label { display: block; margin: 8px 12px 4px; padding-top: 8px; border-top: 1px solid var(--line); font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--blue-hover); }

.header-actions { display: flex; align-items: center; gap: 8px; flex: none; }
.header-actions .btn { padding: 10px 15px; font-size: 13.5px; }
.btn-account { display: inline-flex; align-items: center; gap: 7px; padding: 9px 12px; border: 1px solid var(--line); border-radius: 10px; font-family: var(--ff-title); font-weight: 500; font-size: 13px; color: var(--text); transition: .2s; white-space: nowrap; }
.btn-account:hover { border-color: var(--line-strong); color: #fff; }
.btn-account .soon { font-size: 9px; background: rgba(96,165,250,.18); color: var(--blue-hover); padding: 2px 6px; border-radius: 20px; letter-spacing: .04em; }

.burger { display: none; background: none; border: 1px solid var(--line); border-radius: 9px; padding: 9px; color: #fff; }
.burger svg { width: 22px; height: 22px; }

/* ---------------- Hero ---------------- */
.hero { position: relative; overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; background:
  radial-gradient(900px 500px at 78% 12%, rgba(37,99,235,.22), transparent 60%),
  radial-gradient(700px 500px at 8% 90%, rgba(59,130,246,.12), transparent 55%); pointer-events: none; }
.hero .container { position: relative; }
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 50px; align-items: center; padding: 76px 0 64px; }
.hero h1 { font-size: clamp(34px,5vw,56px); font-weight: 800; line-height: 1.05; letter-spacing: -.01em; margin-bottom: 22px; }
.hero p.lead { font-size: 18px; color: var(--text-2); max-width: 520px; margin: 0 0 30px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 12px; }

.hero-visual { position: relative; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow); aspect-ratio: 4/3.1; background: var(--card-grad); }
.hero-visual img { width: 100%; height: 100%; object-fit: cover; }
.hero-visual::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg,transparent 40%, rgba(11,18,32,.55)); }

/* ---------------- Diferenciais strip ---------------- */
.diffs { background: var(--bg-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.diffs-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; padding: 34px 0; }
.diff { display: flex; gap: 14px; align-items: flex-start; }
.diff .ic { position: relative; width: 54px; height: 54px; flex: none; border-radius: 15px; display: grid; place-items: center; overflow: hidden;
  background: linear-gradient(155deg, rgba(94,152,255,.28), rgba(31,111,235,.06) 70%);
  border: 1px solid rgba(94,152,255,.32); color: var(--blue-hover);
  box-shadow: 0 8px 20px -10px rgba(31,111,235,.6), inset 0 1px 0 rgba(255,255,255,.08); }
.diff .ic::after { content:""; position:absolute; top:-18px; left:50%; transform:translateX(-50%); width:60px; height:46px; background: radial-gradient(closest-side, rgba(94,152,255,.5), transparent); opacity:.5; }
.diff .ic svg { position: relative; z-index: 1; width: 27px; height: 27px; }
.diff h4 { font-size: 15px; margin-bottom: 3px; }
.diff p { font-size: 12.5px; margin: 0; color: #aeb9cc; line-height: 1.45; }

/* ---------------- Cards (solutions) ---------------- */
.cards-grid { display: grid; gap: 22px; }
.cards-3 { grid-template-columns: repeat(3,1fr); }
.cards-4 { grid-template-columns: repeat(4,1fr); }
.cards-7 { grid-template-columns: repeat(4,1fr); }

.card {
  background: var(--card-grad); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 26px 24px; transition: .25s ease; position: relative; overflow: hidden;
}
.card::before { content:""; position:absolute; left:0; top:0; height:3px; width:100%; background: linear-gradient(90deg,var(--blue),var(--blue-hover)); opacity:0; transition:.25s; }
.card:hover { transform: translateY(-5px); border-color: var(--line-strong); box-shadow: var(--glow); }
.card:hover::before { opacity:1; }
.card .ic { width: 50px; height: 50px; border-radius: 13px; display: grid; place-items: center; background: rgba(59,130,246,.1); border: 1px solid var(--line-strong); color: var(--blue-hover); margin-bottom: 18px; }
.card .ic svg { width: 25px; height: 25px; }
.card h3 { font-size: 19px; margin-bottom: 10px; }
.card p { font-size: 14.5px; color: var(--text-2); margin: 0 0 16px; }
.card .num { font-family: var(--ff-title); font-size: 13px; font-weight: 700; color: var(--blue-2); letter-spacing: .1em; margin-bottom: 8px; }
.card ul { list-style: none; margin: 0 0 16px; padding: 0; }
.card ul li { font-size: 13.5px; color: var(--text-2); padding: 5px 0 5px 20px; position: relative; }
.card ul li::before { content:""; position:absolute; left:0; top:11px; width:7px; height:7px; border-radius:2px; background: var(--blue-2); }

/* ---------------- Ecosystem cards ---------------- */
.eco-card { text-align: center; }
.eco-card .ic { margin: 0 auto 18px; width: 56px; height: 56px; }
.eco-card h3 { font-size: 18px; }
.eco-card .tag { font-size: 12px; color: var(--blue-2); font-family: var(--ff-title); letter-spacing: .04em; display:block; margin-bottom: 12px; text-transform: uppercase; }

/* ---------------- Process flow ---------------- */
.flow { display: grid; grid-template-columns: repeat(5,1fr); gap: 14px; position: relative; }
.flow.steps-6 { grid-template-columns: repeat(6,1fr); }
.flow .step { text-align: center; position: relative; }
.flow .step .circle { width: 72px; height: 72px; border-radius: 50%; margin: 0 auto 16px; display: grid; place-items: center; background: var(--bg-2); border: 1px solid var(--line-strong); color: var(--blue-hover); position: relative; z-index: 2; }
.flow .step .circle svg { width: 30px; height: 30px; }
.flow .step:not(:last-child)::after { content:""; position: absolute; top: 36px; left: 60%; right: -40%; height: 2px; background: linear-gradient(90deg,var(--line-strong),transparent); z-index: 1; }
.flow .step .n { font-family: var(--ff-title); font-size: 12px; font-weight: 700; color: var(--blue-2); }
.flow .step h4 { font-size: 16px; margin: 4px 0 6px; }
.flow .step p { font-size: 13px; margin: 0; color: #aeb9cc; }

/* ---------------- Video section ---------------- */
.video-box { position: relative; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line); min-height: 360px; display: grid; place-items: center; background:
  linear-gradient(180deg, rgba(11,18,32,.4), rgba(11,18,32,.85)), var(--card-grad); }
.video-box .play { width: 84px; height: 84px; border-radius: 50%; background: rgba(37,99,235,.9); display: grid; place-items: center; box-shadow: 0 0 0 14px rgba(37,99,235,.18); transition: .25s; }
.video-box .play:hover { transform: scale(1.06); }
.video-box .play svg { width: 32px; height: 32px; color: #fff; margin-left: 4px; }
.video-box .vlabel { position: absolute; bottom: 26px; font-family: var(--ff-title); color: #fff; font-weight: 600; }
.video-reserved { position: absolute; top: 16px; right: 16px; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--text-2); border: 1px dashed var(--line-strong); padding: 5px 10px; border-radius: 20px; }

/* ---------------- Partners / logos ---------------- */
.logos { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; }
.logo-cell { background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px; min-height: 78px; display: grid; place-items: center; padding: 14px; color: #cbd5e1; font-family: var(--ff-title); font-weight: 700; letter-spacing: .02em; transition: .2s; text-align:center; font-size: 15px; }
.logo-cell:hover { border-color: var(--line-strong); color: #fff; }

/* ---------------- Segments ---------------- */
.segments { display: grid; grid-template-columns: repeat(6,1fr); gap: 16px; }
.segment { position: relative; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--line); aspect-ratio: 3/3.4; background: var(--card-grad); display: flex; align-items: flex-end; transition: .25s; }
.segment:hover { border-color: var(--line-strong); transform: translateY(-4px); }
.segment .ic { position: absolute; top: 20px; left: 20px; color: var(--blue-hover); }
.segment .ic svg { width: 30px; height: 30px; }
.segment .lbl { position: relative; z-index: 2; padding: 18px; width: 100%; background: linear-gradient(180deg,transparent, rgba(7,13,24,.92)); }
.segment .lbl h4 { font-size: 16px; }
.segment .lbl p { font-size: 12.5px; margin: 3px 0 0; color: #aeb9cc; }

/* ---------------- Stats ---------------- */
.stats { display: grid; grid-template-columns: repeat(5,1fr); gap: 18px; }
.stat { text-align: center; padding: 18px 14px; border: none; background: none; }
.stats { position: relative; }
.stat:not(:last-child) { border-right: 1px solid var(--line); }
.stat .ic { color: var(--blue-hover); margin-bottom: 10px; display:grid; place-items:center; }
.stat .ic svg { width: 26px; height: 26px; }
.stat .num { font-family: var(--ff-mono); font-size: 30px; font-weight: 700; color: #fff; letter-spacing: -.01em; }
.stat .lbl { font-size: 13px; color: var(--text-2); }

/* ---------------- CTA band ---------------- */
.cta-band { position: relative; overflow: hidden; border-radius: var(--radius-lg); border: 1px solid var(--line-strong); padding: 56px 48px; background:
  radial-gradient(700px 300px at 12% 20%, rgba(37,99,235,.25), transparent 60%), var(--card-grad); }
.cta-band h2 { font-size: clamp(26px,3.2vw,36px); margin-bottom: 14px; }
.cta-band p { font-size: 17px; max-width: 560px; }
.cta-band .actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px; }

/* ---------------- Footer ---------------- */
.site-footer { background: var(--bg-base); border-top: 1px solid var(--line); padding: 64px 0 28px; margin-top: 0; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.1fr; gap: 40px; }
.footer-brand p { font-size: 14px; color: #93a4bd; margin: 16px 0 20px; max-width: 280px; }
.footer-social { display: flex; gap: 12px; }
.footer-social a { width: 36px; height: 36px; border-radius: 9px; border: 1px solid var(--line); display: grid; place-items: center; color: #93a4bd; transition: .2s; }
.footer-social a:hover { border-color: var(--line-strong); color: var(--blue-hover); }
.footer-social svg { width: 16px; height: 16px; }
.footer-col h5 { font-family: var(--ff-title); font-size: 13px; letter-spacing: .14em; text-transform: uppercase; color: #fff; margin-bottom: 18px; }
.footer-col ul { list-style: none; margin: 0; padding: 0; }
.footer-col ul li { margin-bottom: 11px; }
.footer-col ul li a { font-size: 14px; color: #93a4bd; transition: .2s; }
.footer-col ul li a:hover { color: var(--blue-hover); }
.footer-contact li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: #93a4bd; }
.footer-contact svg { width: 15px; height: 15px; color: var(--blue-2); margin-top: 4px; flex: none; }
.footer-bottom { margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; gap: 14px; font-size: 13px; color: #6c7d96; flex-wrap: wrap; }
.footer-bottom a { color: #93a4bd; }
.footer-bottom a:hover { color: var(--blue-hover); }

/* ---------------- Page hero (interior) ---------------- */
.page-hero { position: relative; overflow: hidden; padding: 64px 0 50px; border-bottom: 1px solid var(--line); }
.page-hero::before { content:""; position:absolute; inset:0; background: radial-gradient(800px 400px at 80% 10%, rgba(37,99,235,.18), transparent 60%); }
.page-hero .container { position: relative; }
.page-hero h1 { font-size: clamp(30px,4.4vw,48px); font-weight: 800; margin-bottom: 18px; }
.page-hero p { font-size: 18px; max-width: 620px; }

/* split section (text + image / list) */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.split .media { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line); aspect-ratio: 4/3; background: var(--card-grad); box-shadow: var(--shadow); }
.split .media img { width:100%; height:100%; object-fit: cover; }

.feature-list { list-style: none; padding: 0; margin: 0; }
.feature-list li { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--line); }
.feature-list li:last-child { border-bottom: none; }
.feature-list .ic { width: 40px; height:40px; flex:none; border-radius: 11px; display:grid; place-items:center; background: rgba(59,130,246,.1); border:1px solid var(--line-strong); color: var(--blue-hover); }
.feature-list .ic svg { width: 20px; height:20px; }
.feature-list h4 { font-size: 16px; margin-bottom: 3px; }
.feature-list p { font-size: 14px; margin: 0; color: #aeb9cc; }

/* MVV cards */
.mvv { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }

/* Form */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; }
.form { background: var(--card-grad); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 32px; }
.form .row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field { margin-bottom: 16px; }
.field label { display: block; font-size: 13px; font-family: var(--ff-title); font-weight: 500; color: var(--text); margin-bottom: 7px; }
.field input, .field select, .field textarea {
  width: 100%; background: var(--bg); border: 1px solid var(--line); border-radius: 10px;
  padding: 12px 14px; color: var(--text); font-family: var(--ff-body); font-size: 14px; transition: .2s;
}
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--blue-2); box-shadow: 0 0 0 3px rgba(59,130,246,.15); }
.field textarea { resize: vertical; min-height: 110px; }
.form-note { font-size: 12.5px; color: #6c7d96; margin-top: 8px; }
.form-ok { display:none; background: rgba(34,197,94,.12); border:1px solid rgba(34,197,94,.4); color:#86efac; padding:12px 14px; border-radius:10px; font-size:14px; margin-bottom:16px; }

.contact-channels { display: grid; gap: 14px; }
.channel { display: flex; gap: 14px; align-items: center; background: var(--card-grad); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px 20px; transition:.2s; }
.channel:hover { border-color: var(--line-strong); }
.channel .ic { width: 46px; height:46px; flex:none; border-radius: 12px; display:grid; place-items:center; background: rgba(59,130,246,.12); border:1px solid var(--line-strong); color: var(--blue-hover); }
.channel .ic svg { width:22px; height:22px; }
.channel h4 { font-size: 15px; margin-bottom: 2px; }
.channel p { font-size: 14px; margin: 0; color: var(--blue-hover); }

/* Content/blog cards */
.post { background: var(--card-grad); border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; transition:.25s; }
.post:hover { transform: translateY(-5px); border-color: var(--line-strong); box-shadow: var(--glow); }
.post .thumb { aspect-ratio: 16/9; background: var(--bg-2); position: relative; display:grid; place-items:center; color: var(--blue-2); }
.post .thumb svg { width: 40px; height:40px; opacity:.5; }
.post .body { padding: 20px; }
.post .cat { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--blue-2); font-family: var(--ff-title); font-weight: 700; }
.post h3 { font-size: 17px; margin: 8px 0 8px; }
.post p { font-size: 14px; margin: 0 0 14px; }

.topics { display:flex; flex-wrap: wrap; gap: 10px; justify-content:center; }
.topic { padding: 9px 16px; border-radius: 30px; border: 1px solid var(--line); background: var(--bg-2); font-size: 14px; font-family: var(--ff-title); font-weight: 500; color: var(--text-2); transition:.2s; }
.topic:hover, .topic.active { border-color: var(--blue-2); color: #fff; background: rgba(37,99,235,.15); }

/* utility spacing */
.mt-0 { margin-top: 0; }
.mb-40 { margin-bottom: 40px; }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:22px; }

/* reveal animation */
.reveal { opacity: 0; transform: translateY(24px); transition: .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }

/* =========================================================
   HOME — overrides fiéis ao mockup (carregam depois → vencem)
   ========================================================= */

/* ---- Hero full-bleed ---- */
.hero { position: relative; min-height: 620px; display: flex; align-items: center; overflow: hidden; border-bottom: 1px solid var(--line); }
.hero::before { display: none; }
.hero-img { position: absolute; inset: 0; z-index: 0; width: 100%; height: 100%; object-fit: cover; object-position: center right; }
.hero-overlay { position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(90deg, rgba(8,13,24,.97) 0%, rgba(8,13,24,.9) 40%, rgba(9,16,30,.74) 72%, rgba(11,20,38,.62) 100%),
    linear-gradient(0deg, rgba(8,13,24,.7), transparent 45%),
    linear-gradient(0deg, rgba(37,99,235,.10), rgba(37,99,235,.10)); }
.hero .container { position: relative; z-index: 2; }
.hero-inner { max-width: 740px; padding: 84px 0; }
.hero-inner h1 { font-family: var(--ff-title); font-weight: 800; font-size: clamp(27px,3.5vw,46px); line-height: 1.1; letter-spacing: 0; margin: 0 0 22px; text-transform: uppercase; }
.hero-inner .lead { font-size: 17px; color: var(--text-2); max-width: 460px; margin: 0 0 30px; }
.hero-cta { gap: 10px; }
.hero-cta .btn { padding: 13px 18px; font-size: 14.5px; }
.play-circle { width: 24px; height: 24px; border: 1.6px solid currentColor; border-radius: 50%; display: inline-grid; place-items: center; }
.play-circle svg { width: 10px; height: 10px; margin-left: 1px; }

/* ---- Section head (eyebrow+title left, link right) ---- */
.section-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; margin-bottom: 34px; }
.section-head .eyebrow { margin-bottom: 10px; }

/* ---- Soluções: 7 cards numa linha, com thumbnail ---- */
.sol-grid { display: grid; grid-template-columns: repeat(7,1fr); gap: 16px; }
.sol-card { background: var(--card-grad); border: 1px solid var(--line); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; padding-bottom: 18px; transition: .25s ease; }
.sol-card:hover { transform: translateY(-6px); border-color: var(--line-strong); box-shadow: var(--glow); }
.sol-thumb { position: relative; display: block; aspect-ratio: 4/3.4; background: linear-gradient(155deg,#1a2c4a,#0e1a2e); display: grid; place-items: center; overflow: hidden; }
.sol-thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; }
.sol-thumb .wm { position: relative; z-index: 0; color: rgba(96,165,250,.45); }
.sol-thumb .wm svg { width: 36px; height: 36px; }
.sol-card .ic { width: 38px; height: 38px; border-radius: 10px; margin: 16px 16px 0; display: grid; place-items: center; background: rgba(59,130,246,.1); border: 1px solid var(--line-strong); color: var(--blue-hover); }
.sol-card .ic svg { width: 19px; height: 19px; }
.sol-card h3 { font-size: 13.5px; line-height: 1.28; margin: 13px 14px 8px; overflow-wrap: break-word; }
.sol-card p { font-size: 12.5px; color: #aeb9cc; margin: 0 16px 14px; line-height: 1.5; }
.sol-card .link-arrow { margin: auto 16px 0; font-size: 12.5px; }

/* ---- Ecossistema: 7 cards, ícones coloridos ---- */
.eco-grid { display: grid; grid-template-columns: repeat(7,1fr); gap: 16px; }
.eco-card { position: relative; background: var(--card-grad); border: 1px solid var(--line); border-radius: 14px; padding: 26px 18px 22px; text-align: center; transition: .25s ease; overflow: hidden; display: flex; flex-direction: column; }
.eco-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--c, var(--blue)); opacity: .9; }
.eco-card::after { content: ""; position: absolute; top: -40px; left: 50%; transform: translateX(-50%); width: 120px; height: 90px; background: radial-gradient(closest-side, var(--c, var(--blue)), transparent); opacity: .16; }
.eco-card:hover { transform: translateY(-6px); border-color: color-mix(in srgb, var(--c) 50%, var(--line-strong)); }
.eco-ic { position: relative; z-index: 1; width: 58px; height: 58px; margin: 0 auto 16px; border-radius: 15px; display: grid; place-items: center; color: var(--c, var(--blue-hover)); background: color-mix(in srgb, var(--c) 14%, transparent); border: 1px solid color-mix(in srgb, var(--c) 45%, transparent); }
.eco-ic svg { width: 28px; height: 28px; }
.eco-card h3 { font-size: 17px; line-height: 1.2; margin-bottom: 10px; min-height: 44px; display: flex; align-items: center; justify-content: center; text-align: center; }
.eco-card p { font-size: 12.5px; color: var(--text-2); margin: 0 0 16px; line-height: 1.5; }
.eco-card .link-arrow { font-size: 12.5px; justify-content: center; margin-top: auto; }

/* ---- Vídeo institucional (card grande, foto à direita) ---- */
.video-feature { position: relative; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line);
  background: var(--card-grad); display: grid; grid-template-columns: 1.05fr 1fr; align-items: stretch; min-height: 380px; }
.video-feature .vf-text { padding: 48px; align-self: center; }
.video-feature .vf-text p { color: var(--text-2); font-size: 15px; margin: 16px 0 0; max-width: 420px; }
.video-feature .vf-media { position: relative; min-height: 360px; overflow: hidden; }
.video-feature .vf-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.video-feature .vf-media::after { content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, #141d2c 0%, rgba(20,29,44,.25) 28%, rgba(8,13,24,.45) 100%); }
.video-feature .play { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 3;
  width: 86px; height: 86px; border-radius: 50%; background: rgba(37,99,235,.95); display: grid; place-items: center;
  box-shadow: 0 0 0 14px rgba(37,99,235,.18); transition: .25s; }
.video-feature .play:hover { transform: translate(-50%,-50%) scale(1.07); }
.video-feature .play svg { width: 30px; height: 30px; color: #fff; margin-left: 4px; }
.video-feature .vlabel { position: absolute; bottom: 26px; left: 0; right: 0; text-align: center; z-index: 3;
  color: #fff; font-family: var(--ff-title); font-weight: 600; }
.video-feature .video-reserved { z-index: 3; }

/* ---- Parceiros + Segmentos ---- */
.partners-row { display: grid; grid-template-columns: 1fr 1.15fr 1.25fr; gap: 36px; align-items: start; }
.partners-panel { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; background: rgba(255,255,255,.02); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; }
.plogo { min-height: 84px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; background: #ffffff; border: 1px solid rgba(34,48,77,.22); border-radius: 12px; transition: .2s; padding: 16px 12px; }
.plogo:hover { border-color: #c7d3e6; transform: translateY(-3px); box-shadow: 0 14px 28px -16px rgba(0,0,0,.6); }
.plogo img { height: 30px; max-width: 90%; width: auto; object-fit: contain; transition: .2s; }
.plogo:hover img { transform: scale(1.05); }
.plogo span { font-family: var(--ff-title); font-weight: 700; font-size: 11.5px; letter-spacing: .02em; color: #33405a; }
.plogo:hover span { color: #0a0f1c; }
.seg-block { border-left: 1px solid var(--line); padding-left: 36px; }
.seg-mini-row { display: flex; gap: 10px; flex-wrap: wrap; }
.seg-mini { flex: 0 1 calc((100% - 20px) / 3); min-width: 84px; text-align: center; padding: 18px 8px; border: 1px solid var(--line); border-radius: 12px; background: var(--bg-2); color: var(--text-2); transition: .2s; }
.seg-mini:hover { border-color: var(--line-strong); color: #fff; transform: translateY(-2px); }
.seg-mini span:first-child { position: relative; overflow: hidden; display: flex; width: 50px; height: 50px; border-radius: 14px; align-items: center; justify-content: center; margin: 0 auto 10px; color: var(--blue-hover);
  background: linear-gradient(155deg, rgba(94,152,255,.26), rgba(31,111,235,.05) 72%);
  border: 1px solid rgba(94,152,255,.30);
  box-shadow: 0 8px 20px -12px rgba(31,111,235,.55), inset 0 1px 0 rgba(255,255,255,.07); }
.seg-mini span:first-child::after { content:""; position:absolute; top:-32%; left:50%; transform:translateX(-50%); width:82%; height:72%; border-radius:50%; pointer-events:none; background: radial-gradient(closest-side, rgba(94,152,255,.5), transparent); opacity:.5; }
.seg-mini svg { position: relative; z-index: 1; width: 25px; height: 25px; color: var(--blue-hover); display: block; }
.seg-mini span:last-child { font-size: 12.5px; font-family: var(--ff-title); font-weight: 500; }

/* ---- Footer 5 colunas ---- */
.footer-grid { grid-template-columns: 1.5fr 1fr 1.1fr 1.1fr 1.1fr; }

/* ---- WhatsApp flutuante ---- */
.wpp-float { position: fixed; right: 22px; bottom: 22px; z-index: 200; width: 56px; height: 56px; border-radius: 50%; background: #25D366; color: #fff; display: grid; place-items: center; box-shadow: 0 12px 30px -8px rgba(37,211,102,.7); transition: .2s; }
.wpp-float:hover { transform: scale(1.07); }
.wpp-float svg { width: 30px; height: 30px; }

/* ================= Responsive ================= */
@media (max-width: 1024px) {
  .hero-grid { grid-template-columns: 1fr; gap: 36px; padding: 56px 0 48px; }
  .hero-visual { max-width: 560px; }
  .diffs-grid { grid-template-columns: repeat(2,1fr); gap: 26px; }
  .cards-3, .cards-4, .cards-7 { grid-template-columns: repeat(2,1fr); }
  .flow, .flow.steps-6 { grid-template-columns: repeat(3,1fr); gap: 28px 14px; }
  .flow .step::after { display: none; }
  .segments { grid-template-columns: repeat(3,1fr); }
  .stats { grid-template-columns: repeat(3,1fr); }
  .logos { grid-template-columns: repeat(3,1fr); }
  .split { grid-template-columns: 1fr; gap: 32px; }
  .mvv { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .contact-grid { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  .topbar { display: none; }
  .nav, .header-actions .btn-account, .header-actions .btn { display: none; }
  .burger { display: inline-flex; }
  .section { padding: 56px 0; }

  /* mobile nav drawer */
  .nav.open {
    display: flex; flex-direction: column; align-items: stretch;
    position: fixed; top: var(--header-h); left: 0; right: 0; bottom: 0;
    background: var(--bg); padding: 18px; gap: 4px; overflow-y: auto; z-index: 99;
  }
  .nav.open > a, .nav.open .has-sub > a { font-size: 17px; padding: 14px 12px; border-bottom: 1px solid var(--line); border-radius: 0; }
  .nav.open .submenu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border: none; background: transparent; padding: 0 0 8px 14px; }
  .nav.open .has-sub:hover .submenu { transform: none; }
  .nav.open .caret { display: none; }
  .nav.open .mobile-cta { margin-top: 16px; display: flex; flex-direction: column; gap: 10px; }
  .nav.open .mobile-cta .btn { display: inline-flex; justify-content: center; }

  .hero h1 { font-size: 34px; }
  .diffs-grid { grid-template-columns: 1fr; gap: 18px; }
  .cards-3, .cards-4, .cards-7, .grid-2 { grid-template-columns: 1fr; }
  .flow, .flow.steps-6 { grid-template-columns: repeat(2,1fr); }
  .segments { grid-template-columns: repeat(2,1fr); }
  .stats { grid-template-columns: repeat(2,1fr); }
  .logos { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr; }
  .form .row { grid-template-columns: 1fr; }
  .cta-band { padding: 40px 24px; }
  .footer-bottom { flex-direction: column; }
}

/* ===== Responsive — componentes da Home (mockup) ===== */
@media (max-width: 1100px) {
  .sol-grid { grid-template-columns: repeat(4,1fr); }
  .eco-grid { grid-template-columns: repeat(4,1fr); }
  .partners-row { grid-template-columns: 1fr 1fr; }
  .seg-block { grid-column: 1 / -1; border-left: none; padding-left: 0; border-top: 1px solid var(--line); padding-top: 28px; }
  .footer-grid { grid-template-columns: 1fr 1fr 1fr; }
}
@media (max-width: 1024px) {
  .hero { min-height: 520px; }
  .hero-bg::after { background: linear-gradient(90deg, rgba(11,18,32,.97) 0%, rgba(11,18,32,.9) 55%, rgba(11,18,32,.7) 100%); }
  .video-feature { grid-template-columns: 1fr; min-height: 0; }
  .video-feature .vf-text { padding: 36px 32px 8px; }
  .video-feature .vf-play { padding: 0 32px 40px; align-items: flex-start; }
}
@media (max-width: 720px) {
  .hero-inner { padding: 56px 0; }
  .hero-inner h1 { font-size: 30px; }
  .section-head { flex-direction: column; align-items: flex-start; gap: 10px; }
  .sol-grid { grid-template-columns: repeat(2,1fr); }
  .eco-grid { grid-template-columns: 1fr; }
  .eco-card h3 { min-height: 0; }
  .partners-row { grid-template-columns: 1fr; }
  .partners-panel { grid-template-columns: repeat(2,1fr); }
  .footer-grid { grid-template-columns: 1fr; }
  .video-feature .vf-text, .video-feature .vf-play { padding-left: 24px; padding-right: 24px; }
  .wpp-float { width: 50px; height: 50px; right: 16px; bottom: 16px; }
  .wpp-float svg { width: 26px; height: 26px; }
}

/* =========================================================
   PÁGINA SOBRE
   ========================================================= */
.hero-sobre .hero-inner { max-width: 640px; }
.hero-sobre .hero-inner h1 { text-transform: none; font-size: clamp(27px,3.3vw,42px); }
.hero-mini { display: flex; gap: 30px; margin-top: 30px; flex-wrap: wrap; }
.hero-mini-item { display: flex; flex-direction: column; gap: 10px; }
.hero-mini-item .ic { width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center; background: rgba(59,130,246,.14); border: 1px solid var(--line-strong); color: var(--blue-hover); }
.hero-mini-item .ic svg { width: 20px; height: 20px; }
.hero-mini-item span:last-child { font-size: 12.5px; color: var(--text-2); font-family: var(--ff-title); font-weight: 500; line-height: 1.35; }

.about-split { display: grid; grid-template-columns: .85fr 1.55fr; gap: 44px; align-items: start; }
.about-split p { font-size: 14.5px; }

.tile-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-top: 24px; }
.tile { background: var(--card-grad); border: 1px solid var(--line); border-radius: 12px; padding: 20px 10px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 12px; transition: .2s; }
.tile:hover { border-color: var(--line-strong); transform: translateY(-3px); }
.tile .ic { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; background: rgba(59,130,246,.1); border: 1px solid var(--line-strong); color: var(--blue-hover); }
.tile .ic svg { width: 22px; height: 22px; }
.tile span:last-child { font-size: 12.5px; font-family: var(--ff-title); font-weight: 600; color: var(--text); line-height: 1.3; }

.diff-list { display: grid; grid-template-columns: 1fr 1fr; gap: 22px 24px; margin-top: 24px; }
.diff-item { display: flex; gap: 13px; }
.diff-item .ic { width: 40px; height: 40px; flex: none; border-radius: 11px; display: grid; place-items: center; background: rgba(59,130,246,.1); border: 1px solid var(--line-strong); color: var(--blue-hover); }
.diff-item .ic svg { width: 20px; height: 20px; }
.diff-item h4 { font-size: 15px; margin-bottom: 4px; }
.diff-item p { font-size: 13px; margin: 0; color: #aeb9cc; line-height: 1.45; }

.leader-split { display: grid; grid-template-columns: 1.55fr .85fr; gap: 44px; align-items: start; }
.leaders { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 24px; }
.leader-card { display: flex; gap: 18px; align-items: flex-start; background: var(--card-grad); border: 1px solid var(--line); border-radius: 14px; padding: 22px; }
.leader-photo { width: 104px; height: 104px; flex: none; border-radius: 16px; overflow: hidden; background: linear-gradient(150deg, var(--blue-2), var(--blue)); display: grid; place-items: center; font-family: var(--ff-title); font-weight: 800; font-size: 27px; letter-spacing: .01em; color: #fff; box-shadow: 0 12px 26px -12px rgba(31,111,235,.7); border: 1.5px solid rgba(94,152,255,.4); }
.leader-photo img { width: 100%; height: 100%; object-fit: cover; }
.leader-body h3 { font-size: 17px; }
.leader-body .role { color: var(--blue-2); font-family: var(--ff-title); font-weight: 600; font-size: 12.5px; display: block; margin: 3px 0 10px; }
.leader-body p { font-size: 12.5px; margin: 0; color: #aeb9cc; line-height: 1.5; }

.mvv-side { background: var(--card-grad); border: 1px solid var(--line); border-radius: 16px; padding: 26px 24px; }
.mvv-block { display: flex; gap: 13px; margin-top: 22px; }
.mvv-block .ic { width: 38px; height: 38px; flex: none; border-radius: 10px; display: grid; place-items: center; background: rgba(59,130,246,.1); border: 1px solid var(--line-strong); color: var(--blue-hover); }
.mvv-block .ic svg { width: 19px; height: 19px; }
.mvv-block h4 { font-size: 13px; text-transform: uppercase; letter-spacing: .05em; color: var(--blue-2); margin-bottom: 5px; }
.mvv-block p { font-size: 13px; margin: 0; color: #aeb9cc; line-height: 1.5; }
.values { list-style: none; margin: 8px 0 0; padding: 0; }
.values li { display: flex; align-items: center; gap: 9px; font-size: 13.5px; color: var(--text-2); padding: 5px 0; }
.values li span { width: 26px; height: 26px; flex: none; border-radius: 7px; display: grid; place-items: center; color: var(--blue-hover); background: rgba(59,130,246,.1); }
.values li span svg { width: 14px; height: 14px; }

.seg-photo-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-top: 24px; }
.seg-photo { position: relative; aspect-ratio: 1/1; border-radius: 12px; overflow: hidden; border: 1px solid var(--line); display: flex; align-items: flex-end; transition: .2s; }
.seg-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; transition: .4s; }
.seg-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,13,24,.05) 25%, rgba(8,13,24,.92)); z-index: 1; }
.seg-photo .ic { position: absolute; top: 12px; left: 12px; z-index: 2; color: var(--blue-hover); }
.seg-photo .ic svg { width: 22px; height: 22px; }
.seg-photo .lbl { position: relative; z-index: 2; padding: 12px 14px; font-family: var(--ff-title); font-weight: 600; font-size: 12.5px; color: #fff; }
.seg-photo:hover { border-color: var(--line-strong); }
.seg-photo:hover img { transform: scale(1.06); }

.cta-media { display: grid; grid-template-columns: .55fr 1fr auto; gap: 30px; align-items: center; border: 1px solid var(--line-strong); border-radius: var(--radius-lg); padding: 28px 34px; overflow: hidden;
  background: radial-gradient(600px 240px at 12% 10%, rgba(37,99,235,.22), transparent 60%), var(--card-grad); }
.cta-media-img { border-radius: 14px; overflow: hidden; aspect-ratio: 16/10; }
.cta-media-img img { width: 100%; height: 100%; object-fit: cover; }
.cta-media-body h2 { font-size: clamp(22px,2.5vw,30px); margin-bottom: 8px; }
.cta-media-body p { margin: 0; color: var(--text-2); }
.cta-media-actions { display: flex; flex-direction: column; gap: 12px; }

@media (max-width: 1024px) {
  .about-split, .leader-split { grid-template-columns: 1fr; gap: 36px; }
  .diff-list { grid-template-columns: 1fr; }
  .cta-media { grid-template-columns: 1fr; }
  .cta-media-img { display: none; }
  .cta-media-actions { flex-direction: row; flex-wrap: wrap; }
}
@media (max-width: 720px) {
  .tile-grid { grid-template-columns: repeat(2,1fr); }
  .leaders { grid-template-columns: 1fr; }
  .seg-photo-grid { grid-template-columns: repeat(2,1fr); }
  .hero-mini { gap: 18px; }
  .hero-mini-item { flex: 1; min-width: 130px; }
  .cta-media-actions .btn { flex: 1; justify-content: center; }
}

/* Logo oficial SHIRO (kit de marca) */
.logo-img { height: 34px; width: auto; display: block; }
.site-footer .logo-img { height: 38px; }
@media (max-width: 720px){ .logo-img { height: 30px; } }

/* =========================================================
   PÁGINA SOLUÇÕES
   ========================================================= */
/* sol-hero usa o full-bleed base .hero; só afina overlay e título */
.sol-hero .hero-img { object-position: center center; }
.sol-hero .hero-overlay { background:
  linear-gradient(90deg, rgba(8,13,24,.96) 0%, rgba(8,13,24,.86) 38%, rgba(8,13,24,.45) 62%, rgba(8,13,24,.18) 100%),
  linear-gradient(0deg, rgba(8,13,24,.5), transparent 45%); }
.sol-hero .hero-inner { max-width: 620px; padding: 64px 0; }
.sol-hero .hero-inner h1 { font-size: clamp(23px,2.9vw,38px); }

/* Hub diagram */
.sol-hub { position: relative; aspect-ratio: 1/1; max-width: 460px; margin: 0 auto; width: 100%; }
.hub-lines { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.hub-lines line { stroke: rgba(58,130,255,.45); stroke-width: .4; }
.hub-center { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 100px; height: 100px; border-radius: 24px;
  background: var(--card); border: 1px solid var(--line-strong); display: flex; flex-direction: column; align-items: center; justify-content: center;
  box-shadow: 0 0 28px rgba(31,111,235,.45); z-index: 3; }
.hub-center img { width: 44px; height: 44px; }
.hub-center span { font-family: var(--ff-title); font-weight: 800; font-size: 11px; letter-spacing: .14em; color: #fff; margin-top: 4px; }
.hub-node { position: absolute; transform: translate(-50%,-50%); display: flex; flex-direction: column; align-items: center; gap: 7px; z-index: 3; }
.hub-node .ic { width: 48px; height: 48px; border-radius: 50%; display: grid; place-items: center; background: var(--card); border: 1px solid var(--line-strong); color: var(--blue-2); box-shadow: 0 6px 18px rgba(0,0,0,.45); }
.hub-node .ic svg { width: 22px; height: 22px; }
.hub-node .lbl { font-family: var(--ff-title); font-weight: 600; font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--text-2); white-space: nowrap; }

/* card 07 + ecossistema */
.sol-bottom { display: grid; grid-template-columns: 1fr 2fr; gap: 22px; margin-top: 22px; align-items: start; }
.eco-promo { background: var(--card-grad); border: 1px solid var(--line); border-radius: var(--radius); padding: 28px 30px; }
.eco-promo h3 { font-size: 22px; line-height: 1.25; margin-bottom: 10px; }
.eco-promo > p { font-size: 14.5px; margin-bottom: 20px; max-width: 520px; }
.eco-promo-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-top: 24px; }
.eco-mini { display: flex; align-items: center; gap: 11px; }
.eco-mini .ic { width: 40px; height: 40px; flex: none; border-radius: 11px; display: grid; place-items: center; background: color-mix(in srgb, currentColor 14%, transparent); border: 1px solid color-mix(in srgb, currentColor 42%, transparent); }
.eco-mini .ic svg { width: 20px; height: 20px; }
.eco-mini h5 { font-size: 13px; margin: 0; color: #fff; font-weight: 700; }
.eco-mini > div > span { font-size: 11px; color: var(--text-2); }

/* fluxo integrado */
.int-split { display: grid; grid-template-columns: .8fr 1.7fr; gap: 40px; align-items: center; }
.int-flow { display: flex; align-items: flex-start; justify-content: space-between; gap: 4px; position: relative; }
.int-flow::before { content: ""; position: absolute; top: 28px; left: 6%; right: 6%; height: 2px; background: linear-gradient(90deg, transparent, rgba(58,130,255,.45), transparent); z-index: 0; }
.int-node { display: flex; flex-direction: column; align-items: center; gap: 9px; position: relative; z-index: 1; flex: 1; }
.int-node .ic { width: 56px; height: 56px; border-radius: 50%; display: grid; place-items: center; background: var(--bg-2); border: 1px solid var(--line-strong); color: var(--blue-2); }
.int-node .ic svg { width: 26px; height: 26px; }
.int-node .lbl { font-family: var(--ff-title); font-weight: 600; font-size: 11px; color: var(--text-2); text-align: center; }
.int-core .ic { width: 72px; height: 72px; margin-top: -8px; border: none; color: #fff; background: linear-gradient(135deg, var(--blue-2), var(--blue));
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%); border-radius: 0; box-shadow: 0 0 28px rgba(31,111,235,.6); }
.int-core .ic svg { width: 30px; height: 30px; }
.int-core .lbl { color: #fff; font-weight: 700; }

/* 7 segmentos */
.seg-photo-grid.seg-7 { grid-template-columns: repeat(7,1fr); }

/* CTA split com imagem + checklist */
.cta-split { position: relative; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line-strong);
  display: grid; grid-template-columns: 1.6fr 1fr; gap: 36px; align-items: center; padding: 40px 44px; min-height: 230px; }
.cta-split-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.cta-split-overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(90deg, rgba(6,10,19,.96) 0%, rgba(6,10,19,.88) 55%, rgba(6,10,19,.82) 100%); }
.cta-split-body, .cta-checklist { position: relative; z-index: 2; }
.cta-split-body h2 { font-size: clamp(22px,2.5vw,30px); margin-bottom: 10px; }
.cta-split-body p { color: var(--text-2); margin: 0 0 20px; max-width: 480px; }
.cta-checklist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.cta-checklist li { display: flex; align-items: center; gap: 11px; font-size: 14.5px; color: var(--text); }
.cta-checklist li span { width: 24px; height: 24px; flex: none; border-radius: 7px; display: grid; place-items: center; background: var(--accent-soft, rgba(31,111,235,.12)); color: var(--blue-2); }
.cta-checklist li span svg { width: 15px; height: 15px; }

@media (max-width: 1024px) {
  .sol-hero-grid { grid-template-columns: 1fr; gap: 36px; }
  .sol-hub { max-width: 400px; }
  .sol-bottom { grid-template-columns: 1fr; }
  .int-split { grid-template-columns: 1fr; gap: 30px; }
  .cta-split { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .eco-promo-grid { grid-template-columns: 1fr; }
  .seg-photo-grid.seg-7 { grid-template-columns: repeat(2,1fr); }
  .int-flow { flex-wrap: wrap; gap: 18px; justify-content: center; }
  .int-flow::before { display: none; }
  .int-node { flex: 0 0 28%; }
  .hub-node .lbl { font-size: 9px; }
  .sol-hub { max-width: 320px; }
}

/* Soluções — hero hub (imagem) */
.sol-hub-wrap { width: 100%; }
.sol-hub-img { width: 100%; border-radius: var(--radius-lg); border: 1px solid var(--line-strong); box-shadow: var(--shadow); display: block; }

/* Soluções — 6 cards numa linha, compactos (como o mockup) */
.cards-6 { grid-template-columns: repeat(6,1fr); }
.sol-cards .card { padding: 20px 16px; }
.sol-cards .card .num { font-size: 12px; margin-bottom: 6px; }
.sol-cards .card .ic { width: 42px; height: 42px; border-radius: 11px; margin-bottom: 14px; }
.sol-cards .card .ic svg { width: 21px; height: 21px; }
.sol-cards .card h3 { font-size: 14.5px; line-height: 1.25; margin-bottom: 12px; }
.sol-cards .card ul { margin-bottom: 14px; }
.sol-cards .card ul li { font-size: 11.5px; padding: 4px 0 4px 15px; line-height: 1.35; }
.sol-cards .card ul li::before { top: 9px; width: 6px; height: 6px; }
.sol-cards .card .link-arrow { font-size: 12px; }
@media (max-width: 1100px) { .cards-6 { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 720px)  { .cards-6 { grid-template-columns: repeat(2,1fr); } }

/* Soluções — foto no topo de cada card (como o mockup) */
.sol-cards .card-thumb { display: block; margin: -20px -16px 14px; height: 112px; position: relative; overflow: hidden; background: linear-gradient(160deg,#1a2c4a,#0e1a2e); }
.sol-cards .card-thumb img { width: 100%; height: 100%; object-fit: cover; }
.sol-cards .card-thumb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,13,24,0) 50%, rgba(15,21,36,.96)); }

/* =========================================================
   PÁGINA PROJETOS SOB MEDIDA
   ========================================================= */
.section-title.up { text-transform: uppercase; font-size: clamp(21px,2.8vw,31px); letter-spacing: 0; }

/* Quando faz sentido — 6 cards */
.use-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 16px; }
.use-card { background: var(--card-grad); border: 1px solid var(--line); border-radius: 14px; padding: 26px 18px; text-align: center; transition: .25s; }
.use-card:hover { transform: translateY(-5px); border-color: var(--line-strong); box-shadow: var(--glow); }
.use-card .ic { width: 50px; height: 50px; border-radius: 14px; margin: 0 auto 16px; display: grid; place-items: center; background: rgba(31,111,235,.1); border: 1px solid var(--line-strong); color: var(--blue-2); }
.use-card .ic svg { width: 25px; height: 25px; }
.use-card h3 { font-size: 15px; line-height: 1.3; margin-bottom: 8px; }
.use-card p { font-size: 12.5px; color: var(--text-2); margin: 0; line-height: 1.5; }

/* grade de 5 cards */
.cards-5 { grid-template-columns: repeat(5,1fr); }

/* Exemplos de projetos */
.proj-split { display: grid; grid-template-columns: .82fr 2.2fr; gap: 40px; align-items: center; }
.proj-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 14px; }
.proj-card { display: block; background: var(--card-grad); border: 1px solid var(--line); border-radius: 14px; overflow: hidden; transition: .25s; }
.proj-card:hover { transform: translateY(-5px); border-color: var(--line-strong); box-shadow: var(--glow); }
.proj-card .card-thumb { display: block; height: 118px; position: relative; overflow: hidden; }
.proj-card .card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: .4s; }
.proj-card:hover .card-thumb img { transform: scale(1.06); }
.proj-card .pc-body { padding: 16px; }
.proj-card .pc-body h3 { font-size: 15px; margin-bottom: 7px; }
.proj-card .pc-body p { font-size: 12.5px; color: var(--text-2); margin: 0; line-height: 1.5; }

/* Integrações sem limites */
.integra-grid { display: grid; grid-template-columns: .85fr 1.5fr .9fr; gap: 30px; align-items: center; }
.integra-cells { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.icell { background: #fff; border: 1px solid rgba(34,48,77,.16); border-radius: 10px; padding: 12px 8px; text-align: center; font-family: var(--ff-title); font-weight: 600; font-size: 11.5px; color: #33405a; transition: .2s; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; min-height: 84px; }
.icell:hover { transform: translateY(-2px); box-shadow: 0 12px 24px -14px rgba(0,0,0,.55); border-color: #c7d3e6; }
.icell img { height: 26px; max-width: 78%; width: auto; object-fit: contain; }
.icell .gic { width: 30px; height: 30px; display: grid; place-items: center; color: var(--blue); }
.icell .gic svg { width: 28px; height: 28px; }
.icell.muted { color: #6b7896; }
.icell.muted .gic { color: #94a3c4; }
.integra-side { background: radial-gradient(300px 200px at 50% 0, rgba(31,111,235,.18), transparent 60%), var(--card-grad); border: 1px solid var(--line-strong); border-radius: 16px; padding: 30px 24px; text-align: center; }
.integra-side .ic { width: 56px; height: 56px; border-radius: 15px; margin: 0 auto 16px; display: grid; place-items: center; background: rgba(31,111,235,.12); border: 1px solid var(--line-strong); color: var(--blue-2); }
.integra-side .ic svg { width: 28px; height: 28px; }
.integra-side h3 { font-size: 19px; line-height: 1.25; margin-bottom: 10px; }
.integra-side p { font-size: 13.5px; color: var(--text-2); margin: 0; }

/* CTA final */
.cta-final { display: grid; grid-template-columns: 1.4fr 1fr .9fr; gap: 32px; align-items: center; border: 1px solid var(--line-strong); border-radius: var(--radius-lg); padding: 38px 44px;
  background: radial-gradient(600px 280px at 12% 20%, rgba(31,111,235,.2), transparent 60%), var(--card-grad); }
.cta-final-text h2 { font-size: clamp(22px,2.6vw,30px); margin-bottom: 10px; }
.cta-final-text p { color: var(--text-2); margin: 0; }
.cta-final-actions { display: flex; flex-direction: column; gap: 12px; }

@media (max-width: 1100px) {
  .use-grid { grid-template-columns: repeat(3,1fr); }
  .cards-5 { grid-template-columns: repeat(3,1fr); }
  .proj-split { grid-template-columns: 1fr; gap: 28px; }
  .proj-grid { grid-template-columns: repeat(3,1fr); }
  .integra-grid { grid-template-columns: 1fr; }
  .cta-final { grid-template-columns: 1fr; }
  .cta-final-actions { flex-direction: row; flex-wrap: wrap; }
}
@media (max-width: 720px) {
  .use-grid { grid-template-columns: repeat(2,1fr); }
  .cards-5 { grid-template-columns: repeat(2,1fr); }
  .proj-grid { grid-template-columns: repeat(2,1fr); }
  .integra-cells { grid-template-columns: repeat(2,1fr); }
}

/* Projetos — hero: imagem viva à direita, texto escuro à esquerda (igual mockup) */
.proj-hero .hero-img { object-position: 72% center; }
.proj-hero .hero-overlay {
  background:
    linear-gradient(90deg, rgba(7,12,22,.985) 0%, rgba(7,12,22,.96) 34%, rgba(8,14,26,.72) 56%, rgba(9,16,30,.34) 78%, rgba(9,16,30,.12) 100%),
    linear-gradient(0deg, rgba(7,12,22,.78), transparent 42%),
    linear-gradient(0deg, rgba(31,111,235,.12), rgba(31,111,235,.06)); }
@media (max-width: 900px){
  .proj-hero .hero-overlay { background:
    linear-gradient(90deg, rgba(7,12,22,.97) 0%, rgba(7,12,22,.9) 60%, rgba(8,14,26,.8) 100%),
    linear-gradient(0deg, rgba(7,12,22,.82), transparent 50%); }
}

/* ---- Badges de ícone premium (gradiente + halo) — consistência global ---- */
.card .ic, .use-card .ic, .diff-item .ic, .mvv-block .ic, .channel .ic, .tile .ic, .hero-mini-item .ic {
  position: relative; overflow: hidden;
  background: linear-gradient(155deg, rgba(94,152,255,.26), rgba(31,111,235,.05) 72%);
  border: 1px solid rgba(94,152,255,.30);
  box-shadow: 0 8px 20px -12px rgba(31,111,235,.55), inset 0 1px 0 rgba(255,255,255,.07);
}
.card .ic::after, .use-card .ic::after, .diff-item .ic::after, .mvv-block .ic::after, .channel .ic::after, .tile .ic::after, .hero-mini-item .ic::after {
  content:""; position:absolute; top:-32%; left:50%; transform:translateX(-50%);
  width:82%; height:72%; border-radius:50%; pointer-events:none;
  background: radial-gradient(closest-side, rgba(94,152,255,.5), transparent); opacity:.5;
}
.card .ic svg, .use-card .ic svg, .diff-item .ic svg, .mvv-block .ic svg, .channel .ic svg, .tile .ic svg, .hero-mini-item .ic svg {
  position: relative; z-index: 1;
}

/* ---- Ecossistema — detalhe por solução ---- */
.eco-detail { display: flex; flex-direction: column; gap: 22px; }
.eco-row { position: relative; display: grid; grid-template-columns: .82fr 1.18fr; gap: 40px; align-items: center; padding: 30px; border: 1px solid var(--line); border-radius: 18px; background: var(--card-grad); overflow: hidden; scroll-margin-top: 110px; }
.eco-row::before { content: ""; position: absolute; top: 0; left: 0; bottom: 0; width: 4px; background: var(--c, var(--blue)); }
.eco-row:nth-child(even) .eco-row-visual { order: 2; }
.eco-row:nth-child(even) .eco-row-text { order: 1; }
.eco-row-visual { position: relative; min-height: 210px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; padding: 28px; border-radius: 14px; border: 1px solid color-mix(in srgb, var(--c) 30%, var(--line)); background: radial-gradient(440px 210px at 50% 28%, color-mix(in srgb, var(--c) 22%, transparent), transparent), #0c1424; }
.eco-row-ic { width: 86px; height: 86px; border-radius: 22px; display: grid; place-items: center; color: var(--c, var(--blue-hover)); background: color-mix(in srgb, var(--c) 15%, transparent); border: 1px solid color-mix(in srgb, var(--c) 45%, transparent); box-shadow: 0 20px 44px -18px var(--c); }
.eco-row-ic svg { width: 44px; height: 44px; }
.eco-row-name { font-family: var(--ff-title); font-weight: 800; font-size: 22px; color: #fff; }
.eco-row-tag { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--c, var(--blue-2)); font-weight: 700; }
.eco-row-text h3 { font-size: 23px; margin: 0 0 10px; }
.eco-row-how { font-size: 15px; color: var(--text-2); margin: 0 0 18px; line-height: 1.6; max-width: none; }
.eco-feats { list-style: none; margin: 0 0 18px; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 10px 20px; }
.eco-feats li { display: flex; gap: 9px; align-items: flex-start; font-size: 13.5px; color: var(--text); line-height: 1.42; }
.eco-feats li svg { width: 17px; height: 17px; flex: none; color: var(--c, var(--blue-hover)); margin-top: 1px; }
.eco-benefit { font-size: 14px; color: var(--text); background: color-mix(in srgb, var(--c) 10%, transparent); border-left: 3px solid var(--c, var(--blue)); border-radius: 8px; padding: 12px 14px; margin: 0 0 20px; line-height: 1.5; }
.eco-benefit strong { color: #fff; }
@media (max-width: 900px) {
  .eco-row { grid-template-columns: 1fr; gap: 24px; padding: 22px; }
  .eco-row:nth-child(even) .eco-row-visual { order: 0; }
  .eco-row:nth-child(even) .eco-row-text { order: 0; }
  .eco-feats { grid-template-columns: 1fr; }
}

/* ---- Página de serviço (dedicada) ---- */
.crumb { color: var(--blue-hover); text-decoration: none; }
.crumb:hover { color: #fff; }
.svc-intro { display: grid; grid-template-columns: .9fr 1.1fr; gap: 44px; align-items: start; }
.svc-intro p { color: var(--text-2); font-size: 15.5px; line-height: 1.7; margin: 0 0 16px; }
.svc-intro p:last-child { margin-bottom: 0; }
.svc-related { display: grid; grid-template-columns: auto 1fr auto; gap: 26px; align-items: center; padding: 28px 30px; border: 1px solid color-mix(in srgb, var(--c) 32%, var(--line)); border-radius: 18px;
  background: radial-gradient(420px 200px at 0% 0%, color-mix(in srgb, var(--c) 14%, transparent), transparent), var(--card-grad); }
.svc-related-ic { width: 64px; height: 64px; border-radius: 18px; display: grid; place-items: center; color: var(--c); background: color-mix(in srgb, var(--c) 15%, transparent); border: 1px solid color-mix(in srgb, var(--c) 45%, transparent); box-shadow: 0 16px 36px -16px var(--c); }
.svc-related-ic svg { width: 32px; height: 32px; }
.svc-related-body h3 { font-size: 20px; margin: 4px 0 8px; }
.svc-related-body p { color: var(--text-2); font-size: 14px; margin: 0; line-height: 1.55; max-width: 640px; }
@media (max-width: 860px) {
  .svc-intro { grid-template-columns: 1fr; gap: 18px; }
  .svc-related { grid-template-columns: 1fr; text-align: left; gap: 16px; }
}

/* ---- Página de produto (Ecossistema) ---- */
.prod-hero { position: relative; overflow: hidden; border-bottom: 1px solid var(--line); padding: 78px 0 62px;
  background: radial-gradient(720px 400px at 78% 18%, color-mix(in srgb, var(--c) 24%, transparent), transparent),
              radial-gradient(520px 320px at 8% 96%, color-mix(in srgb, var(--c) 13%, transparent), transparent), var(--bg); }
.prod-hero .container { position: relative; }
.prod-hero-inner { max-width: 760px; }
.prod-hero-ic { display: inline-grid; place-items: center; width: 78px; height: 78px; border-radius: 20px; color: var(--c); margin-bottom: 22px;
  background: color-mix(in srgb, var(--c) 15%, transparent); border: 1px solid color-mix(in srgb, var(--c) 45%, transparent); box-shadow: 0 22px 48px -18px var(--c); }
.prod-hero-ic svg { width: 40px; height: 40px; }
.prod-hero h1 { font-size: clamp(30px,4vw,48px); font-weight: 800; line-height: 1.06; margin: 0 0 16px; }
.prod-hero .lead { font-size: 18px; color: var(--text-2); max-width: 620px; margin: 0 0 28px; }
.prod-hero .eyebrow .crumb { color: var(--c); }
.prod-band { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; padding: 26px 30px; border: 1px solid var(--line); border-radius: 16px; background: var(--card-grad); }
.prod-band p { margin: 0; color: var(--text-2); font-size: 14.5px; }
.prod-band h3 { margin: 0 0 4px; font-size: 18px; }
@media (max-width:720px){ .prod-hero { padding: 56px 0 46px; } }
/* Product hero background image (cinematic, text stays readable on the left) */
.prod-hero.has-bg .prod-hero-img { position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: right center; z-index: 0; }
.prod-hero.has-bg::after { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(640px 380px at 15% 28%, color-mix(in srgb, var(--c) 22%, transparent), transparent 68%),
              linear-gradient(90deg, color-mix(in srgb, var(--bg) 93%, transparent) 0%, color-mix(in srgb, var(--bg) 80%, transparent) 40%, color-mix(in srgb, var(--bg) 52%, transparent) 72%, color-mix(in srgb, var(--bg) 34%, transparent) 100%),
              linear-gradient(0deg, var(--bg) 0%, transparent 62%); }
.prod-hero.has-bg .container { position: relative; z-index: 2; }
/* icon badge stands out over the photo */
.prod-hero.has-bg .prod-hero-ic { background: color-mix(in srgb, var(--c) 20%, rgba(9,13,21,.62));
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
@media (max-width:720px){
  .prod-hero.has-bg .prod-hero-img { opacity: .55; }
  .prod-hero.has-bg::after { background: linear-gradient(0deg, var(--bg) 8%, color-mix(in srgb, var(--bg) 60%, transparent) 100%); }
}

/* O que entregamos — grid 3 col uniforme + alinhamento + card Em Breve */
.sol-cards .card { display: flex; flex-direction: column; padding: 20px 18px; overflow: hidden; }
.sol-cards .card h3 { font-size: 16.5px; line-height: 1.25; }
.sol-cards .card ul li { font-size: 12.5px; padding: 5px 0 5px 16px; line-height: 1.4; }
.sol-cards .card .link-arrow { margin-top: auto; font-size: 13px; }
.sol-cards .card-thumb { height: 152px; margin: -20px -18px 16px; }
.card-soon { justify-content: center; align-items: center; text-align: center; border-style: dashed; background: rgba(255,255,255,.015); }
.card-soon .ic { margin: 0 auto 14px; opacity: .85; }
.card-soon h3 { font-size: 16.5px; color: var(--text); margin-bottom: 8px; }
.card-soon p { font-size: 13px; color: var(--text-2); margin: 0 0 16px; max-width: 240px; }
.soon-badge { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--blue-hover); background: rgba(94,152,255,.12); border: 1px solid var(--line-strong); border-radius: 999px; padding: 6px 14px; }

/* Cards do Ecossistema no formato "O que entregamos" (thumb colorido + ícone) */
.eco-thumb { display: flex; align-items: center; justify-content: center;
  background: radial-gradient(240px 140px at 50% 35%, color-mix(in srgb, var(--c) 32%, transparent), transparent), linear-gradient(160deg, #16203a, #0c1424); }
.eco-thumb::after { display: none; }
.eco-thumb .ic { width: 62px; height: 62px; border-radius: 16px; display: grid; place-items: center; color: var(--c); background: color-mix(in srgb, var(--c) 16%, transparent); border: 1px solid color-mix(in srgb, var(--c) 48%, transparent); box-shadow: 0 14px 30px -14px var(--c); }
.eco-thumb .ic svg { width: 30px; height: 30px; }
.eco-cat { display: block; font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--c, var(--blue-2)); margin-bottom: 6px; }

/* Badge de ícone do card de ecossistema na cor do produto */
.eco-ic-badge { color: var(--c, var(--blue-hover)) !important; background: color-mix(in srgb, var(--c) 14%, transparent) !important; border-color: color-mix(in srgb, var(--c) 42%, transparent) !important; }
.eco-ic-badge::after { background: radial-gradient(closest-side, color-mix(in srgb, var(--c) 55%, transparent), transparent) !important; }
.eco-cat { display: block; font-size: 10.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--c, var(--blue-2)); margin: -2px 0 6px; }

/* Contorno mais definido em todos os badges + círculos do fluxo premium */
.card .ic, .use-card .ic, .diff .ic, .diff-item .ic, .mvv-block .ic, .channel .ic, .tile .ic, .hero-mini-item .ic, .seg-mini span:first-child, .eco-ic-badge { border-width: 1.5px; }
.flow .step .circle { overflow: hidden;
  background: linear-gradient(155deg, rgba(94,152,255,.26), rgba(31,111,235,.05) 72%);
  border: 1.5px solid rgba(94,152,255,.42);
  box-shadow: 0 10px 24px -12px rgba(31,111,235,.55), inset 0 1px 0 rgba(255,255,255,.08); }
.flow .step .circle::after { content:""; position:absolute; top:-28%; left:50%; transform:translateX(-50%); width:82%; height:72%; border-radius:50%; pointer-events:none; background: radial-gradient(closest-side, rgba(94,152,255,.5), transparent); opacity:.5; }
.flow .step .circle svg { position: relative; z-index: 1; }

/* Badges de ícone coloridos por categoria (via --c; default azul) */
.card .ic {
  background: linear-gradient(155deg, color-mix(in srgb, var(--c, #5e98ff) 26%, transparent), color-mix(in srgb, var(--c, #1f6feb) 6%, transparent) 72%);
  border-color: color-mix(in srgb, var(--c, #5e98ff) 38%, transparent);
  color: var(--c, var(--blue-hover)); }
.card .ic::after { background: radial-gradient(closest-side, color-mix(in srgb, var(--c, #5e98ff) 55%, transparent), transparent); }
.sol-card .ic { position: relative; overflow: hidden;
  background: linear-gradient(155deg, color-mix(in srgb, var(--c, #5e98ff) 26%, transparent), color-mix(in srgb, var(--c, #1f6feb) 6%, transparent) 72%);
  border: 1.5px solid color-mix(in srgb, var(--c, #5e98ff) 38%, transparent);
  color: var(--c, var(--blue-hover));
  box-shadow: 0 8px 18px -10px color-mix(in srgb, var(--c, #1f6feb) 60%, transparent), inset 0 1px 0 rgba(255,255,255,.07); }
.sol-card .ic svg { position: relative; z-index: 1; }

/* Liderança — cargo + especialidade em linhas + chips de skill (medalhas) */
.leader-body .role { margin: 3px 0 0; }
.role-spec { display: block; font-size: 11.5px; color: var(--text-2); font-family: var(--ff-title); font-weight: 500; margin: 1px 0 10px; }
.leader-skills { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.skill { display: inline-flex; align-items: center; gap: 6px; padding: 5px 9px; border-radius: 8px; background: rgba(94,152,255,.10); border: 1px solid var(--line-strong); font-family: var(--ff-title); font-size: 10.5px; font-weight: 600; color: #c2cde0; }
.skill img { width: 14px; height: 14px; object-fit: contain; filter: brightness(0) invert(1); opacity: .92; }
.skill .skill-ic { width: 14px; height: 14px; display: grid; place-items: center; color: var(--blue-hover); }
.skill .skill-ic svg { width: 14px; height: 14px; }

/* Skills: ícones-só abaixo da foto, com tooltip no hover */
.leader-card { gap: 22px; }
.leader-left { flex: none; width: 104px; }
.leader-skills { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.leader-skills .skill { position: relative; width: 30px; height: 30px; padding: 0; border-radius: 9px; display: grid; place-items: center; background: rgba(94,152,255,.10); border: 1px solid var(--line-strong); cursor: default; }
.leader-skills .skill img { width: 16px; height: 16px; filter: brightness(0) invert(1); opacity: .9; object-fit: contain; }
.leader-skills .skill .skill-ic { width: 16px; height: 16px; display: grid; place-items: center; }
.leader-skills .skill .skill-ic svg { width: 16px; height: 16px; color: var(--blue-hover); }
.leader-skills .skill::after { content: attr(data-tip); position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%); background: #060a13; color: #fff; font-size: 10.5px; font-family: var(--ff-title); font-weight: 600; padding: 5px 9px; border-radius: 6px; white-space: nowrap; border: 1px solid var(--line-strong); box-shadow: 0 8px 18px -8px rgba(0,0,0,.7); opacity: 0; pointer-events: none; transition: opacity .15s; z-index: 6; }
.leader-skills .skill::before { content: ""; position: absolute; bottom: calc(100% + 3px); left: 50%; transform: translateX(-50%); border: 5px solid transparent; border-top-color: #060a13; opacity: 0; transition: opacity .15s; }
.leader-skills .skill:hover { border-color: var(--blue-hover); background: rgba(94,152,255,.18); }
.leader-skills .skill:hover::after, .leader-skills .skill:hover::before { opacity: 1; }

/* Skill tiles — qualidade: fundo branco + logos coloridos + separação da foto */
.leader-skills { margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--line); }
.leader-skills .skill { background: #fff; border: 1px solid rgba(34,48,77,.16); }
.leader-skills .skill img { filter: none; opacity: 1; width: 17px; height: 17px; }
.leader-skills .skill .skill-ic svg { width: 17px; height: 17px; color: #1f6feb; }
.leader-skills .skill:hover { background: #fff; border-color: #aebfd9; transform: translateY(-1px); }

/* Liderança v2 — skills em linha cheia abaixo do card + ícones nítidos */
.leader-card { display: flex; flex-direction: column; gap: 0; }
.leader-top { display: flex; gap: 20px; align-items: flex-start; }
.leader-skills { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); gap: 7px; }
.leader-skills .skill { width: 32px; height: 32px; }
.leader-skills .skill img { width: 18px; height: 18px; }
.leader-skills .skill .skill-ic svg { width: 18px; height: 18px; color: #1d4ed8; }

/* Liderança v3 — tiles ESCUROS integrados ao tema, ícones claros e nítidos */
.leader-skills .skill { background: linear-gradient(155deg, rgba(94,152,255,.16), rgba(31,111,235,.05)); border: 1px solid rgba(94,152,255,.24); box-shadow: inset 0 1px 0 rgba(255,255,255,.05); }
.leader-skills .skill img { filter: brightness(0) invert(1); opacity: .9; }
.leader-skills .skill .skill-ic svg { color: #a9c6f5; }
.leader-skills .skill:hover { background: rgba(94,152,255,.24); border-color: var(--blue-hover); transform: translateY(-1px); }

/* Liderança v4 — ícones DEBAIXO da foto + logos coloridos (whiten só os escuros) */
.leader-card { flex-direction: row; gap: 22px; align-items: flex-start; }
.leader-left { flex: none; width: 104px; }
.leader-skills { margin-top: 14px; padding-top: 0; border-top: none; gap: 6px; }
.leader-skills .skill { width: 30px; height: 30px; background: linear-gradient(155deg, rgba(94,152,255,.15), rgba(31,111,235,.05)); border: 1px solid rgba(94,152,255,.22); }
.leader-skills .skill img { filter: none; opacity: 1; width: 17px; height: 17px; }
.leader-skills .skill img.inv { filter: brightness(0) invert(1); opacity: .92; }
.leader-skills .skill .skill-ic svg { color: #a9c6f5; }
.leader-skills .skill:hover { background: rgba(94,152,255,.24); border-color: var(--blue-hover); }

/* Liderança v5 — tiles BRANCOS, logos coloridos e 100% visíveis */
.leader-skills .skill { background: #fff; border: 1px solid rgba(34,48,77,.14); box-shadow: 0 2px 6px -3px rgba(0,0,0,.45); }
.leader-skills .skill img { filter: none !important; opacity: 1; }
.leader-skills .skill .skill-ic svg { color: #1f6feb; }
.leader-skills .skill:hover { background: #fff; border-color: #b9c8e0; transform: translateY(-2px); box-shadow: 0 8px 16px -6px rgba(0,0,0,.55); }

/* concept icon usa cor por tema */
.leader-skills .skill .skill-ic svg { color: var(--c, #1f6feb); }

/* skills v7 — ícones reais coloridos (imagens), tile branco premium */
.leader-skills { gap: 7px; }
.leader-skills .skill { width: 34px; height: 34px; border-radius: 9px; background: #fff; border: 1px solid rgba(34,48,77,.12); box-shadow: 0 2px 6px -3px rgba(0,0,0,.4); overflow: visible; }
.leader-skills .skill img { width: 23px; height: 23px; object-fit: contain; filter: none !important; opacity: 1; }
.leader-skills .skill .skill-ic { width: 22px; height: 22px; }
.leader-skills .skill .skill-ic svg { width: 22px; height: 22px; color: var(--c, #1f6feb); }
.leader-skills .skill:hover { background: #fff; border-color: #b9c8e0; transform: translateY(-2px); box-shadow: 0 9px 18px -7px rgba(0,0,0,.5); }

/* skills v8 — grade fixa 3 colunas, alinhamento consistente nos 2 cards */
.leader-skills { display: grid; grid-template-columns: repeat(3, 30px); gap: 6px; justify-content: start; margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); }
.leader-skills .skill { width: 30px; height: 30px; }
.leader-skills .skill img { width: 20px; height: 20px; }
.leader-skills .skill .skill-ic { width: 19px; height: 19px; }
.leader-skills .skill .skill-ic svg { width: 19px; height: 19px; }

/* leader bio — texto justificado p/ bloco alinhado */
.leader-body p { text-align: justify; text-justify: inter-word; hyphens: auto; }

/* ===== Sobre · Liderança + MVV — reformulação v9 ===== */
/* cards empilhados: bio com largura confortável, bem enquadrada */
.leaders { grid-template-columns: 1fr; gap: 16px; }
.leader-card { gap: 24px; padding: 24px 26px; align-items: flex-start; }
.leader-body { flex: 1 1 auto; min-width: 0; }
.leader-body p { text-align: left; hyphens: none; font-size: 13px; line-height: 1.62; color: #b3bed1; max-width: 62ch; }
.leader-body h3 { font-size: 18px; }
.leader-skills { grid-template-columns: repeat(3, 30px); }

/* título da liderança melhor dimensionado */
.lead-title { font-size: clamp(22px, 2.3vw, 29px); line-height: 1.16; max-width: 22ch; }

/* glow + contorno nos títulos */
.glow-eyebrow { color: #7fb0ff; text-shadow: 0 0 14px rgba(56,135,255,.55), 0 0 2px rgba(56,135,255,.4); }
.glow-title { text-shadow: 0 0 26px rgba(56,135,255,.32); }
.glow-title .text-blue, .glow-title { }
.glow-sub { text-shadow: 0 0 12px rgba(94,152,255,.45); }

/* MVV icons coloridos com glow no contorno (usa --c por bloco) */
.mvv-block .ic {
  background: linear-gradient(155deg, color-mix(in srgb, var(--c,#3B82F6) 34%, transparent), color-mix(in srgb, var(--c,#3B82F6) 6%, transparent) 72%) !important;
  border: 1.5px solid color-mix(in srgb, var(--c,#3B82F6) 60%, transparent) !important;
  box-shadow: 0 0 16px -2px color-mix(in srgb, var(--c,#3B82F6) 55%, transparent), 0 8px 20px -12px color-mix(in srgb, var(--c,#3B82F6) 70%, transparent), inset 0 1px 0 rgba(255,255,255,.1) !important;
  color: color-mix(in srgb, var(--c,#3B82F6) 78%, #ffffff) !important;
}
.mvv-block .ic::after { background: radial-gradient(closest-side, color-mix(in srgb, var(--c,#3B82F6) 55%, transparent), transparent) !important; opacity:.6 !important; }

/* valores: chips coloridos com glow */
.values li span {
  width: 28px; height: 28px; border-radius: 8px;
  background: color-mix(in srgb, var(--c,#3B82F6) 16%, transparent);
  border: 1.5px solid color-mix(in srgb, var(--c,#3B82F6) 45%, transparent);
  box-shadow: 0 0 12px -3px color-mix(in srgb, var(--c,#3B82F6) 60%, transparent), inset 0 1px 0 rgba(255,255,255,.08);
  color: color-mix(in srgb, var(--c,#3B82F6) 80%, #ffffff);
}
.values li span svg { width: 15px; height: 15px; }
.values li { padding: 6px 0; }

/* solar/telecom sem fundo branco — vetor transparente, deixa respirar */

/* ===== Sobre · Liderança v10 — volta 2 colunas + MVV mais estreito + título 1 linha ===== */
/* leaders lado a lado de novo; MVV estreitado pra enquadrar os 2 líderes */
.leader-split { grid-template-columns: 1.85fr .72fr; gap: 34px; }
.leaders { grid-template-columns: 1fr 1fr; gap: 16px; }
.leader-card { gap: 16px; padding: 18px 18px 20px; }
.leader-left { width: 92px; }
.leader-skills { grid-template-columns: repeat(3, 28px); gap: 5px; margin-top: 12px; padding-top: 12px; }
.leader-skills .skill { width: 28px; height: 28px; border-radius: 8px; }
.leader-skills .skill img { width: 18px; height: 18px; }
.leader-body h3 { font-size: 15.5px; }
.leader-body .role { font-size: 11.5px; margin: 2px 0 0; }
.leader-body .role-spec { font-size: 11px; }
.leader-body p { text-align: left; hyphens: none; font-size: 12px; line-height: 1.55; color: #b3bed1; max-width: none; margin-top: 9px; }

/* MVV compacto pra caber na coluna estreita */
.mvv-side { padding: 20px 18px; }
.mvv-block { gap: 11px; margin-top: 18px; }
.mvv-block .ic { width: 34px; height: 34px; }
.mvv-block .ic svg { width: 17px; height: 17px; }
.mvv-block h4 { font-size: 12px; }
.mvv-block p { font-size: 12px; line-height: 1.48; }
.values li { font-size: 12.5px; }
.values li span { width: 26px; height: 26px; }

/* título em 1 linha + efeito gradiente com glow */
.lead-title {
  white-space: nowrap; max-width: none;
  font-size: clamp(19px, 2.05vw, 27px); line-height: 1.1; letter-spacing: -.015em;
  background: linear-gradient(92deg, #ffffff 38%, #79acff);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: none; filter: drop-shadow(0 0 20px rgba(56,135,255,.34));
}
@media (max-width: 900px) { .lead-title { white-space: normal; } }

/* ===== Sobre · Liderança v11 — 3 cards alinhados na base + texto justificado ===== */
/* iguala alturas: coluna dos líderes estica até a altura do quadro MVV */
.leader-split { align-items: stretch; }
.leader-split > div:first-child { display: flex; flex-direction: column; }
.leaders { flex: 1 1 auto; align-items: stretch; }
.leader-card { height: 100%; }
/* texto justificado e hifenizado = bloco alinhado e agradável, sem rios */
.leader-body p { text-align: justify; text-justify: inter-word; -webkit-hyphens: auto; hyphens: auto; }

/* ===== Sobre · Liderança v12 — destaques de valor sob a bio ===== */
.leader-highlights { list-style: none; margin: 13px 0 0; padding: 13px 0 0; border-top: 1px solid var(--line); display: grid; gap: 8px; }
.leader-highlights li { display: flex; gap: 9px; align-items: flex-start; font-size: 11.5px; line-height: 1.42; color: #c2cde0; font-family: var(--ff-title); font-weight: 500; }
.leader-highlights li span { width: 18px; height: 18px; flex: none; border-radius: 6px; display: grid; place-items: center; margin-top: 1px; color: var(--blue-hover); background: rgba(94,152,255,.12); border: 1px solid rgba(94,152,255,.22); box-shadow: 0 0 10px -3px rgba(94,152,255,.5); }
.leader-highlights li span svg { width: 12px; height: 12px; }

/* ============================================================
   HEADER REDESIGN — barra premium (logo oficial + nav + botões)
   ============================================================ */

/* ---- Topbar refinada ---- */
.topbar { background: linear-gradient(180deg,#060a13,#070c17); border-bottom: 1px solid rgba(58,130,255,.12); font-size: 12.5px; }
.topbar .container { min-height: 42px; }
.topbar .slogan { color: #8fa3c0; font-family: var(--ff-title); font-weight: 500; letter-spacing: .01em; position: relative; padding-left: 14px; }
.topbar .slogan::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 5px; height: 5px; border-radius: 50%; background: var(--blue-2); box-shadow: 0 0 8px rgba(58,130,255,.8); }
.topbar .tb-right { gap: 16px; }
.topbar .tb-item { color: #aab8cf; font-weight: 500; padding: 4px 2px; transition: color .2s; }
.topbar .tb-item:hover { color: #fff; }
.topbar .tb-item svg { width: 13px; height: 13px; }
.topbar .tb-social { gap: 6px; padding-left: 6px; border-left: 1px solid rgba(58,130,255,.14); margin-left: 4px; }
.topbar .tb-social a { display: grid; place-items: center; width: 28px; height: 28px; border-radius: 8px; border: 1px solid transparent; color: #8fa3c0; }
.topbar .tb-social a:hover { color: #fff; background: rgba(94,152,255,.12); border-color: rgba(94,152,255,.3); transform: translateY(-1px); }

/* ---- Site header / glass + scroll shrink ---- */
.site-header { background: rgba(7,11,20,.82); backdrop-filter: blur(16px) saturate(140%); border-bottom: 1px solid rgba(58,130,255,.14); transition: background .25s, box-shadow .25s, border-color .25s; }
.site-header .bar { height: var(--header-h); transition: height .25s; }
body.scrolled .site-header { background: rgba(6,10,19,.96); box-shadow: 0 10px 34px -18px rgba(0,0,0,.85); border-bottom-color: rgba(58,130,255,.28); }
body.scrolled .site-header .bar { height: calc(var(--header-h) - 14px); }

/* ---- Logo oficial (símbolo + wordmark) ---- */
.logo { gap: 11px; align-items: center; }
.logo-mark { width: 38px; height: 38px; flex: none; object-fit: contain; transition: width .25s, height .25s, filter .25s; filter: drop-shadow(0 2px 8px rgba(58,130,255,.35)); }
body.scrolled .logo-mark { width: 32px; height: 32px; }
.logo-name { display: flex; flex-direction: column; justify-content: center; font-family: var(--ff-title); font-weight: 800; font-size: 20px; line-height: 1; color: #fff; letter-spacing: .16em; }
.logo-name small { font-size: 8px; font-weight: 600; letter-spacing: .42em; color: var(--blue-2); margin-top: 4px; }
.logo:hover .logo-mark { filter: drop-shadow(0 3px 12px rgba(94,152,255,.6)); }

/* ---- Nav ---- */
.nav { gap: 2px; }
.nav > a, .nav .has-sub > a { font-size: 14px; font-weight: 600; padding: 9px 13px; border-radius: 9px; color: #aeb9cc; transition: color .18s, background .18s; }
.nav > a:hover, .nav .has-sub:hover > a { color: #fff; background: rgba(94,152,255,.09); }
.nav > a.active { color: #fff; background: rgba(94,152,255,.10); }
.nav > a.active::after { left: 13px; right: 13px; bottom: 4px; height: 2px; background: linear-gradient(90deg,var(--blue-2),var(--blue-hover)); box-shadow: 0 0 10px rgba(58,130,255,.9); border-radius: 2px; }
.nav .caret { transition: transform .2s; }
.nav .has-sub:hover .caret { transform: rotate(180deg); }

/* ---- Submenu premium ---- */
.submenu { top: calc(100% + 8px); border-radius: 14px; padding: 9px; border: 1px solid rgba(58,130,255,.2); background: linear-gradient(180deg,#0f1524,#0b101d); box-shadow: 0 24px 50px -18px rgba(0,0,0,.85), 0 0 0 1px rgba(0,0,0,.3); }
.submenu a { padding: 10px 13px; border-radius: 9px; font-size: 13.5px; font-weight: 500; transition: background .15s, color .15s, padding-left .15s; }
.submenu a:hover { background: rgba(94,152,255,.12); color: #fff; padding-left: 17px; }

/* ---- Botões premium ---- */
.btn { font-weight: 600; border-radius: 11px; }
.btn-primary { background: linear-gradient(135deg,#2563EB,#3a82ff); box-shadow: 0 12px 28px -10px rgba(37,99,235,.85), inset 0 1px 0 rgba(255,255,255,.22); position: relative; overflow: hidden; }
.btn-primary::after { content: ""; position: absolute; inset: 0; background: linear-gradient(115deg,transparent 32%,rgba(255,255,255,.28) 50%,transparent 68%); transform: translateX(-130%); transition: transform .6s ease; }
.btn-primary:hover { background: linear-gradient(135deg,#1d4ed8,#2f78ff); transform: translateY(-2px); box-shadow: 0 18px 38px -10px rgba(37,99,235,.95), inset 0 1px 0 rgba(255,255,255,.25); }
.btn-primary:hover::after { transform: translateX(130%); }
.header-actions .btn { padding: 10px 17px; font-size: 13.5px; }

/* botão Área do Cliente */
.btn-account { border: 1px solid rgba(58,130,255,.28); background: rgba(255,255,255,.03); border-radius: 11px; padding: 9px 15px; gap: 8px; font-weight: 600; color: #c6d2e6; }
.btn-account svg { width: 16px; height: 16px; color: var(--blue-2); transition: color .2s; }
.btn-account:hover { background: rgba(94,152,255,.10); border-color: var(--blue-2); color: #fff; transform: translateY(-1px); box-shadow: 0 8px 20px -12px rgba(58,130,255,.7); }
.btn-account:hover svg { color: var(--blue-hover); }

/* burger */
.burger { border: 1px solid rgba(58,130,255,.28); border-radius: 10px; }
.burger:hover { background: rgba(94,152,255,.1); border-color: var(--blue-2); }

/* footer logo maior */
.logo-footer .logo-mark { width: 42px; height: 42px; }
.logo-footer .logo-name { font-size: 22px; }
.logo-footer .logo-name small { font-size: 8.5px; }

/* ---- Header ajustes finos: alinhar barras + logo + sociais coloridas ---- */
/* topbar e header com a MESMA largura do conteúdo (1200) -> bordas alinhadas */
.site-header .bar { max-width: var(--maxw); }
.nav { gap: 1px; }
.nav > a, .nav .has-sub > a { padding: 9px 11px; }

/* logo verticalmente centralizado com o texto */
.logo { align-items: center; }
.logo-name { justify-content: center; line-height: 1; }
.logo-mark { align-self: center; }

/* WhatsApp no 2º telefone */
.topbar .tb-item.tb-wpp svg { color: #25D366; }

/* redes sociais coloridas (topbar + footer) */
.tb-social a[aria-label="Instagram"], .footer-social a[aria-label="Instagram"] { color: #E1306C; }
.tb-social a[aria-label="LinkedIn"], .footer-social a[aria-label="LinkedIn"] { color: #0A66C2; }
.tb-social a[aria-label="Facebook"], .footer-social a[aria-label="Facebook"] { color: #1877F2; }
.tb-social a[aria-label="YouTube"], .footer-social a[aria-label="YouTube"] { color: #FF0000; }
.tb-social a:hover { filter: brightness(1.25); transform: translateY(-1px); }
.tb-social a[aria-label="Instagram"]:hover { background: rgba(225,48,108,.14); border-color: rgba(225,48,108,.4); }
.tb-social a[aria-label="LinkedIn"]:hover { background: rgba(10,102,194,.16); border-color: rgba(10,102,194,.45); }
.tb-social a[aria-label="Facebook"]:hover { background: rgba(24,119,242,.16); border-color: rgba(24,119,242,.45); }
.tb-social a[aria-label="YouTube"]:hover { background: rgba(255,0,0,.14); border-color: rgba(255,0,0,.4); }

/* ============================================================
   TOPBAR · vibe NOC/terminal — LED de atividade + slogan shell
   ============================================================ */
.topbar .slogan { display: inline-flex; align-items: center; gap: 9px; padding-left: 0; font-family: var(--ff-mono); font-size: 12px; color: #9fb2cd; letter-spacing: 0; }
/* LED de placa de rede: pisca verde/laranja como atividade de link */
.topbar .slogan::before { content: ""; position: static; left: auto; transform: none; width: 9px; height: 9px; border-radius: 50%; flex: none; background: #22C55E; animation: nicLed 3s linear infinite; }
/* LED de atividade de rede: link verde "aceso", com flickers rápidos e irregulares
   simulando tráfego de dados (blink de pacote), e um blip âmbar de velocidade. */
@keyframes nicLed {
  0%,4%      { background:#22C55E; box-shadow:0 0 9px 1px rgba(34,197,94,.95), 0 0 2px #22C55E; }
  4.4%,5.2%  { background:#0a3d1e; box-shadow:0 0 2px rgba(34,197,94,.25); }   /* pacote */
  5.6%,15%   { background:#22C55E; box-shadow:0 0 9px 1px rgba(34,197,94,.95); }
  15.4%,16%  { background:#0a3d1e; box-shadow:0 0 2px rgba(34,197,94,.25); }   /* pacote */
  16.4%,17%  { background:#22C55E; box-shadow:0 0 9px 1px rgba(34,197,94,.95); }
  17.3%,17.8%{ background:#0a3d1e; box-shadow:0 0 2px rgba(34,197,94,.25); }   /* rajada */
  18.1%,28%  { background:#22C55E; box-shadow:0 0 9px 1px rgba(34,197,94,.95); }
  28.5%,29%  { background:#0a3d1e; box-shadow:0 0 2px rgba(34,197,94,.25); }
  29.5%,44%  { background:#22C55E; box-shadow:0 0 9px 1px rgba(34,197,94,.95); }
  44.4%,46.4%{ background:#F59E0B; box-shadow:0 0 9px 1px rgba(245,158,11,.95), 0 0 2px #F59E0B; } /* blip velocidade */
  46.8%,47.4%{ background:#0a3d1e; box-shadow:0 0 2px rgba(34,197,94,.25); }
  47.8%,57%  { background:#22C55E; box-shadow:0 0 9px 1px rgba(34,197,94,.95); }
  57.4%,58%  { background:#0a3d1e; box-shadow:0 0 2px rgba(34,197,94,.25); }   /* pacote */
  58.4%,59%  { background:#22C55E; box-shadow:0 0 9px 1px rgba(34,197,94,.95); }
  59.3%,59.8%{ background:#0a3d1e; box-shadow:0 0 2px rgba(34,197,94,.25); }   /* rajada dupla */
  60.2%,60.7%{ background:#22C55E; }
  61%,61.5%  { background:#0a3d1e; box-shadow:0 0 2px rgba(34,197,94,.25); }
  62%,75%    { background:#22C55E; box-shadow:0 0 9px 1px rgba(34,197,94,.95); }
  75.5%,76.2%{ background:#0a3d1e; box-shadow:0 0 2px rgba(34,197,94,.25); }   /* pacote */
  76.6%,90%  { background:#22C55E; box-shadow:0 0 9px 1px rgba(34,197,94,.95); }
  90.5%,91%  { background:#0a3d1e; box-shadow:0 0 2px rgba(34,197,94,.25); }
  91.5%,100% { background:#22C55E; box-shadow:0 0 9px 1px rgba(34,197,94,.95); }
}
/* prompt de shell */
.topbar .slogan .prompt { color: #22C55E; font-weight: 700; }
/* texto digitado como terminal (typewriter + cursor piscando) */
.topbar .slogan .typed { display: inline-block; overflow: hidden; white-space: nowrap; vertical-align: bottom; border-right: 2px solid #5e98ff; width: 0; animation: shTyping 3s steps(49,end) .5s forwards, shCaret .85s step-end infinite; }
@keyframes shTyping { to { width: 49ch; } }
@keyframes shCaret { 50% { border-color: transparent; } }
@media (prefers-reduced-motion: reduce) {
  .topbar .slogan .typed { width: 49ch; animation: none; border-right: none; }
  .topbar .slogan::before { animation: none; background: #22C55E; box-shadow: 0 0 8px #22C55E; }
}

/* ============================================================
   LOGIN / Área do Cliente
   ============================================================ */
.login-body { min-height: 100vh; display: grid; place-items: center; background: var(--bg-base); position: relative; overflow: hidden; padding: 32px 20px; }
.login-bg { position: fixed; inset: 0; z-index: 0; background:
  radial-gradient(60% 50% at 50% 0%, rgba(37,99,235,.18), transparent 70%),
  radial-gradient(40% 40% at 85% 90%, rgba(59,130,246,.12), transparent 70%); pointer-events: none; }
.login-wrap { position: relative; z-index: 1; width: 100%; max-width: 400px; display: flex; flex-direction: column; align-items: center; gap: 22px; }
.login-logo { transform: scale(1.05); }
.login-logo .logo-mark { width: 44px; height: 44px; }
.login-logo .logo-name { font-size: 22px; }

.login-card { width: 100%; background: linear-gradient(180deg, rgba(20,28,46,.9), rgba(11,16,29,.92)); border: 1px solid rgba(58,130,255,.2); border-radius: 18px; padding: 30px 28px; box-shadow: 0 30px 70px -28px rgba(0,0,0,.85), inset 0 1px 0 rgba(255,255,255,.05); }
.login-badge { display: inline-flex; align-items: center; gap: 7px; font-family: var(--ff-title); font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--blue-hover); background: rgba(94,152,255,.12); border: 1px solid rgba(94,152,255,.25); border-radius: 999px; padding: 5px 12px; }
.login-badge span { display: inline-grid; place-items: center; }
.login-badge svg { width: 13px; height: 13px; }
.login-card h1 { font-size: 23px; margin: 16px 0 6px; letter-spacing: -.01em; }
.login-sub { font-size: 13px; color: var(--text-2); margin: 0 0 22px; line-height: 1.5; }

.login-form { display: flex; flex-direction: column; gap: 14px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field span { font-family: var(--ff-title); font-size: 12px; font-weight: 600; color: #c2cde0; }
.field input { width: 100%; padding: 12px 14px; border-radius: 11px; border: 1px solid var(--line-strong); background: rgba(6,10,19,.6); color: #fff; font-size: 14px; font-family: var(--ff-body); transition: border-color .2s, box-shadow .2s, background .2s; }
.field input::placeholder { color: #5d6b82; }
.field input:focus { outline: none; border-color: var(--blue-2); background: rgba(6,10,19,.85); box-shadow: 0 0 0 3px rgba(58,130,255,.18); }

.login-row { display: flex; align-items: center; justify-content: space-between; font-size: 12.5px; margin: 2px 0 4px; }
.remember { display: inline-flex; align-items: center; gap: 7px; color: var(--text-2); cursor: pointer; }
.remember input { accent-color: var(--blue-2); width: 15px; height: 15px; }
.login-link { color: var(--blue-hover); font-weight: 500; }
.login-link:hover { text-decoration: underline; }
.login-submit { width: 100%; justify-content: center; margin-top: 4px; }
.login-note { font-size: 11.5px; color: #8090a8; text-align: center; margin: 12px 0 0; line-height: 1.45; }
.login-note.show { color: var(--blue-hover); }
.login-foot { text-align: center; font-size: 13px; color: var(--text-2); margin: 20px 0 0; padding-top: 18px; border-top: 1px solid var(--line); }
.login-foot a { color: var(--blue-hover); font-weight: 600; }
.login-back { display: inline-flex; align-items: center; gap: 7px; font-family: var(--ff-title); font-size: 13px; font-weight: 500; color: #8fa3c0; }
.login-back:hover { color: #fff; }

/* ---- Logo: wordmark vetorial oficial (SHIRO + TECNOLOGIA alinhados) ---- */
.logo-wordmark { height: 30px; width: auto; display: block; transition: height .25s; }
body.scrolled .logo-wordmark { height: 26px; }
.logo-footer .logo-wordmark { height: 36px; }
.login-logo .logo-wordmark { height: 34px; }

/* ===== Comparação Operadora x Corporativa (infra) ===== */
.center .section-sub { margin-left: auto; margin-right: auto; }
.vs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 30px; }
.vs-col { background: var(--card-grad); border: 1px solid var(--line); border-radius: 16px; padding: 24px 24px 22px; position: relative; }
.vs-col .vs-tag { display: inline-flex; align-items: center; gap: 8px; font-family: var(--ff-title); font-weight: 700; font-size: 13px; letter-spacing: .02em; padding: 7px 14px; border-radius: 999px; margin-bottom: 6px; }
.vs-col.bad { border-color: rgba(239,68,68,.22); }
.vs-col.bad .vs-tag { color: #fca5a5; background: rgba(239,68,68,.12); border: 1px solid rgba(239,68,68,.3); }
.vs-col.good { border-color: rgba(34,197,94,.28); box-shadow: 0 0 0 1px rgba(34,197,94,.12), 0 18px 40px -22px rgba(34,197,94,.45); }
.vs-col.good .vs-tag { color: #86efac; background: rgba(34,197,94,.12); border: 1px solid rgba(34,197,94,.35); }
.vs-col ul { list-style: none; margin: 14px 0 0; padding: 0; display: grid; gap: 11px; }
.vs-col li { position: relative; padding-left: 28px; font-size: 13.5px; line-height: 1.45; color: #b3bed1; }
.vs-col li::before { position: absolute; left: 0; top: 0; font-family: var(--ff-title); font-weight: 800; font-size: 14px; width: 19px; height: 19px; border-radius: 50%; display: grid; place-items: center; line-height: 1; }
.vs-col.bad li::before { content: "\00d7"; color: #fca5a5; background: rgba(239,68,68,.14); }
.vs-col.good li::before { content: "\2713"; color: #86efac; background: rgba(34,197,94,.16); font-size: 11px; }
@media (max-width: 720px) { .vs-grid { grid-template-columns: 1fr; } }

/* ===== Produtos que combinam (cross-sell em cards) ===== */
.combo-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.combo-card { display: flex; flex-direction: column; gap: 9px; background: var(--card-grad); border: 1px solid var(--line); border-radius: 16px; padding: 24px 22px; transition: transform .2s, border-color .2s, box-shadow .2s; }
.combo-card:hover { transform: translateY(-3px); border-color: color-mix(in srgb, var(--c) 50%, var(--line)); box-shadow: 0 22px 44px -24px color-mix(in srgb, var(--c) 70%, transparent); }
.combo-card.featured { border-color: color-mix(in srgb, var(--c) 45%, var(--line)); box-shadow: 0 0 0 1px color-mix(in srgb, var(--c) 16%, transparent), 0 22px 46px -26px color-mix(in srgb, var(--c) 60%, transparent); }
.combo-badge { width: 48px; height: 48px; border-radius: 13px; display: grid; place-items: center; color: color-mix(in srgb, var(--c) 78%, #fff); background: color-mix(in srgb, var(--c) 18%, transparent); border: 1.5px solid color-mix(in srgb, var(--c) 45%, transparent); box-shadow: 0 0 16px -3px color-mix(in srgb, var(--c) 55%, transparent); }
/* optional banner image at the top of a combo-card (ecosystem cards) */
.combo-card .combo-thumb { display: block; margin: -24px -22px 4px; height: 124px; position: relative; overflow: hidden; border-radius: 16px 16px 0 0; background: linear-gradient(160deg, #1a2c4a, #0e1a2e); }
.combo-card .combo-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.combo-card:hover .combo-thumb img { transform: scale(1.05); }
.combo-card .combo-thumb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,13,24,0) 42%, var(--bg)); }
.combo-card .combo-thumb + .combo-badge { margin-top: -34px; position: relative; z-index: 1; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.combo-badge svg { width: 24px; height: 24px; }
.combo-cat { font-family: var(--ff-title); font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: color-mix(in srgb, var(--c) 68%, #fff); }
.combo-card h3 { font-size: 18px; margin: 0; }
.combo-card p { font-size: 13px; color: var(--text-2); line-height: 1.52; margin: 0; flex: 1; }
.combo-link { display: inline-flex; align-items: center; gap: 7px; font-family: var(--ff-title); font-weight: 600; font-size: 13px; color: color-mix(in srgb, var(--c) 75%, #fff); margin-top: 4px; }
.combo-link svg { width: 15px; height: 15px; transition: transform .2s; }
.combo-card:hover .combo-link svg { transform: translateX(3px); }
@media (max-width: 880px) { .combo-grid { grid-template-columns: 1fr; } }

/* ===== Carrossel de soluções/produtos que combinam ===== */
.combo-carousel { position: relative; }
.combo-track { display: flex; gap: 18px; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; padding: 6px 4px; margin: 0 -4px; scrollbar-width: none; -ms-overflow-style: none; }
.combo-track::-webkit-scrollbar { display: none; }
.combo-track > .combo-card { flex: 0 0 322px; scroll-snap-align: start; }
.combo-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; background: rgba(15,21,36,.94); border: 1px solid var(--line-strong); color: #fff; cursor: pointer; z-index: 4; transition: background .2s, border-color .2s, opacity .2s; box-shadow: 0 12px 28px -10px rgba(0,0,0,.75); }
.combo-nav:hover { background: var(--blue); border-color: var(--blue); }
.combo-nav svg { width: 20px; height: 20px; }
.combo-nav.prev { left: -18px; } .combo-nav.next { right: -18px; }
.combo-nav[disabled] { opacity: 0; pointer-events: none; }
@media (max-width: 880px) {
  .combo-track > .combo-card { flex: 0 0 85%; }
  .combo-nav { display: none; }
}

/* Home · faixa de diferenciais tem 5 cards -> 5 colunas (não herdar o 4 das soluções) */
.diffs .diffs-grid { grid-template-columns: repeat(5, 1fr); gap: 20px; }
@media (max-width: 1024px) { .diffs .diffs-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 620px) { .diffs .diffs-grid { grid-template-columns: 1fr; } }

/* Equilibra a quebra de linha dos títulos (evita palavra órfã) */
h1, h2, .section-title, .hero h1, .lead-title { text-wrap: balance; }
.lead, .section-sub { text-wrap: pretty; }

/* ============================================================
   ARTIGOS / CONTEÚDO (blog técnico)
   ============================================================ */
.article-hero { position: relative; min-height: 440px; display: flex; align-items: flex-end; overflow: hidden; border-bottom: 1px solid var(--line); }
.article-hero-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.article-hero .a-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(6,10,19,.5) 0%, rgba(6,10,19,.82) 65%, var(--bg) 100%); }
.article-hero .container { position: relative; z-index: 1; padding-top: 64px; padding-bottom: 44px; }
.article-hero h1 { font-size: clamp(27px,3.6vw,44px); max-width: 20ch; margin: 12px 0 16px; line-height: 1.12; }
.article-lead { font-size: clamp(15px,1.5vw,18px); color: #c6d2e6; max-width: 64ch; line-height: 1.6; }
.article-meta { display: flex; flex-wrap: wrap; gap: 18px; margin-top: 20px; font-family: var(--ff-title); font-size: 12.5px; color: #8fa3c0; }
.article-meta span { display: inline-flex; align-items: center; gap: 7px; }
.article-meta svg { width: 14px; height: 14px; color: var(--blue-2); }
.article-tag { display: inline-block; font-family: var(--ff-title); font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--blue-hover); background: rgba(94,152,255,.12); border: 1px solid var(--line-strong); border-radius: 999px; padding: 5px 12px; }

.article-layout { display: grid; grid-template-columns: 256px minmax(0,1fr); gap: 54px; align-items: start; padding: 50px 24px 24px; }
.article-toc { position: sticky; top: 92px; }
.article-toc .toc-title { font-family: var(--ff-title); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--blue-2); margin-bottom: 12px; }
.article-toc nav { display: flex; flex-direction: column; border-left: 2px solid var(--line); }
.article-toc nav a { padding: 7px 14px; font-size: 13px; color: var(--text-2); border-left: 2px solid transparent; margin-left: -2px; transition: .15s; line-height: 1.35; }
.article-toc nav a:hover, .article-toc nav a.active { color: #fff; border-left-color: var(--blue-2); }
.toc-cta { margin-top: 24px; background: var(--card-grad); border: 1px solid var(--line-strong); border-radius: 14px; padding: 18px; }
.toc-cta h4 { font-size: 14px; margin-bottom: 6px; }
.toc-cta p { font-size: 12.5px; color: var(--text-2); margin: 0 0 13px; line-height: 1.5; }
.toc-cta .btn { width: 100%; justify-content: center; padding: 10px; font-size: 13px; }

.article-body { max-width: 768px; min-width: 0; }
.article-body > h2 { font-size: clamp(21px,2.3vw,27px); margin: 40px 0 14px; letter-spacing: -.01em; scroll-margin-top: 92px; }
.article-body h3 { font-size: 18px; margin: 26px 0 10px; color: #eaf0fb; }
.article-body p { font-size: 15.5px; line-height: 1.74; color: #c4cee0; margin: 0 0 18px; }
.article-body a { color: var(--blue-hover); text-decoration: underline; text-underline-offset: 2px; }
.article-body ul, .article-body ol { margin: 0 0 18px; padding-left: 22px; color: #c4cee0; font-size: 15.5px; line-height: 1.7; }
.article-body li { margin-bottom: 8px; }
.article-body strong { color: #fff; font-weight: 600; }
.article-body figure { margin: 28px 0; }
.article-body figure img { width: 100%; border-radius: 14px; border: 1px solid var(--line); display: block; }
.article-body figcaption { font-size: 12.5px; color: #8fa3c0; margin-top: 9px; text-align: center; }
.article-body blockquote { margin: 26px 0; padding: 16px 22px; border-left: 3px solid var(--blue-2); background: rgba(58,130,255,.06); border-radius: 0 12px 12px 0; font-size: 16px; color: #dbe4f3; }
.article-body blockquote p { margin: 0; color: #dbe4f3; }

.norma-box { margin: 26px 0; background: linear-gradient(155deg, rgba(94,152,255,.12), rgba(31,111,235,.03)); border: 1px solid var(--line-strong); border-radius: 14px; padding: 18px 20px; }
.norma-box .nb-label { display: inline-flex; align-items: center; gap: 7px; font-family: var(--ff-title); font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--blue-hover); margin-bottom: 8px; }
.norma-box .nb-label svg { width: 14px; height: 14px; }
.norma-box p { margin: 0; font-size: 14px; color: #c4cee0; line-height: 1.6; }

.compare-table { width: 100%; border-collapse: collapse; margin: 26px 0; font-size: 14px; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.compare-table th, .compare-table td { padding: 12px 16px; text-align: left; border-bottom: 1px solid var(--line); vertical-align: top; }
.compare-table thead th { background: var(--bg-2); font-family: var(--ff-title); font-size: 12.5px; color: #fff; }
.compare-table tbody td:first-child { color: #aeb9cc; font-weight: 500; }
.compare-table tbody tr:last-child td { border-bottom: none; }
.compare-table .ok { color: #4ade80; font-weight: 600; }
.compare-table .no { color: #f87171; font-weight: 600; }

.ref-list { margin: 46px 0 0; padding: 24px 26px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 14px; }
.ref-list h3 { font-size: 15px; margin: 0 0 14px; }
.ref-list ol { margin: 0; padding-left: 20px; }
.ref-list li { font-size: 13px; color: #aeb9cc; margin-bottom: 10px; line-height: 1.5; }
.ref-list a { color: var(--blue-hover); word-break: break-word; }

@media (max-width: 920px) {
  .article-layout { grid-template-columns: 1fr; gap: 24px; }
  .article-toc { position: static; }
  .article-toc nav { display: none; }
  .toc-cta { margin-top: 0; }
}

/* posts (hub de conteúdo) com imagem real */
.post { display: block; }
.post .thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.post .body .post-meta { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: #8fa3c0; font-family: var(--ff-title); font-weight: 600; margin-bottom: 12px; }
.post .body .post-meta svg { width: 13px; height: 13px; color: var(--blue-2); }
.post .body .link-arrow { font-weight: 600; }

/* topbar: respiro entre o LED e o prompt + animação controlada via JS */
.topbar .slogan::before { margin-right: 5px; }
.topbar .slogan .typed { width: auto; animation: shCaret .85s step-end infinite; }
.topbar .slogan .typed.code { color: #8fd9b0; }

/* topbar: centralização vertical fina do slogan */
.topbar .container { min-height: 50px; align-items: center; }
.topbar .slogan { line-height: 1; }
.topbar .slogan .prompt { line-height: 1; }
.topbar .slogan .typed { vertical-align: middle; line-height: 1; }
.topbar .tb-right { line-height: 1; }

/* topbar: fonte com mais presença para reduzir o vazio */
.topbar .slogan { font-size: 13.5px; }
.topbar .tb-item { font-size: 13.5px; }
.topbar .tb-item svg { width: 15px; height: 15px; }
.topbar .tb-social svg { width: 16px; height: 16px; }
.topbar .tb-social a { width: 30px; height: 30px; }

/* formulários — honeypot, erro e estado de envio */
.hp-field { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.form-err { display: none; background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.35); color: #fca5a5; border-radius: 12px; padding: 13px 16px; font-size: 13.5px; margin-bottom: 16px; }
button[type="submit"]:disabled { opacity: .65; cursor: progress; }

/* artigo: tags, FAQ e leitura recomendada */
.article-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.article-tags .article-tag { background: rgba(94,152,255,.14); }
.faq { display: grid; gap: 12px; margin: 8px 0 10px; }
.faq-item { background: var(--card-grad); border: 1px solid var(--line); border-radius: 14px; padding: 18px 20px; }
.faq-item h3 { font-size: 16px; margin: 0 0 6px; color: #eaf0fb; }
.faq-item p { font-size: 14.5px; color: #c4cee0; margin: 0; line-height: 1.6; }
.related-reading { margin: 34px 0 0; padding: 22px 24px; background: linear-gradient(155deg, rgba(94,152,255,.1), rgba(31,111,235,.02)); border: 1px solid var(--line-strong); border-radius: 14px; }
.related-reading h3 { font-size: 15px; margin: 0 0 12px; }
.related-reading ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 9px; }
.related-reading li { font-size: 14.5px; }
.related-reading a { color: var(--blue-hover); display: inline-flex; align-items: center; gap: 7px; }
.related-reading a::before { content: "→"; color: var(--blue-2); }
