/* ============================================================================
   SPEEDX — PÁGINA INSTITUCIONAL (consome tokens + componentes)
============================================================================ */

body { overflow-x: hidden; }

.container { max-width: 1120px; margin: 0 auto; padding: 0 var(--sp-5); }

/* ------------------------------- HEADER ---------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: var(--z-topbar);
  background: var(--glass); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border-subtle);
}
.site-header__bar {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-4); padding: var(--sp-3) var(--sp-5);
  max-width: 1120px; margin: 0 auto;
}
.brand { display: flex; align-items: center; gap: var(--sp-2); text-decoration: none; }
.brand__bolt { width: 24px; height: 24px; color: var(--accent); }
.brand__name { font-size: var(--fs-heading-md); font-weight: var(--fw-heavy); letter-spacing: -0.02em; color: var(--text); }
.brand__x { color: var(--primary); }

.site-nav { display: none; align-items: center; gap: var(--sp-6); }
.site-nav a {
  font-size: var(--fs-body-sm); font-weight: var(--fw-medium);
  color: var(--text-secondary); text-decoration: none;
  transition: color var(--t-base) var(--ease);
}
.site-nav a:hover { color: var(--text); }
@media (min-width: 1024px) { .site-nav { display: flex; } }

.site-header__cta { display: flex; gap: var(--sp-2); }

/* -------------------------------- HERO ----------------------------------- */
.hero {
  padding: var(--sp-16) 0 var(--sp-12);
  text-align: center;
  background:
    radial-gradient(900px 420px at 50% -80px, var(--primary-soft), transparent 70%),
    var(--bg);
}
.hero__badge { margin-bottom: var(--sp-5); }
.hero h1 {
  font-size: var(--fs-display); font-weight: var(--fw-heavy);
  line-height: var(--lh-tight); letter-spacing: -0.03em;
  max-width: 760px; margin: 0 auto var(--sp-5);
}
.hero h1 .destaque { color: var(--primary); }
.hero__sub {
  font-size: var(--fs-body-lg); color: var(--text-secondary);
  max-width: 620px; margin: 0 auto var(--sp-8);
}
.hero__acoes { display: flex; flex-wrap: wrap; gap: var(--sp-3); justify-content: center; margin-bottom: var(--sp-4); }
.hero__downloads { display: flex; flex-wrap: wrap; gap: var(--sp-3); justify-content: center; }

/* --------------------------- CARDS DE CONFIANÇA -------------------------- */
.confianca { padding: var(--sp-12) 0; }
.secao-titulo { font-size: var(--fs-heading-xl); font-weight: var(--fw-bold); letter-spacing: -0.02em; text-align: center; margin-bottom: var(--sp-2); }
.secao-sub { text-align: center; color: var(--text-secondary); max-width: 560px; margin: 0 auto var(--sp-10); }

.confianca__grid {
  display: grid; gap: var(--sp-4);
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}
.confianca__item { display: flex; gap: var(--sp-4); align-items: flex-start; padding: var(--sp-5); }
.confianca__icone {
  flex: none; width: 44px; height: 44px; border-radius: var(--r-md);
  background: var(--primary-soft); color: var(--primary);
  display: flex; align-items: center; justify-content: center;
}
.confianca__icone .icon { width: 22px; height: 22px; }
.confianca__titulo { font-size: var(--fs-body); font-weight: var(--fw-bold); margin-bottom: 2px; display: flex; align-items: center; gap: var(--sp-2); }
.confianca__texto { font-size: var(--fs-body-sm); color: var(--text-secondary); }

/* ------------------------------ OS DOIS APPS ------------------------------ */
.apps-secao { padding: var(--sp-12) 0; background: var(--surface); border-block: 1px solid var(--border-subtle); }
.apps-grid { display: grid; gap: var(--sp-6); grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }

