@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@latest/dist/web/static/pretendard.min.css");:root{--bg:#f6f7f9;--surface:#ffffff;--surface-2:#f9fafb;--border:#eaecef;--border-strong:#dfe2e7;--text:#1c2024;--muted:#6b7280;--muted-2:#9aa1ac;--primary:#2f6bf6;--primary-weak:#eef3ff;--primary-ink:#1d4ed8;--green:#0f9d6b;--green-bg:#e7f6ef;--red:#d64545;--red-bg:#fdecec;--amber:#b9750a;--amber-bg:#fdf3e3;--blue:#2f6bf6;--blue-bg:#eaf1ff;--radius:12px;--sidebar-w:232px}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}a{color:var(--primary);text-decoration:none}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:18px 14px}.brand{display:flex;align-items:center;gap:10px;padding:4px 8px 18px}.brand-logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#3b6ef6,#5b8cff);display:grid;place-items:center;color:#fff;flex-shrink:0}.brand-name{font-weight:700;font-size:15px;letter-spacing:-.2px}.brand-sub{font-size:11px;color:var(--muted-2)}.nav-group{margin-top:14px}.nav-label{font-size:10.5px;font-weight:600;color:var(--muted-2);letter-spacing:.06em;text-transform:uppercase;padding:0 10px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;color:#41474e;font-weight:500;font-size:13.5px;cursor:pointer;margin-bottom:2px}.nav-item:hover{background:var(--surface-2)}.nav-item.active{background:var(--primary-weak);color:var(--primary-ink);font-weight:600}.nav-item svg{width:17px;height:17px;opacity:.9}.sidebar-foot{margin-top:auto;border-top:1px solid var(--border);padding-top:12px}.stat-row{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);padding:3px 10px}.stat-row b{color:var(--text);font-weight:700}.main{flex:1 1;min-width:0;display:flex;flex-direction:column}.topbar{height:60px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:5}.topbar h1{font-size:17px;font-weight:700;margin:0;letter-spacing:-.3px}.topbar-spacer{flex:1 1}.user-chip{display:flex;align-items:center;gap:9px}.avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700}.user-meta{line-height:1.15}.user-meta .em{font-size:12.5px;font-weight:600}.user-meta .ro{font-size:11px;color:var(--muted-2)}.icon-btn{background:none;border:none;color:var(--muted);cursor:pointer;padding:6px;border-radius:8px;display:grid;place-items:center}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.content{padding:24px;max-width:1400px;width:100%}.page-sub{color:var(--muted);font-size:13px;margin:-4px 0 16px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:0;overflow:hidden}.card-pad{padding:18px}table{border-collapse:collapse;width:100%;font-size:13.5px}thead th{background:var(--surface-2);color:var(--muted);font-weight:600;font-size:12px;text-align:left;white-space:nowrap}tbody td,thead th{padding:11px 14px;border-bottom:1px solid var(--border)}tbody td{color:var(--text)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--surface-2)}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:600}.badge.green{background:var(--green-bg);color:var(--green)}.badge.red{background:var(--red-bg);color:var(--red)}.badge.amber{background:var(--amber-bg);color:var(--amber)}.badge.blue{background:var(--blue-bg);color:var(--blue)}.badge.gray{background:#eef0f3;color:#6b7280}.btn,button{font-family:inherit;font-size:13px;font-weight:600;padding:8px 14px;border-radius:9px;border:1px solid var(--primary);background:var(--primary);color:#fff;cursor:pointer;transition:.12s}button:hover{filter:brightness(.96)}button:disabled{opacity:.5;cursor:default}button.ghost{background:var(--surface);color:var(--text);border-color:var(--border-strong)}button.sm{padding:5px 10px;font-size:12px;border-radius:7px}input,select{font-family:inherit;font-size:13.5px;padding:8px 11px;border:1px solid var(--border-strong);border-radius:9px;background:var(--surface);color:var(--text);outline:none}input:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-weak)}input[type=number]{width:88px}.search{width:320px;max-width:100%}.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:16px;gap:16px}.tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:block;color:inherit;transition:.14s}.tile:hover{border-color:var(--primary);box-shadow:0 6px 20px rgba(47,107,246,.08);transform:translateY(-1px)}.tile-ic{width:38px;height:38px;border-radius:10px;background:var(--primary-weak);color:var(--primary-ink);display:grid;place-items:center;margin-bottom:12px}.tile-t{font-weight:700;font-size:15px}.tile-d{font-size:12.5px;color:var(--muted);margin-top:3px}.login-wrap{min-height:100vh;display:grid;place-items:center;background:var(--bg)}.login-card{width:360px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px}.login-card input{width:100%;margin:6px 0}.login-card button{width:100%;margin-top:8px}