/* ============================================================
   auth.css — Widget de cuenta, login, perfil y panel admin
   ============================================================ */

/* ---------- Botón pequeño ---------- */
.btn-sm { padding: 7px 14px; font-size: 0.85rem; }

/* ---------- Widget de cuenta en el header ---------- */
.account { position: relative; margin-left: 12px; flex-shrink: 0; }
.account-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 10px 5px 5px; border: 1px solid var(--border); border-radius: var(--r-pill);
  background: var(--surface); color: var(--text); font-size: 0.85rem; font-weight: 600;
  transition: border-color var(--ease);
}
.account-btn:hover { border-color: var(--border-2); }
.avatar {
  width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--blue), var(--blue-600)); color: #fff;
  font-size: 0.85rem; font-weight: 700;
}
.account-name { max-width: 90px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.caret { color: var(--text-dim); font-size: 0.7rem; }

.account-menu {
  position: absolute; right: 0; top: calc(100% + 8px); width: 230px; z-index: 80;
  background: var(--surface-2); border: 1px solid var(--border-2); border-radius: var(--r-md);
  box-shadow: var(--shadow-md); padding: 6px; display: flex; flex-direction: column;
}
.account-head { padding: 10px 12px; border-bottom: 1px solid var(--border); margin-bottom: 6px; }
.account-head strong { display: block; font-size: 0.92rem; }
.account-head small { color: var(--text-dim); font-size: 0.78rem; }
.account-menu a, .account-menu button {
  text-align: left; padding: 9px 12px; border-radius: var(--r-sm); font-size: 0.88rem;
  color: var(--text-muted); transition: background var(--ease), color var(--ease);
}
.account-menu a:hover, .account-menu button:hover { background: var(--surface); color: var(--text); }
.account-menu a.up { color: var(--blue-300); font-weight: 600; }
.account-menu #logout-btn { color: #ff6b8a; border-top: 1px solid var(--border); margin-top: 4px; }

@media (max-width: 860px) {
  .account { margin-left: auto; order: 3; }
  .nav-toggle { margin-left: 8px; }
  .account-name { display: none; }
}

/* ---------- Páginas de autenticación ---------- */
.auth-page { min-height: calc(100vh - var(--header-h)); display: grid; place-items: center; padding: 40px 20px; }
.auth-card { width: 100%; max-width: 430px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--shadow-md); overflow: hidden; }
.auth-tabs { display: flex; border-bottom: 1px solid var(--border); }
.auth-tabs button { flex: 1; padding: 15px; font-weight: 600; color: var(--text-muted); border-bottom: 2px solid transparent; }
.auth-tabs button.active { color: var(--blue-300); border-bottom-color: var(--blue); background: var(--blue-soft); }
.auth-form { padding: 28px 28px 32px; display: flex; flex-direction: column; gap: 14px; }
.auth-form h1 { font-size: 1.5rem; }
.auth-form > .muted { margin-top: -8px; margin-bottom: 6px; font-size: 0.9rem; }
.auth-form label { display: flex; flex-direction: column; gap: 6px; font-size: 0.85rem; font-weight: 600; color: var(--text-muted); }
.auth-form input {
  padding: 11px 14px; background: var(--bg-2); border: 1px solid var(--border-2);
  border-radius: var(--r-sm); color: var(--text); font-weight: 400; font-size: 0.95rem;
}
.auth-form input:focus { border-color: var(--blue); outline: none; }
.auth-error { background: rgba(255,80,110,0.12); border: 1px solid rgba(255,80,110,0.4); color: #ff8fa3; padding: 9px 12px; border-radius: var(--r-sm); font-size: 0.85rem; }
.auth-hint { font-size: 0.8rem; color: var(--text-dim); text-align: center; margin-top: 4px; }
.auth-hint code { background: var(--bg-2); padding: 2px 6px; border-radius: 4px; color: var(--blue-300); }

/* ---------- Gate (acceso restringido) ---------- */
.gate { text-align: center; padding: 90px 20px; max-width: 480px; margin-inline: auto; }
.gate h1 { margin-bottom: 14px; }
.gate .btn { margin-top: 22px; }

/* ---------- Página de cuenta ---------- */
.account-layout { padding: 30px 0 60px; }
.account-banner { display: flex; align-items: center; gap: 18px; padding: 24px; background: linear-gradient(120deg, var(--blue-soft), var(--surface) 60%); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: 22px; }
.avatar-lg { width: 64px; height: 64px; font-size: 1.6rem; }
.account-banner h1 { font-size: 1.6rem; }
.plan-pill { margin-left: auto; padding: 7px 16px; border-radius: var(--r-pill); font-weight: 700; font-size: 0.85rem; }
.plan-pill.free { background: var(--surface-2); color: var(--text-muted); border: 1px solid var(--border-2); }
.plan-pill.pro { background: var(--amber); color: #3a2a00; }

.account-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-bottom: 20px; }
.acc-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 22px; }
.acc-card h3 { font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-dim); margin-bottom: 12px; }
.acc-card .big { font-size: 1.8rem; font-weight: 800; margin-bottom: 6px; }
.acc-card .res-options { margin: 0 0 12px; }
.acc-card .btn { margin-top: 10px; }
.res-opt.locked { color: var(--text-dim); border-style: dashed; }
.acc-stats { display: flex; flex-direction: column; gap: 12px; }
.acc-stats li { display: flex; justify-content: space-between; align-items: baseline; color: var(--text-muted); font-size: 0.9rem; border-bottom: 1px solid var(--border); padding-bottom: 10px; }
.acc-stats strong { font-size: 1.1rem; color: var(--text); }

