@import "https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg:#0f1117;--bg2:#161b27;--bg3:#1e2535;--border:#2a3347;--text:#e2e8f0;--text2:#89a;--text3:#567;--accent:#3b82f6;--accent2:#60a5fa;--accent-dim:#3b82f61f;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--header-h:56px;--sidebar-w:220px;--radius:8px;--radius-lg:12px;--shadow:0 2px 8px #0000004d;--font:"Noto Sans KR", sans-serif;--font-mono:"JetBrains Mono", monospace;--transition:.18s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select{font-family:inherit}.app-layout{flex-direction:column;height:100%;display:flex}.app-body{margin-top:var(--header-h);flex:1;display:flex;overflow:hidden}.app-main{flex:1;padding:28px;overflow-y:auto}.header{height:var(--header-h);background:var(--bg2);border-bottom:1px solid var(--border);z-index:100;position:fixed;top:0;left:0;right:0}.header-inner{justify-content:space-between;align-items:center;height:100%;padding:0 24px;display:flex}.header-logo{color:var(--accent2);align-items:center;gap:10px;display:flex}.header-title{letter-spacing:-.3px;color:var(--text);font-size:17px;font-weight:700}.header-sub{color:var(--text3);background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:2px 8px;font-size:11px}.header-right{align-items:center;gap:12px;display:flex}.role-badge{border:1px solid var(--border);color:var(--text2);border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;display:flex}.role-badge[data-role=admin]{border-color:var(--accent);color:var(--accent2);background:var(--accent-dim)}.btn-login{border-radius:var(--radius);background:var(--accent);color:#fff;transition:background var(--transition);align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;display:flex}.btn-login:hover{background:var(--accent2)}.btn-logout{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}.btn-logout:hover{color:var(--text);border-color:var(--text3)}.sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);flex-shrink:0;overflow-y:auto}.sidebar-nav{flex-direction:column;gap:2px;padding:16px 12px;display:flex}.sidebar-link{border-radius:var(--radius);color:var(--text2);transition:all var(--transition);align-items:center;gap:10px;padding:9px 12px;font-size:13.5px;display:flex}.sidebar-link:hover{background:var(--bg3);color:var(--text)}.sidebar-link.active{background:var(--accent-dim);color:var(--accent2);font-weight:500}.page-title{color:var(--text);letter-spacing:-.3px;margin-bottom:24px;font-size:20px;font-weight:700}.page-loading{justify-content:center;align-items:center;height:300px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.card-title{color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:13px;font-weight:500}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}.stat-label{color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:500}.stat-value{color:var(--text);font-size:26px;font-weight:700;font-family:var(--font-mono);letter-spacing:-1px}.stat-sub{color:var(--text3);margin-top:4px;font-size:12px}.stat-up{color:var(--success)}.stat-down{color:var(--danger)}.table-wrap{border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13.5px}thead th{background:var(--bg3);text-align:left;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;padding:10px 14px;font-size:12px;font-weight:600}tbody tr{border-top:1px solid var(--border);transition:background var(--transition)}tbody tr:hover{background:var(--bg3)}tbody td{color:var(--text2);padding:10px 14px}tbody td:first-child{color:var(--text)}.badge{border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.badge-blue{background:var(--accent-dim);color:var(--accent2)}.badge-green{color:var(--success);background:#10b9811f}.badge-yellow{color:var(--warning);background:#f59e0b1f}.badge-red{color:var(--danger);background:#ef44441f}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);width:340px;padding:28px;box-shadow:0 20px 60px #00000080}.modal-title{margin-bottom:6px;font-size:17px;font-weight:700}.modal-desc{color:var(--text2);margin-bottom:18px;font-size:13px}.modal-input{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);transition:border-color var(--transition);outline:none;padding:10px 14px;font-size:14px}.modal-input:focus{border-color:var(--accent)}.modal-error{color:var(--danger);margin-top:8px;font-size:12px}.modal-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.btn-cancel{border-radius:var(--radius);color:var(--text2);background:var(--bg3);border:1px solid var(--border);transition:all var(--transition);padding:8px 16px;font-size:13px}.btn-cancel:hover{color:var(--text)}.btn-confirm{border-radius:var(--radius);background:var(--accent);color:#fff;transition:background var(--transition);padding:8px 20px;font-size:13px;font-weight:500}.btn-confirm:hover{background:var(--accent2)}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.filter-select,.filter-input{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);transition:border-color var(--transition);outline:none;padding:7px 12px;font-size:13px}.filter-select:focus,.filter-input:focus{border-color:var(--accent)}.filter-select option{background:var(--bg2)}.chart-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;padding:20px}.chart-title{color:var(--text);margin-bottom:16px;font-size:14px;font-weight:600}.grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}@media (width<=900px){.grid-2,.grid-3{grid-template-columns:1fr}}.empty-state{color:var(--text3);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-state p{font-size:14px}.pagination{justify-content:center;gap:6px;margin-top:20px;display:flex}.page-btn{border-radius:var(--radius);min-width:32px;height:32px;color:var(--text2);background:var(--bg2);border:1px solid var(--border);transition:all var(--transition);justify-content:center;align-items:center;font-size:13px;display:flex}.page-btn:hover{border-color:var(--accent);color:var(--accent2)}.page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}
