/* ════════════════════════════════════════════════════════════════
   MOVE BRASIL — Tema gov.br (independente)
   Paleta e tipografia inspiradas no Padrão Digital de Governo.
   Mobile-first. v1.0.0
   ════════════════════════════════════════════════════════════════ */

:root {
  --gov-blue:        #1351B4;
  --gov-blue-dark:   #0C326F;
  --gov-blue-night:  #071D41;
  --gov-blue-light:  #C5D4EB;
  --gov-blue-bg:     #E8EEF7;
  --gov-yellow:      #FFCD07;
  --gov-green:       #168821;
  --gov-green-dark:  #117417;
  --gov-red:         #E52207;
  --gov-gray-90:     #1B1B1B;
  --gov-gray-80:     #333333;
  --gov-gray-60:     #555555;
  --gov-gray-40:     #888888;
  --gov-gray-20:     #CCCCCC;
  --gov-gray-10:     #E6E6E6;
  --gov-gray-05:     #F2F2F2;
  --gov-white:       #FFFFFF;

  --gov-radius:      8px;
  --gov-radius-lg:   16px;
  --gov-shadow:      0 2px 8px rgba(0,0,0,.08);
  --gov-shadow-lg:   0 8px 28px rgba(7,29,65,.18);
  --gov-maxw:        1100px;

  --font-head: "Rawline", "Inter", system-ui, -apple-system, sans-serif;
  --font-body: "Inter", system-ui, -apple-system, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--font-body);
  color: var(--gov-gray-90); background: var(--gov-white);
  line-height: 1.55; font-size: 16px; -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4 { font-family: var(--font-head); line-height: 1.2; margin: 0 0 .5em; }
p { margin: 0 0 1em; }
a { color: var(--gov-blue); }
img { max-width: 100%; display: block; }
.gov-container { width: 100%; max-width: var(--gov-maxw); margin: 0 auto; padding: 0 16px; }

