/* ============================================================
   somado · components.css — botões, cards, nav, footer, etc.
   ============================================================ */

/* ---------- Botões ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  font-weight: var(--fw-bold);
  font-size: var(--fs-base);
  line-height: 1;
  padding: 1rem 1.6rem;
  border-radius: var(--radius-pill);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), background var(--dur) var(--ease);
  text-align: center;
  min-height: 52px;
}
.btn svg { width: 1.25em; height: 1.25em; flex: none; }
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary {
  background: var(--grad-orange);
  color: #fff;
  box-shadow: var(--shadow-orange);
}
.btn--primary:hover { color: #fff; box-shadow: 0 14px 38px hsl(20 90% 50% / 0.38); }

.btn--lg { font-size: var(--fs-md); padding: 1.2rem 2.2rem; min-height: 60px; }

.btn--ghost {
  background: transparent;
  color: var(--navy-900);
  border: 2px solid var(--color-border-strong);
}
.btn--ghost:hover { color: var(--navy-900); border-color: var(--orange-500); background: var(--color-primary-soft); }

.btn--on-navy { background: #fff; color: var(--navy-900); }
.btn--on-navy:hover { color: var(--navy-900); }

.btn--block { display: flex; width: 100%; }

/* ---------- WhatsApp floating button ---------- */
.wa-float {
  position: fixed;
  right: 18px; bottom: 18px;
  z-index: 90;
  width: 58px; height: 58px;
  border-radius: 50%;
  background: var(--color-whatsapp);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 24px hsl(145 60% 30% / 0.4);
  transition: transform var(--dur) var(--ease);
}
.wa-float:hover { transform: scale(1.07); }
.wa-float svg { width: 32px; height: 32px; }

/* ---------- Nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 80;
  background: hsl(0 0% 100% / 0.88);
  backdrop-filter: saturate(160%) blur(10px);
  border-bottom: 1px solid var(--color-border);
}
.nav__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-2); height: 72px; }
.nav__logo img { height: 38px; width: auto; }
.nav__links { display: flex; align-items: center; gap: var(--sp-3); }
.nav__links a { font-weight: var(--fw-medium); font-size: var(--fs-sm); color: var(--navy-800); }
.nav__links a:hover { color: var(--color-primary-strong); }
.nav__cta { margin-left: var(--sp-1); }
.nav__cta .btn { padding: 0.7rem 1.2rem; min-height: 44px; font-size: var(--fs-sm); }
/* o CTA é um <a> dentro de .nav__links, cujo `color` venceria por especificidade
   e deixava o texto escuro no botão laranja — força branco em repouso e hover */
.nav__cta .btn, .nav__cta .btn:hover { color: #fff; font-weight: var(--fw-bold); }
.nav__toggle { display: none; width: 44px; height: 44px; align-items: center; justify-content: center; }
.nav__toggle span, .nav__toggle span::before, .nav__toggle span::after {
  content: ''; display: block; width: 24px; height: 2px; background: var(--navy-900); border-radius: 2px; transition: var(--dur);
}
.nav__toggle span::before { transform: translateY(-7px); }
.nav__toggle span::after  { transform: translateY(5px); }
.nav.is-open .nav__toggle span { background: transparent; }
.nav.is-open .nav__toggle span::before { transform: rotate(45deg); }
.nav.is-open .nav__toggle span::after  { transform: rotate(-45deg) translateY(-2px); }

@media (max-width: 900px) {
  .nav__toggle { display: flex; }
  .nav__links {
    position: absolute; left: 0; right: 0; top: 72px;
    flex-direction: column; align-items: stretch; gap: 0;
    background: #fff; border-bottom: 1px solid var(--color-border);
    padding: var(--sp-2) var(--gutter) var(--sp-3);
    box-shadow: var(--shadow-md);
    transform: translateY(-12px); opacity: 0; pointer-events: none; transition: var(--dur);
  }
  .nav.is-open .nav__links { transform: none; opacity: 1; pointer-events: auto; }
  .nav__links a { padding: 0.9rem 0; border-bottom: 1px solid var(--color-border); font-size: var(--fs-base); }
  .nav__cta { margin: var(--sp-2) 0 0; }
  .nav__cta .btn { width: 100%; }
}

/* ---------- Nav/Footer enxutos (landing bare: só logo + WhatsApp) ---------- */
.nav--bare .nav__cta { margin-left: 0; }
.nav--bare .nav__logo { cursor: default; }
@media (max-width: 900px) {
  .nav--bare .nav__cta { margin: 0; }
  .nav--bare .nav__cta .btn { padding: 0.6rem 1rem; }
}
.footer--bare .footer__bare {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  gap: var(--sp-2); padding-bottom: var(--sp-4);
}
.footer--bare .footer__brandline { max-width: 40ch; color: #9AA6C2; }
.footer--bare .footer__bottom { justify-content: center; text-align: center; }

/* ---------- Cards genéricos ---------- */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--sp-3);
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.card__icon {
  width: 52px; height: 52px; border-radius: var(--radius-md);
  background: var(--color-primary-soft); color: var(--orange-600);
  display: flex; align-items: center; justify-content: center; margin-bottom: var(--sp-2);
}
.card__icon svg { width: 26px; height: 26px; }
.card h3 { margin-bottom: 0.4rem; }
.card p { color: var(--color-text-muted); font-size: var(--fs-sm); }

/* ---------- Card de pacote/plano ---------- */
.plan {
  position: relative;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--sp-4) var(--sp-3) var(--sp-3);
  display: flex; flex-direction: column; gap: var(--sp-2);
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.plan:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.plan--featured {
  border: 2px solid var(--orange-500);
  box-shadow: var(--shadow-orange);
}
.plan__badge {
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  background: var(--grad-orange); color: #fff;
  font-size: var(--fs-xs); font-weight: var(--fw-bold);
  padding: 0.4rem 0.9rem; border-radius: var(--radius-pill); white-space: nowrap;
}
.plan__name { font-size: var(--fs-lg); font-weight: var(--fw-extrabold); color: var(--navy-900); }
.plan__price { font-size: var(--fs-xl); font-weight: var(--fw-extrabold); color: var(--navy-900); }
.plan__price small { display: block; font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--color-text-muted); }
.plan__tag { font-size: var(--fs-sm); color: var(--color-text-muted); }
.plan__features { display: flex; flex-direction: column; gap: 0.6rem; margin-block: var(--sp-1); flex: 1; }
.plan__features li { display: flex; gap: 0.5rem; align-items: flex-start; font-size: var(--fs-sm); }
.plan__features li svg { width: 18px; height: 18px; color: var(--color-success); flex: none; margin-top: 3px; }

