:root{--auth-bg:#0d0f14;--auth-card:rgba(27,29,35,0.94);--auth-card-2:#15171c;--auth-border:#31343c;--auth-text:#f2f3f5;--auth-muted:#9ca3af;--auth-muted-2:#717784;--auth-input:#111318;--auth-button:#343842;--auth-button-hover:#424854}*{box-sizing:border-box}html,body{min-height:100%}body{margin:0;background:radial-gradient(circle at 20% 20%,rgba(85,90,105,.18),transparent 32%),radial-gradient(circle at 80% 80%,rgba(80,84,96,.14),transparent 30%),var(--auth-bg);color:var(--auth-text);font-family:'Playpen Sans',system-ui,sans-serif}.auth-page{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{width:min(430px,100%);padding:34px;border:1px solid var(--auth-border);border-radius:22px;background:linear-gradient(180deg,var(--auth-card),var(--auth-card-2));box-shadow:0 24px 70px rgba(0,0,0,.48);text-align:center}.auth-badge{display:inline-flex;padding:8px 13px;border:1px solid var(--auth-border);border-radius:999px;color:var(--auth-muted);background:rgba(255,255,255,.035);font-size:13px;margin-bottom:16px}.auth-card h1{margin:0 0 10px;font-size:30px;letter-spacing:-0.03em}.auth-subtitle{margin:0 0 24px;color:var(--auth-muted);font-size:14px}.auth-error{margin-bottom:16px;padding:12px 14px;border-radius:12px;background:rgba(239,68,68,.10);border:1px solid rgba(239,68,68,.28);color:#fca5a5;font-size:13px}.auth-form{display:grid;gap:15px}.auth-field{display:grid;gap:8px;text-align:left;color:var(--auth-muted);font-size:13px;font-weight:700}.auth-field input{width:100%;height:48px;padding:0 14px;border-radius:13px;border:1px solid #2d3038;background:var(--auth-input);color:var(--auth-text);outline:none;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.auth-field input:focus{border-color:#5b6270;box-shadow:0 0 0 4px rgba(120,128,145,.12);background:#14171d}.auth-password-control{position:relative;width:100%}.auth-password-control input{padding-right:52px}.password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:36px;height:36px;padding:0;border:0;border-radius:11px;background:transparent;color:var(--auth-muted);display:grid;place-items:center;cursor:pointer;box-shadow:none;transition:background .18s ease,color .18s ease}.password-toggle:hover,.password-toggle:focus-visible{background:rgba(255,255,255,.06);color:var(--auth-text);outline:none}.password-toggle svg{width:18px;height:18px;fill:currentColor;display:block}.password-toggle .eye-closed{display:none}.password-toggle.is-visible .eye-open{display:none}.password-toggle.is-visible .eye-closed{display:block}.auth-submit,.discord-link{width:100%;min-height:48px;border-radius:13px;display:inline-flex;align-items:center;justify-content:center;gap:10px;box-sizing:border-box;text-decoration:none;font-family:inherit;font-weight:800;cursor:pointer;transition:transform .18s ease,filter .18s ease,box-shadow .18s ease}.auth-submit{margin-top:4px;border:1px solid #4b515d;background:linear-gradient(180deg,var(--auth-button-hover),var(--auth-button));color:#fff;box-shadow:0 12px 28px rgba(0,0,0,.24)}.auth-submit:hover,.discord-link:hover{transform:translateY(-1px);filter:brightness(1.08)}.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--auth-muted-2);font-size:12px}.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--auth-border)}.discord-link{border:1px solid var(--auth-border);background:rgba(255,255,255,.04);color:var(--auth-text)}.discord-icon{width:20px;height:20px;fill:currentColor}.footer-text{margin:20px 0 0;font-size:12px;color:var(--auth-muted-2);line-height:1.45}@media (max-width:480px){.auth-card{padding:26px 20px}.auth-card h1{font-size:26px}}