*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0b1020;color:#111827}#root{min-height:100vh}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}.container{max-width:1080px;margin:0 auto;padding:1.5rem}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;overflow:auto;background:#f1f5f9}.sidebar{width:240px;min-height:100vh;background:#0f172a;color:#e2e8f0;display:flex;flex-direction:column;flex-shrink:0;border-right:1px solid rgba(148,163,184,.2)}.sidebar-brand{padding:1.25rem 1.25rem 1rem;font-weight:700;font-size:1.1rem;letter-spacing:.02em;border-bottom:1px solid rgba(148,163,184,.15)}.sidebar-nav{flex:1;padding:1rem 0;display:flex;flex-direction:column;gap:.25rem}.sidebar-nav a{color:#94a3b8;padding:.6rem 1.25rem;font-size:.95rem;text-decoration:none;transition:color .15s,background .15s;border-left:3px solid transparent}.sidebar-nav a:hover{color:#f1f5f9;background:#3b82f61f}.sidebar-nav a.active{color:#60a5fa;background:#3b82f626;border-left-color:#3b82f6}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid rgba(148,163,184,.15);display:flex;flex-direction:column;gap:.5rem}.sidebar-user{font-size:.8rem;color:#94a3b8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout{width:100%;padding:.5rem;font-size:.85rem;background:#334155;color:#e2e8f0;border:none;border-radius:8px;cursor:pointer}.sidebar-logout:hover{background:#475569}button,input,select,textarea{font:inherit;padding:.55rem .75rem;margin:.25rem 0}button{cursor:pointer;background:#2563eb;color:#fff;border:none;border-radius:999px;padding-inline:1.5rem;font-weight:500;box-shadow:0 10px 15px #2563eb40;transition:background .15s ease,transform .08s ease,box-shadow .15s ease}button:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 18px 25px #2563eb4d}button:active{transform:translateY(0);box-shadow:0 6px 12px #2563eb33}button.secondary{background:#4b5563;box-shadow:none}button.secondary:hover{background:#374151}.card{background:#fff;border-radius:18px;padding:1.75rem;margin:1.5rem 0;box-shadow:0 20px 45px #0f172a40}h1,h2{margin-top:0;color:#0f172a}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2.5rem 1.25rem;background:radial-gradient(circle at top left,#1d4ed8 0,#020617 55%)}.auth-shell{width:100%;max-width:980px;display:grid;grid-template-columns:1.2fr 1fr;gap:0;background:#0f172abf;border-radius:26px;overflow:hidden;box-shadow:0 35px 80px #0000008c;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid rgba(148,163,184,.18)}.auth-visual{position:relative;padding:2rem;color:#e5e7eb;display:flex;flex-direction:column;justify-content:space-between;background-image:linear-gradient(135deg,#2563eb1a,#082f49f2),url(https://images.pexels.com/photos/958545/pexels-photo-958545.jpeg?auto=compress&cs=tinysrgb&w=1600);background-size:cover;background-position:center}.auth-visual-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top left,rgba(59,130,246,.6),transparent 55%),linear-gradient(to bottom right,#0f172ad9,#0f172ad9);mix-blend-mode:multiply}.auth-visual-content{position:relative;z-index:1}.auth-logo{font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:.9rem;color:#bfdbfe;margin-bottom:.75rem}.auth-title{font-size:2.1rem;font-weight:700;line-height:1.15;margin-bottom:.9rem;color:#f9fafb}.auth-subtitle{font-size:.98rem;color:#cbd5f5;max-width:260px}.auth-highlight-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin-top:1.4rem}.auth-pill{padding:.5rem .8rem;border-radius:999px;background:#0f172abf;border:1px solid rgba(148,163,184,.35);font-size:.78rem;display:inline-flex;align-items:center;gap:.35rem;color:#e5e7eb}.auth-pill-dot{width:6px;height:6px;border-radius:999px;background:#22c55e;box-shadow:0 0 8px #22c55ee6}.auth-footer-text{font-size:.8rem;color:#9ca3af;margin-top:1.75rem}.auth-form-wrapper{background:#f9fafb;padding:2.25rem 2.25rem 2.5rem;display:flex;flex-direction:column;justify-content:center}.auth-form-header{margin-bottom:1.5rem}.auth-form-title{font-size:1.5rem;font-weight:600;margin-bottom:.25rem;color:#0f172a}.auth-form-subtitle{font-size:.9rem;color:#6b7280}.auth-form-subtitle a{color:#2563eb;font-weight:500}.auth-form{display:flex;flex-direction:column;gap:.9rem}.auth-field label{display:block;margin-bottom:.25rem;font-size:.85rem;font-weight:500;color:#4b5563}.auth-field input{width:100%;border-radius:999px;border:1px solid #d1d5db;padding-inline:1rem;background:#fff;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease}.auth-field input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 1px #2563eb4d;background:#f9fafb}.auth-actions{margin-top:.75rem;display:flex;flex-direction:column;gap:.75rem}.auth-error{background:#fef2f2;color:#b91c1c;border-radius:999px;padding:.55rem .9rem;font-size:.82rem;border:1px solid #fecaca;margin-bottom:.4rem}.auth-muted{font-size:.8rem;color:#6b7280}.auth-muted strong{color:#111827}@media (max-width: 880px){.auth-shell{grid-template-columns:1fr}.auth-visual{display:none}.auth-form-wrapper{padding:2rem 1.5rem 2.25rem}}@media (max-width: 600px){.container{padding-inline:1rem}.auth-page{padding-inline:.75rem;padding-block:1.75rem}}