@media (max-width: 860px) { .account-cards { grid-template-columns: 1fr; } }

/* ---------- Panel admin ---------- */
.admin-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 20px; padding: 30px 0 24px; flex-wrap: wrap; }
.admin-head h1 { font-size: 1.8rem; }
.admin-kpis { display: flex; gap: 14px; }
.kpi { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 12px 22px; text-align: center; }
.kpi strong { display: block; font-size: 1.6rem; color: var(--blue-300); }
.kpi span { font-size: 0.75rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.05em; }

.admin-layout { display: grid; grid-template-columns: 420px 1fr; gap: 24px; align-items: start; padding-bottom: 70px; }
.admin-form-card, .admin-list-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 24px; }
.admin-form-card { position: sticky; top: calc(var(--header-h) + 16px); }
.admin-form-card h2, .admin-list-card h2 { font-size: 1.2rem; margin-bottom: 18px; }

.admin-form { display: flex; flex-direction: column; gap: 14px; }
.admin-form label { display: flex; flex-direction: column; gap: 6px; font-size: 0.82rem; font-weight: 600; color: var(--text-muted); }
.admin-form input[type=text], .admin-form select {
  padding: 10px 12px; background: var(--bg-2); border: 1px solid var(--border-2);
  border-radius: var(--r-sm); color: var(--text); font-weight: 400; font-size: 0.9rem;
}
.admin-form input:focus, .admin-form select:focus { border-color: var(--blue); outline: none; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.color-field { display: flex; gap: 8px; align-items: center; }
.color-field input[type=color] { width: 46px; height: 40px; padding: 2px; background: var(--bg-2); border: 1px solid var(--border-2); border-radius: var(--r-sm); cursor: pointer; }
.color-field input[type=text] { flex: 1; font-family: var(--font-mono); }

.maps-field { border: 1px solid var(--border); border-radius: var(--r-sm); padding: 12px 14px; }
.maps-field legend { font-size: 0.8rem; font-weight: 600; color: var(--text-muted); padding: 0 6px; }
.maps-checks { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
.maps-checks .check { font-size: 0.85rem; }

.form-preview { display: flex; align-items: center; gap: 14px; padding: 12px; background: var(--bg-2); border-radius: var(--r-sm); }
.form-preview span { font-size: 0.82rem; color: var(--text-dim); font-weight: 600; }
.prev-thumb { width: 72px; height: 72px; border-radius: var(--r-sm); overflow: hidden; margin-left: auto; border: 1px solid var(--border-2); }
.form-actions { display: flex; gap: 10px; }

.admin-table { width: 100%; border-collapse: collapse; }
.admin-table th { text-align: left; font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-dim); padding: 8px 10px; border-bottom: 1px solid var(--border); }
.admin-table td { padding: 10px; border-bottom: 1px solid var(--border); font-size: 0.88rem; vertical-align: middle; }
.row-thumb { width: 46px; }
.row-thumb svg { width: 38px; height: 38px; border-radius: 6px; }
.row-actions { display: flex; gap: 4px; justify-content: flex-end; }
.mini-btn { width: 30px; height: 30px; display: inline-grid; place-items: center; border: 1px solid var(--border-2); border-radius: var(--r-sm); font-size: 0.85rem; color: var(--text-muted); }
.mini-btn:hover { border-color: var(--blue-400); color: var(--text); }
.mini-btn.danger:hover { border-color: #ff6b8a; color: #ff6b8a; }
.admin-empty { padding: 30px; text-align: center; }
.admin-note { margin-top: 16px; font-size: 0.8rem; color: var(--text-dim); }

@media (max-width: 980px) {
  .admin-layout { grid-template-columns: 1fr; }
  .admin-form-card { position: static; }
}

/* ---------- Aviso de plan en el detalle ---------- */
.plan-locked { display: flex; gap: 10px; align-items: center; background: rgba(251,191,36,0.1); border: 1px solid rgba(251,191,36,0.35); color: var(--amber); padding: 12px 14px; border-radius: var(--r-sm); font-size: 0.85rem; margin-bottom: 14px; }
.plan-locked a { color: var(--blue-300); font-weight: 600; text-decoration: underline; }

/* ============================================================
   RANGOS / TIERS (planes Patreon)
   ============================================================ */
.plans-grid-4 { grid-template-columns: repeat(4, 1fr); max-width: 1100px; }
@media (max-width: 980px) { .plans-grid-4 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .plans-grid-4 { grid-template-columns: 1fr; } }

.tiers-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.tier-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 22px; border-top: 3px solid var(--accent, var(--blue)); }
.tier-card.current { box-shadow: 0 0 0 2px var(--accent, var(--blue)); }
.tier-card h3 { font-size: 1.05rem; }
.tier-price { font-size: 2rem; font-weight: 800; margin: 8px 0; letter-spacing: -0.03em; }
.tier-price span { font-size: 0.85rem; font-weight: 500; color: var(--text-dim); }
.tier-card .muted { font-size: 0.86rem; min-height: 48px; }
.tier-res { color: var(--accent, var(--blue-300)); font-weight: 600; font-size: 0.9rem; margin: 10px 0 14px; }
.tier-current { display: block; text-align: center; padding: 10px; background: var(--blue-soft);
  border-radius: var(--r-sm); color: var(--blue-300); font-weight: 600; font-size: 0.88rem; }
@media (max-width: 860px) { .tiers-grid { grid-template-columns: 1fr; } }

/* ============================================================
   AFILIADOS: cuestionario + panel de solicitudes
   ============================================================ */
.affiliate-page { max-width: 720px; margin: 0 auto; padding: 36px 0 70px; }
.affiliate-intro { background: linear-gradient(120deg, var(--blue-soft), var(--surface) 60%);
  border: 1px solid var(--border); border-radius: var(--r-lg); padding: 28px; margin-bottom: 24px; }
.affiliate-intro h1 { font-size: 1.8rem; margin-bottom: 10px; }
.affiliate-perks { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }
.affiliate-perks span { font-size: 0.82rem; padding: 5px 12px; border-radius: var(--r-pill);
  background: var(--surface); border: 1px solid var(--border-2); color: var(--text-muted); }
.affiliate-form { background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 26px; display: flex; flex-direction: column; gap: 16px; }
.affiliate-form label { display: flex; flex-direction: column; gap: 6px; font-size: 0.85rem; font-weight: 600; color: var(--text-muted); }
.affiliate-form input, .affiliate-form textarea {
  padding: 11px 14px; background: var(--bg-2); border: 1px solid var(--border-2);
  border-radius: var(--r-sm); color: var(--text); font: inherit; font-size: 0.92rem; }
.affiliate-form textarea { resize: vertical; min-height: 70px; }
.affiliate-form input:focus, .affiliate-form textarea:focus { border-color: var(--blue); outline: none; }
.affiliate-status { padding: 16px 18px; border-radius: var(--r-md); margin-bottom: 22px; font-size: 0.92rem; }
.affiliate-status.pendiente { background: rgba(251,191,36,0.1); border: 1px solid rgba(251,191,36,0.35); color: var(--amber); }
.affiliate-status.aprobado { background: rgba(52,211,153,0.1); border: 1px solid rgba(52,211,153,0.35); color: var(--green); }
.affiliate-status.rechazado { background: rgba(255,107,138,0.1); border: 1px solid rgba(255,107,138,0.35); color: #ff8fa3; }

.req-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md);
  padding: 18px; margin-bottom: 14px; }
