:root{color:#0f172a;background:#f1f5f9;font-family:Segoe UI,system-ui,sans-serif;line-height:1.5}*{box-sizing:border-box}body{min-height:100vh;margin:0}a{color:#1d4ed8}code{font-family:ui-monospace,monospace}.app-shell{grid-template-columns:minmax(220px,260px) 1fr;min-height:100vh;display:grid}.sidebar{color:#e2e8f0;background:#0f172a;border-right:1px solid #1e293b;flex-direction:column;min-height:100vh;padding:.875rem .65rem;display:flex}.sidebar-top{flex-direction:column;flex:1;min-height:0;display:flex;overflow:auto}.brand{letter-spacing:-.02em;border-bottom:1px solid #1e293b;margin-bottom:.5rem;padding:.35rem .5rem .85rem;font-size:1rem;font-weight:700}.nav{flex-direction:column;flex:1;gap:.65rem;padding-bottom:.5rem;display:flex}.nav-section:first-of-type .nav-section-title{margin-top:0}.nav-section-title{letter-spacing:.06em;text-transform:uppercase;color:#64748b;margin-top:.15rem;padding:.35rem .5rem .2rem;font-size:.65rem;font-weight:600}.nav-list{flex-direction:column;gap:.1rem;margin:0;padding:0;list-style:none;display:flex}.nav-link{color:#cbd5e1;border-radius:6px;padding:.38rem .5rem;font-size:.875rem;line-height:1.3;text-decoration:none;display:block}.nav-link:hover{color:#fff;background:#1e293b}.nav-link.active{color:#fff;background:#1d4ed8;font-weight:500}.sidebar-logout{text-align:left;border-top:1px solid #1e293b;flex-shrink:0;width:100%;margin-top:.5rem;padding-top:.65rem}.main{padding:1.25rem 1.5rem 2rem;overflow:auto}.panel{background:#fff;border-radius:10px;max-width:1200px;padding:1.25rem;box-shadow:0 1px 3px #0f172a14}.panel h1{margin-top:0;font-size:1.35rem}.grid2{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;display:grid}.field{flex-direction:column;gap:.25rem;margin-bottom:.65rem;display:flex}.field label{color:#475569;font-size:.85rem}input,select,textarea{font:inherit;border:1px solid #cbd5e1;border-radius:6px;padding:.45rem .5rem}table{border-collapse:collapse;width:100%;font-size:.9rem}th,td{text-align:left;border-bottom:1px solid #e2e8f0;padding:.45rem .35rem}th{color:#64748b;font-weight:600}.btn{font:inherit;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:.4rem .75rem}.btn.primary{color:#fff;background:#2563eb;border-color:#1d4ed8}.btn.danger{color:#b91c1c;background:#fef2f2;border-color:#fecaca}.btn.ghost{color:#e2e8f0;background:0 0;border-color:#0000}.btn.ghost:hover{background:#1e293b}.form-actions{gap:.5rem;margin-top:.5rem;display:flex}.muted{color:#64748b;font-size:.9rem}.error{color:#b91c1c;white-space:pre-wrap}.login-wrap{place-items:center;min-height:100vh;padding:1rem;display:grid}.login-card{background:#fff;border-radius:12px;width:100%;max-width:380px;padding:1.5rem;box-shadow:0 10px 40px #0f172a1f}.login-card h1{margin-top:0}
