:root{--bg-base: #0a0b0c;--bg-primary: #0f1114;--bg-secondary: #161a1f;--bg-card: #1c2128;--bg-elevated: #232a32;--border: #2d353e;--border-subtle: #252b33;--text: #e8eaed;--text-muted: #8b949e;--text-dim: #6e7681;--accent: #22d3ee;--accent-dim: #0891b2;--accent-glow: rgba(34, 211, 238, .25);--accent-bg: rgba(34, 211, 238, .08);--success: #34d399;--success-bg: rgba(52, 211, 153, .12);--danger: #f87171;--danger-bg: rgba(248, 113, 113, .12);--warning: #fbbf24;--warning-bg: rgba(251, 191, 36, .12);--font-display: "Noto Sans KR", sans-serif;--font-body: "Noto Sans KR", "Malgun Gothic", sans-serif;--text-xs: .7rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.0625rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--ease-out: cubic-bezier(.16, 1, .3, 1);--dur-fast: .15s;--dur-normal: .22s;--dur-slow: .32s}*{box-sizing:border-box}body{font-family:var(--font-body);font-size:var(--text-base);font-weight:400;margin:0;background:var(--bg-base);color:var(--text);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;opacity:.02;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E")}a{color:var(--accent);text-decoration:none;transition:color var(--dur-fast) var(--ease-out)}a:hover{color:var(--accent-dim)}input,select,textarea,button{font-family:inherit;font-size:inherit}input,select,textarea{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-primary);color:var(--text);transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}input::placeholder,textarea::placeholder{color:var(--text-dim)}button{padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);border:none;cursor:pointer;font-weight:500;font-family:var(--font-display);background:var(--accent);color:var(--bg-base);transition:background var(--dur-fast),transform var(--dur-fast),box-shadow var(--dur-fast)}button:hover:not(:disabled){background:var(--accent-dim);box-shadow:0 0 12px var(--accent-glow)}button:active:not(:disabled){transform:scale(.98)}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}button.secondary:hover:not(:disabled){background:var(--border);border-color:var(--border);box-shadow:none}button.danger{background:var(--danger);color:#fff}button.danger:hover:not(:disabled){background:#ef4444;box-shadow:0 0 12px #f871714d}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--bg-secondary);border-right:1px solid var(--border-subtle);padding:var(--space-6) 0;display:flex;flex-direction:column;flex-shrink:0}.sidebar-logo{padding:0 var(--space-6) var(--space-6);font-family:var(--font-display);font-weight:700;font-size:var(--text-xl);letter-spacing:.05em;background:linear-gradient(135deg,var(--accent) 0%,#67e8f9 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.sidebar-nav a{padding:var(--space-3) var(--space-6);color:var(--text-muted);display:flex;align-items:center;gap:var(--space-3);transition:all var(--dur-fast) var(--ease-out);border-left:3px solid transparent;margin-left:0}.sidebar-nav a:hover{color:var(--text);background:var(--accent-bg)}.sidebar-nav a.active{color:var(--accent);background:var(--accent-bg);border-left-color:var(--accent);font-weight:500}.main{flex:1;padding:var(--space-8);overflow-x:auto;animation:pageIn var(--dur-slow) var(--ease-out)}@keyframes pageIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-5);box-shadow:0 1px #0003}.card h3{margin:0 0 var(--space-4);font-family:var(--font-display);font-size:var(--text-base);font-weight:600;color:var(--text);letter-spacing:.02em}.table-wrap{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-5);box-shadow:0 1px #0003}table{width:100%;border-collapse:collapse}th,td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--border-subtle)}th{background:var(--bg-secondary);font-family:var(--font-display);font-weight:500;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}tr:last-child td{border-bottom:none}tr{transition:background var(--dur-fast)}tr:hover td{background:var(--accent-bg)}.stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color var(--dur-fast),box-shadow var(--dur-fast)}.stat-card:hover{border-color:var(--border);box-shadow:0 4px 12px #0003}.stat-card .label{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:.05em}.stat-card .value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;color:var(--text);letter-spacing:-.02em}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:overlayIn var(--dur-normal) var(--ease-out)}.modal-overlay .card{margin:0;min-width:320px;max-width:90vw;animation:modalIn var(--dur-slow) var(--ease-out)}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.alert{padding:var(--space-4);margin-bottom:var(--space-5);border-radius:var(--radius-md);font-size:var(--text-sm);animation:alertIn var(--dur-normal) var(--ease-out)}.alert-success{background:var(--success-bg);border:1px solid rgba(52,211,153,.3);color:var(--success)}.alert-error{background:var(--danger-bg);border:1px solid rgba(248,113,113,.3);color:var(--danger)}@keyframes alertIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.page-title{margin:0 0 var(--space-6);font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;color:var(--text);letter-spacing:-.02em}.loading-wrap{display:flex;align-items:center;justify-content:center;min-height:200px;padding:var(--space-8)}.loading-full{min-height:100vh}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.spinner-text{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--text-muted)}@keyframes spin{to{transform:rotate(360deg)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.login-card{width:100%;max-width:400px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:0 8px 32px #0006,0 1px #ffffff0a inset;animation:loginCardIn var(--dur-slow) var(--ease-out)}@keyframes loginCardIn{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-title{margin:0 0 var(--space-2);font-family:var(--font-display);font-size:var(--text-3xl);font-weight:700;letter-spacing:.08em;background:linear-gradient(135deg,var(--accent) 0%,#67e8f9 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{margin:0 0 var(--space-6);font-size:var(--text-sm);color:var(--text-muted)}.login-page .form-field{margin-bottom:var(--space-4)}.login-page .form-field label{display:block;font-size:var(--text-sm);font-weight:500;margin-bottom:var(--space-2);color:var(--text-muted)}.login-page .form-field input{width:100%}.login-error{margin:0 0 var(--space-4);font-size:var(--text-sm);color:var(--danger)}.login-submit{width:100%;padding:var(--space-4);font-size:var(--text-base)}.btn-group{display:flex;gap:var(--space-2);flex-wrap:wrap}.chart-row{display:flex;justify-content:space-between;padding:var(--space-3) 0;border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm)}.chart-row:last-child{border-bottom:none}
