/* portal.css — shared styles for /portal (login + dashboard).
   Phase 1B extraction (2026-04-25). Phase 2 will replace the inline shells
   with a Vue 3 SPA reading from /api/portal/*; this file will be retired
   into frontend-src/portal/ at that point. Brand colours: #0a0a0f, #f0a500,
   #111118. Keep variants tight — design-system pass (Phase 5) will move
   these onto tokens. */

*{box-sizing:border-box}
body{margin:0;background:#0a0a0f;font-family:'Helvetica Neue',Arial,sans-serif;color:#fff;min-height:100vh}
body.portal-login{display:flex;flex-direction:column}

nav{background:#111118;border-bottom:1px solid rgba(255,255,255,0.07);padding:16px 24px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-size:20px;font-weight:900;text-decoration:none;color:#fff}.nav-logo span{color:#f0a500}
.nav-links a{color:#9ca3af;text-decoration:none;font-size:14px;margin-left:20px}
.nav-links a:hover{color:#fff}

/* ── Login card ───────────────────────────────────────────────────────────── */
.center{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 16px}
.card{background:#111118;border:1px solid rgba(255,255,255,0.08);border-radius:16px;padding:36px 32px;width:100%;max-width:440px}
.icon-row{text-align:center;margin-bottom:14px}
.icon{font-size:42px}
h1{margin:0 0 6px;font-size:22px;font-weight:900}
.lead{color:#9ca3af;font-size:13px;line-height:1.6;margin:0 0 22px;text-align:center}
.pref{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
.pref-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:18px 12px;border-radius:12px;text-decoration:none;cursor:pointer;background:linear-gradient(135deg,rgba(240,165,0,0.12),rgba(229,9,20,0.08));border:1px solid rgba(240,165,0,0.32);color:#fff;font-weight:700;font-size:13px;transition:transform .12s,border-color .15s,box-shadow .15s}
.pref-btn:hover{transform:translateY(-2px);border-color:rgba(240,165,0,0.6);box-shadow:0 6px 18px rgba(240,165,0,0.18)}
.pref-btn.disabled{opacity:0.55;cursor:not-allowed;pointer-events:none;border-color:rgba(255,255,255,0.08);background:rgba(255,255,255,0.03)}
.pref-btn .pi{font-size:24px;line-height:1}
.pref-btn .ps{font-size:10px;color:#f0a500;letter-spacing:0.06em;text-transform:uppercase;font-weight:800}
.pref-btn.disabled .ps{color:#6b7280}
.or{display:flex;align-items:center;gap:10px;color:#4b5563;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;margin:0 0 18px}
.or::before,.or::after{content:'';flex:1;height:1px;background:rgba(255,255,255,0.06)}
input{width:100%;padding:12px 16px;background:#0a0a0f;border:1px solid rgba(255,255,255,0.1);border-radius:8px;color:#fff;font-size:15px;margin-bottom:12px;outline:none}
input:focus{border-color:#f0a500}
.btn-primary{width:100%;padding:13px;background:#f0a500;color:#000;font-weight:700;font-size:15px;border:none;border-radius:8px;cursor:pointer}
.fallback{margin-top:22px;padding-top:18px;border-top:1px dashed rgba(255,255,255,0.06);text-align:center}
.fallback-label{color:#4b5563;font-size:11px;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:8px}
.discord-link{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#9ca3af;text-decoration:none;padding:6px 12px;border-radius:6px;border:1px solid rgba(255,255,255,0.06);transition:color .12s,border-color .12s}
.discord-link:hover{color:#5865f2;border-color:rgba(88,101,242,0.4)}
.discord-link svg{width:14px;height:14px;flex-shrink:0}

/* ── Dashboard shell ──────────────────────────────────────────────────────── */
.wrap{max-width:800px;margin:0 auto;padding:40px 20px}
.sub{color:#6b7280;font-size:14px;margin-bottom:20px}
.panel{background:#111118;border:1px solid rgba(255,255,255,0.07);border-radius:14px;padding:24px;margin-bottom:20px}
.panel-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#f0a500;margin-bottom:16px}
.btn{display:inline-block;padding:11px 22px;border-radius:8px;font-size:14px;font-weight:700;text-decoration:none;cursor:pointer;border:none}
.btn-gold{background:#f0a500;color:#000}
.btn-ghost{background:transparent;color:#f0a500;border:1px solid rgba(240,165,0,0.3)}
.btn-ghost:hover{background:rgba(240,165,0,0.06)}
.no-creds{background:rgba(240,165,0,0.06);border:1px solid rgba(240,165,0,0.2);border-radius:10px;padding:16px;font-size:13px;color:#9ca3af;margin-top:8px}
.tab-nav{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,0.07);margin-bottom:28px}
.tab-btn{padding:10px 20px;background:none;border:none;color:#6b7280;font-size:14px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s}
.tab-btn:hover{color:#fff}
.tab-btn.active{color:#f0a500;border-bottom:2px solid #f0a500}
.tab-panel{display:none}.tab-panel.active{display:block}
.row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.05)}
.row:last-child{border-bottom:none}
.row .lbl{color:#6b7280;font-size:13px;min-width:120px}
.row .val{font-family:monospace;font-size:13px;color:#f0a500;word-break:break-all;flex:1;text-align:right}
.copy-btn{background:rgba(240,165,0,0.1);border:1px solid rgba(240,165,0,0.2);color:#f0a500;padding:4px 10px;border-radius:6px;cursor:pointer;font-size:11px;margin-left:10px;flex-shrink:0}
.expiry-pill{display:inline-block;padding:6px 14px;background:rgba(255,255,255,0.04);border-radius:20px;font-size:13px;font-weight:700;margin-top:8px}
.spinner{text-align:center;padding:60px;color:#4b5563}
.alert{padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:14px}
.alert-success{background:rgba(34,197,94,0.1);border:1px solid rgba(34,197,94,0.2);color:#22c55e}
.alert-error{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.2);color:#ef4444}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:8px 0;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:#6b7280;border-bottom:1px solid rgba(255,255,255,0.07)}
td{padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.04);font-size:13px;color:#d1d5db}
.credits-pill{background:rgba(240,165,0,0.15);color:#f0a500;border:1px solid rgba(240,165,0,0.3);border-radius:20px;padding:4px 12px;font-size:13px;font-weight:700}
select{background:#1a1a24;border:1px solid rgba(255,255,255,0.15);border-radius:8px;padding:10px 14px;color:#fff;font-size:14px;outline:none}
.field-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:12px}
.field-grid label{display:block;font-size:13px;color:#9ca3af;margin-bottom:6px;font-weight:600}
.field-grid input,.field-grid select{width:100%}

@media (max-width:420px){.card{padding:30px 22px}.pref{grid-template-columns:1fr}}
