:root{--bg:#f4f7fb;--panel:#ffffff;--text:#17212f;--muted:#6b7280;--primary:#172554;--primary2:#1d4ed8;--border:#dbe2ea;--danger:#b91c1c;--ok:#166534}
*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none}
.login-body{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(180deg,#f8fafc,#eaf0f8)}
.login-wrap{max-width:1120px;width:100%;display:grid;grid-template-columns:1.15fr .85fr;gap:24px}.brand-panel,.form-panel,.box,.stat-card,.modal-card{background:var(--panel);border:1px solid var(--border);border-radius:22px;box-shadow:0 8px 30px rgba(0,0,0,.05)}
.brand-panel{padding:34px}.brand-panel h1{font-size:42px;margin:12px 0}.brand-panel p{color:var(--muted);line-height:1.7}.pill,.role-badge,.tag-pill,.danger-badge,.muted-badge{display:inline-block;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:700}.pill,.role-badge,.tag-pill,.muted-badge{background:#eef2ff;color:#312e81}.danger-badge{background:#fee2e2;color:#991b1b}.info-card{margin-top:18px;padding:16px;border-radius:18px;background:#f8fafc;border:1px solid var(--border)}
.form-panel{padding:30px}.form-grid{display:grid;gap:12px}label{font-size:14px;font-weight:700}input,select,textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:14px;background:#fff;font-size:14px}textarea{min-height:96px;resize:vertical}
button,.primary-btn,.outline-btn,.small-btn{cursor:pointer;border:none;border-radius:14px;padding:12px 16px;font-weight:700}.primary-btn,button[type='submit']{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff}.outline-btn,.small-btn{background:#fff;border:1px solid var(--border);color:var(--text)}.danger-btn{color:#fff;background:var(--danger)}.small-btn{padding:8px 10px}.hint-box,.flash{margin-top:14px;padding:14px;border-radius:14px}.hint-box{background:#f8fafc;border:1px solid var(--border)}.flash{border:1px solid var(--border)}.flash.success{background:#ecfdf5;color:var(--ok)}.flash.error{background:#fef2f2;color:var(--danger)}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 28px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.topbar h1{margin:0 0 3px 0;font-size:22px}.topbar p{margin:0;color:var(--muted)}.topbar-actions{display:flex;gap:10px;align-items:center}
.container{max-width:1500px;margin:0 auto;padding:24px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.stats-grid.six{grid-template-columns:repeat(3,1fr)}.stat-card{padding:20px}.stat-card small{color:var(--muted)}.stat-card h3{font-size:28px;margin:8px 0}.stat-card p{margin:0;color:var(--muted)}
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin:24px 0}.tab-btn{background:#fff;border:1px solid var(--border);padding:12px 16px;border-radius:14px;font-weight:700}.tab-btn.active{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff}.panel{display:none}.active-panel{display:block}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}.box{padding:24px}.box p{color:var(--muted);line-height:1.7}.panel-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin:18px 0}.panel-head h2{margin:0 0 4px 0}.panel-head p{margin:0;color:var(--muted)}
.table-wrap{overflow:auto;background:#fff;border:1px solid var(--border);border-radius:20px}table{width:100%;border-collapse:collapse;min-width:980px}th,td{padding:14px;border-bottom:1px solid #edf2f7;text-align:left;vertical-align:top}th{background:#f8fafc}.action-cell{display:flex;gap:8px;align-items:center}form{margin:0}.inline-form{display:flex;gap:10px;max-width:620px}.tags-wrap{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.modal{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:center;justify-content:center;padding:22px}.hidden{display:none}.modal-card{width:min(920px,100%);padding:22px}.modal-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.grid-1{display:grid;gap:14px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:1100px){.stats-grid,.stats-grid.six,.two-col,.login-wrap,.grid-2{grid-template-columns:1fr}.container{padding:16px}.topbar{padding:16px}}
@media print{.no-print,.topbar-actions,.tabs{display:none!important}body{background:#fff}.box,.stat-card,.table-wrap{box-shadow:none}}
