/* =============================================================
   Catita Auto Center — page styles
   Built on the Static Sites DS tokens. Only project knobs here are
   the hue (logo blue) + accent (logo orange) + body font (Inter).
   Load order: tokens.css → base.css → components.css → styles.css
   ============================================================= */

:root {
  --hue: 211;          /* logo blue */
  --sat: 88%;
  --c-accent: hsl(26 94% 52%);          /* logo orange */
  --c-accent-strong: hsl(24 92% 46%);
  --ff-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* Raio único do projeto — UM só valor em TODOS os elementos (8px).
     Sobrescreve a escala de raios do DS para padronizar botões, cards,
     chips, ícones e imagens no mesmo arredondamento. */
  --r-xs: 8px; --r-sm: 8px; --r-md: 8px; --r-lg: 8px; --r-full: 8px;
}

body { background: var(--c-bg); font-family: var(--ff-body); color: var(--c-ink); }
h1, h2, h3, h4, h5, h6 { font-family: var(--ff-display); letter-spacing: -0.02em; }
p, .btn, label, input, textarea, select, .nav__link, .footer, .tag, .stat__label { font-family: var(--ff-body); }

/* ---------- Shared layout helpers ---------- */
.section { padding-block: var(--sp-96); }
.section--tight { padding-block: var(--sp-64); }
.full-bleed { width: 100%; }
.stack > * + * { margin-top: var(--sp-24); }
.stack-8 > * + * { margin-top: var(--sp-8); }
.lead { color: var(--c-muted); max-width: 60ch; text-wrap: balance; }
.eyebrow {
  display: inline-flex; align-items: center; gap: var(--sp-8);
  color: var(--c-accent-strong); font-family: var(--ff-body);
  font-size: var(--fs-p-s); font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
}
.eyebrow::before { content: ""; width: 24px; height: 2px; background: var(--c-accent); }
.center { text-align: center; }
.center .lead { margin-inline: auto; }
.center .eyebrow { justify-content: center; }

/* Accent-coloured (orange) button variant on top of the DS button base */
.btn { white-space: nowrap; }
.btn--accent { background: var(--c-accent); color: var(--c-50); }
.btn--accent:hover { background: var(--c-accent-strong); }
.btn .ic { width: 20px; height: 20px; flex: none; }
.btn--lg .ic { width: 24px; height: 24px; }

/* ---------- Image placeholders ---------- */
.ph {
  position: relative; overflow: hidden;
  background:
    repeating-linear-gradient(45deg,
      hsl(var(--hue) 24% 90%) 0 14px,
      hsl(var(--hue) 28% 86%) 14px 28px);
  border-radius: var(--r-lg);
  display: grid; place-items: center;
}
.ph::after {
  content: attr(data-label);
  font-family: var(--ff-body); font-size: var(--fs-p-s);
  color: var(--c-700); background: var(--c-50);
  padding: var(--sp-8) var(--sp-16); border-radius: var(--r-sm);
  box-shadow: var(--shadow);
}
.ph--dark {
  background:
    repeating-linear-gradient(45deg,
      hsl(var(--hue) 18% 13%) 0 14px,
      hsl(var(--hue) 20% 16%) 14px 28px);
}
.ph--hero { aspect-ratio: 4 / 5; }
.ph--wide { aspect-ratio: 16 / 10; }

/* =============================================================
   HEADER + HERO — one contiguous dark region (logo reads white)
   ============================================================= */
.topdark { background: var(--c-950); color: var(--c-100); }

.site-header {
  position: sticky; top: 0; z-index: 30;
  background: hsl(var(--hue) 16% 6% / .82);
  backdrop-filter: saturate(1.4) blur(10px);
  border-bottom: 1px solid hsl(var(--hue) 20% 22% / .6);
}
.nav { display: flex; align-items: center; gap: var(--sp-32); padding-block: var(--sp-16); grid-column: 1 / -1; }
.brand { display: flex; align-items: center; text-decoration: none; }
.brand img { height: 44px; width: 186px; flex: none; }
.nav__links { display: flex; gap: var(--sp-28); margin-left: auto; }
.nav__link { color: var(--c-300); text-decoration: none; font-size: var(--fs-p-s); font-weight: 500; padding: var(--sp-8) 0; transition: color .15s ease; }
.nav__link:hover { color: var(--c-50); }
.nav__cta { display: flex; gap: var(--sp-16); align-items: center; }
/* Hambúrguer discreto: só o ícone, sem a caixa azul */
.nav__toggle { display: none; background: transparent; border-color: transparent; color: var(--c-100); padding: var(--sp-8); aspect-ratio: auto; }
.nav__toggle:hover { background: transparent; color: var(--c-50); }
/* WhatsApp dentro do menu hambúrguer (escondido no desktop) */
.nav__menu-cta { display: none; }
.btn--ghost-light { background: transparent; color: var(--c-100); border-color: hsl(var(--hue) 20% 30%); }
.btn--ghost-light:hover { background: hsl(var(--hue) 20% 14%); color: var(--c-50); }

