/* ══════════════════════════════════════════════════════════
   NOVATY — novaty.com.br
   Identidade derivada do app Novaty Fit:
   bg #09090b · verde #00e5a0 · cards com borda · badges pill
   ══════════════════════════════════════════════════════════ */
:root {
  --bg:        #09090b;
  --bg-card:   #141416;
  --bg-card-2: #101014;
  --border:    #232329;
  --white:     #f5f5f7;
  --gray-300:  #c6c6cf;
  --gray-400:  #9a9aa4;
  --gray-500:  #6f6f7a;
  --verde:     #00e5a0;
  --verde-bg:  rgba(0, 229, 160, 0.08);
  --teal:      #2a9d8f;
  --laranja:   #f4a261;
  --vermelho:  #e63946;
  --gelo:      #a8dadc;
  --radius:    22px;
  --radius-sm: 12px;
  --maxw:      1080px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
}

body {
  background: var(--bg);
  color: var(--gray-300);
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

::selection { background: var(--verde); color: #09090b; }

a { color: var(--verde); text-decoration: none; }
a:hover { text-decoration: underline; }
a:focus-visible, button:focus-visible {
  outline: 2px solid var(--verde);
  outline-offset: 3px;
  border-radius: 4px;
}

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

/* ── Cabeçalho ─────────────────────────────────────────── */
.topo {
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 10;
  background: rgba(9, 9, 11, 0.86);
  backdrop-filter: blur(10px);
}
.topo-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 0;
}
.marca {
  font-family: "Archivo", "Inter", sans-serif;
  font-weight: 900; font-size: 20px; letter-spacing: 3px;
  color: var(--white); text-decoration: none;
}
.marca:hover { text-decoration: none; }
.marca .ponto { color: var(--verde); }
.topo-nav { display: flex; gap: 26px; }
.topo-nav a {
  color: var(--gray-400); font-size: 12px; font-weight: 700;
  letter-spacing: 1.6px; text-transform: uppercase;
}
.topo-nav a:hover { color: var(--verde); text-decoration: none; }
@media (max-width: 560px) { .topo-nav { display: none; } }

/* ── Eyebrow / badges (vernáculo do app) ───────────────── */
.eyebrow {
  font-size: 11px; font-weight: 800; letter-spacing: 2.5px;
  text-transform: uppercase; color: var(--verde);
}
.badge {
  display: inline-block;
  font-size: 11px; font-weight: 800; letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 6px 16px; border-radius: 999px;
  border: 1px solid var(--verde);
  color: var(--verde); background: var(--verde-bg);
}
.badge.b-teal     { border-color: var(--teal);     color: var(--teal);     background: rgba(42,157,143,.09); }
.badge.b-gelo     { border-color: var(--gelo);     color: var(--gelo);     background: rgba(168,218,220,.07); }
.badge.b-cinza    { border-color: var(--border);   color: var(--gray-400); background: transparent; }

/* ── Hero ──────────────────────────────────────────────── */
.hero { position: relative; padding: 96px 0 84px; overflow: hidden; }
.hero h1 {
  font-family: "Archivo", sans-serif;
  font-weight: 900;
  font-size: clamp(38px, 7vw, 72px);
  line-height: 1.04;
  letter-spacing: -0.5px;
  color: var(--white);
  max-width: 15ch;
}
.hero h1 em { font-style: normal; color: var(--verde); }
.hero p.lead {
  margin-top: 22px; max-width: 52ch;
  font-size: 18px; color: var(--gray-400);
}
.hero .eyebrow { display: block; margin-bottom: 18px; }

/* Trilha GPS — assinatura visual */
.trilha {
  position: absolute; inset: 0; z-index: -1;
  width: 100%; height: 100%; pointer-events: none; opacity: .9;
}
.trilha .rota {
  fill: none; stroke: var(--verde); stroke-width: 2;
  stroke-linecap: round; stroke-linejoin: round;
  stroke-dasharray: 2400; stroke-dashoffset: 2400;
  animation: correr 4.5s cubic-bezier(.5, 0, .2, 1) .3s forwards;
  opacity: .35;
}
.trilha .km { fill: var(--verde); opacity: 0; animation: surgir .6s ease forwards; }
.trilha .km:nth-of-type(2) { animation-delay: 1.6s; }
.trilha .km:nth-of-type(3) { animation-delay: 2.6s; }
.trilha .km:nth-of-type(4) { animation-delay: 3.6s; }
.trilha .partida {
  fill: none; stroke: var(--verde); stroke-width: 2; opacity: .5;
  transform-origin: center; transform-box: fill-box;
  animation: pulsar 2.4s ease-out infinite;
}
@keyframes correr  { to { stroke-dashoffset: 0; } }
@keyframes surgir  { to { opacity: .8; } }
@keyframes pulsar  { 0% { transform: scale(.6); opacity: .6; } 100% { transform: scale(1.6); opacity: 0; } }
@media (prefers-reduced-motion: reduce) {
  .trilha .rota { stroke-dashoffset: 0; }
  .trilha .km   { opacity: .8; }
}

/* ── Seções ────────────────────────────────────────────── */
.secao { padding: 76px 0; border-top: 1px solid var(--border); }
.secao-head { margin-bottom: 40px; }
.secao-head h2 {
  font-family: "Archivo", sans-serif; font-weight: 900;
  font-size: clamp(26px, 4vw, 38px); color: var(--white);
  margin-top: 10px; letter-spacing: -0.3px;
}

/* ── Cards de app (eco do menu do app) ─────────────────── */
.apps-grid {
  display: grid; gap: 22px;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
}
.app-card {
  background: var(--bg-card);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  padding: 30px 28px;
  display: flex; flex-direction: column; gap: 14px;
  transition: border-color .25s ease, transform .25s ease;
}
.app-card:hover { border-color: var(--verde); transform: translateY(-3px); }
.app-card.destaque { border-color: rgba(0, 229, 160, .45); background: var(--bg-card-2); }
.app-card h3 {
  font-family: "Archivo", sans-serif; font-weight: 900;
  font-size: 21px; letter-spacing: 1px; color: var(--white);
  text-transform: uppercase;
}
.app-card p { font-size: 14.5px; color: var(--gray-400); flex: 1; }
.app-card .rodape-card {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; flex-wrap: wrap; margin-top: 6px;
}
.app-card .links-legais { font-size: 13px; }
.app-card .links-legais a { color: var(--gray-400); }
.app-card .links-legais a:hover { color: var(--verde); }

/* Pontos de modalidade (cores reais do app) */
.modalidades { display: flex; gap: 14px; flex-wrap: wrap; font-size: 12.5px; color: var(--gray-500); }
.modalidades span { display: inline-flex; align-items: center; gap: 6px; }
.dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.dot.corrida { background: var(--verde); }
.dot.gps     { background: var(--teal); }
.dot.hiit    { background: var(--laranja); }
.dot.marcial { background: var(--vermelho); }
.dot.jejum   { background: var(--gelo); }

/* ── Contato ───────────────────────────────────────────── */
.contato-box {
  background: var(--bg-card);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  padding: 36px 32px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; flex-wrap: wrap;
}
.contato-box .email {
  font-family: "Archivo", sans-serif; font-weight: 800;
  font-size: clamp(18px, 3vw, 26px); color: var(--white);
  word-break: break-all;
}
.contato-box .email:hover { color: var(--verde); text-decoration: none; }

/* ── Rodapé ────────────────────────────────────────────── */
.rodape {
  border-top: 1px solid var(--border);
  padding: 36px 0 48px;
  font-size: 13px; color: var(--gray-500);
}
.rodape-inner { display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.rodape a { color: var(--gray-400); }

/* ══════════════════════════════════════════════════════════
   Páginas de documento (política / exclusão)
   ══════════════════════════════════════════════════════════ */
.doc { max-width: 760px; margin: 0 auto; padding: 64px 24px 96px; }
.doc .eyebrow { display: block; }
.doc h1 {
  font-family: "Archivo", sans-serif; font-weight: 900;
  font-size: clamp(28px, 5vw, 42px); color: var(--white);
  line-height: 1.12; margin: 12px 0 10px;
}
.doc .meta {
  font-size: 13px; color: var(--gray-500);
  padding-bottom: 28px; border-bottom: 1px solid var(--border);
  margin-bottom: 36px;
}
.doc h2 {
  font-family: "Archivo", sans-serif; font-weight: 800;
  font-size: 21px; color: var(--white);
  margin: 44px 0 12px;
  padding-left: 14px;
  border-left: 3px solid var(--verde);
}
.doc h3 { font-size: 16px; color: var(--white); margin: 26px 0 8px; }
.doc p, .doc li { font-size: 16px; color: var(--gray-300); }
.doc p  { margin: 12px 0; }
.doc ul { margin: 12px 0 12px 22px; }
.doc li { margin: 7px 0; }
.doc strong { color: var(--white); }
.doc .resumo {
  background: var(--verde-bg);
  border: 1px solid rgba(0, 229, 160, .35);
  border-radius: var(--radius-sm);
  padding: 20px 22px;
  margin: 26px 0;
}
.doc .resumo p { margin: 8px 0; font-size: 15px; }
.doc .resumo .eyebrow { margin-bottom: 6px; }
.doc .aviso {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-left: 3px solid var(--laranja);
  border-radius: var(--radius-sm);
  padding: 16px 20px; margin: 22px 0;
  font-size: 14.5px; color: var(--gray-400);
}
.doc table { width: 100%; border-collapse: collapse; margin: 16px 0; font-size: 14.5px; }
.doc th, .doc td { text-align: left; padding: 10px 12px; border: 1px solid var(--border); vertical-align: top; }
.doc th { color: var(--white); background: var(--bg-card); font-size: 12px; letter-spacing: 1px; text-transform: uppercase; }
.doc .voltar { display: inline-block; margin-bottom: 26px; font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
