/* assets/css/auth.css */
:root { --bg0:#0b0f1a; --bg1:#0f172a; --panel:rgba(12,14,20,.72); --line:rgba(255,255,255,.10); --line2:rgba(255,255,255,.06); --txt:rgba(255,255,255,.92); --mut:rgba(255,255,255,.62); --mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace; }
html, body{ height:100%; }
body{ margin:0; color:var(--txt); overflow:hidden; background:radial-gradient(900px 600px at 18% 18%, rgba(79,193,255,.14), transparent 60%), radial-gradient(820px 560px at 82% 28%, rgba(168,85,247,.12), transparent 60%), radial-gradient(900px 560px at 40% 92%, rgba(34,197,94,.08), transparent 55%), linear-gradient(180deg, var(--bg0), var(--bg1)); }

.stage{ height:calc(100% - 44px); display:grid; place-items:center; padding:22px 14px; }
.window{ width:min(900px, 100%); border:1px solid var(--line); border-radius:16px; overflow:hidden; background:var(--panel); box-shadow:0 26px 80px rgba(0,0,0,.55), 0 1px 0 rgba(255,255,255,.04) inset; backdrop-filter:blur(10px); }
.titlebar{ display:flex; align-items:center; justify-content:space-between; padding:10px 12px; border-bottom:1px solid var(--line2); background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02)); gap:10px; }
.dots{ display:flex; gap:8px; align-items:center; flex:0 0 auto; } .dot{ width:10px; height:10px; border-radius:50%; }
.dot.red{ background:#ff5f57; } .dot.yel{ background:#febc2e; } .dot.grn{ background:#28c840; }
.pill{ font-family:var(--mono); font-size:12px; color:var(--mut); border:1px solid var(--line2); background:rgba(255,255,255,.03); padding:4px 8px; border-radius:999px; white-space:nowrap; }

.content{ display:grid; grid-template-columns: 1.2fr 0.8fr; min-height:480px; }
.left{ padding:32px; border-right:1px solid var(--line2); background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01)); }
.right{ padding:32px; background:radial-gradient(520px 240px at 30% 10%, rgba(79,193,255,.10), transparent 60%), radial-gradient(520px 240px at 80% 85%, rgba(168,85,247,.10), transparent 60%); display:flex; flex-direction:column; justify-content:center; }

h1{ margin:0 0 8px 0; font-size:24px; font-weight:800; letter-spacing:-0.5px; }
.subtitle{ margin:0 0 24px 0; color:var(--mut); font-size:14px; line-height:1.5; }

.msg{ border-radius:10px; padding:10px 12px; border:1px solid var(--line2); background:rgba(255,255,255,.03); font-size:13px; margin:0 0 16px 0; font-family:var(--mono); }
.msg.bad{ border-color:rgba(239,68,68,.35); background:rgba(239,68,68,.08); color:#ffaaaa; }
.msg.ok{ border-color:rgba(34,197,94,.32); background:rgba(34,197,94,.10); color:#4ade80; }

.field{ margin-bottom:16px; }
.label{ font-size:12px; color:var(--mut); margin-bottom:6px; font-family:var(--mono); font-weight:700; text-transform:uppercase; letter-spacing:0.5px; }
.input2{ width:100%; padding:12px; border-radius:10px; border:1px solid var(--line2); background:rgba(255,255,255,.05); color:var(--txt); outline:none; font-size:14px; font-family:var(--mono); box-sizing:border-box; transition:border-color 0.2s; }
.input2:focus{ border-color:rgba(79,193,255,.55); box-shadow:0 0 0 4px rgba(79,193,255,.14); background:rgba(255,255,255,.08); }

.actions{ display:flex; gap:12px; align-items:center; flex-wrap:wrap; margin-top:24px; }

/* FIX: Added missing closing parenthesis at the end of the linear-gradient below */
.btnPrimary{ display:inline-flex; align-items:center; justify-content:center; gap:10px; padding:12px 18px; border-radius:10px; border:1px solid rgba(79,193,255,.32); background:linear-gradient(180deg, rgba(79,193,255,.22), rgba(79,193,255,.12)); color:#e8f7ff; cursor:pointer; font-weight:900; font-size:14px; font-family:var(--mono); box-shadow:0 14px 30px rgba(0,0,0,.24); transition:all 0.15s; }
.btnPrimary:hover{ filter:brightness(1.06); transform:translateY(-1px); }

.btnGhost{ display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 18px; border-radius:10px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.03); color:rgba(255,255,255,.86); cursor:pointer; font-weight:700; font-size:13px; font-family:var(--mono); text-decoration:none; transition:background 0.15s; }
.btnGhost:hover{ background:rgba(255,255,255,.08); color:#fff; }

.role-card { border:1px solid var(--line2); border-radius:12px; background:rgba(255,255,255,.03); padding:16px; margin-bottom:16px; }
.role-title { font-weight:800; font-size:14px; margin-bottom:6px; display:flex; align-items:center; gap:8px; }
.role-desc { font-size:13px; color:var(--mut); line-height:1.5; }
.role-icon { font-size:18px; }

.topbar{ border-bottom:1px solid rgba(255,255,255,.08) !important; background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)) !important; backdrop-filter:blur(10px); box-shadow:0 10px 30px rgba(0,0,0,.20); display:flex; justify-content:space-between; padding:0 20px; height:44px; align-items:center; }
.brand{ display:flex; gap:12px; align-items:center; }
.badge{ border:1px solid rgba(255,255,255,.10) !important; background:rgba(255,255,255,.03) !important; color:rgba(255,255,255,.82) !important; font-family:var(--mono) !important; padding:4px 8px; border-radius:6px; font-size:12px; }

@media (max-width: 800px){ body{ overflow:auto; } .stage{ height:auto; display:block; } .content{ grid-template-columns:1fr; } .left{ border-right:0; border-bottom:1px solid var(--line2); } }