/* ---------- Hero (vídeo de fundo em loop) ---------- */
.hero-section { position: relative; overflow: hidden; background: var(--c-950); }
.hero__video {
  position: absolute; inset: 0; z-index: 0;
  width: 100%; height: 100%; object-fit: cover;
}
.hero__scrim {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(90deg,
      var(--c-950) 0%,
      hsl(var(--hue) 16% 6% / .78) 42%,
      hsl(var(--hue) 16% 6% / .42) 70%,
      hsl(var(--hue) 16% 6% / .30) 100%),
    linear-gradient(0deg, var(--c-950) 0%, transparent 30%),
    hsl(var(--hue) 16% 6% / .22);
}
.hero-section .workspace { position: relative; z-index: 2; }
.hero { grid-column: 1 / -1; padding-block: var(--sp-96) var(--sp-128); }
.hero__copy { display: flex; flex-direction: column; gap: var(--sp-24); align-items: flex-start; max-width: 640px; }
.hero h1 { color: var(--c-50); }
.hero .lead { color: var(--c-200); }
.hero__actions { display: flex; gap: var(--sp-16); flex-wrap: wrap; }
/* Pares de botões em linha: mesmo tamanho (largura igual) */
.hero__actions .btn, .loc-actions .btn { flex: 1 1 0; }
.chips { display: flex; flex-wrap: wrap; gap: var(--sp-12); margin-top: var(--sp-40); }
.chip {
  display: inline-flex; align-items: center; gap: var(--sp-8); white-space: nowrap;
  font-size: var(--fs-p-s); font-weight: 500; color: var(--c-200);
  background: hsl(var(--hue) 18% 13%); border: 1px solid hsl(var(--hue) 20% 22%);
  padding: var(--sp-8) var(--sp-16); border-radius: var(--r-full);
}
.chip svg { width: 16px; height: 16px; color: var(--c-accent); flex: none; }
.hero__badge {
  display: inline-flex; align-items: center; gap: var(--sp-8);
  background: var(--c-accent); color: var(--c-50);
  font-weight: 700; font-size: var(--fs-p-s);
  padding: var(--sp-12) var(--sp-20); border-radius: var(--r-full);
  box-shadow: var(--shadow); align-self: flex-start;
}
.hero__badge .dot { width: 8px; height: 8px; border-radius: var(--r-full); background: var(--c-50); animation: pulse 1.8s ease-in-out infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: .35; } }
@media (prefers-reduced-motion: reduce) { .hero__badge .dot { animation: none; } }

/* =============================================================
   PRONTA ENTREGA — 3 highlight cards
   ============================================================= */
.cards-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-32); grid-column: 1 / -1; }
.pcard { display: flex; flex-direction: column; gap: var(--sp-16); align-items: flex-start; }
.pcard__icon {
  width: 56px; height: 56px; border-radius: var(--r-md);
  display: grid; place-items: center;
  background: var(--c-100); color: var(--c-primary-strong);
}
.pcard__icon svg { width: 28px; height: 28px; }
.pcard h5 { display: flex; align-items: baseline; gap: var(--sp-8); flex-wrap: wrap; }
.tag {
  font-size: 13px; font-weight: 700; letter-spacing: .04em;
  color: var(--c-accent-strong); background: hsl(26 94% 52% / .12);
  padding: 4px var(--sp-8); border-radius: var(--r-sm); text-transform: uppercase;
}
.pcard p { color: var(--c-muted); }
.pcard__link {
  display: inline-flex; align-items: center; gap: var(--sp-8);
  color: var(--c-primary-strong); font-weight: 700; font-size: var(--fs-p-s);
  text-decoration: none; margin-top: auto;
}
.pcard__link svg { width: 18px; height: 18px; }
.pcard__link:hover { color: var(--c-ink); }