/* ---------- Listas de check ---------- */
.checklist li { display: flex; gap: 0.6rem; align-items: flex-start; margin-bottom: 0.7rem; }
.checklist li svg { width: 22px; height: 22px; flex: none; margin-top: 2px; }
.checklist--pos li svg { color: var(--color-success); }
.checklist--neg li svg { color: var(--color-text-muted); }

/* ---------- Timeline de passos ---------- */
.steps { display: grid; gap: var(--sp-3); grid-template-columns: repeat(4, 1fr); }
.step__num {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--grad-orange); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: var(--fw-extrabold); font-size: var(--fs-md); margin-bottom: var(--sp-2);
}
.step h3 { font-size: var(--fs-md); margin-bottom: 0.3rem; }
.step p { color: var(--color-text-muted); font-size: var(--fs-sm); }
@media (max-width: 860px) { .steps { grid-template-columns: 1fr; } }

/* ---------- Accordion (FAQ) ---------- */
.acc { border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; background: #fff; }
.acc + .acc { margin-top: var(--sp-1); }
.acc__btn {
  width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--sp-2);
  padding: 1.15rem 1.3rem; text-align: left; font-weight: var(--fw-semibold); font-size: var(--fs-md); color: var(--navy-900);
}
.acc__btn:hover { color: var(--color-primary-strong); }
.acc__btn svg { width: 22px; height: 22px; flex: none; transition: transform var(--dur) var(--ease); color: var(--orange-500); }
.acc.is-open .acc__btn svg { transform: rotate(45deg); }
.acc__panel { max-height: 0; overflow: hidden; transition: max-height 0.3s var(--ease); }
.acc__panel-inner { padding: 0 1.3rem 1.25rem; color: var(--color-text-muted); font-size: var(--fs-sm); }

/* ---------- Footer ---------- */
.footer { background: var(--navy-900); color: #C5CEE3; padding-block: var(--sp-8) var(--sp-4); }
.footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: var(--sp-4); }
.footer h4 { color: #fff; font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: var(--sp-2); }
.footer__logo { height: 60px; width: auto; margin-bottom: var(--sp-2); }
.footer a:hover { color: var(--orange-400); }
.footer li { margin-bottom: 0.55rem; font-size: var(--fs-sm); }
.footer__brandline { font-size: var(--fs-sm); max-width: 32ch; color: #9AA6C2; }
.footer__bottom {
  margin-top: var(--sp-6); padding-top: var(--sp-3); border-top: 1px solid hsl(220 30% 30% / 0.5);
  display: flex; flex-wrap: wrap; gap: 0.5rem var(--sp-2); justify-content: space-between; align-items: center;
  font-size: var(--fs-xs); color: #8190B0;
}
.footer__bottom a { color: #B6C0DA; }
@media (max-width: 760px) { .footer__grid { grid-template-columns: 1fr; gap: var(--sp-3); } }

/* ---------- LGPD consent banner ---------- */
.consent {
  position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 95;
  background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg); padding: var(--sp-2) var(--sp-3);
  display: none; gap: var(--sp-2); align-items: center; flex-wrap: wrap;
  max-width: 920px; margin-inline: auto;
}
.consent.is-shown { display: flex; }
.consent p { font-size: var(--fs-sm); color: var(--color-text-muted); flex: 1; min-width: 240px; }
.consent__actions { display: flex; gap: 0.6rem; flex-wrap: wrap; }
.consent .btn { padding: 0.65rem 1.1rem; min-height: 42px; font-size: var(--fs-sm); }

/* ---------- CTA de pacotes (sem valores à mostra) ---------- */
.pacotes-cta { text-align: center; max-width: 640px; margin-inline: auto; }
.pacotes-cta .btn { margin-inline: auto; }
.pacotes-cta__note { margin-top: var(--sp-2); font-size: var(--fs-sm); color: var(--color-text-muted); }

/* ---------- Grid utilitário de cards ---------- */
.grid { display: grid; gap: var(--sp-3); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px) { .grid--4 { grid-template-columns: repeat(2, 1fr); } .grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 680px) { .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; } }
