:root{--bg: #f6f7fb;--surface: #ffffff;--border: #e3e6ee;--text: #1c2231;--text-dim: #6b7280;--primary: #2563eb;--primary-dim: #dbeafe;--danger: #dc2626;--success: #16a34a;--warning: #d97706;--shadow: 0 1px 2px rgba(0,0,0,.05), 0 1px 3px rgba(0,0,0,.04);--sidebar-width: 240px;--topbar-height: 52px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Apple SD Gothic Neo,Noto Sans KR,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:15px;-webkit-text-size-adjust:100%}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:#0f172a;color:#e2e8f0;padding:24px 16px;display:flex;flex-direction:column;gap:4px}.sidebar .brand{font-size:18px;font-weight:700;margin-bottom:24px;color:#fff;letter-spacing:-.3px}.sidebar a{color:#cbd5e1;text-decoration:none;padding:9px 12px;border-radius:8px;font-size:14px}.sidebar a:hover{background:#1e293b;color:#fff}.sidebar a.active{background:var(--primary);color:#fff}.sidebar .nav-section{margin:14px 12px 4px;font-size:11px;font-weight:700;letter-spacing:.5px;color:#64748b;text-transform:uppercase}.sidebar .footer{margin-top:auto;font-size:12px;color:#64748b;border-top:1px solid #1e293b;padding-top:12px}.sidebar .credit{margin-top:12px;padding-top:10px;border-top:1px solid #1e293b;font-size:11px;color:#64748b;text-align:center;letter-spacing:.2px}.topbar,.menu-toggle,.sidebar-backdrop{display:none}.main{flex:1;padding:28px 40px;overflow:auto;min-width:0}.main>*{max-width:1600px}.main>*:not(.payslip){margin-left:0;margin-right:0}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}.page-header h1{font-size:24px;margin:0;letter-spacing:-.3px}.page-header .sub{color:var(--text-dim);font-size:14px;margin-top:2px}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);padding:18px 20px;margin-bottom:16px}.card h2{font-size:15px;margin:0 0 12px}.grid{display:grid;gap:14px}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}@media (max-width: 1100px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.grid-3,.grid-2{grid-template-columns:1fr}}@media (max-width: 640px){.grid-4{grid-template-columns:1fr}}.kpi{display:flex;flex-direction:column;gap:4px}.kpi .label{font-size:13px;color:var(--text-dim)}.kpi .value{font-size:26px;font-weight:700;letter-spacing:-.5px}.kpi .delta{font-size:12px;color:var(--text-dim)}.card table{width:100%}table{width:100%;border-collapse:collapse;font-size:14px}th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:top}th{background:#f8fafc;color:var(--text-dim);font-weight:600;font-size:12px}tr:hover td{background:#fafbff}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}button{font:inherit;background:var(--primary);color:#fff;border:none;border-radius:7px;padding:8px 14px;cursor:pointer;min-height:36px}button:hover{filter:brightness(1.05)}button.ghost{background:transparent;color:var(--primary);border:1px solid var(--border)}button.danger{background:var(--danger)}button.success{background:var(--success)}button.sm{padding:5px 9px;font-size:12px;min-height:0}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{font:inherit;border:1px solid var(--border);border-radius:7px;padding:7px 10px;background:#fff;color:var(--text);max-width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--primary-dim);border-color:var(--primary)}.form-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.field{display:flex;flex-direction:column;gap:4px}.field label{font-size:12px;color:var(--text-dim)}.badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:999px;background:#f1f5f9;color:var(--text-dim)}.badge.pending{background:#fef3c7;color:#92400e}.badge.approved{background:#dcfce7;color:#166534}.badge.rejected{background:#fee2e2;color:#991b1b}.badge.canceled{background:#e5e7eb;color:#374151}.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.toolbar .spacer{flex:1}.user-switcher{display:flex;align-items:center;gap:6px}.user-switcher select{min-width:160px}.notice{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;padding:10px 14px;border-radius:8px;font-size:12px;margin-bottom:12px}.payslip{max-width:720px;margin:0 auto;background:#fff;border:1px solid var(--border);padding:32px;border-radius:10px}.payslip h2{text-align:center;margin:0 0 20px}.payslip table{font-size:13px}.payslip .total td{font-weight:700;background:#f8fafc}.payslip-meta{display:flex;justify-content:space-between;margin-bottom:16px;font-size:13px;gap:16px;flex-wrap:wrap}@media (max-width: 900px){.main{padding:20px 18px}.page-header h1{font-size:19px}.card{padding:14px}.payslip{padding:20px}}@media (max-width: 768px){:root{--sidebar-width: 260px}.layout{display:block;min-height:100vh}.topbar{display:flex;align-items:center;gap:10px;height:var(--topbar-height);padding:0 14px;background:#0f172a;color:#fff;position:sticky;top:0;z-index:30}.topbar .brand{font-size:16px;font-weight:700}.menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:transparent;color:#fff;border:1px solid #334155;border-radius:8px;padding:0;min-height:0}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);max-width:80vw;transform:translate(-100%);transition:transform .22s ease;z-index:50;overflow-y:auto;padding-top:20px}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:40;opacity:0;pointer-events:none;transition:opacity .2s ease}.sidebar-backdrop.open{opacity:1;pointer-events:auto}.main{padding:16px 14px 32px}.page-header{flex-direction:column;align-items:flex-start;gap:10px}.page-header h1{font-size:18px}.page-header .form-row{width:100%}.kpi .value{font-size:18px}.toolbar>*{font-size:13px}.form-row>input,.form-row>select{flex:1 1 140px;min-width:0}.card table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}th,td{white-space:nowrap}.payslip{padding:16px;border-radius:8px}.payslip-meta{flex-direction:column;gap:10px}.payslip h2{font-size:17px}}@media (max-width: 420px){.main{padding:14px 10px 28px}.card{padding:12px;border-radius:8px}.page-header h1{font-size:17px}th,td{padding:8px 9px}}@media print{.sidebar,.topbar,.sidebar-backdrop,.toolbar,.page-header button{display:none!important}.main{padding:0}.payslip{border:none}.card table{display:table;overflow:visible}}