/* =============================================================
   SERVIÇOS — icon grid
   ============================================================= */
.svc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-32); grid-column: 1 / -1; }
.scard { padding: 0; overflow: hidden; display: flex; flex-direction: column; }
.scard .ph { border-radius: 0; }
.scard__img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; display: block; background: var(--c-100); }
.ph--svc { aspect-ratio: 4 / 3; }
.scard__body { padding: var(--sp-24); display: flex; flex-direction: column; gap: var(--sp-8); }
.scard h6 { color: var(--c-ink); }
.scard p { color: var(--c-muted); }

/* Micro-movimento no hover dos cards */
.card { transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: transparent; }
.scard__img { transition: transform .45s ease; }
.scard:hover .scard__img { transform: scale(1.06); }
@media (prefers-reduced-motion: reduce) {
  .card, .scard__img { transition: none; }
  .card:hover { transform: none; }
  .scard:hover .scard__img { transform: none; }
}
.svc-note {
  grid-column: 1 / -1; margin-top: var(--sp-48);
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-24);
  flex-wrap: wrap;
  background: var(--c-surface); border: 1px solid var(--c-border);
  border-radius: var(--r-lg); padding: var(--sp-32) var(--sp-40);
}
.svc-note p { color: var(--c-ink); font-weight: 500; font-size: var(--fs-p-l); }
.svc-note p span { color: var(--c-muted); display: block; font-weight: 400; font-size: var(--fs-p-s); margin-top: var(--sp-4); }

/* =============================================================
   DIFERENCIAIS — 4 flat cards
   ============================================================= */
.cards-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-32); grid-column: 1 / -1; }
.feat { display: flex; flex-direction: column; gap: var(--sp-16); }
.feat__icon {
  width: 52px; height: 52px; border-radius: var(--r-full);
  display: grid; place-items: center;
  background: var(--c-primary); color: var(--c-50);
}
.feat__icon svg { width: 26px; height: 26px; }
.feat p { color: var(--c-muted); }

/* =============================================================
   LOCALIZAÇÃO — split: map placeholder + details
   ============================================================= */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-64); grid-column: 1 / -1; align-items: center; }
/* Mapa incorporado (Google Maps) */
.map { aspect-ratio: 16 / 10; border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--c-border); background: var(--c-100); }
.map iframe { display: block; width: 100%; height: 100%; border: 0; }
.info-list { display: flex; flex-direction: column; gap: var(--sp-24); margin-top: var(--sp-8); }
.info { display: flex; gap: var(--sp-16); align-items: flex-start; }
.info__icon { width: 44px; height: 44px; flex: none; border-radius: var(--r-md); display: grid; place-items: center; background: var(--c-100); color: var(--c-primary-strong); }
.info__icon svg { width: 22px; height: 22px; }
.info b { display: block; font-family: var(--ff-display); font-weight: 600; font-size: var(--fs-p-m); color: var(--c-ink); margin-bottom: var(--sp-4); }
.info span, .info a { color: var(--c-muted); font-size: var(--fs-p-m); text-decoration: none; }
.info a:hover { color: var(--c-primary-strong); }
.loc-actions { display: flex; gap: var(--sp-16); flex-wrap: wrap; margin-top: var(--sp-32); }
/* =============================================================
   CTA FINAL — bloco centralizado, WhatsApp em destaque
   ============================================================= */
.cta {
  grid-column: 1 / -1;
  display: flex; flex-direction: column; align-items: center; text-align: center;
  gap: var(--sp-24);
  background: var(--c-surface); border: 1px solid var(--c-border);
  border-radius: var(--r-lg); padding: var(--sp-96) var(--sp-48);
}
.cta .lead { margin-inline: auto; }
.cta__actions { display: flex; gap: var(--sp-16); flex-wrap: wrap; justify-content: center; margin-top: var(--sp-8); width: 100%; max-width: 560px; }
.cta__actions .btn { flex: 1 1 0; }

/* =============================================================
   FOOTER
   ============================================================= */
