:root{--navy:#062451;--navy2:#0c356d;--teal:#12aaa4;--teal2:#0e8e89;--bg:#f4f7fb;--text:#16213a;--muted:#657083;--border:#e4eaf2;--white:#fff;--shadow:0 12px 34px rgba(6,36,81,.10);--radius:18px}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:inherit}.login-page{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;background:linear-gradient(135deg,#061f49,#07386d)}.login-brand{padding:70px;color:#fff;display:flex;flex-direction:column;justify-content:center;background:linear-gradient(90deg,rgba(6,36,81,.92),rgba(6,36,81,.58)),url('logo.png') center/420px no-repeat}.login-brand img{width:240px;margin-bottom:30px}.login-brand h1{font-size:48px;line-height:1.05;margin:0 0 18px}.login-brand p{font-size:18px;color:#dbe9ff;max-width:620px}.login-card-wrap{display:flex;align-items:center;justify-content:center;padding:30px;background:#f8fbff}.login-card{width:min(460px,100%);background:#fff;border-radius:24px;padding:34px;box-shadow:var(--shadow)}.login-card h2{margin:0 0 8px;color:var(--navy);font-size:32px}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:700;margin-bottom:7px;color:var(--navy)}input,select,textarea{width:100%;padding:12px 14px;border:1px solid #d8e2ef;border-radius:12px;font:inherit;background:#fff}textarea{min-height:100px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border:0;border-radius:12px;background:var(--teal);color:#fff;font-weight:800;cursor:pointer}.btn:hover{background:var(--teal2)}.btn.secondary{background:#edf3fb;color:var(--navy)}.btn.danger{background:#d83535}.btn.small{padding:8px 12px;font-size:13px}.full{width:100%}.topbar{height:74px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:5}.topbar .brand{display:flex;align-items:center;gap:12px}.topbar .brand img{height:54px;width:auto}.topbar .brand strong{font-size:20px;color:var(--navy)}.layout{display:grid;grid-template-columns:280px 1fr;min-height:calc(100vh - 74px)}.sidebar{background:var(--navy);color:#fff;padding:20px 14px}.sidebar a{display:flex;align-items:center;gap:11px;padding:12px 14px;border-radius:12px;color:#dce9ff;margin-bottom:4px;font-weight:600}.sidebar a:hover,.sidebar a.active{background:#0d3c78;color:#fff}.content{padding:28px;overflow:auto}.module-hero{background:linear-gradient(135deg,var(--navy),var(--navy2));border-radius:22px;color:#fff;padding:26px 30px;margin-bottom:22px;box-shadow:var(--shadow)}.module-hero h1,.module-hero h3{margin:0 0 6px}.module-hero p{margin:0;color:#dbe9ff}.grid{display:grid;gap:18px}.grid.cols-2{grid-template-columns:repeat(2,1fr)}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-4{grid-template-columns:repeat(4,1fr)}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:18px}.stat h2{font-size:34px;margin:8px 0 0;color:var(--navy)}.muted{color:var(--muted)}.table-wrap{overflow:auto;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}table{width:100%;border-collapse:collapse}th,td{padding:13px 14px;border-bottom:1px solid #eef2f7;text-align:left;vertical-align:top}th{background:#f8fbff;color:var(--navy);font-size:13px;text-transform:uppercase;letter-spacing:.03em}.badge{display:inline-block;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:800;background:#eef3fb;color:#24415f}.badge.good{background:#e9f9ef;color:#11743b}.badge.warn{background:#fff4d7;color:#9d6700}.badge.danger{background:#ffe8e8;color:#a21d1d}.actions{display:flex;gap:8px;flex-wrap:wrap}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-grid .span2{grid-column:1/-1}.alert{padding:13px 16px;border-radius:12px;margin-bottom:16px;font-weight:700}.alert-success{background:#eaf8ee;color:#156b33}.alert-danger{background:#ffe9e9;color:#9b1c1c}.alert-warning{background:#fff6dd;color:#946200}.permission-table input{width:auto}.mobile-toggle{display:none}.footer-note{color:#8290a6;text-align:center;padding:20px}@media(max-width:900px){.login-page{grid-template-columns:1fr}.login-brand{display:none}.layout{grid-template-columns:1fr}.sidebar{display:none}.sidebar.open{display:block}.mobile-toggle{display:inline-flex}.grid.cols-2,.grid.cols-3,.grid.cols-4,.form-grid{grid-template-columns:1fr}.form-grid .span2{grid-column:auto}.content{padding:18px}.topbar{padding:0 14px}.topbar .brand img{height:44px}}