/* ==============================
   CodeHub Sistemas — UI Nova (Tech Theme)
   ============================== */

/* ---------- Reset & Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color: #0F172A;
  background: #fff;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul, ol { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4 { margin: 0 0 .6rem 0; line-height: 1.2; }

/* ---------- Paleta (marca) ---------- */
:root{
  /* Base de marca */
  --brand:#0D2B3E;
  --brand-700:#071B28;

  /* Acentos “tech” (ciano/azul) */
  --accent:#0EA5FF;            /* ciano moderno (principal) */
  --accent-2:#2563EB;          /* azul profundo para blend */
  --accent-light:#4FC4FF;      /* ciano claro elegante */
  --accent-soft:#AEEBFF;       /* muito claro, para detalhes */

  /* Superfícies e textos */
  --beige:#E6E0D4;
  --bg-muted:#F2F6FB;          /* levemente mais definido que F5F7FA */
  --border:#CBD5E1;            /* borda mais visível (era E2E8F0) */
  --text:#0F172A;
  --muted:#475569;

  /* Tokens visuais */
  --radius:14px;
  --shadow:0 16px 40px rgba(5, 31, 51, .16);
  --shadow-soft:0 10px 26px rgba(5, 31, 51, .10);

  /* Foco/estados */
  --focus:#2DD4BF;             /* turquesa visível no foco */
  --ok:#22c55e;
  --warn:#ef4444;

  /* Gradientes prontos */
  --grad-accent: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  --grad-surface: linear-gradient(180deg, #FFFFFF 0%, #F9FBFF 100%);
}

/* Dark mode opcional */
@media (prefers-color-scheme: dark) {
  :root{
    --bg-muted:#0b1621;
    --border:#1f2937;
    --text:#E6EDF3;
    --muted:#B4C1CD;
    --brand:#103049;
    --brand-700:#0B2637;
    --accent:#37B7F7;
    --accent-2:#3B82F6;
    --accent-light:#9EE6FF;
    --accent-soft:#CBE9FF;
  }
  body{ background:#0b121a; }
}

/* ---------- Helpers ---------- */
.container { width: min(1160px, 92%); margin-inline: auto; }
.muted { color: var(--muted); }
.no-scroll { overflow: hidden; }

/* Estados de foco consistentes */
:where(a, button, .btn, input, select, textarea) :focus { outline: none; }
:where(a, button, .btn, input, select, textarea):focus-visible{
  outline: 3px solid color-mix(in srgb, var(--focus) 80%, transparent);
  outline-offset: 2px;
  border-radius: 12px;
}

/* Reduzir animações para quem prefere menos movimento */
@media (prefers-reduced-motion: reduce) {
  *{ animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

/* ---------- Botões ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.95rem 1.25rem;
  border-radius:12px; font-weight:800; letter-spacing:.2px;
  color:#fff; background:linear-gradient(135deg,var(--brand) 0%, var(--brand-700) 100%);
  border:1px solid #0b1c29; box-shadow:var(--shadow);
  transition:transform .15s ease, filter .2s ease, box-shadow .2s ease;
}
.btn:hover{ transform:translateY(-1px); filter:brightness(1.05); }
.btn:active{ transform:translateY(0); filter:brightness(.98); }

.btn--ghost{
  color:var(--brand);
  background:transparent;
  border:1px solid var(--brand);
  box-shadow:none;
}
.btn--ghost:hover{ background:rgba(13,43,62,.06); }

/* Botão primário – Tech gradient + leve glow */
.btn--primary{
  background: var(--grad-accent);
  border:1px solid color-mix(in srgb, var(--accent) 70%, transparent);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--accent) 25%, transparent);
  color:#fff; font-weight:800;
}
.btn--primary:hover{
  filter:none; transform: translateY(-2px);
  box-shadow: 0 18px 36px color-mix(in srgb, var(--accent) 30%, transparent);
}
.btn--nav{ padding:.7rem 1rem; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(13,43,62,.12);
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.site-header.is-compact{ transform:translateY(-4px); background:rgba(255,255,255,.94); box-shadow: 0 10px 28px rgba(0,0,0,.06); }

.nav-wrap{
  display:grid; grid-template-columns:auto 1fr auto;
  align-items:center; gap:1rem; padding:1rem 0;
}
.brand{ display:inline-flex; align-items:center; gap:.85rem; }
.brand img{ width:72px; height:72px; border-radius:14px; }
.brand-text{ display:inline-flex; gap:.45rem; align-items:baseline; }
.brand-name{ font-weight:900; letter-spacing:.6px; font-size:1.65rem; color:var(--brand); }
.brand-sub{ font-weight:900; letter-spacing:.6px; font-size:1.15rem; color:var(--accent); }

.nav{ display:flex; align-items:center; gap:1.2rem; justify-content:flex-end; }
.nav a{
  padding:.6rem .85rem; border-radius:10px; color:var(--text); font-weight:800; letter-spacing:.2px;
}
.nav a:hover{ background:rgba(13,43,62,.06); }
.nav a.is-active{ color:var(--accent); background:rgba(18,163,224,.12); }
.nav .btn{ margin-left:.6rem; }

/* Toggle (mobile) */
.nav-toggle{
  appearance:none; background:transparent; border:0; padding:.5rem;
  display:none; cursor:pointer;
}
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--text); margin:5px 0; border-radius:2px; }

/* Mobile menu aberto */
.nav.is-open{
  position:fixed; inset:72px 0 0 0; /* abaixo do header */
  background:rgba(255,255,255,.98);
  display:flex; flex-direction:column; gap:8px; padding:16px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
}

/* ---------- Hero ---------- */
.hero{
  text-align:center; padding:4rem 0 2rem 0;
  /* Superfície técnica sutil (grid + glow radial) – sem animação */
  background:
    radial-gradient(80% 50% at 50% -20%, color-mix(in srgb, var(--accent) 10%, transparent) 0%, transparent 70%),
    repeating-linear-gradient(90deg, color-mix(in srgb, var(--accent) 6%, transparent) 0 1px, transparent 1px 54px),
    repeating-linear-gradient(0deg,  color-mix(in srgb, var(--accent) 6%, transparent) 0 1px, transparent 1px 54px);
  background-attachment: scroll;
}
.hero h1{ font-size:2.6rem; font-weight:900; color:var(--brand); margin-bottom:1rem; }
.hero .highlight{ color:var(--accent); }
.hero p.lead{ font-size:1.2rem; max-width:720px; margin:0 auto 1.4rem auto; color:var(--muted); }
.hero .slogan{ font-weight:900; font-size:1.1rem; color:var(--accent); margin-bottom:1.8rem; }
.hero-cta{ display:flex; justify-content:center; gap:1rem; flex-wrap:wrap; }

/* ---------- Seções ---------- */
.section{ padding:2rem 0; }
.section--alt{ background:var(--bg-muted); padding:2rem 0; }
.section h2{
  font-size:1.8rem; font-weight:900; color:var(--brand); margin-bottom:1rem;
  display:flex; align-items:center; gap:.6rem;
}
.section h2 .icon{ width:28px; height:28px; }
.section-desc{ font-size:1.1rem; color:var(--muted); margin-bottom:1.4rem; }

/* ---------- Cards ---------- */
.cards{ display:flex; flex-direction:column; gap:1.6rem; }

.card{
  background: var(--grad-surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  padding:1.6rem;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow);
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border));
}
.card h3{ font-size:1.3rem; font-weight:900; color:var(--brand); margin-bottom:.8rem; }
.card p{ color:var(--muted); margin-bottom:1rem; }
.card .btn{ margin-top:.6rem; }

