*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#0c0c0e;--surface:#141417;--card:#1c1c20;--border:rgba(255,255,255,.07);--text:#f0f0f2;--dim:#8a8a92;--accent:#e94e3c;--accent2:#f06a5a;--accent3:#c93a2a;--green:#2bde73;--radius:12px;--radius-sm:6px;--transition:0.35s ease}
html{scroll-behavior:smooth}
body{font-family:system-ui,-apple-system,'Inter','Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}
a{color:var(--accent2);text-decoration:none}
a:hover{color:var(--accent)}
img{max-width:100%}
h1,h2,h3,h4{font-weight:600;line-height:1.3}
p{color:var(--dim);font-size:.95rem}

.auth-page{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:24px}
.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px 32px}
.auth-card .logo{text-align:center;margin-bottom:32px}
.auth-card .logo a{font-size:1.1rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#fff}
.auth-card h1{font-size:1.3rem;text-align:center;margin-bottom:4px}
.auth-card .subtitle{text-align:center;font-size:13px;color:var(--dim);margin-bottom:28px}

.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--dim);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:inherit;transition:var(--transition);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(233,78,60,.15)}
.form-group input::placeholder{color:rgba(138,138,146,.5)}
.form-group .error{font-size:12px;color:var(--accent);margin-top:4px}
.form-group .hint{font-size:11px;color:var(--dim);margin-top:4px}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a8a92' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 24px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:.5px;font-family:inherit;width:100%}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent3)}
.btn-secondary{background:var(--card);color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--border)}
.btn-danger{background:#dc2626;color:#fff}
.btn-danger:hover{background:#b91c1c}
.btn-sm{padding:8px 16px;font-size:11px;width:auto}
.btn:disabled{opacity:.5;cursor:not-allowed}

.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:20px;line-height:1.5}
.alert-error{background:rgba(233,78,60,.1);border:1px solid rgba(233,78,60,.2);color:var(--accent2)}
.alert-success{background:rgba(43,222,115,.1);border:1px solid rgba(43,222,115,.2);color:var(--green)}
.alert-info{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.2);color:#60a5fa}

.auth-footer{text-align:center;margin-top:24px;font-size:13px;color:var(--dim)}
.auth-footer a{font-weight:600}

.flash{position:fixed;top:20px;right:20px;z-index:999;max-width:400px;animation:slideIn .3s ease}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

.recovery-codes{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:16px 0}
.recovery-codes code{padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:4px;font-size:13px;font-family:monospace;text-align:center;color:var(--text)}