.app-card { padding: var(--sp-8); display: flex; flex-direction: column; gap: var(--sp-4); }
.app-card__cabeca { display: flex; align-items: center; gap: var(--sp-4); }
.app-card__icone {
  width: 56px; height: 56px; flex: none; border-radius: var(--r-lg);
  display: flex; align-items: center; justify-content: center;
}
.app-card__icone--verde  { background: var(--accent); color: #05130C; }
.app-card__icone--escuro { background: #101613; color: var(--accent); }
.app-card__icone svg { width: 28px; height: 28px; }
.app-card h3 { font-size: var(--fs-heading-md); font-weight: var(--fw-bold); }
.app-card__tag { font-size: var(--fs-caption); color: var(--text-muted); }

.app-card ul { list-style: none; display: flex; flex-direction: column; gap: var(--sp-2); }
.app-card li { display: flex; gap: var(--sp-2); align-items: flex-start; font-size: var(--fs-body-sm); color: var(--text-secondary); }
.app-card li .icon--sm { color: var(--primary); margin-top: 2px; }

.app-card__botoes { display: flex; flex-wrap: wrap; gap: var(--sp-3); }

.app-card__qr {
  display: flex; align-items: center; gap: var(--sp-4);
  background: var(--surface-sunken); border-radius: var(--r-md); padding: var(--sp-3) var(--sp-4);
}
.app-card__qr img { width: 84px; height: 84px; border-radius: var(--r-sm); background: #fff; padding: 4px; }
.app-card__qr span { font-size: var(--fs-caption); color: var(--text-muted); }

/* --------------------------- MOCKUPS DOS APPS ---------------------------- */
.mockup {
  margin: 0 auto; width: 210px; height: 420px;
  border-radius: 32px; background: var(--text);
  padding: 10px; box-shadow: var(--shadow-floating);
}
.mockup__tela {
  width: 100%; height: 100%; border-radius: 24px; overflow: hidden;
  background: linear-gradient(160deg, #DCE9E2 0%, #C3D8CC 45%, #DCE9E2 100%);
  position: relative;
}
.mockup__pill {
  position: absolute; top: 12px; left: 12px; right: 12px;
  height: 26px; border-radius: var(--r-full);
  background: rgba(255,255,255,.9); box-shadow: var(--shadow-sm);
  display: flex; align-items: center; padding: 0 10px;
  font-size: 10px; font-weight: var(--fw-bold); color: var(--text);
  gap: 4px;
}
.mockup__pill svg { width: 12px; height: 12px; color: var(--accent); }
.mockup__rota {
  position: absolute; inset: 0;
}
.mockup__sheet {
  position: absolute; left: 0; right: 0; bottom: 0;
  background: #fff; border-radius: 18px 18px 0 0;
  padding: 12px; box-shadow: 0 -4px 20px rgba(16,22,19,.15);
  display: flex; flex-direction: column; gap: 8px;
}
.mockup__linha  { height: 10px; border-radius: 6px; background: var(--surface-sunken); }
.mockup__linha--60 { width: 60%; }
.mockup__botao {
  height: 30px; border-radius: 10px; background: var(--primary);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 10px; font-weight: var(--fw-bold);
}

/* ----------------------------- COMO FUNCIONA ----------------------------- */
.como { padding: var(--sp-12) 0; }
.como__grid { display: grid; gap: var(--sp-4); grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); }
.passo { padding: var(--sp-6); text-align: left; }
.passo__num {
  width: 36px; height: 36px; border-radius: var(--r-md);
  background: var(--primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: var(--fw-bold); margin-bottom: var(--sp-4);
}
.passo h3 { font-size: var(--fs-body-lg); font-weight: var(--fw-bold); margin-bottom: var(--sp-1); }
.passo p { font-size: var(--fs-body-sm); color: var(--text-secondary); }

/* ------------------------------ MOTORISTAS ------------------------------- */
.motoristas { padding: var(--sp-12) 0; background: #101613; color: #F1F5F3; }
.motoristas .secao-titulo { color: #fff; }
.motoristas .secao-sub { color: #AEBCB5; }
.motoristas__grid { display: grid; gap: var(--sp-4); grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); margin-bottom: var(--sp-8); }
.motoristas__item {
  padding: var(--sp-5); border-radius: var(--r-lg);
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.09);
}
.motoristas__item .icon { color: var(--accent); margin-bottom: var(--sp-3); }
.motoristas__item h3 { font-size: var(--fs-body-lg); font-weight: var(--fw-bold); margin-bottom: var(--sp-1); }
.motoristas__item p { font-size: var(--fs-body-sm); color: #AEBCB5; }
.motoristas__cta { display: flex; justify-content: center; gap: var(--sp-3); flex-wrap: wrap; }
.motoristas .btn--secondary { background: transparent; color: #fff; border-color: rgba(255,255,255,.3); }
.motoristas .btn--secondary:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.5); }

/* -------------------------------- FOOTER ---------------------------------- */
.site-footer { padding: var(--sp-12) 0 var(--sp-8); background: var(--surface); border-top: 1px solid var(--border-subtle); }
.site-footer__grid {
  display: grid; gap: var(--sp-8);
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  margin-bottom: var(--sp-8);
}
.site-footer h4 { font-size: var(--fs-label); font-weight: var(--fw-semibold); color: var(--text-muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: var(--sp-3); }
.site-footer ul { list-style: none; display: flex; flex-direction: column; gap: var(--sp-2); }
.site-footer a { font-size: var(--fs-body-sm); color: var(--text-secondary); text-decoration: none; }
.site-footer a:hover { color: var(--primary); }

.site-footer__status { display: inline-flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-body-sm); color: var(--text-secondary); }
.site-footer__status .status-pill__dot { background: var(--text-muted); }
.site-footer__status--ok .status-pill__dot { background: var(--success); box-shadow: 0 0 0 3px var(--success-soft); }

.site-footer__base {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: var(--sp-3); padding-top: var(--sp-6);
  border-top: 1px solid var(--border-subtle);
  font-size: var(--fs-caption); color: var(--text-muted);
}

/* ----------------------------- RESPONSIVO -------------------------------- */
@media (max-width: 767px) {
  .hero { padding-top: var(--sp-10); }
  .hero__acoes .btn, .hero__downloads .btn { flex: 1 1 100%; }
  .site-header__cta .btn { min-height: 40px; padding: 0 var(--sp-4); font-size: var(--fs-body-sm); }
}