/* ── Barra topo gov.br ───────────────────────────────────────── */
.gov-topbar {
  background: var(--gov-blue-night); color: #fff;
  font-size: 13px; padding: 6px 0;
}
.gov-topbar .gov-container { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.gov-topbar__brand { display: flex; align-items: center; gap: 8px; font-weight: 700; letter-spacing: .5px; }
.gov-topbar__brand b { color: var(--gov-yellow); }
.gov-topbar__tag { opacity: .85; font-size: 12px; }

/* ── Header ──────────────────────────────────────────────────── */
.gov-header {
  background: #fff; border-bottom: 4px solid var(--gov-yellow);
  position: sticky; top: 0; z-index: 50; box-shadow: var(--gov-shadow);
}
.gov-header .gov-container { display: flex; align-items: center; justify-content: space-between; padding-top: 12px; padding-bottom: 12px; gap: 12px; }
.gov-logo { display: flex; align-items: center; gap: 10px; }
.gov-logo__mark {
  width: 40px; height: 40px; border-radius: var(--gov-radius);
  background: var(--gov-blue); color: #fff; display: grid; place-items: center;
  font-weight: 800; font-family: var(--font-head); font-size: 20px;
}
.gov-logo__txt { font-family: var(--font-head); font-weight: 700; font-size: 18px; color: var(--gov-blue-night); line-height: 1.1; }
.gov-logo__txt span { display: block; font-size: 12px; font-weight: 500; color: var(--gov-gray-60); }
.gov-header__nav { display: none; gap: 18px; }
.gov-header__nav a { color: var(--gov-gray-80); text-decoration: none; font-size: 14px; font-weight: 500; }
.gov-header__nav a:hover { color: var(--gov-blue); }
@media (min-width: 880px) { .gov-header__nav { display: flex; } }

/* ── Botões ──────────────────────────────────────────────────── */
.gov-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-body); font-weight: 600; font-size: 16px;
  padding: 14px 26px; border-radius: 100px; border: 2px solid transparent;
  cursor: pointer; text-decoration: none; transition: all .18s ease; line-height: 1;
}
.gov-btn--primary { background: var(--gov-blue); color: #fff; }
.gov-btn--primary:hover { background: var(--gov-blue-dark); transform: translateY(-1px); }
.gov-btn--yellow { background: var(--gov-yellow); color: var(--gov-blue-night); }
.gov-btn--yellow:hover { filter: brightness(.96); transform: translateY(-1px); }
.gov-btn--whats { background: var(--gov-green); color: #fff; }
.gov-btn--whats:hover { background: var(--gov-green-dark); transform: translateY(-1px); }
.gov-btn--ghost { background: transparent; color: var(--gov-blue); border-color: var(--gov-blue); }
.gov-btn--ghost:hover { background: var(--gov-blue-bg); }
.gov-btn--lg { font-size: 18px; padding: 17px 34px; }
.gov-btn--block { width: 100%; }
.gov-btn[disabled] { opacity: .55; cursor: not-allowed; transform: none; }

/* ── Hero ────────────────────────────────────────────────────── */
.gov-hero {
  background: linear-gradient(135deg, var(--gov-blue-night), var(--gov-blue));
  color: #fff; padding: 48px 0 56px; position: relative; overflow: hidden;
}
.gov-hero::after {
  content: ""; position: absolute; right: -120px; top: -120px;
  width: 380px; height: 380px; border-radius: 50%;
  background: radial-gradient(circle, rgba(255,205,7,.22), transparent 70%);
}
.gov-hero__grid { display: grid; gap: 28px; align-items: center; }
@media (min-width: 880px) { .gov-hero__grid { grid-template-columns: 1.1fr .9fr; } }
.gov-hero__badge {
  display: inline-flex; align-items: center; gap: 8px; background: rgba(255,205,7,.18);
  color: var(--gov-yellow); border: 1px solid rgba(255,205,7,.4);
  padding: 6px 14px; border-radius: 100px; font-size: 13px; font-weight: 600; margin-bottom: 18px;
}
.gov-hero h1 { font-size: clamp(28px, 6vw, 46px); color: #fff; }
.gov-hero h1 b { color: var(--gov-yellow); }
.gov-hero__lead { font-size: 18px; opacity: .95; margin-bottom: 24px; max-width: 36ch; }
.gov-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; }
.gov-hero__points { list-style: none; padding: 0; margin: 22px 0 0; display: grid; gap: 10px; }
.gov-hero__points li { display: flex; align-items: center; gap: 10px; font-size: 15px; }
.gov-hero__points .ic { color: var(--gov-yellow); font-weight: 800; }

/* ── Faixa de destaques ──────────────────────────────────────── */
.gov-strip { background: var(--gov-yellow); color: var(--gov-blue-night); padding: 16px 0; }
.gov-strip__grid { display: grid; gap: 14px; grid-template-columns: 1fr; text-align: center; }
@media (min-width: 700px) { .gov-strip__grid { grid-template-columns: repeat(4, 1fr); } }
.gov-strip__item b { display: block; font-family: var(--font-head); font-size: 22px; }
.gov-strip__item span { font-size: 13px; }

/* ── Seções ──────────────────────────────────────────────────── */
.gov-section { padding: 52px 0; }
.gov-section--alt { background: var(--gov-gray-05); }
.gov-section__title { text-align: center; font-size: clamp(24px, 4vw, 34px); color: var(--gov-blue-night); }
.gov-section__sub { text-align: center; color: var(--gov-gray-60); max-width: 56ch; margin: 0 auto 36px; }

/* ── Cards de elegibilidade / benefícios ─────────────────────── */
.gov-cards { display: grid; gap: 18px; grid-template-columns: 1fr; }
@media (min-width: 700px) { .gov-cards { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .gov-cards--3 { grid-template-columns: repeat(3, 1fr); } }
.gov-card {
  background: #fff; border: 1px solid var(--gov-gray-10); border-radius: var(--gov-radius-lg);
  padding: 26px; box-shadow: var(--gov-shadow);
}
.gov-card__ic {
  width: 52px; height: 52px; border-radius: 14px; background: var(--gov-blue-bg);
  color: var(--gov-blue); display: grid; place-items: center; font-size: 26px; margin-bottom: 14px;
}
.gov-card h3 { font-size: 19px; color: var(--gov-blue-night); }
.gov-card p { color: var(--gov-gray-60); font-size: 15px; margin: 0; }

/* ── Bancos parceiros ────────────────────────────────────────── */
.gov-banks { display: grid; gap: 14px; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 700px) { .gov-banks { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 980px) { .gov-banks { grid-template-columns: repeat(4, 1fr); } }
.gov-bank {
  background: #fff; border: 1px solid var(--gov-gray-10); border-radius: var(--gov-radius);
  padding: 18px 14px; text-align: center; box-shadow: var(--gov-shadow);
}
.gov-bank__logo {
  height: 44px; display: grid; place-items: center; margin-bottom: 8px;
  font-family: var(--font-head); font-weight: 800; font-size: 18px; color: var(--gov-blue);
}
.gov-bank span { font-size: 13px; color: var(--gov-gray-60); }

/* ── Passos (como funciona) ──────────────────────────────────── */
.gov-steps { display: grid; gap: 18px; grid-template-columns: 1fr; counter-reset: step; }
@media (min-width: 880px) { .gov-steps { grid-template-columns: repeat(4, 1fr); } }
.gov-step { position: relative; padding: 24px 18px; background: #fff; border-radius: var(--gov-radius-lg); border: 1px solid var(--gov-gray-10); }
.gov-step__n {
  width: 40px; height: 40px; border-radius: 50%; background: var(--gov-blue); color: #fff;
  display: grid; place-items: center; font-family: var(--font-head); font-weight: 800; margin-bottom: 12px;
}
.gov-step h4 { color: var(--gov-blue-night); font-size: 17px; }
.gov-step p { font-size: 14px; color: var(--gov-gray-60); margin: 0; }

/* ── Formulário multi-etapas ─────────────────────────────────── */
.gov-formwrap { max-width: 720px; margin: 0 auto; }
.gov-form {
  background: #fff; border: 1px solid var(--gov-gray-10); border-radius: var(--gov-radius-lg);
  box-shadow: var(--gov-shadow-lg); overflow: hidden;
}
.gov-form__head { background: var(--gov-blue-night); color: #fff; padding: 22px 26px; }
.gov-form__head h3 { color: #fff; margin: 0 0 4px; font-size: 20px; }
.gov-form__head p { margin: 0; opacity: .85; font-size: 14px; }
.gov-progress { display: flex; gap: 6px; padding: 16px 26px 0; }
.gov-progress__bar { flex: 1; height: 6px; border-radius: 100px; background: var(--gov-gray-10); overflow: hidden; }
.gov-progress__bar.is-done { background: var(--gov-green); }
.gov-progress__bar.is-current { background: var(--gov-blue); }
.gov-form__body { padding: 22px 26px 26px; }
.gov-step-panel { display: none; }
.gov-step-panel.is-active { display: block; animation: govFade .25s ease; }
@keyframes govFade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.gov-step-panel__title { font-size: 18px; color: var(--gov-blue-night); margin-bottom: 4px; }
.gov-step-panel__hint { font-size: 13px; color: var(--gov-gray-60); margin-bottom: 18px; }

.gov-field { margin-bottom: 16px; }
.gov-field label { display: block; font-weight: 600; font-size: 14px; margin-bottom: 6px; color: var(--gov-gray-80); }
.gov-field label .req { color: var(--gov-red); }
.gov-input, .gov-select {
  width: 100%; padding: 13px 14px; font-size: 16px; font-family: var(--font-body);
  border: 1px solid var(--gov-gray-20); border-radius: var(--gov-radius); background: #fff;
  color: var(--gov-gray-90); transition: border-color .15s, box-shadow .15s;
}
.gov-input:focus, .gov-select:focus { outline: none; border-color: var(--gov-blue); box-shadow: 0 0 0 3px var(--gov-blue-bg); }
.gov-field--error .gov-input, .gov-field--error .gov-select { border-color: var(--gov-red); }
.gov-field__err { color: var(--gov-red); font-size: 12px; margin-top: 5px; display: none; }
.gov-field--error .gov-field__err { display: block; }
.gov-row { display: grid; gap: 14px; grid-template-columns: 1fr; }
@media (min-width: 560px) { .gov-row--2 { grid-template-columns: 1fr 1fr; } .gov-row--3 { grid-template-columns: 1fr 1fr 1fr; } }

/* opções tipo cartão (radio) */
.gov-opts { display: grid; gap: 10px; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 560px) { .gov-opts--3 { grid-template-columns: repeat(3, 1fr); } }
.gov-opt { position: relative; }
.gov-opt input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.gov-opt__box {
  display: flex; flex-direction: column; gap: 2px; padding: 14px; border-radius: var(--gov-radius);
  border: 2px solid var(--gov-gray-20); background: #fff; cursor: pointer; transition: all .15s; height: 100%;
}
.gov-opt__box b { font-size: 15px; color: var(--gov-gray-90); }
.gov-opt__box small { font-size: 12px; color: var(--gov-gray-60); }
.gov-opt input:checked + .gov-opt__box { border-color: var(--gov-blue); background: var(--gov-blue-bg); }
.gov-opt input:focus-visible + .gov-opt__box { box-shadow: 0 0 0 3px var(--gov-blue-bg); }

.gov-consent { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: var(--gov-gray-60); margin-top: 4px; }
.gov-consent input { margin-top: 3px; width: 18px; height: 18px; accent-color: var(--gov-blue); flex-shrink: 0; }

.gov-form__nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 22px; }
.gov-form__nav .gov-btn { flex: 1; }

.gov-form__success { text-align: center; padding: 18px 0; }
.gov-form__success .ic { font-size: 56px; }

/* ── FAQ ─────────────────────────────────────────────────────── */
.gov-faq { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: 10px; }
.gov-faq__item { border: 1px solid var(--gov-gray-10); border-radius: var(--gov-radius); background: #fff; overflow: hidden; }
.gov-faq__q {
  width: 100%; text-align: left; background: none; border: none; cursor: pointer;
  padding: 18px 20px; font-size: 16px; font-weight: 600; color: var(--gov-blue-night);
  display: flex; justify-content: space-between; align-items: center; gap: 12px; font-family: var(--font-body);
}
.gov-faq__q .chev { transition: transform .2s; flex-shrink: 0; color: var(--gov-blue); }
.gov-faq__item.is-open .gov-faq__q .chev { transform: rotate(180deg); }
.gov-faq__a { max-height: 0; overflow: hidden; transition: max-height .25s ease; }
.gov-faq__a p { padding: 0 20px 18px; margin: 0; color: var(--gov-gray-60); font-size: 15px; }

/* ── Disclaimer ──────────────────────────────────────────────── */
.gov-disclaimer {
  background: var(--gov-gray-05); border-top: 1px solid var(--gov-gray-10);
  padding: 22px 0; font-size: 13px; color: var(--gov-gray-60);
}
.gov-disclaimer b { color: var(--gov-gray-80); }

/* ── Footer ──────────────────────────────────────────────────── */
.gov-footer { background: var(--gov-blue-night); color: #cdd8ea; padding: 34px 0; font-size: 14px; }
.gov-footer a { color: var(--gov-yellow); }
.gov-footer__grid { display: grid; gap: 18px; grid-template-columns: 1fr; }
@media (min-width: 700px) { .gov-footer__grid { grid-template-columns: 2fr 1fr 1fr; } }
.gov-footer h4 { color: #fff; font-size: 15px; }

/* ── Botão flutuante WhatsApp ────────────────────────────────── */
.gov-wa-float {
  position: fixed; right: 18px; bottom: 18px; z-index: 60;
  background: var(--gov-green); color: #fff; border-radius: 100px;
  padding: 14px 20px; font-weight: 700; text-decoration: none; box-shadow: var(--gov-shadow-lg);
  display: inline-flex; align-items: center; gap: 8px; transition: transform .15s;
}
.gov-wa-float:hover { transform: scale(1.04); }
.gov-wa-float svg { width: 22px; height: 22px; fill: currentColor; }

/* ════════════════════════════════════════════════════════════════
   PÁGINA DE VÍDEO (VSL) — sem scroll
   ════════════════════════════════════════════════════════════════ */
body.move-video {
  height: 100vh; height: 100dvh; overflow: hidden;
  background: var(--gov-blue-night); color: #fff;
}
.vsl {
  height: 100vh; height: 100dvh; display: flex; flex-direction: column;
}
.vsl__bar {
  flex-shrink: 0; background: var(--gov-blue-night); border-bottom: 3px solid var(--gov-yellow);
  padding: 10px 16px; display: flex; align-items: center; justify-content: space-between; gap: 10px;
}
.vsl__brand { display: flex; align-items: center; gap: 8px; font-family: var(--font-head); font-weight: 700; }
.vsl__brand .gov-logo__mark { width: 32px; height: 32px; font-size: 16px; }
.vsl__stage {
  flex: 1; position: relative; display: flex; align-items: center; justify-content: center;
  background: #000; min-height: 0;
}
.vsl__video { width: 100%; height: 100%; object-fit: contain; background: #000; }
.vsl__foot {
  flex-shrink: 0; padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  background: var(--gov-blue-night); text-align: center;
}
.vsl__foot p { margin: 0 0 8px; font-size: 13px; opacity: .8; }

/* Popup "piti" do vídeo */
.vsl-popup {
  position: absolute; inset: 0; z-index: 30;
  background: rgba(7,29,65,.78); backdrop-filter: blur(3px);
  display: none; align-items: center; justify-content: center; padding: 18px;
  animation: govFade .3s ease;
}
.vsl-popup.is-open { display: flex; }
.vsl-popup__card {
  background: #fff; color: var(--gov-gray-90); border-radius: var(--gov-radius-lg);
  max-width: 420px; width: 100%; padding: 30px 26px; text-align: center; box-shadow: var(--gov-shadow-lg);
  border-top: 6px solid var(--gov-yellow); position: relative;
}
.vsl-popup__card h3 { font-size: 22px; color: var(--gov-blue-night); }
.vsl-popup__card p { color: var(--gov-gray-60); font-size: 15px; }
.vsl-popup__close {
  position: absolute; top: 10px; right: 12px; background: none; border: none;
  font-size: 24px; line-height: 1; cursor: pointer; color: var(--gov-gray-40);
}

/* ════════════════════════════════════════════════════════════════
   PÁGINA DE INFORMAÇÕES (info)
   ════════════════════════════════════════════════════════════════ */
.gov-info-hero {
  background: linear-gradient(135deg, var(--gov-blue), var(--gov-blue-dark)); color: #fff; padding: 44px 0;
}
.gov-info-hero h1 { color: #fff; font-size: clamp(26px, 5vw, 40px); }
.gov-info-hero p { opacity: .95; max-width: 52ch; }
.gov-info-list { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: 16px; }
.gov-info-list__item { display: flex; gap: 16px; align-items: flex-start; }
.gov-info-list__ic {
  flex-shrink: 0; width: 44px; height: 44px; border-radius: 12px; background: var(--gov-blue-bg);
  color: var(--gov-blue); display: grid; place-items: center; font-size: 22px; font-weight: 800;
}
.gov-info-list__item h4 { color: var(--gov-blue-night); margin: 0 0 4px; font-size: 17px; }
.gov-info-list__item p { margin: 0; color: var(--gov-gray-60); font-size: 15px; }

.gov-cta-band { background: var(--gov-green); color: #fff; padding: 44px 0; text-align: center; }
.gov-cta-band h2 { color: #fff; font-size: clamp(22px, 4vw, 32px); }
.gov-cta-band p { opacity: .95; max-width: 50ch; margin: 0 auto 22px; }

.move-icon { font-style: normal; }

/* ── Landing enxuta: hero simples + formulário no topo ─────────────── */
.gov-hero--simple { padding: 44px 0 72px; text-align: center; }
.gov-hero--simple .gov-hero__badge { margin: 0 auto 14px; }
.gov-hero--simple h1 { font-size: clamp(26px, 5.5vw, 40px); max-width: 20ch; margin: 0 auto 12px; line-height: 1.15; }
.gov-hero--simple .gov-hero__lead { margin: 0 auto; max-width: 50ch; opacity: .95; }
.gov-form-section { background: var(--gov-gray-05); padding: 0 0 52px; }
.gov-formwrap--lift { margin-top: -48px; position: relative; z-index: 3; }
.gov-form-foot { text-align: center; color: var(--gov-gray-60); font-size: 13px; margin: 16px auto 0; max-width: 56ch; }
.gov-form-foot a { color: var(--gov-blue); }

/* ── Hero: microlinha de 3 passos + chamada ────────────────────────── */
.gov-hero__steps {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 10px 12px; margin: 26px auto 0; max-width: 760px;
}
.gov-hero__step {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16);
  color: #fff; font-size: 14px; font-weight: 600;
  padding: 9px 14px; border-radius: 100px;
}
.gov-hero__step i {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; border-radius: 50%; font-style: normal; font-size: 12px; font-weight: 800;
  background: rgba(255,255,255,.18); color: #fff;
}
.gov-hero__step--win {
  background: var(--gov-yellow); border-color: var(--gov-yellow); color: var(--gov-blue-night);
}
.gov-hero__step--win i { background: var(--gov-blue-night); color: var(--gov-yellow); }
.gov-hero__arrow { color: rgba(255,255,255,.5); font-weight: 800; }
.gov-hero__cue { margin: 22px 0 0; font-size: 14px; font-weight: 700; color: var(--gov-yellow); }
@media (max-width: 560px) {
  .gov-hero__arrow { display: none; }
  .gov-hero__steps { gap: 8px; }
  .gov-hero__step { width: 100%; justify-content: center; }
}

/* ── Feedback do autocomplete de CEP ───────────────────────────────── */
.gov-field__hint { display: block; margin-top: 5px; font-size: 12px; color: var(--gov-gray-60); min-height: 14px; }
.gov-field__hint--loading { color: var(--gov-gray-60); }
.gov-field__hint--ok { color: var(--gov-green); font-weight: 600; }
.gov-field__hint--error { color: var(--gov-red); font-weight: 600; }

/* ── Footer: bloco de contato + linha legal ────────────────────────── */
.gov-contact { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.gov-contact li { display: flex; align-items: flex-start; gap: 9px; color: #cdd8ea; font-size: 14px; line-height: 1.45; }
.gov-contact__ic { flex: 0 0 auto; opacity: .9; }
.gov-contact a { color: #fff; text-decoration: none; }
.gov-contact a:hover { text-decoration: underline; }
.gov-footer__legal {
  margin-top: 24px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.12);
  color: #9fb0c9; font-size: 12.5px;
}
