/* ============================================================================
   Tema ESTRUTURAL: SST Evolution (saas-techblue)
   Visual SaaS big-tech (Linear/Vercel/Stripe): hero escuro azul-marinho com
   malha radial, gradiente azul→ciano, acento violeta, painel de conformidade
   ilustrativo e cards translúcidos.
   - Override de tokens (azul + ciano + violeta), escopado em [data-theme-skin].
   - Estilos das seções da home estrutural (.sx-*) — todos via tokens.
   Carregado pelo motor de temas APÓS os CSS canônicos. Nenhum componente novo
   do core é redefinido — apenas tokens e classes próprias prefixadas .sx-*.
   ============================================================================ */

/* ── Tokens (claro) ─────────────────────────────────────────────────────── */
:root[data-theme-skin="saas-techblue"] {
    --primary:#1d4ed8; --primary-dark:#1e40af; --primary-light:#dbeafe;
    --accent:#0ea5e9; --accent-hover:#0284c7;
    --site-primary:#1d4ed8; --site-primary-dark:#1e40af; --site-primary-light:#eff4ff;
    --site-accent:#0ea5e9; --site-accent-hover:#0284c7; --site-accent-light:#e0f2fe;
    --radius:12px; --radius-lg:16px;

    /* Tokens próprios do tema (hex permitido apenas aqui — nas definições) */
    --sx-navy:#0f172a;
    --sx-navy-2:#1e3a5f;
    --sx-blue:#1d4ed8;
    --sx-cyan:#0ea5e9;
    --sx-violet:#7c3aed;
    --sx-ink:#0f172a;
    --sx-muted:#475569;
    --sx-soft:#64748b;
    --sx-card:#ffffff;
    --sx-bg:#f8fafc;
    --sx-border:#e2e8f0;
    --sx-green:#16a34a;
    --sx-amber:#d97706;
    --sx-grad-hero:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f172a 100%);
    --sx-grad-primary:linear-gradient(135deg,#1d4ed8,#0ea5e9);
    --sx-grad-cta:linear-gradient(135deg,#1d4ed8 0%,#7c3aed 100%);
    --sx-grad-1:linear-gradient(135deg,#1d4ed8,#6366f1);
    --sx-grad-2:linear-gradient(135deg,#0ea5e9,#06b6d4);
    --sx-grad-3:linear-gradient(135deg,#7c3aed,#a855f7);
    --sx-grad-4:linear-gradient(135deg,#059669,#10b981);
    --sx-grad-5:linear-gradient(135deg,#d97706,#f59e0b);
    --sx-grad-6:linear-gradient(135deg,#be185d,#ec4899);
}

/* ── Tokens (escuro) ────────────────────────────────────────────────────── */
:root[data-theme="dark"][data-theme-skin="saas-techblue"] {
    --primary:#60a5fa; --primary-dark:#3b82f6; --primary-light:rgba(96,165,250,.15);
    --accent:#38bdf8; --accent-hover:#0ea5e9;
    --site-primary:#60a5fa; --site-primary-dark:#3b82f6; --site-primary-light:rgba(96,165,250,.12);
    --site-accent:#38bdf8; --site-accent-hover:#0ea5e9; --site-accent-light:rgba(56,189,248,.15);

    --sx-ink:#f1f5f9;
    --sx-muted:#94a3b8;
    --sx-soft:#94a3b8;
    --sx-card:#1e293b;
    --sx-bg:#0f172a;
    --sx-border:#1e293b;
    --sx-green:#4ade80;
    --sx-amber:#fb923c;
}

/* ── Chrome compartilhado (topbar / header / footer) — escopado ─────────── */
[data-theme-skin="saas-techblue"] .topbar-strip { background: var(--sx-navy); border-bottom: 1px solid rgba(255,255,255,.06); }
[data-theme-skin="saas-techblue"] .sx-header { border-top: 3px solid transparent; border-image: var(--sx-grad-primary) 1; }
[data-theme-skin="saas-techblue"] .sx-header.scrolled { box-shadow: 0 4px 32px rgba(15,23,42,.12); }

/* CTA do menu (gradiente) */
.sx-nav-cta {
    display: inline-block;
    background: var(--sx-grad-primary);
    color: #fff;
    font-weight: 700;
    font-size: .85rem;
    padding: .55rem 1.1rem;
    border-radius: var(--radius);
    box-shadow: 0 4px 14px rgba(29,78,216,.3);
    transition: var(--transition);
    white-space: nowrap;
}
.sx-nav-cta:hover { opacity: .92; color: #fff; transform: translateY(-1px); }

/* ── Botões em contextos do tema ────────────────────────────────────────── */
/* Primário vira gradiente nas seções do tema */
.sx-hero .ui-btn-primary,
.sx-cta .ui-btn-primary,
.sx-foot-cta .ui-btn-primary,
.sx-how-section .ui-btn-primary {
    background: var(--sx-grad-primary);
    border: none; color: #fff;
    box-shadow: 0 6px 18px rgba(29,78,216,.32);
}
.sx-hero .ui-btn-primary:hover,
.sx-cta .ui-btn-primary:hover,
.sx-foot-cta .ui-btn-primary:hover,
.sx-how-section .ui-btn-primary:hover { opacity: .94; }

/* Secundário sobre fundo escuro = vidro translúcido */
.sx-hero .ui-btn-secondary,
.sx-cta .ui-btn-secondary,
.sx-foot-cta .ui-btn-secondary {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.22);
    color: #fff;
}
.sx-hero .ui-btn-secondary:hover,
.sx-cta .ui-btn-secondary:hover,
.sx-foot-cta .ui-btn-secondary:hover { background: rgba(255,255,255,.16); color: #fff; }

/* Botão claro (faixa de urgência / contraste sobre cor) */
.sx-btn-light { background: #fff; color: var(--sx-blue); border: 1px solid #fff; box-shadow: 0 4px 20px rgba(0,0,0,.18); }
.sx-btn-light:hover { background: #eff4ff; color: var(--sx-blue); }
.sx-urgency .sx-btn-light { color: #b91c1c; }
.sx-urgency .sx-btn-light:hover { background: #fef2f2; color: #991b1b; }

/* ══════════════════════════════════════════════════════════════════════════
   SEÇÕES DA HOME
   ══════════════════════════════════════════════════════════════════════════ */

/* ── Cabeçalho de seção / eyebrow ───────────────────────────────────────── */
.sx-section-head { max-width: 640px; margin: 0 0 3rem; }
.sx-section-head.sx-centered { margin-left: auto; margin-right: auto; text-align: center; }
.sx-section-title { font-size: clamp(1.7rem, 3vw, 2.5rem); font-weight: 800; letter-spacing: -.02em; line-height: 1.15; color: var(--sx-ink); margin: 0 0 .9rem; }
.sx-section-sub { font-size: 1.05rem; color: var(--sx-muted); line-height: 1.7; margin: 0; }
.sx-centered .sx-section-sub { margin-left: auto; margin-right: auto; }
.sx-section-sub.sx-mb { margin-bottom: 1.75rem; }
.sx-tag { display: inline-flex; align-items: center; gap: 6px; background: var(--site-primary-light); color: var(--site-primary); font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 5px 12px; border-radius: 100px; margin-bottom: 1rem; }
.sx-tag-dot { width: 6px; height: 6px; background: var(--site-primary); border-radius: 50%; display: inline-block; }
.sx-tag-dark { background: rgba(29,78,216,.25); color: #93c5fd; border: 1px solid rgba(29,78,216,.4); }
.sx-tag-dot-light { background: #60a5fa; }
.sx-mt { margin-top: 1.5rem; }
.sx-center-cta { text-align: center; margin-top: 2.25rem; }

/* ── HERO ───────────────────────────────────────────────────────────────── */
.sx-hero { position: relative; overflow: hidden; background: var(--sx-grad-hero); color: #fff; padding: 5.5rem 0 4.5rem; }
.sx-hero::before { content: ''; position: absolute; inset: 0; pointer-events: none;
    background: radial-gradient(ellipse 80% 60% at 50% -10%, rgba(29,78,216,.4), transparent),
                radial-gradient(ellipse 50% 50% at 82% 85%, rgba(14,165,233,.16), transparent); }
.sx-hero::after { content: ''; position: absolute; inset: 0; pointer-events: none;
    background-image: radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px); background-size: 32px 32px; }
.sx-hero-inner { position: relative; z-index: 1; max-width: 920px; margin: 0 auto; text-align: center; }
.sx-hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(29,78,216,.3); color: #bfdbfe; border: 1px solid rgba(147,197,253,.25); font-size: .76rem; font-weight: 600; letter-spacing: .04em; padding: 6px 15px; border-radius: 100px; margin-bottom: 1.5rem; }
.sx-hero-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--sx-cyan); box-shadow: 0 0 0 4px rgba(14,165,233,.25); }
.sx-hero-title { font-size: clamp(2.4rem, 5vw, 4rem); font-weight: 900; letter-spacing: -.035em; line-height: 1.06; color: #fff; margin: 0 0 1.25rem; }
.sx-accent { background: linear-gradient(135deg,#60a5fa,#38bdf8); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.sx-hero-sub { font-size: 1.1rem; color: rgba(255,255,255,.72); line-height: 1.7; max-width: 620px; margin: 0 auto 2rem; }
.sx-hero-ctas { display: flex; flex-wrap: wrap; gap: .85rem; justify-content: center; }

/* Social proof */
.sx-hero-proof { display: inline-flex; align-items: center; gap: 12px; margin-top: 2rem; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 100px; padding: 8px 18px 8px 12px; }
.sx-proof-avatars { display: flex; }
.sx-proof-avatar { width: 30px; height: 30px; border-radius: 50%; border: 2px solid var(--sx-navy); display: flex; align-items: center; justify-content: center; font-size: .72rem; font-weight: 800; color: #fff; margin-left: -8px; }
.sx-proof-avatar:first-child { margin-left: 0; }
.sx-av-blue { background: var(--sx-blue); } .sx-av-cyan { background: var(--sx-cyan); } .sx-av-violet { background: var(--sx-violet); } .sx-av-green { background: #10b981; }
.sx-proof-text { font-size: .85rem; color: rgba(255,255,255,.75); }
.sx-proof-text strong { color: #fff; font-weight: 700; }

/* Painel ilustrativo (mockup) */
.sx-mockup { position: relative; z-index: 1; max-width: 880px; margin: 3rem auto 0; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 20px; padding: 1.5rem; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); box-shadow: 0 30px 60px rgba(0,0,0,.35); }
.sx-mockup-bar { display: flex; align-items: center; gap: 8px; margin-bottom: 1.25rem; }
.sx-mockup-dot { width: 10px; height: 10px; border-radius: 50%; }
.sx-dot-red { background: #ef4444; } .sx-dot-yellow { background: #f59e0b; } .sx-dot-green { background: #22c55e; }
.sx-mockup-url { font-size: .76rem; color: rgba(255,255,255,.5); margin-left: 8px; }
.sx-kpi-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 1.25rem; }
.sx-kpi { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); border-radius: 12px; padding: 14px; text-align: left; }
.sx-kpi-l { font-size: .68rem; text-transform: uppercase; letter-spacing: .05em; color: rgba(255,255,255,.5); margin-bottom: 6px; }
.sx-kpi-v { font-size: 1.3rem; font-weight: 800; color: #fff; line-height: 1; }
.sx-kpi-unit { font-size: .8rem; font-weight: 600; color: rgba(255,255,255,.55); margin-left: 2px; }
.sx-kv-green .sx-kpi-v { color: #4ade80; } .sx-kv-blue .sx-kpi-v { color: #60a5fa; } .sx-kv-cyan .sx-kpi-v { color: #38bdf8; } .sx-kv-violet .sx-kpi-v { color: #a78bfa; }
.sx-mockup-prog { display: flex; flex-direction: column; gap: 12px; }
.sx-prog-row { display: flex; align-items: center; gap: 12px; }
.sx-prog-label { flex: 1; font-size: .8rem; color: rgba(255,255,255,.75); text-align: left; }
.sx-prog-bar { width: 120px; height: 6px; border-radius: 4px; background: rgba(255,255,255,.12); overflow: hidden; flex-shrink: 0; }
.sx-prog-fill { height: 100%; border-radius: 4px; }
.sx-pf-green { background: #4ade80; } .sx-pf-cyan { background: #38bdf8; } .sx-pf-blue { background: #60a5fa; } .sx-pf-violet { background: #a78bfa; }
.sx-prog-pct { font-size: .78rem; font-weight: 700; color: #fff; min-width: 38px; text-align: right; }

/* ── FAIXA DE NÚMEROS ───────────────────────────────────────────────────── */
.sx-trust { background: var(--sx-card); border-bottom: 1px solid var(--sx-border); }
.sx-trust-inner { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; padding: 2.25rem 0; }
.sx-trust-stat { text-align: center; }
.sx-trust-num { font-size: 2rem; font-weight: 800; letter-spacing: -.03em; color: var(--site-primary); line-height: 1; }
.sx-trust-label { font-size: .82rem; color: var(--sx-muted); margin-top: 6px; }

/* ── ÁREAS DE ATUAÇÃO ───────────────────────────────────────────────────── */
.sx-areas-section { background: var(--sx-bg); padding: 5rem 0; }
.sx-areas-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.sx-area-card { position: relative; display: flex; align-items: flex-start; gap: 1rem; background: var(--sx-card); border: 1px solid var(--sx-border); border-radius: 16px; padding: 1.5rem; text-decoration: none; transition: transform .2s, box-shadow .2s, border-color .2s; }
.sx-area-card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(15,23,42,.12); border-color: var(--site-primary); }
.sx-area-ico { flex-shrink: 0; width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 1.4rem; color: #fff; box-shadow: 0 4px 12px rgba(15,23,42,.2); }
.sx-ico-1 { background: var(--sx-grad-1); } .sx-ico-2 { background: var(--sx-grad-2); } .sx-ico-3 { background: var(--sx-grad-3); }
.sx-ico-4 { background: var(--sx-grad-4); } .sx-ico-5 { background: var(--sx-grad-5); } .sx-ico-6 { background: var(--sx-grad-6); }
.sx-area-body { flex: 1; min-width: 0; }
.sx-area-name { font-size: 1rem; font-weight: 700; color: var(--sx-ink); margin: 0 0 4px; line-height: 1.3; }
.sx-area-count { font-size: .82rem; color: var(--sx-muted); margin: 0; }

/* Card CTA (largura total) */
.sx-area-cta { grid-column: 1 / -1; background: var(--sx-grad-cta); border-color: transparent; justify-content: center; text-align: center; padding: 2.25rem 1.5rem; }
.sx-area-cta:hover { transform: translateY(-3px); box-shadow: 0 16px 40px rgba(29,78,216,.35); border-color: transparent; }
.sx-area-cta-content { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.sx-area-cta-count { font-size: 2.6rem; font-weight: 900; color: #fff; line-height: 1; letter-spacing: -.04em; }
.sx-area-cta-label { font-size: .76rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; color: rgba(255,255,255,.78); }
.sx-area-cta-desc { font-size: .85rem; color: rgba(255,255,255,.78); line-height: 1.5; margin: 6px 0 14px; max-width: 320px; }
.sx-area-cta-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.sx-area-cta .ui-btn-primary { background: #fff; color: var(--sx-blue); border-color: #fff; }
.sx-area-cta .ui-btn-secondary { background: transparent; border: 1px solid rgba(255,255,255,.6); color: #fff; }

/* ── GESTÃO / PAINEL DE CONFORMIDADE ────────────────────────────────────── */
.sx-sbg-section { background: var(--sx-card); padding: 5rem 0; }
.sx-split { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.sx-score-card { background: var(--sx-grad-primary); border-radius: 20px; padding: 2.25rem; color: #fff; box-shadow: 0 20px 50px rgba(29,78,216,.25); }
.sx-score-head { text-align: center; margin-bottom: 1.75rem; }
.sx-score-label { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: rgba(255,255,255,.7); margin-bottom: 1rem; }
.sx-score-circle { width: 140px; height: 140px; border-radius: 50%; background: rgba(255,255,255,.12); border: 8px solid rgba(255,255,255,.2); box-shadow: 0 0 0 4px rgba(255,255,255,.08); margin: 0 auto; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.sx-score-num { font-size: 2.6rem; font-weight: 800; line-height: 1; }
.sx-score-sub { font-size: .72rem; color: rgba(255,255,255,.7); font-weight: 600; }
.sx-score-badge { display: inline-flex; align-items: center; gap: 6px; background: rgba(74,222,128,.2); border: 1px solid rgba(74,222,128,.4); border-radius: 100px; padding: 4px 14px; margin-top: 1rem; }
.sx-score-badge-dot { width: 6px; height: 6px; border-radius: 50%; background: #4ade80; }
.sx-score-badge-text { font-size: .7rem; font-weight: 700; color: #4ade80; letter-spacing: .04em; }
.sx-score-rows { display: flex; flex-direction: column; gap: 12px; }
.sx-score-row { display: flex; align-items: center; gap: 12px; }
.sx-score-row-label { flex: 1; font-size: .8rem; color: rgba(255,255,255,.78); }
.sx-score-bar { width: 84px; height: 6px; border-radius: 4px; background: rgba(255,255,255,.15); overflow: hidden; flex-shrink: 0; }
.sx-score-bar-fill { height: 100%; border-radius: 4px; }
.sx-bf-green { background: #4ade80; } .sx-bf-orange { background: #fb923c; }
.sx-score-row-pct { font-size: .8rem; font-weight: 700; min-width: 40px; text-align: right; }
.sx-pct-green { color: #4ade80; } .sx-pct-orange { color: #fb923c; }

.sx-pillars { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; }
.sx-pillar { display: flex; gap: .75rem; align-items: flex-start; }
.sx-pillar-ico { font-size: 1.3rem; line-height: 1; flex-shrink: 0; }
.sx-pillar-title { font-size: .95rem; font-weight: 700; color: var(--sx-ink); margin-bottom: 2px; }
.sx-pillar-desc { font-size: .84rem; color: var(--sx-muted); line-height: 1.5; }

/* ── SERVIÇOS ───────────────────────────────────────────────────────────── */
.sx-services-section { background: var(--sx-bg); padding: 5rem 0; }
.sx-services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.sx-service-card { position: relative; overflow: hidden; display: flex; flex-direction: column; gap: .75rem; background: var(--sx-card); border: 1px solid var(--sx-border); border-radius: 16px; padding: 2rem 1.75rem; text-decoration: none; transition: transform .2s, box-shadow .2s, border-color .2s; }
.sx-service-card:hover { transform: translateY(-4px); border-color: var(--site-primary); box-shadow: 0 16px 40px rgba(29,78,216,.14); }
.sx-service-ico { font-size: 2rem; line-height: 1; }
.sx-service-name { font-size: 1.05rem; font-weight: 700; color: var(--sx-ink); line-height: 1.3; margin: 0; }
.sx-service-desc { font-size: .875rem; color: var(--sx-muted); line-height: 1.6; flex: 1; margin: 0; }
.sx-service-more { font-size: .82rem; font-weight: 600; color: var(--site-primary); }

/* ── COMO FUNCIONA (faixa escura) ───────────────────────────────────────── */
.sx-how-section { background: var(--sx-navy); padding: 5rem 0; }
.sx-section-title.sx-on-dark { color: #f8fafc; }
.sx-section-sub.sx-on-dark-sub { color: #94a3b8; }
.sx-how-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.sx-how-card { position: relative; overflow: hidden; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 16px; padding: 2rem; transition: background .2s, border-color .2s; }
.sx-how-card:hover { background: rgba(255,255,255,.07); border-color: rgba(59,130,246,.4); }
.sx-how-num { position: absolute; top: 18px; right: 20px; font-size: 2.6rem; font-weight: 900; line-height: 1; letter-spacing: -.05em; color: #fff; opacity: .08; }
.sx-how-ico { width: 52px; height: 52px; border-radius: 14px; background: rgba(29,78,216,.2); border: 1px solid rgba(29,78,216,.35); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; margin-bottom: 1.25rem; }
.sx-how-step { font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: #60a5fa; margin-bottom: 8px; }
.sx-how-title { font-size: 1.05rem; font-weight: 700; color: #f1f5f9; margin: 0 0 .6rem; }
.sx-how-desc { font-size: .85rem; color: #94a3b8; line-height: 1.7; margin: 0; }
.sx-how-cta { text-align: center; margin-top: 2.75rem; }

/* ── URGÊNCIA NR-1 ──────────────────────────────────────────────────────── */
.sx-urgency { position: relative; overflow: hidden; background: linear-gradient(135deg,#7f1d1d 0%,#dc2626 50%,#b91c1c 100%); padding: 4rem 0; }
.sx-urgency::before { content: ''; position: absolute; inset: 0; pointer-events: none;
    background: radial-gradient(ellipse 60% 80% at 10% 50%, rgba(239,68,68,.25) 0%, transparent 60%),
                radial-gradient(ellipse 40% 60% at 90% 50%, rgba(127,29,29,.4) 0%, transparent 60%); }
.sx-urgency-inner { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; text-align: center; gap: 1rem; max-width: 720px; margin: 0 auto; }
.sx-urgency-deadline { display: inline-flex; align-items: center; gap: 6px; background: rgba(0,0,0,.25); border: 1px solid rgba(255,255,255,.2); color: #fca5a5; font-size: .74rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 5px 14px; border-radius: 999px; }
.sx-urgency-icon { font-size: 2.4rem; line-height: 1; filter: drop-shadow(0 2px 8px rgba(0,0,0,.2)); }
.sx-urgency h2 { font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 800; color: #fff; margin: 0; letter-spacing: -.02em; line-height: 1.2; }
.sx-urgency p { font-size: .96rem; color: rgba(255,255,255,.85); margin: 0; line-height: 1.65; }
.sx-urgency strong { color: #fff; font-weight: 700; }
.sx-urgency .sx-btn-light { margin-top: .5rem; }
[data-theme="dark"] .sx-urgency { background: linear-gradient(135deg,#5b21b6 0%,#1d4ed8 100%); }

/* ── DEPOIMENTOS ────────────────────────────────────────────────────────── */
.sx-test-section { background: var(--sx-bg); padding: 5rem 0; }
.sx-test-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.sx-test-card { background: var(--sx-card); border: 1px solid var(--sx-border); border-radius: 16px; padding: 1.75rem; }
.sx-test-card blockquote { margin: 0 0 1rem; color: var(--sx-muted); font-style: italic; line-height: 1.7; }
.sx-test-card figcaption strong { display: block; color: var(--sx-ink); }
.sx-test-card figcaption span { font-size: .82rem; color: var(--sx-soft); }

/* ── CTA FINAL ──────────────────────────────────────────────────────────── */
.sx-cta { position: relative; overflow: hidden; background: var(--sx-grad-cta); padding: 4.5rem 0; }
.sx-cta::before { content: ''; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(ellipse 60% 80% at 80% 20%, rgba(124,58,237,.4), transparent); }
.sx-cta-inner { position: relative; z-index: 1; text-align: center; max-width: 680px; margin: 0 auto; }
.sx-cta-inner h2 { color: #fff; font-size: clamp(1.6rem, 2.8vw, 2.3rem); font-weight: 800; margin: 0 0 .75rem; letter-spacing: -.02em; }
.sx-cta-inner p { color: rgba(255,255,255,.82); font-size: 1.05rem; margin: 0 0 2rem; line-height: 1.6; }
.sx-cta-actions { justify-content: center; }

/* ── FOOTER (faixa de CTA + topo em gradiente) ──────────────────────────── */
.sx-foot-cta { background: var(--sx-grad-cta); }
.sx-foot-cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 1.25rem; padding: 1.75rem 0; flex-wrap: wrap; }
.sx-foot-cta-text strong { display: block; color: #fff; font-size: 1.2rem; }
.sx-foot-cta-text span { color: rgba(255,255,255,.85); font-size: .92rem; }
.sx-foot-cta-btns { display: flex; gap: .75rem; flex-wrap: wrap; }
.sx-foot-cta .ui-btn-primary { background: #fff; color: var(--sx-blue); border-color: #fff; box-shadow: none; }
.sx-foot-cta .ui-btn-secondary { background: transparent; border: 1px solid rgba(255,255,255,.6); color: #fff; }
[data-theme-skin="saas-techblue"] .sx-footer { border-top: 3px solid transparent; border-image: var(--sx-grad-primary) 1; }

/* ── Dark mode: títulos sobre fundo claro ───────────────────────────────── */
[data-theme="dark"] .sx-section-title,
[data-theme="dark"] .sx-area-name,
[data-theme="dark"] .sx-service-name,
[data-theme="dark"] .sx-pillar-title,
[data-theme="dark"] .sx-test-card figcaption strong { color: var(--sx-ink); }
[data-theme="dark"] .sx-section-title.sx-on-dark { color: #f8fafc; }

/* ── Responsivo ─────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .sx-areas-grid, .sx-services-grid, .sx-test-grid { grid-template-columns: repeat(2, 1fr); }
    .sx-how-grid { grid-template-columns: repeat(2, 1fr); }
    .sx-kpi-row { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
    .sx-split { grid-template-columns: 1fr; gap: 2.5rem; }
    .sx-trust-inner { grid-template-columns: repeat(2, 1fr); gap: 1.75rem; }
}
@media (max-width: 640px) {
    .sx-hero { padding: 3.75rem 0 3rem; }
    .sx-areas-grid, .sx-services-grid, .sx-test-grid, .sx-how-grid, .sx-pillars { grid-template-columns: 1fr; }
    .sx-prog-bar { width: 80px; }
    .sx-foot-cta-inner { justify-content: center; text-align: center; }
}