.req-card h3 { font-size: 1rem; }
.req-card .req-meta { color: var(--text-dim); font-size: 0.82rem; margin-bottom: 10px; }
.req-card dl { display: grid; grid-template-columns: 130px 1fr; gap: 6px 12px; font-size: 0.88rem; margin-bottom: 14px; }
.req-card dt { color: var(--text-dim); }
.req-actions { display: flex; gap: 8px; }
.req-state { font-size: 0.78rem; font-weight: 700; padding: 3px 10px; border-radius: var(--r-pill); }
.req-state.pendiente { background: rgba(251,191,36,0.15); color: var(--amber); }
.req-state.aprobado { background: rgba(52,211,153,0.15); color: var(--green); }
.req-state.rechazado { background: rgba(255,107,138,0.15); color: #ff8fa3; }

/* ============================================================
   PÁGINAS LEGALES (términos, privacidad)
   ============================================================ */
.legal-page { max-width: 820px; margin: 0 auto; padding: 40px 0 70px; }
.legal-page h1 { font-size: 2rem; margin-bottom: 8px; }
.legal-updated { color: var(--text-dim); font-size: 0.85rem; margin-bottom: 10px; }
.legal-disclaimer { background: rgba(251,191,36,0.1); border: 1px solid rgba(251,191,36,0.3);
  color: var(--amber); padding: 14px 16px; border-radius: var(--r-sm); font-size: 0.86rem; margin-bottom: 28px; }
.legal-page h2 { font-size: 1.2rem; margin: 30px 0 10px; padding-top: 10px; border-top: 1px solid var(--border); }
.legal-page h3 { font-size: 1rem; margin: 18px 0 6px; }
.legal-page p, .legal-page li { color: var(--text-muted); font-size: 0.94rem; line-height: 1.7; }
.legal-page ul { padding-left: 22px; margin: 8px 0; list-style: disc; }
.legal-page li { margin-bottom: 6px; }
.legal-toc { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md);
  padding: 18px 22px; margin-bottom: 28px; }
.legal-toc ol { padding-left: 20px; }
.legal-toc a { color: var(--blue-300); }
.legal-toc a:hover { text-decoration: underline; }