/* ---------- Formulários ---------- */
.form{ max-width:700px; margin:0 auto; display:grid; gap:1.2rem; }
.form-group{ display:flex; flex-direction:column; }
.form-group label{ font-weight:600; margin-bottom:.4rem; color:var(--text); }
.form-group input, .form-group select, .form-group textarea{
  padding:.8rem 1rem; border:1px solid #ddd; border-radius:8px; font-size:1rem;
  transition:border-color .2s, box-shadow .2s;
  background:#fff; color:var(--text);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 30%, transparent);
  outline:none;
}
.form-actions{ text-align:center; }
.btn.btn--primary{
  background: var(--grad-accent);
  color:#fff; font-weight:800; padding:.9rem 2rem; border-radius:10px;
  transition:background .2s, transform .2s, box-shadow .2s;
  border:1px solid color-mix(in srgb, var(--accent) 70%, transparent);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--accent) 25%, transparent);
}
.btn.btn--primary:hover{ transform:translateY(-2px); box-shadow: 0 18px 36px color-mix(in srgb, var(--accent) 30%, transparent); }
.form-feedback{ margin-top:1rem; font-weight:600; text-align:center; }
.form-feedback.success{ color:var(--ok); }
.form-feedback.error{ color:var(--warn); }

/* ---------- Footer ---------- */
.site-footer{
  background:var(--brand-700); color:#E8EEF5; padding:2rem 0; text-align:center;
}
.site-footer p{ margin:0; font-size:.9rem; color:#d6deea; }
.site-footer a{ color:var(--accent-soft); font-weight:700; }
.site-footer a:hover{ text-decoration:underline; }

/* Footer Grid */
.footer-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px,1fr));
  gap:2rem; padding:2rem 0; text-align:left;
}
.footer-grid h4{ margin-bottom:.8rem; font-size:1.1rem; color:#ffffff; }
.footer-grid .list li{ margin-bottom:.4rem; }
.footer-grid .list a{ color:#DCE3EE; transition:color .2s ease; }
.footer-grid .list a:hover{ color:var(--accent-soft); }

/* Marca inversa no footer */
.brand--inverse .brand-name{ color:#DCE3EE; }
.brand--inverse .brand-sub{ color:#ffffff; }
.brand--inverse p{ margin-top:.8rem; color:#DCE3EE; font-size:.9rem; }

/* Footer Copy + link Topo */
.footer-copy{
  border-top:1px solid rgba(255,255,255,.15);
  padding:1rem 0; text-align:center; font-size:.85rem; color:#DCE3EE;

  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.footer-copy small{ color:#DCE3EE; }
.to-top{ color:#bfdbfe; text-decoration:none; font-weight:700; }
.to-top:hover{ text-decoration:underline; }

/* ---------- FAB WhatsApp ---------- */
.fab-wpp{
  position:fixed; right:16px; bottom:16px;
  width:56px; height:56px; border-radius:50%;
  display:grid; place-items:center;
  background:#22c55e; color:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.25);
  z-index:1000;
  transition:transform .15s ease, filter .2s ease;
}
.fab-wpp:hover{ transform:translateY(-1px); filter:brightness(1.05); }

/* ---------- Responsividade ---------- */
@media (min-width: 768px){
  .hero h1{ font-size:3rem; }
  .section{ padding:3rem 0; }
  .section--alt{ padding:3rem 0; }

  .form{ grid-template-columns:1fr 1fr; }
  .form-group:nth-child(5),
  .form-group:nth-child(6),
  .form-actions,
  .form-feedback{ grid-column:span 2; }
}

/* Header responsivo */
@media (max-width: 920px){
  .nav-toggle{ display:block; }
  .nav{ display:none; }
  .nav.is-open{ display:flex; }
  .nav-wrap{ grid-template-columns:auto 1fr auto; }
  .brand img{ width:56px; height:56px; }
  .brand-name{ font-size:1.45rem; }
  .brand-sub{ font-size:1rem; }
}

/* ---------- Breadcrumb ---------- */
.breadcrumb {
  background: transparent;
  padding: .5rem 0 0 0;
  margin: 0 0 1rem 0;
  font-size: .92rem;
  color: var(--muted);
}
.breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
}
.breadcrumb a {
  color: var(--brand);
  font-weight: 600;
}
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb .sep { opacity: .5; margin: 0 .15rem; }
.breadcrumb [aria-current="page"] { color: var(--text); font-weight: 700; }

/* ==============================
   HEADER "VIVO" + MOBILE DRAWER
   ============================== */

/* Linha fina colorida no topo */
.header--alive .header-accent{
  display:block;
  height:3px;
  background: linear-gradient(90deg, var(--accent) 0%, color-mix(in srgb, var(--accent) 50%, var(--brand)) 60%, var(--brand) 100%);
}

/* Wrapper compacto */
.header--alive .nav-wrap.nav--alive{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:1rem;
  padding:.65rem 0;
}

/* Marca */
.header--alive .brand img{ width:84px; height:84px; border-radius:14px; }
.header--alive .brand-name{ font-size:1.85rem; letter-spacing:.6px; }
.header--alive .brand-sub{ font-size:1.05rem; }

/* Bordas e sombra */
.site-header{
  background:rgba(255,255,255,.96);
  backdrop-filter: blur(8px);
  border-bottom:1px solid rgba(13,43,62,.18);
  transition: background .2s ease, box-shadow .2s ease, transform .2s ease;
}
.site-header.is-compact{
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(13,43,62,.08);
}

/* Menu desktop */
.nav{
  display:flex; align-items:center; justify-content:flex-end; gap:1.2rem;
}
.nav a{
  padding:.6rem .9rem; border-radius:10px; font-weight:800; color: var(--text); letter-spacing:.2px;
}
.nav a:hover{ background: rgba(13,43,62,.06); }
.nav a.is-active{ background: rgba(18,163,224,.12); color: var(--brand); }
.nav .nav-cta{ padding:.6rem 1rem; }

/* Mobile drawer */
.nav-toggle{ appearance:none; background:transparent; border:0; padding:.5rem; display:none; cursor:pointer; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--text); margin:5px 0; border-radius:2px; }

@media (max-width: 960px){
  .nav-toggle{ display:block; }
  .nav{
    display:none; position: fixed; top: 0; right: 0; bottom: 0;
    width: min(82vw, 340px);
    background: #ffffff;
    padding: 88px 16px 16px;
    box-shadow: -12px 0 28px rgba(0,0,0,.16);
    border-left:1px solid var(--border);
    flex-direction: column; gap:.4rem; overflow:auto;
    transform: translateX(100%); transition: transform .25s ease; z-index: 999;
  }
  .nav.is-open{ display:flex; transform: translateX(0); }
  .nav a{ display:block; width:100%; font-size:1.05rem; }
  .nav .nav-cta{ width:100%; text-align:center; margin-top:.3rem; }
  .header--alive .nav-wrap.nav--alive{ padding:.5rem 0; }
  .brand-logo{ width:68px; height:68px; }
  .header--alive .brand-name{ font-size:1.55rem; }
}

/* ===== Dark Mode (prefers-color-scheme) ===== */
@media (prefers-color-scheme: dark){
  :root{
    --text:#E6EDF3;
    --muted:#B4C1CD;
    --brand:#1F3A52;
    --brand-700:#172C3F;
    --accent:#37B7F7;
    --accent-2:#3B82F6;
    --accent-light:#9EE6FF;
    --bg-muted:#0F1720;
    --border:#213245;
  }
  body{ background:#0C1218; color:var(--text); }
  .site-header{ background: rgba(13,22,30,.88); border-bottom-color: rgba(55,183,247,.18); }
  .site-header.is-compact{ box-shadow: 0 6px 22px rgba(0,0,0,.35); }
  .header--alive .header-accent{
    background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 50%, var(--brand)) 70%, var(--brand));
  }
  .nav a{ color: var(--text); }
  .nav a:hover{ background: rgba(255,255,255,.06); }
  .nav a.is-active{ background: rgba(55,183,247,.14); color: var(--accent); }
  @media (max-width:960px){
    .nav{ background:#101821; border-left-color:#203042; box-shadow: -12px 0 28px rgba(0,0,0,.45); }
  }
  .brand-name{ color: var(--text); }
  .brand-sub{ color: var(--accent); }
}

/* ===== Preferências de movimento ===== */
@media (prefers-reduced-motion: reduce){
  .nav, .site-header{ transition: none !important; }
}

/* ===== Card com mídia lateral ===== */
.card--with-media .card-grid{
  display: grid;
  grid-template-columns: 1.35fr .95fr; /* texto | imagem */
  gap: 1.2rem;
  align-items: center;
}
.card--with-media .card-col--media{ display: grid; place-items: center; }
.card--with-media .card-media{
  width: 100%;
  max-width: 440px;
  border-radius: 12px;
  box-shadow: var(--shadow-soft);
}
@media (max-width: 960px){
  .card--with-media .card-grid{ grid-template-columns: 1fr; }
  .card--with-media .card-col--media{ order: -1; }
  .card--with-media .card-media{ max-width: 360px; }
}

/* Oculta ícones decorativos em <img.icon> caso existam */
.section h2 > img.icon,
.card h3 > img.icon { display: none !important; }

/*************************************
 * Modo Escuro – Ajustes de Legibilidade (extra)
 *************************************/
@media (prefers-color-scheme: dark){
  :root{
    --text:  #EAF0F6;
    --muted: #B8C4D0;
    --hint:  #94A3B8;
    --brand:     #2A4F6B;
    --brand-700: #1E3D55;
    --accent:    #4FC4FF;
    --bg-muted:  #0F1720;
    --border:    #263747;
  }
  body{ background:#0B1218; color:var(--text); }

  .site-header{ background: rgba(13,22,30,.92); border-bottom-color: rgba(79,196,255,.22); }
  .site-header.is-compact{ box-shadow: 0 6px 20px rgba(0,0,0,.45); }
  .brand-name{ color: var(--text); }
  .brand-sub { color: var(--accent); }

  .nav a{ color: var(--text); }
  .nav a:hover{ background: rgba(255,255,255,.06); }
  .nav a.is-active{ color: var(--accent); background: rgba(79,196,255,.16); }

  @media (max-width: 960px){
    .nav{ background:#0E1821; border-left-color:#213243; box-shadow:-12px 0 28px rgba(0,0,0,.5); }
  }

  h1, h2{ color: #F1F6FA; }
  h3, h4{ color: #E5EDF4; }
  p, li { color: var(--text); }
  .muted, .section-desc { color: var(--muted); }

  a { color: var(--accent); }
  a:hover { text-decoration: underline; }

  .breadcrumb { color: var(--muted); }
  .breadcrumb a { color: #CBE9FF; }
  .breadcrumb [aria-current="page"] { color: var(--text); }

  .section--alt{ background: #0E1821; }
  .card{
    background:#0F1B25;
    border-color: var(--border);
    box-shadow: 0 10px 26px rgba(0,0,0,.35);
  }
  .card:hover{ box-shadow: 0 14px 36px rgba(0,0,0,.45); }
  .card h3{ color:#EAF0F6; }
  .card p, .card li{ color:#DDE7F0; }

  .tag{
    display:inline-block; padding:.25rem .5rem; border-radius:8px;
    background: rgba(79,196,255,.13);
    color:#CBE9FF; border: 1px solid rgba(79,196,255,.28);
    font-weight:700;
  }

  .btn{ box-shadow: 0 12px 28px rgba(0,0,0,.35); }
  .btn--primary{
    background: linear-gradient(135deg,#39B6FF 0%, #2B8CC2 100%);
    border-color: #2B8CC2;
    color:#0A131A;
  }
  .btn--primary:hover{ filter: brightness(1.08); }
  .btn--ghost{ color: #D7EAFE; border-color:#3B6E8F; }
  .btn--ghost:hover{ background: rgba(59,110,143,.25); }

  .site-footer{ background:#0A131A; color:#DCE3EE; }
  .footer-grid h4{ color:#F1F6FA; }
  .footer-grid .list a{ color:#CBE9FF; }
  .footer-grid .list a:hover{ color:#7FDBFF; }
  .footer-copy{ border-top-color: rgba(255,255,255,.15); color:#C7D4E0; }
}

/************************************************************
 * DARK MODE – CONTRASTE ALTO (texto SEMPRE claro no site)
 * Cole no FINAL do style.css para sobrescrever tudo no dark
 ************************************************************/
@media (prefers-color-scheme: dark) {
  :root{
    /* Texto e hierarquia – sempre claros */
    --text:  #F8FAFC;   /* quase branco */
    --muted: #E2E8F0;   /* texto secundário claro */
    --hint:  #C7D2FE;   /* detalhes/labels */

    /* Marca e acento – tech com bom contraste */
    --brand:     #163043;   /* base azul-profundo */
    --brand-700: #0C1F2C;   /* fundo principal escuro */
    --accent:    #4FC4FF;   /* ciano claro legível */
    --accent-2:  #60A5FA;   /* azul claro de apoio */
    --accent-light:#AEEBFF; /* detalhes muito claros */

    /* Superfícies e bordas */
    --bg-muted:  #0A141B;   /* seções alternadas */
    --border:    #1E293B;   /* borda visível (sem sumir) */

    /* Sombreamento coerente com fundo escuro */
    --shadow:      0 16px 40px rgba(0,0,0,.50);
    --shadow-soft: 0 10px 26px rgba(0,0,0,.38);

    /* Gradientes */
    --grad-accent:  linear-gradient(135deg,#4FC4FF 0%, #3B82F6 100%);
    --grad-surface: linear-gradient(180deg, #0F1B25 0%, #0C1620 100%);
  }

  /* Plano geral */
  body{ background:#081018; color:var(--text); }

  /* Header fixo claro sobre fundo escuro */
  .site-header{
    background: rgba(10, 18, 26, .90);
    border-bottom-color: rgba(79,196,255,.25);
    backdrop-filter: blur(10px);
  }
  .site-header.is-compact{ box-shadow: 0 10px 28px rgba(0,0,0,.55); }

  /* Navegação */
  .nav a{ color: var(--text); }
  .nav a:hover{ background: rgba(255,255,255,.06); }
  .nav a.is-active{
    color: var(--accent);
    background: color-mix(in srgb, var(--accent) 18%, transparent);
  }

  /* HERO – fundo técnico sutil e textos claros */
  .hero{
    background:
      radial-gradient(80% 50% at 50% -20%, color-mix(in srgb, var(--accent) 14%, transparent) 0%, transparent 70%),
      repeating-linear-gradient(90deg, color-mix(in srgb, var(--accent) 8%, transparent) 0 1px, transparent 1px 54px),
      repeating-linear-gradient(0deg,  color-mix(in srgb, var(--accent) 8%, transparent) 0 1px, transparent 1px 54px);
  }
  .hero h1,
  .hero__title { color:#F1F6FA; }
  .hero .slogan { color: var(--accent); }
  .hero .lead  { color: var(--muted); }
  .typewriter  { color: var(--accent); }

  /* Seções */
  .section--alt{ background: var(--bg-muted); }
  .section h2{ color: #F1F6FA; }
  .section-desc{ color: var(--muted); }

  /* Cards – fundo escuro real, borda clara e sombra */
  .card{
    background: var(--grad-surface);
    border-color: var(--border);
    box-shadow: var(--shadow-soft);
  }
  .card:hover{ box-shadow: var(--shadow); }
  .card h3{ color:#F1F6FA; }
  .card p, .card li{ color:#E6EEF5; }
  .card .list li::before { color: var(--accent-2); }

  /* Botões – alto contraste */
  .btn{
    color:#0B131A;
    box-shadow: 0 12px 28px rgba(0,0,0,.55);
  }
  .btn--primary{
    background: var(--grad-accent);
    border-color: color-mix(in srgb, var(--accent) 70%, transparent);
    color: #061018; /* texto escuro no primário claro p/ contraste */
    text-shadow: 0 1px 0 rgba(255,255,255,.35);
  }
  .btn--primary:hover{
    box-shadow: 0 18px 36px color-mix(in srgb, var(--accent) 35%, transparent);
  }
  .btn--ghost{
    color: #E8F2FA;
    border-color: color-mix(in srgb, #E8F2FA 60%, transparent);
  }
  .btn--ghost:hover{
    background: rgba(255,255,255,.06);
  }

  /* Breadcrumb e links */
  .breadcrumb{ color: var(--muted); }
  .breadcrumb a{ color: var(--accent-light); }
  .breadcrumb [aria-current="page"]{ color: var(--text); }
  a { color: var(--accent-light); }
  a:hover { text-decoration: underline; }

  /* Inputs/Form – texto claro e foco visível */
  .form-group input,
  .form-group select,
  .form-group textarea{
    background: #0E1821;
    color: #F8FAFC;
    border-color: #203244;
  }
  .form-group input:focus,
  .form-group select:focus,
  .form-group textarea:focus{
    border-color: var(--accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 35%, transparent);
  }

  /* Footer */
  .site-footer{ background:#071B28; color:#EAF0F6; }
  .footer-grid h4{ color:#F8FAFC; }
  .footer-grid .list a{ color:#AEEBFF; }
  .footer-grid .list a:hover{ color:#CFF4FF; }
  .footer-copy{ border-top-color: rgba(255,255,255,.15); color:#D5E3EF; }

  /* Seta grande – cor clara e legível */
  .cta-attention { color: #AEEBFF; }
  .cta-attention__svg { stroke: #AEEBFF; }

  /* WhatsApp FAB – mantém identidade e contraste */
  .fab-wpp{ box-shadow: 0 10px 28px rgba(0,0,0,.55); }

  /* Navegação mobile no dark */
  @media (max-width:960px){
    .nav{
      background:#0A141B;
      border-left-color:#1C2A36;
      box-shadow: -12px 0 28px rgba(0,0,0,.55);
    }
  }
}

/****************************************************
 * AJUSTES TECH PARA TODAS AS PÁGINAS INTERNAS
 * (solucoes.php, contato.php, setores.php,
 *  o-que-fazemos.php, quem-somos.php)
 ****************************************************/

/* ========= Fundo técnico leve igual o HERO ========== */

.page-hero,
.page-header,
.internal-hero {
  background:
    radial-gradient(80% 50% at 50% -20%, color-mix(in srgb, var(--accent) 10%, transparent) 0%, transparent 70%),
    repeating-linear-gradient(90deg, color-mix(in srgb, var(--accent) 6%, transparent) 0 1px, transparent 1px 54px),
    repeating-linear-gradient(0deg,  color-mix(in srgb, var(--accent) 6%, transparent) 0 1px, transparent 1px 54px);
  padding: 3.2rem 0 1.5rem 0;
  text-align: center;
  margin-bottom: 2.4rem;
}

/* ========= TÍTULO PRINCIPAL DAS INTERNAS ========== */

.internal-title,
.page-title,
.section-title {
  font-size: clamp(26px, 4vw, 38px);
  font-weight: 900;
  color: var(--brand);
  margin-bottom: 0.8rem;
}

.internal-subtitle,
.page-subtitle {
  font-size: 1.2rem;
  color: var(--muted);
  max-width: 720px;
  margin-inline: auto;
  margin-bottom: 1.8rem;
}

/* ========= PARÁGRAFOS DAS INTERNAS ========== */

.internal-text,
.page-text,
.page-content p {
  font-size: 1.05rem;
  color: var(--muted);
  line-height: 1.55;
  margin-bottom: 1.25rem;
}

/* ========= CARDS INTERNOS (mesmo estilo Tech da Home) ========== */

.internal-card,
.page-card,
.content-card {
  background: var(--grad-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.6rem;
  box-shadow: var(--shadow-soft);
  margin-bottom: 1.4rem;
  transition: transform .2s ease, box-shadow .2s ease;
}

.internal-card:hover,
.page-card:hover,
.content-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border));
}

.internal-card h2,
.internal-card h3,
.page-card h2,
.page-card h3 {
  color: var(--brand);
  font-size: 1.45rem;
  font-weight: 900;
}

/* ========= LISTAS INTERNAS (quem-somos, setores, o que fazemos) ========== */

.internal-list li,
.page-list li {
  margin-bottom: .6rem;
  padding-left: 1.2rem;
  color: var(--muted);
  font-size: 1.02rem;
  position: relative;
}

.internal-list li::before,
.page-list li::before {
  content: "›";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent);
  font-size: 1.2rem;
}

/* ========= BREADCRUMB TECH ========== */

.breadcrumb {
  margin-bottom: 1.6rem;
  color: var(--muted);
  text-align: left;
}

.breadcrumb a {
  color: var(--accent);
  font-weight: 700;
}

.breadcrumb a:hover {
  color: var(--accent-light);
}

.breadcrumb .sep {
  opacity: .6;
}

/* ========= DARK MODE CORRIGIDO PARA INTERNAS ========== */

@media (prefers-color-scheme: dark) {

  .internal-title,
  .section-title,
  .page-title {
    color: #F8FAFC !important;
  }

  .internal-subtitle,
  .page-subtitle {
    color: #DDE7F0 !important;
  }

  .internal-text,
  .page-text,
  .page-content p {
    color: #E6EEF5 !important;
  }

  .internal-card,
  .page-card,
  .content-card {
    background: var(--grad-surface);
    border-color: var(--border);
    box-shadow: var(--shadow-soft);
  }

  .internal-card h2,
  .internal-card h3,
  .page-card h2,
  .page-card h3 {
    color: #F1F6FA !important;
  }

  .internal-list li,
  .page-list li {
    color: #DCE7F5 !important;
  }

  .internal-list li::before,
  .page-list li::before {
    color: var(--accent-light) !important;
  }
}

/* Forçar tema (opcional) */
html.force-dark body{ background:#0B1218; color:#EAF0F6; }
html.force-dark .site-header{ background: rgba(13,22,30,.92); border-bottom-color: rgba(79,196,255,.22); }
html.force-dark .nav a{ color:#EAF0F6; }
html.force-dark .nav a:hover{ background: rgba(255,255,255,.06); }
html.force-dark .nav a.is-active{ color:#4FC4FF; background: rgba(79,196,255,.16); }
html.force-dark .section--alt{ background:#0E1821; }
html.force-dark .card{ background:#0F1B25; border-color:#263747; box-shadow:0 10px 26px rgba(0,0,0,.35); }
html.force-dark .card h3{ color:#EAF0F6; }
html.force-dark .card p, html.force-dark .card li{ color:#DDE7F0; }
html.force-dark .tag{ background: rgba(79,196,255,.13); color:#CBE9FF; border:1px solid rgba(79,196,255,.28); }
html.force-dark .btn--primary{ background: linear-gradient(135deg,#39B6FF 0%, #2B8CC2 100%); border-color:#2B8CC2; color:#0A131A; }
html.force-dark .btn--ghost{ color:#D7EAFE; border-color:#3B6E8F; }
html.force-dark .btn--ghost:hover{ background: rgba(59,110,143,.25); }
html.force-dark .site-footer{ background:#0A131A; color:#DCE3EE; }
html.force-dark .footer-grid h4{ color:#F1F6FA; }
html.force-dark .footer-grid .list a{ color:#CBE9FF; }

html.force-light body{ background:#fff; color:#0F172A; }

/* Campos de formulário */
.form-group input,
.form-group select,
.form-group textarea { color: #0F172A; }
.form-group input,
.form-group select,
.form-group textarea { color: #0F172A; } /* mantém legível no claro */

/* Container: logo à esquerda, login à direita */
.nav-wrap { display: flex; align-items: center; justify-content: space-between; }

/* Botão de login */
.nav-login {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .6rem .9rem;
  border-radius: 8px;
  color: var(--text);
  font-weight: 700;
  transition: background .2s ease, color .2s ease;
  margin-left: auto;
  min-width: 44px;
}
.nav-login:hover { background: rgba(13,43,62,.06); color: var(--accent); }
.nav-login svg { flex-shrink: 0; display: inline-block; }

@media (max-width: 768px) and (orientation: portrait) {
  .nav-login { margin-right: -20px; }
  .nav-login-text { display: none; }
  .nav-login svg { display: inline-block; }
}

.label-feature {
  display: inline-block;
  padding: .4rem .8rem;
  border-radius: 4px;
  font-weight: 600;
  text-transform: uppercase;
  background-color: transparent;
  transition: background-color .2s, color .2s, border-color .2s;
}

/* Tags */
.tag {
  display: inline-block;
  padding: .4rem .8rem;
  margin: .2rem;
  border-radius: 4px;
  font-weight: 600;
  text-transform: uppercase;
  font-size: .85rem;
  background-color: transparent;
  transition: background-color .2s, color .2s, border-color .2s;
}

/* Lista nos cards (se usar) */
.card .list { margin: 0.8rem 0 0 0; padding-left: 1.2rem; list-style: none; }
.card .list li {
  margin-bottom: 0.5rem;
  font-size: 0.98rem;
  line-height: 1.5;
  color: var(--text);
  opacity: 0.95; /* leve suavização */
}
.card .list li::before {
  content: "✔"; position: absolute; left: 0; color: #0073e6; font-size: 0.9rem;
}

/* === Typewriter (Home) === */
.hero { padding: 64px 16px 40px; text-align: center; }
.hero__title {
  font-size: clamp(26px, 4vw, 40px);
  font-weight: 800;
  line-height: 1.2;
  color: #0f172a;
  margin: 0 0 12px 0;
}
.typewriter { color: var(--accent); white-space: nowrap; }
.cursor {
  display: inline-block; width: 2px; height: 1em; background: currentColor;
  margin-left: 2px; transform: translateY(2px);
  animation: blink .95s step-end infinite;
}
@keyframes blink { 50% { opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .cursor { animation: none; } }

/* =======================
   Scroll-reveal (genérico)
   ======================= */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .65s cubic-bezier(.22,.61,.36,1), transform .65s cubic-bezier(.22,.61,.36,1); will-change: opacity, transform; }
.reveal.is-visible { opacity: 1; transform: none; }
.reveal--up { transform: translateY(28px); }
.reveal--up-sm { transform: translateY(14px); }
.reveal--left { transform: translateX(-26px); }
.reveal--right { transform: translateX(26px); }
.reveal.delay-1 { transition-delay: .1s; }
.reveal.delay-2 { transition-delay: .2s; }
.reveal.delay-3 { transition-delay: .3s; }
.reveal.delay-4 { transition-delay: .4s; }
@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.is-visible { transition: none !important; opacity: 1 !important; transform: none !important; }
}

/* === Ajustes do typewriter no mobile (evita overflow) === */
@media (max-width: 480px) {
  .hero__title { font-size: clamp(20px, 6.2vw, 28px); }
  .typewriter { white-space: normal; word-break: break-word; }
  .typewriter-wrap { display: inline; }
  .cursor { display: none; }
}

/* === Estabilização do typewriter (evita deslocamento do layout) === */
.typewriter-wrap {
  display: inline-block;
  min-height: var(--tw-minh, auto);
  min-width:  var(--tw-minw, auto);
  vertical-align: baseline;
}
.hero__title, #hero-title { line-height: 1.2; }
.cursor { line-height: 1; height: 1em; vertical-align: -0.1em; }
@media (min-width: 481px) { .typewriter { white-space: nowrap; } }

/* ================================
   CTA principal: pulso + seta
   ================================ */
.btn.btn--primary.cta--pulse {
  position: relative; overflow: hidden; display: inline-flex; align-items: center; gap: .55rem; font-weight: 800;
}
.btn.btn--primary .cta-arrow {
  transform: translateX(0); transition: transform .26s ease, opacity .26s ease; opacity: .92;
}
.btn.btn--primary:hover .cta-arrow, .btn.btn--primary:focus-visible .cta-arrow {
  transform: translateX(3px); opacity: 1;
}
.btn.btn--primary.cta--pulse::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.18) 20%, transparent 40%);
  transform: translateX(-120%); transition: transform .6s ease; pointer-events: none;
}
.btn.btn--primary.cta--pulse:hover::after, .btn.btn--primary.cta--pulse:focus-visible::after { transform: translateX(120%); }

@keyframes pulse-soft {
  0%   { transform: translateZ(0) scale(1);    box-shadow: 0 6px 16px color-mix(in srgb, var(--accent) 26%, transparent); }
  50%  { transform: translateZ(0) scale(1.015); box-shadow: 0 10px 28px color-mix(in srgb, var(--accent) 30%, transparent); }
  100% { transform: translateZ(0) scale(1);    box-shadow: 0 6px 16px color-mix(in srgb, var(--accent) 26%, transparent); }
}
.btn.btn--primary.cta--pulse { animation: pulse-soft 1.8s ease-in-out 8s infinite; will-change: transform, box-shadow; }
.btn.btn--primary:active { transform: translateY(1px) scale(.995); }
.btn.btn--primary:focus-visible { outline: 3px solid color-mix(in srgb, var(--accent) 60%, transparent); outline-offset: 2px; }
@media (prefers-reduced-motion: reduce) {
  .btn.btn--primary.cta--pulse { animation: none !important; }
  .btn.btn--primary .cta-arrow { transition: none !important; }
  .btn.btn--primary.cta--pulse::after { transition: none !important; }
}

/* ================================
   SETA GRANDE — AZUL CLARO + MOBILE VERTICAL (↓)
   ================================ */
:root { --cta-arrow-color: #7FDBFF; } /* pode trocar: #AEEBFF, #9EE6FF, #4FC4FF */

.hero-cta {
  position: relative; display: inline-flex; align-items: center; justify-content: center; gap: 1.2rem; flex-wrap: wrap;
}
.cta-attention {
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--cta-arrow-color);
  filter: drop-shadow(0 4px 10px rgba(0,0,0,.25));
  margin-right: .4rem;
}
.cta-attention__svg {
  width: 84px; height: 84px; stroke: var(--cta-arrow-color);
  transform-origin: center; --base-rot: 0deg;
  animation: cta-openclose-strong 1.1s ease-in-out infinite, cta-wiggle-strong 1.4s ease-in-out infinite alternate;
}
@media (max-width: 520px) {
  .hero-cta { gap: 1rem; }
  .hero-cta .cta-attention { order: -1; width: 100%; justify-content: center; margin: 0 0 .5rem 0; }
  .hero-cta .cta-attention__svg { --base-rot: 90deg; width: 74px; height: 74px; }
}
@keyframes cta-openclose-strong {
  0%   { transform: rotate(var(--base-rot)) scale(0.70); }
  50%  { transform: rotate(var(--base-rot)) scale(1.22); }
  100% { transform: rotate(var(--base-rot)) scale(0.70); }
}
@keyframes cta-wiggle-strong {
  0%   { transform: rotate(var(--base-rot)) translateX(0); }
  50%  { transform: rotate(var(--base-rot)) translateX(14px); }
  100% { transform: rotate(var(--base-rot)) translateX(0); }
}
@media (prefers-reduced-motion: reduce) {
  .cta-attention__svg { animation: none !important; transform: rotate(var(--base-rot)) !important; }
}

/* =======================
   Ícones SVG animados nos cards
   ======================= */
.card h3.with-icon { display: flex; align-items: center; gap: .55rem; }
.iconic { display: inline-grid; place-items: center; width: 26px; height: 26px; color: var(--accent); flex-shrink: 0; }
.iconic svg { width: 100%; height: 100%; display: block; }

.iconic--gear svg { animation: gear-spin 6s linear infinite; }
@keyframes gear-spin { to { transform: rotate(360deg); } }

.iconic--chart svg path { transform-origin: center bottom; animation: chart-pop 2.8s ease-in-out infinite; }
@keyframes chart-pop { 0%,100% { transform: scaleY(1); opacity: .95; } 50% { transform: scaleY(1.08); opacity: 1; } }

.iconic--link svg path { animation: link-pulse 2.2s ease-in-out infinite; }
@keyframes link-pulse { 0%,100% { stroke-width: 2; } 50% { stroke-width: 2.6; } }

.iconic--target svg circle:nth-child(2) { transform-origin: center; animation: target-ping 2.6s ease-in-out infinite; }
@keyframes target-ping { 0% { transform: scale(1); opacity: 1; } 70% { transform: scale(1.3); opacity: 0.25; } 100% { transform: scale(1); opacity: 1; } }

.iconic--shield svg path:last-child { stroke: currentColor; animation: shield-check 2.2s ease-in-out infinite; }
@keyframes shield-check { 0%,100% { stroke-dasharray: 0 60; } 50% { stroke-dasharray: 60 0; } }

.iconic--ship svg { animation: ship-bob 3.4s ease-in-out infinite; }
@keyframes ship-bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-2px); } }

.iconic--headset svg { animation: headset-breath 3s ease-in-out infinite; }
@keyframes headset-breath { 0%,100% { transform: scale(1); opacity: .95; } 50% { transform: scale(1.05); opacity: 1; } }

.iconic--globe svg { animation: globe-tilt 4.5s ease-in-out infinite; }
@keyframes globe-tilt { 0%,100% { transform: rotate(0deg); } 50% { transform: rotate(-6deg); } }

.card:hover .iconic svg { filter: drop-shadow(0 2px 6px rgba(0,0,0,.08)); }

@media (prefers-reduced-motion: reduce) {
  .iconic svg, .iconic svg * { animation: none !important; }
}

/* ================================
   Alinhamento da seta no CTA do rodapé (ações finais)
   ================================ */
.section#porque-codehub .actions { line-height: 0; }
.section#porque-codehub .actions .cta-attention,
.section#porque-codehub .actions .btn { display: inline-flex; vertical-align: middle; line-height: 1; }
.section#porque-codehub .actions .cta-attention { align-items: center; justify-content: center; margin: 0 12px 0 0; transform: translateY(0); }
.section#porque-codehub .actions .btn.btn--primary { position: relative; top: 0; }
.section#porque-codehub .actions .cta-attention__svg { --base-rot: 0deg; }
@media (max-width: 520px) {
  .section#porque-codehub .actions { line-height: 1; }
  .section#porque-codehub .actions .cta-attention,
  .section#porque-codehub .actions .btn { display: block; margin-left: auto; margin-right: auto; }
  .section#porque-codehub .actions .cta-attention { margin-bottom: 8px; }
  .section#porque-codehub .actions .cta-attention__svg { --base-rot: 90deg; }
}

/* ===== Quem somos – Mobile: garantir legibilidade em "Como trabalhamos" e "Nossos valores" ===== */
@media (max-width: 600px) {
  /* Ajuste amplo para os dois blocos (troque .quem-somos/.section--quem-somos se tiver outra classe raiz) */
  .quem-somos .como-trabalhamos,
  .quem-somos .nossos-valores,
  .section--quem-somos .como-trabalhamos,
  .section--quem-somos .nossos-valores {
    color: #0F172A !important;
  }

  .quem-somos .como-trabalhamos p,
  .quem-somos .nossos-valores p,
  .section--quem-somos .como-trabalhamos p,
  .section--quem-somos .nossos-valores p {
    color: #0F172A !important;
    font-size: 1.05rem;
    line-height: 1.65;
  }

  .quem-somos .como-trabalhamos h3,
  .quem-somos .nossos-valores h3,
  .section--quem-somos .como-trabalhamos h3,
  .section--quem-somos .nossos-valores h3 {
    color: #0D2B3E !important;
    font-weight: 900;
  }
}

/* Dark mode no mobile — texto sempre CLARO */
@media (prefers-color-scheme: dark) and (max-width: 600px) {
  .quem-somos .como-trabalhamos,
  .quem-somos .nossos-valores,
  .section--quem-somos .como-trabalhamos,
  .section--quem-somos .nossos-valores { color: #F8FAFC !important; }

  .quem-somos .como-trabalhamos p,
  .quem-somos .nossos-valores p,
  .section--quem-somos .como-trabalhamos p,
  .section--quem-somos .nossos-valores p { color: #E6EEF5 !important; }

  .quem-somos .como-trabalhamos h3,
  .quem-somos .nossos-valores h3,
  .section--quem-somos .como-trabalhamos h3,
  .section--quem-somos .nossos-valores h3 { color: #F1F6FA !important; }
}

/* ===== Formulário: contraste e legibilidade ===== */

.contato-form label,
.page-contact label,
form label {
  color: var(--text);
  font-weight: 700;
}

.contato-form input,
.contato-form select,
.contato-form textarea,
.page-contact input,
.page-contact select,
.page-contact textarea,
form input,
form select,
form textarea {
  background: #FFFFFF;
  color: #0F172A;
  border: 1px solid #94A3B8;          /* mais visível */
  border-radius: 10px;
  padding: .85rem 1rem;
  font-size: 1rem;
  transition: border-color .2s, box-shadow .2s, background-color .2s, color .2s;
}

/* Placeholder visível no claro */
.contato-form ::placeholder,
.page-contact ::placeholder,
form ::placeholder {
  color: #64748B; /* cinza-azulado legível */
  opacity: 1;
}

/* Foco forte (coerente com o tema tech) */
.contato-form input:focus,
.contato-form select:focus,
.contato-form textarea:focus,
.page-contact input:focus,
.page-contact select:focus,
.page-contact textarea:focus,
form input:focus,
form select:focus,
form textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 30%, transparent);
  outline: none;
}

/* Dark mode: campos escuros, texto claro, placeholder claro */
@media (prefers-color-scheme: dark) {
  .contato-form label,
  .page-contact label,
  form label {
    color: #F8FAFC !important;
  }

  .contato-form input,
  .contato-form select,
  .contato-form textarea,
  .page-contact input,
  .page-contact select,
  .page-contact textarea,
  form input,
  form select,
  form textarea {
    background: #0E1821 !important;
    color: #F8FAFC !important;
    border-color: #203244 !important;
  }

  .contato-form ::placeholder,
  .page-contact ::placeholder,
  form ::placeholder {
    color: #C7D2FE !important; /* bem claro */
    opacity: 1;
  }

  .contato-form input:focus,
  .contato-form select:focus,
  .contato-form textarea:focus,
  .page-contact input:focus,
  .page-contact select:focus,
  .page-contact textarea:focus,
  form input:focus,
  form select:focus,
  form textarea:focus {
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 40%, transparent) !important;
  }
}

/* ===== Listas com ✔ conferido (setores & o-que-fazemos) ===== */

/* Texto da lista mais legível */
.setores .list li,
.o-que-fazemos .list li,
.page-list--checked li,
.list.list--checked li {
  color: var(--muted);
  font-size: 1.02rem;
  line-height: 1.5;
}

/* Marcador ✔ maior e em ciano/azul claro */
.setores .list li::before,
.o-que-fazemos .list li::before,
.page-list--checked li::before,
.list.list--checked li::before {
  content: "✔";
  position: absolute;
  left: 0;
  top: .05rem;
  font-weight: 900;
  color: var(--accent);
  font-size: 1.05rem; /* aumente para 1.2rem se quiser mais destaque */
}

/* Se a lista NÃO tiver position relativo, garantir recuo adequado */
.setores .list,
.o-que-fazemos .list,
.page-list--checked,
.list.list--checked {
  position: relative;
  padding-left: 1.2rem;
}

/* Dark mode: reforça o contraste do marcador e do texto */
@media (prefers-color-scheme: dark) {
  .setores .list li,
  .o-que-fazemos .list li,
  .page-list--checked li,
  .list.list--checked li {
    color: #E6EEF5 !important;
  }
  .setores .list li::before,
  .o-que-fazemos .list li::before,
  .page-list--checked li::before,
  .list.list--checked li::before {
    color: var(--accent-light) !important;
  }
}

/* (Opcional) Estilo badge para check – mais “tech” */
.list-badge li {
  padding-left: 1.75rem;
}
.list-badge li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .15rem;
  width: 1rem;
  height: 1rem;
  border-radius: 8px;
  background: var(--grad-accent);
  box-shadow: 0 4px 10px color-mix(in srgb, var(--accent) 30%, transparent);
}
.list-badge li::after {
  content: "✓";
  position: absolute;
  left: .17rem;
  top: .02rem;
  font-size: .9rem;
  color: #061018; /* contraste sobre o badge claro */
  font-weight: 900;
}
@media (prefers-color-scheme: dark) {
  .list-badge li::after { color: #061018; } /* mantém contraste */
}

/* Títulos das páginas internas (soluções, setores, o que fazemos) */
.solucoes h1, .solucoes h2,
.setores h1, .setores h2,
.o-que-fazemos h1, .o-que-fazemos h2,
.quem-somos h1, .quem-somos h2,
.contato h1, .contato h2 {
  color: var(--brand);
  font-weight: 900;
}
@media (prefers-color-scheme: dark) {
  .solucoes h1, .solucoes h2,
  .setores h1, .setores h2,
  .o-que-fazemos h1, .o-que-fazemos h2,
  .quem-somos h1, .quem-somos h2,
  .contato h1, .contato h2 {
    color: #F1F6FA !important;
  }
}

/* Header fixo no topo */
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
  background-color: transparent; /* cor inicial */
}

/* Quando rolar a página, adicionar uma classe via JS */
header.scrolled {
  background-color: #ffffff; /* fundo branco */
  box-shadow: 0 2px 6px rgba(0,0,0,0.1); /* leve sombra */
}

/* ================================
   Rodapé (CTA final) — Centralizar seta no MOBILE
   ================================ */
@media (max-width: 520px) {
  /* O bloco de ações vira flex column para garantir centro perfeito */
  .section#porque-codehub .actions{
    display: flex !important;
    flex-direction: column;
    align-items: center;     /* centro horizontal */
    justify-content: center; /* centro vertical da pilha */
    gap: 8px;                /* espaço entre seta e botão */
    text-align: center;      /* redundância segura */
  }

  /* A seta ocupa apenas o conteúdo e zera margens conflitantes */
  .section#porque-codehub .actions .cta-attention{
    display: inline-flex !important;
    width: auto !important;
    margin: 0 !important;                /* remove margens antigas */
    align-items: center;
    justify-content: center;
  }

  /* O SVG fica exatamente no centro; mantém orientação ↓ já definida */
  .section#porque-codehub .actions .cta-attention__svg{
    --base-rot: 90deg;       /* seta para BAIXO no mobile */
    margin: 0 auto;          /* centraliza o próprio SVG */
    transform-origin: center;
  }
}
/* ---------- Utilitários ---------- */
.hidden{ display:none !important; }
.text-center{ text-align:center !important; }
.text-right{ text-align:right !important; }
.mt-0{ margin-top:0 !important; }
.mb-0{ margin-bottom:0 !important; }
.mt-1{ margin-top:.25rem !important; }
.mt-2{ margin-top:.5rem !important; }
.mt-3{ margin-top:1rem !important; }
.mb-1{ margin-bottom:.25rem !important; }
.mb-2{ margin-bottom:.5rem !important; }
.mb-3{ margin-bottom:1rem !important; }

/* ==============================
   CORREÇÃO FINAL LISTA SOLUÇÕES
   ============================== */

/* padrão (modo claro) */
.solucoes .card .list li {
  color: #0F172A; /* preto elegante */
}

/* modo escuro */
@media (prefers-color-scheme: dark) {
  .solucoes .card .list li {
    color: #E6EEF5; /* branco suave */
  }
}

/* ==============================
   FIX ÍCONES LISTA (✔ alinhado)
   ============================== */

.solucoes .card .list {
  padding-left: 0; /* remove bagunça padrão */
}

.solucoes .card .list li {
  position: relative;
  padding-left: 1.6rem; /* espaço pro ícone */
  margin-bottom: 0.5rem;
}

/* Ícone ✔ */
.solucoes .card .list li::before {
  content: "✔";
  position: absolute;
  left: 0;
  top: 0.15rem; /* ajusta alinhamento vertical */
  font-size: 0.95rem;
  font-weight: bold;
  color: var(--accent);
}

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.brand-logo {
  height: 42px;
  width: auto;
}

.brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}