@import "https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700&display=swap";:root{--primary:#e8604c;--primary-dark:#c4503d;--primary-light:#f5877a;--primary-bg:#fff1ee;--secondary:#ff9a7b;--teal:#2ec4b6;--teal-light:#e0f7f5;--accent:#ffd166;--bg:#fff8f2;--surface:#fff;--surface-2:#fff3ee;--border:#f0e0da;--border-strong:#ddc8c2;--text-1:#1a1a2e;--text-2:#4a4a6a;--text-muted:#9ca3af;--text-danger:#dc2626;--text-success:#059669;--shadow-sm:0 2px 8px #e8604c14;--shadow-md:0 4px 16px #e8604c1f;--shadow-lg:0 8px 32px #e8604c29;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-full:9999px;--header-h:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg);color:var(--text-1);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}#root{min-height:100vh}.btn{border-radius:var(--radius-full);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:6px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 12px #e8604c59}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 16px #e8604c66}.btn-ghost{color:var(--text-2);border:1.5px solid var(--border-strong);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--surface-2);border-color:var(--primary-light);color:var(--primary)}.btn-excel{color:#fff;border-radius:var(--radius-md);background:linear-gradient(135deg,#1d6f42,#217346);padding:12px 28px;font-size:15px;box-shadow:0 4px 12px #1d6f424d}.btn-excel:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 18px #1d6f4266}.btn-full{justify-content:center;width:100%;padding:14px;font-size:16px}.btn-icon{background:var(--surface-2);cursor:pointer;width:36px;height:36px;color:var(--text-2);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:background .2s;display:flex}.btn-icon:hover{background:var(--border)}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.spinner-sm{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.text-muted{color:var(--text-muted)}.text-danger{color:var(--text-danger)}.text-bold{font-weight:700}.badge{border-radius:var(--radius-full);padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.badge--teal{background:var(--teal-light);color:var(--teal)}.badge--orange{background:var(--primary-bg);color:var(--primary)}.tag{background:var(--teal-light);color:var(--teal);border-radius:var(--radius-full);margin-left:6px;padding:1px 6px;font-size:11px;font-weight:600;display:inline-block}.divider{background:var(--border);height:1px;margin:10px 0}.login-container{background:linear-gradient(135deg,#fff8f2 0%,#ffe8e0 50%,#fff0e8 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.login-card{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);z-index:1;padding:48px 40px;position:relative}.login-header{text-align:center;margin-bottom:36px}.login-logo{margin-bottom:12px;font-size:52px;line-height:1}.login-title{color:var(--primary);margin-bottom:4px;font-size:26px;font-weight:700}.login-subtitle{color:var(--text-muted);font-size:14px}.login-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{color:var(--text-2);font-size:13px;font-weight:600}.form-input{border:2px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-1);background:var(--surface);outline:none;padding:14px 16px;font-family:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #e8604c1a}.form-input:disabled{background:var(--bg);opacity:.7}.error-message{border-radius:var(--radius-sm);color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;align-items:center;gap:6px;padding:12px 14px;font-size:14px;display:flex}.info-message{background:var(--primary-bg);border-radius:var(--radius-sm);color:var(--primary);align-items:center;gap:8px;padding:10px 14px;font-size:14px;display:flex}.login-hint{text-align:center;color:var(--text-muted);margin-top:20px;font-size:12px;line-height:1.8}.login-deco{opacity:.12;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:60px;position:absolute}.login-deco-1{top:8%;right:5%;transform:rotate(-15deg)}.login-deco-2{bottom:10%;left:4%;transform:rotate(10deg)}.login-deco-3{font-size:40px;top:40%;left:2%}.page-container{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.page-header{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);z-index:100;position:sticky;top:0}.page-header--admin{background:linear-gradient(135deg, var(--primary) 0%, #c4503d 100%);border-bottom:none}.page-header--admin .brand-name,.page-header--admin .brand-icon{color:#fff}.page-header--admin .btn-ghost{color:#ffffffe6;border-color:#fff6}.page-header--admin .btn-ghost:hover{color:#fff;background:#ffffff26;border-color:#ffffffb3}.page-header--admin .month-badge{color:#fff;background:#fff3}.page-header-inner{justify-content:space-between;align-items:center;max-width:1100px;height:100%;margin:0 auto;padding:0 20px;display:flex}.page-header-brand{align-items:center;gap:10px;display:flex}.brand-icon{font-size:24px}.brand-name{color:var(--primary);font-size:18px;font-weight:700}.admin-badge{border-radius:var(--radius-full);color:#fff;vertical-align:middle;background:#ffffff40;margin-left:8px;padding:2px 10px;font-size:11px;font-weight:700;display:inline-block}.page-header-right{align-items:center;gap:12px;display:flex}.month-badge{background:var(--primary-bg);color:var(--primary);border-radius:var(--radius-full);padding:5px 14px;font-size:13px;font-weight:600}.month-picker{background:var(--primary-bg);color:var(--primary);border:1.5px solid var(--primary);border-radius:var(--radius-full);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234f46e5' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:6px 28px 6px 12px;font-size:13px;font-weight:600}.month-picker:hover{background-color:color-mix(in srgb, var(--primary) 12%, transparent)}.page-header--admin .month-picker{color:#fff;background-color:#ffffff26;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23ffffff' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");border-color:#ffffff80}.page-header--admin .month-picker option{color:#fff;background:#3730a3}.page-main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:32px 20px 60px}.loading-state{color:var(--text-2);flex-direction:column;align-items:center;gap:16px;padding:80px 20px;font-size:15px;display:flex}.error-card,.empty-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-align:center;flex-direction:column;align-items:center;gap:12px;max-width:480px;margin:40px auto;padding:60px 20px;display:flex}.error-icon,.empty-icon{font-size:48px}.error-card h3,.empty-card h3{color:var(--text-1);font-size:18px;font-weight:700}.error-card p,.empty-card p{color:var(--text-muted);font-size:14px;line-height:1.7}.payslip-wrapper{max-width:680px;margin:0 auto}.payslip-intro{margin-bottom:24px}.payslip-intro h2{color:var(--text-1);margin-bottom:4px;font-size:22px;font-weight:700}.payslip-intro p{color:var(--text-muted);font-size:14px}.payslip{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.payslip-header{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);color:#fff;justify-content:space-between;align-items:flex-start;padding:28px 28px 20px;display:flex}.payslip-header-left{flex:1}.payslip-badge{border-radius:var(--radius-full);background:#fff3;margin-bottom:8px;padding:3px 12px;font-size:12px;font-weight:600;display:inline-block}.payslip-name{margin-bottom:4px;font-size:24px;font-weight:700}.payslip-meta{opacity:.85;font-size:13px}.payslip-highlight{border-bottom:1px solid var(--border);background:linear-gradient(135deg,#fff3ee,#ffe8e0);justify-content:space-between;align-items:center;padding:20px 28px;display:flex}.payslip-highlight-label{color:var(--text-2);font-size:14px;font-weight:600}.payslip-highlight-amount{color:var(--primary);font-size:26px;font-weight:800}.payslip-section{border-bottom:1px solid var(--border);padding:20px 28px}.payslip-section:last-of-type{border-bottom:none}.payslip-section-title{color:var(--text-2);letter-spacing:.02em;margin-bottom:14px;font-size:14px;font-weight:700}.payslip-section-body{flex-direction:column;gap:8px;display:flex}.payslip-row{justify-content:space-between;align-items:center;gap:12px;font-size:14px;display:flex}.payslip-row--bold{margin-top:4px;font-size:15px}.payslip-row-label{color:var(--text-2);flex-wrap:wrap;align-items:center;gap:4px;display:flex}.payslip-row-value{text-align:right;font-weight:500}.empty-state-sm{color:var(--text-muted);text-align:center;padding:12px 0;font-size:13px}.weekly-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.weekly-header-cell{text-align:center;color:var(--text-muted);letter-spacing:.03em;padding:4px 0 6px;font-size:11px;font-weight:700}.weekly-header-cell--sun{color:#ef4444}.weekly-header-cell--sat{color:#3b82f6}.daily-cell{border-radius:var(--radius-sm);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:3px;min-height:50px;padding:6px 2px;font-size:12px;display:flex}.daily-cell--active{background:var(--primary-bg);border:1px solid var(--primary-light)}.daily-cell--empty{background:var(--bg);border:1px solid var(--border)}.daily-cell--placeholder{background:0 0;border:none;min-height:50px}.daily-cell--sun .daily-date{color:#ef4444}.daily-cell--sat .daily-date{color:#3b82f6}.daily-date{color:var(--text-1);font-size:11px;font-weight:600}.daily-hours{color:var(--primary);font-size:12px;font-weight:700}.daily-cell--empty .daily-hours{color:var(--text-muted);font-size:11px;font-weight:400}.tag--freelancer{color:#92400e;vertical-align:middle;background:#fef3c7;border:1px solid #fcd34d;border-radius:4px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:700}.payslip-row--clickable{cursor:pointer;border-radius:var(--radius-sm);justify-content:space-between;align-items:center;margin:0 -4px;padding:6px 4px;transition:background .15s;display:flex}.payslip-row--clickable:hover{background:var(--primary-bg)}.holiday-toggle-icon{color:var(--text-muted);margin-left:4px;font-size:10px}.holiday-detail-panel{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);margin:4px 0 8px;padding:12px 14px;font-size:13px}.holiday-detail-title{color:var(--primary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:12px;font-weight:700}.holiday-detail-row{border-bottom:1px dashed var(--border);color:var(--text-2);justify-content:space-between;align-items:baseline;gap:8px;padding:4px 0;display:flex}.holiday-detail-row:last-child{color:var(--text-1);border-bottom:none;font-weight:500}.holiday-detail-row strong{color:var(--primary)}.payslip-total{background:var(--surface-2);flex-direction:column;gap:10px;padding:20px 28px;display:flex}.payslip-total-row{color:var(--text-2);justify-content:space-between;font-size:14px;display:flex}.payslip-total-row--final{color:var(--primary);border-top:2px solid var(--primary-light);margin-top:4px;padding-top:10px;font-size:18px;font-weight:800}.payslip-note{color:var(--text-muted);background:var(--bg);border-top:1px solid var(--border);padding:14px 28px;font-size:12px;line-height:1.7}.admin-summary-banner{flex-wrap:wrap;gap:16px;margin-bottom:28px;display:flex}.admin-summary-item{background:var(--surface);border-radius:var(--radius-md);min-width:160px;box-shadow:var(--shadow-sm);border:1px solid var(--border);flex-direction:column;flex:1;gap:6px;padding:20px 24px;display:flex}.admin-summary-num{color:var(--primary);font-size:22px;font-weight:800}.admin-summary-label{color:var(--text-muted);font-size:12px;font-weight:500}.admin-actions{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:28px;display:flex}.admin-actions-hint{color:var(--text-muted);font-size:13px}.admin-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.emp-card{background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1.5px solid var(--border);cursor:pointer;flex-direction:column;transition:all .2s;display:flex;overflow:hidden}.emp-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-md);transform:translateY(-3px)}.emp-card:focus{outline:2px solid var(--primary);outline-offset:2px}.emp-card-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:18px 20px 14px;display:flex}.emp-avatar{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:18px;font-weight:700;display:flex}.emp-name{color:var(--text-1);font-size:16px;font-weight:700}.emp-id{color:var(--text-muted);margin-top:1px;font-size:12px}.emp-card-badges{flex-wrap:wrap;justify-content:flex-end;gap:4px;margin-left:auto;display:flex}.emp-card-body{flex-direction:column;flex:1;gap:8px;padding:14px 20px;display:flex}.emp-stat{justify-content:space-between;align-items:center;font-size:14px;display:flex}.emp-stat--highlight{border-top:1px solid var(--border);margin-top:4px;padding-top:10px;font-weight:700}.emp-stat--highlight .emp-stat-label{color:var(--text-1);font-size:15px}.emp-stat--highlight .emp-stat-value{color:var(--primary);font-size:16px}.emp-stat-label{color:var(--text-muted);font-size:13px}.emp-stat-value{color:var(--text-1);font-weight:600}.emp-card-footer{background:var(--bg);color:var(--primary);text-align:right;padding:10px 20px;font-size:12px;font-weight:600}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#1a1a2e80;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-content{border-radius:var(--radius-lg);width:100%;max-width:640px;max-height:calc(100vh - 40px);box-shadow:var(--shadow-lg);animation:.25s modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}@media (width<=600px){.login-card{padding:36px 24px}.page-header-inner{padding:0 16px}.brand-name{font-size:16px}.page-main{padding:20px 16px 60px}.admin-summary-banner{gap:10px}.admin-summary-item{min-width:calc(50% - 5px);padding:16px}.admin-summary-num{font-size:17px}.admin-grid{grid-template-columns:1fr}.payslip-header{padding:20px 20px 16px}.payslip-name{font-size:20px}.payslip-highlight{padding:16px 20px}.payslip-highlight-amount{font-size:22px}.payslip-section,.payslip-total{padding:16px 20px}.payslip-note{padding:12px 20px}.weekly-grid{gap:3px}.daily-cell{min-height:44px;padding:4px 1px}.weekly-header-cell,.daily-date{font-size:10px}.daily-hours{font-size:11px}.modal-content{max-height:calc(100vh - 20px)}.month-badge{display:none}}@media (width<=400px){.admin-actions{flex-direction:column;align-items:flex-start}.btn-excel{justify-content:center;width:100%}}
