:root{--purple:#6e56cf;--purple-dark:#5b44b8;--purple-deep:#4a3596;--purple-soft:#f1ecfe;--purple-muted:#8b7fb0;--bg:#fbfbfd;--bg-elevated:#fbfbfd;--surface:#fff;--border:#ececf1;--text:#18181b;--text-secondary:#52525b;--muted:#a1a1aa;--primary:var(--purple);--primary-soft:var(--purple-soft);--accent-warm:#d97706;--danger:#dc2626;--success:#16a34a;--warning:#d97706;--sidebar-w:248px;--radius:14px;--radius-sm:9px;--radius-pill:999px;--shadow:0 1px 2px #1018280a;--shadow-card:0 4px 16px #1018281a;--font:"Pretendard Variable", "Pretendard", "Apple SD Gothic Neo", system-ui, -apple-system, "Segoe UI", sans-serif}*,:before,:after{box-sizing:border-box}html,body{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;margin:0}input,textarea,[contenteditable=true]{-webkit-user-select:text;user-select:text}img{-webkit-user-drag:none;user-drag:none}#root{height:100%}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;height:100vh;display:flex;position:sticky;top:0}.sidebar__brand{padding:22px 20px 14px}.sidebar__brand-logo{background:linear-gradient(135deg, #7c5cff, var(--purple));color:#fff;letter-spacing:-.03em;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:15px;font-weight:800;display:inline-flex;box-shadow:0 2px 8px #6e56cf59}.sidebar__brand-title{letter-spacing:-.02em;color:var(--text);font-size:14.5px;font-weight:700;line-height:1.25}.sidebar__brand-sub{color:var(--muted);margin-top:2px;font-size:11px;font-weight:500;line-height:1.45}.sidebar__nav{flex-direction:column;flex:1;gap:2px;padding:2px 12px 16px;display:flex;overflow:auto}.sidebar__label{letter-spacing:.07em;color:#b5b5be;padding:6px 14px 4px;font-size:10.5px;font-weight:700}.nav-link{border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:11px;padding:9px 11px;font-size:13.5px;font-weight:500;transition:background .15s,color .15s;display:flex}.nav-link:hover{color:var(--text);background:#f7f7f9}.nav-link--active{background:var(--purple-soft);color:var(--purple);font-weight:600}.nav-link__mark{width:18px;height:18px;color:inherit;flex-shrink:0;justify-content:center;align-items:center;display:flex}.nav-link__mark svg{width:18px;height:18px}.nav-link--active .nav-link__mark{color:inherit}.sidebar__foot{color:var(--muted);border-top:1px solid #f1f1f4;padding:12px;font-size:11px;line-height:1.45}.main-wrap{background:var(--bg);flex-direction:column;flex:1;min-width:0;display:flex}.header{background:var(--surface);border-bottom:1px solid var(--border);z-index:5;justify-content:space-between;align-items:center;min-height:61px;padding:10px 28px;display:flex;position:sticky;top:0}.header__title{letter-spacing:-.02em;color:var(--text);font-size:15px;font-weight:700}.header__meta{color:var(--text-secondary);border-radius:var(--radius-sm);border:1px solid var(--border);background:#f7f7f9;align-items:center;gap:10px;padding:8px 14px;font-size:12.5px;font-weight:500;display:flex}.main{width:100%;max-width:1440px;margin:0 auto;padding:28px 32px 40px}.page-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px;display:flex}.page-head h1{letter-spacing:-.03em;color:var(--text);margin:0;font-size:23px;font-weight:800}.page-head p{color:var(--text-secondary);margin:7px 0 0;font-size:14px;line-height:1.5}.row{flex-wrap:wrap;gap:12px;display:flex}.grid-kpi{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:22px;display:grid}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card--purple{background:linear-gradient(135deg, var(--purple) 0%, var(--purple-dark) 100%);color:#fff;border:none;box-shadow:0 6px 18px #5b44b838}.card--purple .kpi-label,.card--purple .kpi-foot,.card--purple .muted{color:#ffffffd9!important}.card--purple .kpi-value{color:#fff!important}.card__bd{padding:18px 20px}.card__hd{letter-spacing:-.01em;border-bottom:1px solid #f1f1f4;padding:16px 20px;font-size:15px;font-weight:700}.card__hd--on-purple{color:#fff;border-bottom-color:#fff3}.kpi-label{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:600}.kpi-value{letter-spacing:-.02em;color:var(--text);font-variant-numeric:tabular-nums;font-size:28px;font-weight:800}.kpi-foot{color:var(--muted);margin-top:6px;font-size:12px}.quick-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-bottom:22px;display:grid}.quick-card{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);color:inherit;text-align:left;cursor:pointer;width:100%;font:inherit;align-items:center;gap:14px;padding:16px 18px;transition:transform .15s,box-shadow .15s;display:flex}a.quick-card:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}button.quick-card{cursor:pointer}.quick-card__icon{background:var(--purple-soft);width:44px;height:44px;color:var(--purple);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:800;display:flex}.quick-card__title{font-size:15px;font-weight:700}.quick-card__desc{color:var(--text-secondary);margin-top:3px;font-size:12px}.btn{border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;color:#3f3f46;border:1px solid #e4e4ea;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-size:13.5px;font-weight:600;transition:background .15s,border-color .15s,transform .1s;display:inline-flex}.btn:hover{background:#fbfbfd}.btn:active{transform:scale(.98)}.btn--primary{background:var(--purple);color:#fff;border-color:#0000;box-shadow:0 1px 3px #6e56cf66}.btn--primary:hover{background:var(--purple-dark)}.btn--ghost{color:var(--purple);background:0 0;border-color:#0000}.btn--ghost:hover{background:var(--purple-soft);color:var(--purple-dark)}.btn--sm{border-radius:8px;padding:7px 13px;font-size:12px}.btn--danger{color:var(--danger);background:#fef2f2;border-color:#fbd5d5}.badge{border-radius:var(--radius-pill);color:var(--text-secondary);background:#f4f4f5;border:none;align-items:center;padding:4px 11px;font-size:11.5px;font-weight:600;display:inline-flex}.badge--success{color:#15803d;background:#ecfdf3}.badge--warn{color:#b45309;background:#fffaeb}.badge--muted{color:var(--text-secondary);background:#f4f4f5}.badge--danger{color:#b91c1c;background:#fef2f2}.badge--info{color:#1d4ed8;background:#eff4ff}.table-wrap{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);overflow:auto}table.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th,.data-table td{text-align:left;white-space:nowrap;border-bottom:1px solid #f4f4f5;padding:13px 18px}.data-table th{letter-spacing:0;color:var(--muted);background:#fbfbfd;font-size:11.5px;font-weight:700}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:#fbfbfd}.form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px 18px;display:grid}.field label{color:var(--text-secondary);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.input,.textarea,.select{border-radius:var(--radius-sm);color:#27272a;background:var(--surface);border:1px solid #e4e4ea;width:100%;padding:10px 13px;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.textarea{resize:vertical;min-height:100px}.input:focus,.textarea:focus,.select:focus{border-color:var(--purple);outline:none;box-shadow:0 0 0 3px #6e56cf1f}.toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;font-size:14px;display:inline-flex}.toggle input{width:36px;height:20px;accent-color:var(--purple)}.drawer-overlay{z-index:40;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#18181b6b;position:fixed;inset:0}.drawer{background:var(--surface);z-index:41;flex-direction:column;width:min(480px,100vw - 40px);height:100%;display:flex;position:fixed;top:0;right:0;box-shadow:-12px 0 40px #10182829}.drawer__hd{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:18px 22px;display:flex}.drawer__bd{flex:1;padding:18px 22px;overflow:auto}.drawer__ft{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:16px 22px;display:flex}.modal-overlay{z-index:50;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#18181b73;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:18px;flex-direction:column;width:min(520px,100%);max-height:90vh;display:flex;box-shadow:0 24px 60px #0000004d}.modal__hd{border-bottom:1px solid #f1f1f4;padding:20px 24px;font-size:16px;font-weight:800}.modal__bd{padding:20px 24px;overflow:auto}.modal__ft{border-top:1px solid #f1f1f4;justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.tag-list{flex-wrap:wrap;gap:8px;display:flex}.tag{border-radius:var(--radius-pill);background:var(--purple-soft);color:var(--purple);border:none;padding:5px 12px;font-size:12.5px;font-weight:600}.split{grid-template-columns:1fr 380px;gap:20px;display:grid}@media (width<=960px){.split{grid-template-columns:1fr}.sidebar{display:none}}.empty{text-align:center;color:var(--muted);padding:40px;font-size:15px}.tabs{border-radius:var(--radius-sm);background:#f4f4f5;border:none;gap:0;width:fit-content;margin-bottom:18px;padding:3px;display:inline-flex}.tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:7px;padding:7px 15px;font-size:12.5px;font-weight:600}.tab--on{color:#27272a;background:#fff;box-shadow:0 1px 2px #00000014}.pill-important{color:var(--danger);background:#fef2f2;border-radius:6px;margin-right:8px;padding:3px 9px;font-size:11px;font-weight:700}.muted{color:var(--text-secondary);font-size:14px}