.site-footer { background: var(--c-950); color: var(--c-300); padding-block: var(--sp-64); }
.footer { display: grid; grid-template-columns: 1.6fr 1fr 1.4fr; gap: var(--sp-48); grid-column: 1 / -1; }
.footer a { color: var(--c-300); text-decoration: none; }
.footer a:hover { color: var(--c-100); }
.footer__col { display: flex; flex-direction: column; gap: var(--sp-16); font-size: var(--fs-p-s); }
.footer__col b { color: var(--c-100); font-family: var(--ff-display); font-weight: 600; font-size: var(--fs-p-m); margin-bottom: var(--sp-8); }
.footer__brand img { height: 48px; width: 202px; margin-bottom: var(--sp-16); }
.footer__brand p { color: var(--c-400); max-width: 40ch; }
.footer__line { display: flex; align-items: flex-start; gap: var(--sp-8); }
.footer__line svg { width: 18px; height: 18px; flex: none; color: var(--c-primary); margin-top: 2px; }
.footer__bottom {
  grid-column: 1 / -1; display: flex; justify-content: space-between; flex-wrap: wrap;
  gap: var(--sp-16); margin-top: var(--sp-48); padding-top: var(--sp-24);
  border-top: 1px solid hsl(var(--hue) 14% 20%); font-size: var(--fs-p-s); color: var(--c-400);
}

/* =============================================================
   MOBILE
   ============================================================= */
@media (max-width: 1024px) {
  .cards-4 { grid-template-columns: repeat(2, 1fr); }
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  /* Nav colapsa em hamburguer já na faixa tablet (evita estouro horizontal) */
  .nav__links, .nav__cta .btn--ghost-light, .nav__cta .btn--accent { display: none; }
  .nav__toggle { display: inline-flex; margin-left: auto; }
  .nav__links--open {
    display: flex; position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column; gap: 0; background: var(--c-950);
    border-bottom: 1px solid hsl(var(--hue) 20% 22%); padding: var(--sp-16) var(--sp-24);
  }
  .nav__links--open .nav__link { padding: var(--sp-16) 0; border-bottom: 1px solid hsl(var(--hue) 20% 18%); }
  .nav__links--open .nav__menu-cta { display: inline-flex; width: 100%; justify-content: center; margin-top: var(--sp-16); }
}
@media (max-width: 880px) {
  :root {
    --btn-lg-fs: 18px; --btn-lg-px: 24px; --btn-lg-py: 18px;
    --btn-md-fs: 16px; --btn-md-px: 20px; --btn-md-py: 16px;
    --btn-sm-fs: 15px; --btn-sm-px: 20px; --btn-sm-py: 14px;
  }
  .section { padding-block: var(--sp-64); }
  .hero { padding-block: var(--sp-48) var(--sp-64); }
  /* Hero no mobile: scrim translúcido (vertical) — mostra o vídeo, sem 100% preto */
  .hero__scrim { background: linear-gradient(180deg, hsl(var(--hue) 16% 6% / .38) 0%, hsl(var(--hue) 16% 6% / .82) 100%); }
  .cards-3, .cards-4, .svc-grid, .split { grid-template-columns: 1fr; }
  .split { gap: var(--sp-40); }
  .cta { padding: var(--sp-48) var(--sp-24); }
  .svc-note { flex-direction: column; align-items: flex-start; padding: var(--sp-24); }
  .footer { grid-template-columns: 1fr; gap: var(--sp-32); }
}

/* =============================================================
   CELULAR RETRATO (≤767) — botões de ação ocupam a linha toda e o
   rótulo pode quebrar, pra nunca passar da caixa / desrespeitar o padding.
   ============================================================= */
@media (max-width: 767px) {
  .hero__actions .btn,
  .loc-actions .btn,
  .cta__actions .btn { flex: 1 1 100%; white-space: normal; }
}

/* =============================================================
   WHATSAPP — botão flutuante fixo (todas as telas e versões),
   com o ícone oficial do WhatsApp. Verde/branco = marca.
   ============================================================= */
.wa-fab {
  position: fixed; right: var(--sp-24); bottom: var(--sp-24); z-index: 45;
  display: inline-flex; align-items: center; justify-content: center;
  width: 60px; height: 60px;
  background: #25d366; color: #fff;
  border-radius: 99px;            /* exceção: único elemento fora do raio único (8px) da página */
  box-shadow: var(--shadow);
  transition: transform .15s ease, background-color .15s ease;
}
.wa-fab:hover { background: #1ebe57; transform: translateY(-2px); }
.wa-fab svg { width: 34px; height: 34px; }
@media (max-width: 767px) {
  .wa-fab { right: var(--sp-16); bottom: var(--sp-16); width: 56px; height: 56px; }
}
