:root{
  --bg:#f4f5f7;--panel:#fff;--line:#e6e8eb;--ink:#1f2937;--muted:#6b7280;
  --sidebar:#20242e;--sb-ink:#c4c9d4;--accent:#e6a700;--accent-d:#cf9500;--accent-soft:#fff8e6;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Malgun Gothic",sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
.app{display:flex;min-height:100vh}
.sidebar{width:218px;background:var(--sidebar);flex-shrink:0;display:flex;flex-direction:column}
.sidebar .logo{padding:19px 22px;font-size:16px;font-weight:700;color:#fff;letter-spacing:-.3px;display:flex;align-items:center;gap:9px;border-bottom:1px solid rgba(255,255,255,.07)}
.mark{width:20px;height:20px;background:var(--accent);border-radius:5px;display:inline-block;flex-shrink:0}
.sidebar nav{padding:8px 0;display:flex;flex-direction:column}
.sidebar nav a{padding:10px 22px;font-size:13.5px;color:var(--sb-ink);border-left:3px solid transparent}
.sidebar nav a:hover{background:rgba(255,255,255,.05);color:#fff}
.sidebar nav a.on{background:rgba(230,167,0,.13);color:#fff;border-left-color:var(--accent);font-weight:600}
.sidebar nav a.disabled{color:#5b616e;cursor:default}
.sidebar nav a.disabled:hover{background:none;color:#5b616e}
.sidebar nav .group{padding:15px 22px 5px;font-size:11px;letter-spacing:.4px;color:#6b7280;font-weight:600}
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{background:var(--panel);border-bottom:1px solid var(--line);height:57px;display:flex;align-items:center;justify-content:space-between;padding:0 26px}
.topbar h1{font-size:16px;font-weight:600;margin:0}
.topbar .user{display:flex;align-items:center;gap:13px;font-size:13px;color:var(--muted)}
.topbar .user form{margin:0}
.topbar .user .uname{font-weight:600;color:var(--ink)}
.topbar .user button{background:none;border:1px solid var(--line);border-radius:6px;padding:6px 13px;font-size:13px;color:var(--ink);cursor:pointer}
.topbar .user button:hover{background:var(--bg)}
.content{padding:24px 26px;flex:1}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.metric{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px 18px}
.metric .label{font-size:12.5px;color:var(--muted)}
.metric .value{font-size:25px;font-weight:700;margin-top:5px;letter-spacing:-.5px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:10px;margin-bottom:20px;overflow:hidden}
.panel-head{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid var(--line)}
.panel-head h2{font-size:14.5px;font-weight:600;margin:0}
.panel-body{padding:20px}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;font-size:12px;font-weight:600;color:var(--muted);padding:11px 16px;border-bottom:1px solid var(--line);background:#fafbfc}
tbody td{padding:13px 16px;border-bottom:1px solid var(--line);font-size:13.5px}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fafbfc}
.row-actions{text-align:right;white-space:nowrap}
.row-actions form{display:inline}
.empty{text-align:center;color:var(--muted);padding:44px 0}
.btn{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#3a2e00;font-weight:600;border:none;border-radius:7px;padding:9px 16px;font-size:13.5px;cursor:pointer;transition:background .12s}
.btn:hover{background:var(--accent-d)}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink);font-weight:500}
.btn.ghost:hover{background:var(--bg)}
.btn.danger{background:#fff;border:1px solid #f0caca;color:#c0392b;font-weight:500}
.btn.danger:hover{background:#fdf2f2}
.btn.sm{padding:5px 11px;font-size:12.5px}
.form-row{margin-bottom:15px}
.form-row label{display:block;font-size:13px;color:var(--ink);font-weight:500;margin-bottom:6px}
.form-row input{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:7px;font-size:14px;background:#fff}
.form-row input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.form-actions{display:flex;gap:10px;margin-top:8px}
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#20242e}
.login-box{background:#fff;border-radius:14px;padding:38px 34px;width:340px;box-shadow:0 12px 44px rgba(0,0,0,.28)}
.login-logo{font-size:21px;font-weight:700;text-align:center;letter-spacing:-.3px;display:flex;align-items:center;justify-content:center;gap:8px}
.login-sub{text-align:center;color:var(--muted);font-size:13px;margin:7px 0 26px}
.login-box input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:8px;font-size:14px;margin-bottom:11px}
.login-box input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.login-box button{width:100%;padding:12px;background:var(--accent);color:#3a2e00;font-weight:700;border:none;border-radius:8px;font-size:15px;cursor:pointer;margin-top:4px}
.login-box button:hover{background:var(--accent-d)}
.login-err{color:#c0392b;font-size:13px;text-align:center;margin:14px 0 0}
.login-ok{color:#1d9e75;font-size:13px;text-align:center;margin:14px 0 0}
@media(max-width:760px){.metrics{grid-template-columns:repeat(2,1fr)}}

/* logo */
.logo-img{width:26px;height:26px;border-radius:6px;background:#fff;object-fit:contain;display:block;flex-shrink:0}
.login-head{text-align:center;margin-bottom:18px}
.login-logo-img{width:60px;height:60px;border-radius:14px;background:#fff;object-fit:contain;display:block;margin:0 auto 8px;border:1px solid var(--line)}
.login-title{font-size:21px;font-weight:700;letter-spacing:-.3px}
.login-desc{font-size:12.5px;color:var(--muted);text-align:center;line-height:1.6;margin:0 0 20px;padding:12px 14px;background:var(--accent-soft);border-radius:8px}
.login-desc b{color:#7a5b00}
.login-foot{text-align:center;font-size:11.5px;color:#9aa0a8;margin:20px 0 0;letter-spacing:.3px}
.logo-img{width:30px;height:30px}
.login-logo-img{width:84px;height:84px;border:none;border-radius:0;margin:0 auto 6px}
.user .agency{background:var(--accent-soft);color:#7a5b00;font-weight:600;padding:5px 11px;border-radius:20px;font-size:12.5px}
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}
.b-gray{background:#eef0f2;color:#5f6672}
.b-blue{background:#e6f1fb;color:#185fa5}
.b-green{background:#eaf3de;color:#3b6d11}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.radio-row{display:flex;gap:18px;padding-top:4px}
.radio{display:flex;align-items:center;gap:6px;font-weight:400;font-size:14px;cursor:pointer}
.radio input{width:auto}
.err{display:block;color:#c0392b;font-size:12px;margin-top:5px}
.form-row input:invalid{border-color:#f0caca}
.link{color:#185fa5;font-weight:500}
.kv{width:100%;border-collapse:collapse}
.kv th{text-align:left;width:88px;color:var(--muted);font-weight:500;font-size:12.5px;padding:9px 12px;background:#fafbfc;border:1px solid var(--line)}
.kv td{padding:9px 12px;border:1px solid var(--line);font-size:13.5px}
.assign-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.assign-form select{padding:9px 12px;border:1px solid var(--line);border-radius:7px;font-size:14px;min-width:240px;background:#fff}
.alert-err{background:#fdf2f2;border:1px solid #f0caca;color:#c0392b;padding:10px 14px;border-radius:8px;margin-bottom:14px;font-size:13.5px}
.kv tbody tr:last-child th, .kv tbody tr:last-child td{border-bottom:1px solid var(--line)}
