/* Páginas "app-like" do site: /cadastro, /conta, /compra/sucesso, /compra/cancelado.
   Reusa os tokens e o .btn da landing page (assets/styles.css, carregado antes).
   Aqui só o layout/forma das telas logadas — tema escuro, na identidade da LP. */

body.app {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--bg);
}

/* ── Topo simples (só a marca, volta pra LP) ───────────────────────────────── */
.app-nav {
  border-bottom: 1px solid var(--line);
  background: rgba(10, 15, 13, .72);
  backdrop-filter: saturate(140%) blur(14px);
}
.app-nav .nav-inner {
  display: flex;
  align-items: center;
  max-width: 720px;
  margin: 0 auto;
  padding: 16px 24px;
}

/* ── Container central ─────────────────────────────────────────────────────── */
.app-main {
  flex: 1;
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  padding: 40px 24px 72px;
}
.app-main.narrow { max-width: 460px; }

.app-head { margin-bottom: 28px; }
.app-head h1 {
  font-size: clamp(26px, 4vw, 34px);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1.1;
}
.app-head p { color: var(--txt-2); margin-top: 10px; line-height: 1.6; }

/* ── Cartões ───────────────────────────────────────────────────────────────── */
.app-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  margin-bottom: 18px;
}
.app-card h2 {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -.01em;
  margin-bottom: 4px;
}
.app-card .hint { color: var(--txt-3); font-size: 14px; margin-bottom: 16px; line-height: 1.5; }

/* ── Formulários ───────────────────────────────────────────────────────────── */
.field { margin-bottom: 14px; }
.field label {
  display: block;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--txt-2);
  margin-bottom: 6px;
}
.field input {
  width: 100%;
  font-family: var(--font);
  font-size: 15px;
  color: var(--txt);
  background: var(--panel-2);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  transition: border-color .15s;
}
.field input::placeholder { color: var(--txt-3); }
.field input:focus { border-color: var(--green-2); }
.btn-block { width: 100%; }
.field-row { display: flex; gap: 12px; }
.field-row .field { flex: 1; }

/* ── Saldo ─────────────────────────────────────────────────────────────────── */
.balance {
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.balance .num {
  font-size: clamp(34px, 7vw, 48px);
  font-weight: 800;
  letter-spacing: -.03em;
  color: var(--green);
  line-height: 1;
}
.balance .lbl { color: var(--txt-2); font-weight: 600; }
.balance.offline .num { color: var(--txt-2); }

/* ── Pacotes (radios estilo cartão + lista de compra) ──────────────────────── */
.pkgs { display: grid; gap: 10px; margin-bottom: 8px; }
.pkg {
  display: flex;
  align-items: center;
  gap: 14px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  cursor: pointer;
  transition: border-color .15s, background .15s;
}
.pkg:hover { border-color: var(--green-2); }
.pkg input { accent-color: var(--green-2); width: 18px; height: 18px; flex-shrink: 0; }
.pkg.selected { border-color: var(--green); background: rgba(47, 224, 138, .06); }
.pkg-body { flex: 1; }
.pkg-name { font-weight: 700; }
.pkg-meta { color: var(--txt-3); font-size: 13.5px; margin-top: 2px; }
.pkg-price { font-weight: 800; font-size: 17px; white-space: nowrap; }
.pkg .badge {
  font-size: 11px; font-weight: 700; color: var(--green-ink);
  background: var(--green); border-radius: 100px; padding: 3px 9px; margin-left: 8px;
}

/* lista de compra (na /conta — botão por pacote) */
.buy-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
}
.buy-row + .buy-row { margin-top: 10px; }

/* ── Extrato: resumo (total no topo de cada bloco) ─────────────────────────── */
.extract-summary:empty { display: none; }
/* O divisor e o espaçamento ficam com a lista (.ledger) logo abaixo — assim o
   bloco "Consumo", que mostra só o total, não fica com uma linha solta no fim. */
.extract-summary + .ledger { border-top: 1px solid var(--line); margin-top: 16px; }
.extract-summary .es-head { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.extract-summary .es-num {
  font-size: clamp(28px, 6vw, 38px);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1;
  color: var(--txt);
}
.extract-summary .es-num.pos { color: var(--green); }
.extract-summary .es-lbl { color: var(--txt-2); font-weight: 600; }
.extract-summary .es-sub { color: var(--txt-3); font-size: 13.5px; margin-top: 8px; }

/* ── Extrato ───────────────────────────────────────────────────────────────── */
.ledger { list-style: none; }
.ledger li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}
.ledger li:last-child { border-bottom: none; }
.ledger .lg-reason { font-weight: 600; }
.ledger .lg-date { color: var(--txt-3); font-size: 13px; margin-top: 2px; }
.ledger .lg-delta { font-weight: 800; white-space: nowrap; }
.ledger .lg-delta.pos { color: var(--green); }
.ledger .lg-delta.neg { color: var(--txt-2); }
.ledger-empty { color: var(--txt-3); padding: 8px 0; }

/* ── Mensagens (erro / sucesso / info) ─────────────────────────────────────── */
.msg { border-radius: var(--radius-sm); padding: 12px 14px; font-size: 14px; line-height: 1.5; margin-bottom: 14px; }
.msg.err { background: rgba(255, 90, 90, .1); border: 1px solid rgba(255, 90, 90, .35); color: #ffb4b4; }
.msg.ok { background: rgba(47, 224, 138, .1); border: 1px solid rgba(47, 224, 138, .3); color: var(--green); }
.msg.info { background: var(--panel-2); border: 1px solid var(--line-2); color: var(--txt-2); }

/* ── tema claro (páginas app) — segue o [data-theme] do <html>; os tokens já
   viram via styles.css, aqui só os hex cravados pro fundo escuro ── */
[data-theme="light"] .app-nav { background: rgba(255, 255, 255, .82); }
[data-theme="light"] .msg.err { color: #b42318; }

/* ── Divisor de seção ──────────────────────────────────────────────────────── */
.app-card .sep {
  border: none;
  border-top: 1px solid var(--line);
  margin: 20px 0;
}
.app-card h2.sub { margin-top: 4px; }

/* ── Estado / loading ──────────────────────────────────────────────────────── */
.center-state {
  text-align: center;
  padding: 48px 0;
}
.spinner {
  width: 36px; height: 36px;
  border: 3px solid var(--line-2);
  border-top-color: var(--green);
  border-radius: 50%;
  margin: 0 auto 18px;
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .spinner { animation: none; } }

.muted-link {
  display: inline-block;
  margin-top: 14px;
  color: var(--txt-2);
  font-size: 14px;
  text-decoration: underline;
  text-underline-offset: 3px;
  background: none; border: none; cursor: pointer; font-family: var(--font);
}
.muted-link:hover { color: var(--txt); }

.row-between { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.stack > * + * { margin-top: 12px; }

@media (max-width: 520px) {
  .field-row { flex-direction: column; gap: 0; }
  .app-card { padding: 18px; }
}
