:root{--bg:#f4efe6;--panel:#fffaf4d1;--border:#223d371f;--text-h:#1d2f2a;--text-soft:#546660;--muted:#6a7771;--muted-strong:#42504a;--accent:#13705d;--shadow:0 18px 45px #2a3f3814, 0 8px 18px #2a3f380d;--sans:"Pretendard", "Noto Sans KR", system-ui, sans-serif;--heading:"SUIT", "Pretendard", "Noto Sans KR", system-ui, sans-serif;font:16px/1.55 var(--sans);color:var(--text-h);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#f8d67857,#0000 24%),radial-gradient(circle at 100% 0,#13705d2e,#0000 28%),linear-gradient(#f7f3eb,#efe6d8)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:radial-gradient(circle at 0 0,#f8d67857,#0000 24%),radial-gradient(circle at 100% 0,#13705d2e,#0000 28%),linear-gradient(#f7f3eb,#efe6d8);min-width:320px;margin:0}body,button,input,select,textarea{font:inherit}a{color:inherit}#root{min-height:100svh}h1,h2,h3,p{margin:0}h1,h2,h3{font-family:var(--heading);color:var(--text-h)}h1{letter-spacing:-.04em;font-size:clamp(2rem,4vw,3.6rem);line-height:.98}h2{letter-spacing:-.03em;font-size:clamp(1.25rem,2vw,1.7rem);line-height:1.15}.app-shell{min-height:100svh}.auth-mode{justify-content:center;align-items:stretch;padding:24px;display:flex}.dashboard-shell{grid-template-columns:280px minmax(0,1fr);gap:24px;padding:24px;display:grid}.auth-shell{grid-template-columns:minmax(0,1.2fr) minmax(340px,420px);gap:24px;width:min(1220px,100%);display:grid}.main-panel,.page-grid,.stack-list,.topbar-metrics,.sidebar-nav,.spotlight-grid,.balance-summary-grid,.request-table{gap:20px;display:grid}.main-panel{align-content:start}.card{border:1px solid var(--border);background:var(--panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow);border-radius:28px;padding:24px}.sidebar{flex-direction:column;gap:24px;height:calc(100svh - 48px);display:flex;position:sticky;top:24px}.sidebar-brand{gap:8px;display:grid}.sidebar-nav{gap:12px}.nav-button,.primary-button,.secondary-button,.ghost-button,.calendar-cell{font:inherit;cursor:pointer;border:1px solid #0000;border-radius:18px;transition:transform .18s,box-shadow .18s,background .18s,border-color .18s}.nav-button{color:var(--text-h);text-align:left;background:#ffffff8c;padding:14px 16px}.nav-button.active{background:linear-gradient(135deg,#13705d2e,#f8d67842);border-color:#13705d2e}.primary-button,.secondary-button,.ghost-button{justify-content:center;align-items:center;padding:12px 18px;text-decoration:none;display:inline-flex}.primary-button{background:var(--accent);color:#f8f5ec}.secondary-button{color:var(--accent);background:#13705d1f}.ghost-button{color:var(--text-h);border-color:var(--border);background:#fff9}.nav-button:hover,.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.calendar-cell:hover{transform:translateY(-1px)}.sidebar-logout{margin-top:auto}.topbar{grid-template-columns:minmax(0,1fr) auto;align-items:end;display:grid}.topbar-metrics{grid-auto-flow:column;gap:12px}.topbar-metrics span,.spotlight-item,.summary-cell,.hero-badges span,.sample-box{border:1px solid var(--border);background:#ffffff94;border-radius:20px;padding:16px}.hero-panel{color:#f7f5ef;background:radial-gradient(circle at 0 0,#f8d67838,#0000 30%),linear-gradient(135deg,#17352f,#285648 58%,#816235);border-radius:36px;flex-direction:column;justify-content:space-between;min-height:580px;padding:36px;display:flex}.hero-copy{color:#f7f5efcc;max-width:36rem}.hero-badges{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.hero-badges span,.sample-box{background:#ffffff14;border-color:#ffffff29}.auth-card{align-self:center}.card-heading{gap:6px;margin-bottom:18px;display:grid}.eyebrow{text-transform:uppercase;letter-spacing:.18em;color:var(--accent);font-size:.78rem}.hero-panel .eyebrow{color:#f6d78f}.section-copy,.subtle-text,.empty-copy,.timeline-date,.card-heading p,.spotlight-item span,.summary-cell span,.employee-label small,.calendar-cell small{color:var(--muted)}.field{gap:8px;display:grid}.inline-field{max-width:360px}.field span{color:var(--text-soft)}.field input,.field select,.field textarea{border:1px solid var(--border);width:100%;font:inherit;color:var(--text-h);background:#ffffffd6;border-radius:16px;padding:14px 16px}.field textarea{resize:vertical;min-height:110px}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);outline:2px solid #13705d2e}.form-message{border-radius:16px;padding:12px 14px}.form-message.success{color:#166b45;background:#1987541f}.form-message.error{color:#9c2d2d;background:#b131311a}.spotlight-grid,.balance-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.spotlight-item,.summary-cell{gap:10px;display:grid}.spotlight-item strong,.summary-cell strong{font-size:1.5rem;line-height:1.15}.approval-item,.history-item{border-top:1px solid var(--border);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:16px;padding:16px 0;display:grid}.approval-item:first-child,.history-item:first-child{border-top:none;padding-top:0}.schedule-editor-grid{grid-template-columns:minmax(0,1.4fr) minmax(320px,.8fr);align-items:start}.calendar-topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.calendar-nav{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;display:grid}.calendar-weekdays{color:var(--text-soft);margin-bottom:10px;font-size:.9rem}.calendar-cell{text-align:left;background:#ffffffb3;align-content:start;gap:8px;min-height:108px;padding:12px;display:grid}.calendar-cell.muted{cursor:default;background:#ffffff47;min-height:84px}.calendar-cell.selected{border-color:var(--accent);box-shadow:0 0 0 2px #13705d1f}.calendar-date-number{color:var(--text-soft);font-size:.92rem}.calendar-cell.working{background:#ffffffb3}.calendar-cell.special,.schedule-chip.special,.legend-chip.special{color:#9a6700;background:#e0a7222e}.calendar-cell.leave,.schedule-chip.leave,.status-chip.approved,.legend-chip.leave{color:#166b45;background:#19875424}.schedule-chip.pending,.status-chip.pending,.calendar-cell.pending,.legend-chip.pending{color:#9a6700;background:#e0a72224}.schedule-chip.working,.legend-chip.working{color:var(--text-h);background:#1d2f2a14}.calendar-action-row,.legend-row{flex-wrap:wrap;gap:10px;display:flex}.legend-row.compact{margin-bottom:16px}.legend-chip,.status-chip,.schedule-chip{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;padding:10px 12px;font-size:.84rem;display:inline-flex}.status-chip.rejected{color:#9c2d2d;background:#b131311f}.schedule-table{gap:10px;display:grid;overflow-x:auto}.schedule-row{align-items:center;gap:10px;display:grid}.schedule-row-month{grid-template-columns:180px repeat(31,minmax(78px,1fr))}.schedule-head{color:var(--text-soft);font-size:.92rem}.current-row{background:#13705d0f;border-radius:18px;padding:6px}.employee-label{display:grid}.request-table{gap:0}.request-row{border-top:1px solid var(--border);grid-template-columns:1fr 1fr 1fr 1fr 1.4fr 120px;align-items:center;gap:16px;padding:14px 0;display:grid}.request-row-head,.request-row-admin-head{color:var(--text-soft);font-size:.92rem}.request-row:first-child{border-top:none;padding-top:0}.request-row-admin-head{grid-template-columns:repeat(6,minmax(0,1fr))}.inline-action{width:100%}.overview-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;display:grid}.stat-card,.profile-card{min-height:150px}.accent-card{background:linear-gradient(135deg, #13705d1f, #f8d67833), var(--panel)}.stat-label{color:var(--text-soft);margin-bottom:16px}.stat-value{font-family:var(--heading);color:var(--text-h);margin-bottom:14px;font-size:2.4rem;line-height:1;display:block}.stat-value.small{font-size:1.8rem}.stat-meta{color:var(--muted)}.policy-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.policy-grid div{border:1px solid var(--border);background:#ffffff8c;border-radius:18px;padding:18px}@media (width<=1200px){.dashboard-shell,.auth-shell,.topbar,.overview-grid,.spotlight-grid,.balance-summary-grid,.policy-grid,.schedule-editor-grid{grid-template-columns:1fr}.sidebar{height:auto;position:static}.topbar-metrics{grid-auto-flow:row}}@media (width<=900px){.dashboard-shell,.auth-mode{padding:16px}.request-row,.request-row-admin-head,.schedule-row-month{min-width:1200px}.hero-badges,.calendar-grid{grid-template-columns:1fr}.calendar-weekdays{display:none}}@media (width<=640px){.card,.hero-panel{border-radius:24px;padding:20px}.approval-item,.history-item,.calendar-topbar{grid-template-columns:1fr}}.calendar-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:end;gap:16px;margin-bottom:18px;display:flex}.month-badge{border:1px solid var(--border);color:var(--accent);background:#13705d14;border-radius:16px;justify-content:center;align-items:center;padding:12px 16px;font-weight:600;display:inline-flex}.drag-copy-guide{margin-top:4px}.calendar-cell.outing,.schedule-chip.outing,.legend-chip.outing{color:#2450b5;background:#2962ff1f}.calendar-cell.sick,.schedule-chip.sick,.legend-chip.sick{color:#9c2d2d;background:#b131311f}.calendar-cell.half,.schedule-chip.half,.legend-chip.half{color:#6b46c1;background:#8a5cf624}.month-badge-group{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.edit-badge{border:1px solid var(--border);color:var(--text-soft);background:#ffffffc7;border-radius:16px;justify-content:center;align-items:center;padding:12px 16px;font-weight:600;display:inline-flex}.edit-badge.active{color:var(--accent);background:#13705d1f}.selection-guide{border:1px solid var(--border);background:#fff9;border-radius:20px;gap:8px;padding:16px;display:grid}.selection-guide strong{color:var(--text-h)}.selection-guide p{color:var(--muted);margin:0}.selected-date-list{flex-wrap:wrap;gap:8px;display:flex}.selected-date-chip{color:var(--accent);background:#13705d1a;border-radius:999px;justify-content:center;align-items:center;padding:8px 12px;font-size:.84rem;display:inline-flex}.primary-button:disabled,.secondary-button:disabled,.ghost-button:disabled{opacity:.55;cursor:not-allowed;transform:none}.calendar-cell.offday,.schedule-chip.offday,.legend-chip.offday{color:#6d4c41;background:#6d4c411f}.schedule-context-wrap{position:relative}.calendar-context-menu{z-index:30;border:1px solid var(--border);min-width:170px;max-width:190px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffcf5f5;border-radius:18px;gap:8px;padding:10px;display:grid;position:fixed}.context-menu-button{font:inherit;text-align:left;cursor:pointer;color:var(--text-h);background:#ffffffb3;border:1px solid #0000;border-radius:14px;padding:10px 12px}.context-menu-button.working{background:#1d2f2a14}.context-menu-button.leave{color:#166b45;background:#19875424}.context-menu-button.outing{color:#2450b5;background:#2962ff1f}.context-menu-button.sick{color:#9c2d2d;background:#b131311f}.context-menu-button.half{color:#6b46c1;background:#8a5cf624}.context-menu-button.offday{color:#6d4c41;background:#6d4c411f}.context-menu-button.pending{color:#9a6700;background:#e0a72224}.main-panel,.card,.auth-shell,.dashboard-shell,.topbar,.calendar-card,.request-table,.schedule-table{min-width:0}.request-table{overflow-x:auto}.request-row,.request-row-head,.request-row-admin-head,.request-row-wide{min-width:900px}@media (width<=1200px){.topbar{gap:16px}.topbar-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=900px){body,#root{overflow-x:hidden}.dashboard-shell,.auth-mode{gap:16px;padding:12px}.auth-shell,.sidebar{gap:16px}.sidebar-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.nav-button{text-align:center}.topbar{grid-template-columns:1fr;gap:14px}.topbar-metrics{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-flow:initial}.topbar-metrics span,.spotlight-item,.summary-cell,.hero-badges span,.sample-box{padding:14px}.approval-item,.history-item,.calendar-topbar,.calendar-toolbar{grid-template-columns:1fr;align-items:stretch;display:grid}.calendar-nav,.month-badge-group,.calendar-action-row{width:100%}.calendar-nav button,.calendar-action-row button,.month-badge,.edit-badge{flex:auto}.calendar-card,.schedule-table,.request-table{-webkit-overflow-scrolling:touch;overflow-x:auto}.calendar-grid{gap:8px;min-width:560px}.calendar-weekdays{display:grid}.calendar-cell{gap:6px;min-height:88px;padding:10px}.calendar-cell strong,.calendar-cell small{font-size:.78rem;line-height:1.25}.schedule-row-month{grid-template-columns:140px repeat(31,minmax(64px,1fr));min-width:1040px}.request-row,.request-row-head,.request-row-admin-head,.request-row-wide{gap:12px;min-width:820px}.overview-grid,.spotlight-grid,.balance-summary-grid,.policy-grid{grid-template-columns:1fr}.hero-panel{min-height:auto;padding:24px}.hero-badges{grid-template-columns:1fr}}@media (width<=640px){.card,.hero-panel{border-radius:20px;padding:16px}.sidebar-nav,.topbar-metrics{grid-template-columns:1fr}.calendar-grid{min-width:520px}.calendar-cell{min-height:80px;padding:8px}.calendar-date-number{font-size:.8rem}.calendar-cell strong,.calendar-cell small,.legend-chip,.status-chip,.schedule-chip,.selected-date-chip{font-size:.74rem}.request-row,.request-row-head,.request-row-admin-head,.request-row-wide{min-width:760px}.schedule-row-month{min-width:980px}.context-menu-button{padding:9px 10px}}.mobile-month-card{gap:14px;display:grid}.mobile-team-heading p{margin:0}.mobile-calendar-card{overflow:hidden}.mobile-calendar-weekdays{color:var(--text-soft);grid-template-columns:repeat(7,minmax(0,1fr));gap:4px;font-size:.72rem;display:grid}.mobile-calendar-weekdays span{text-align:center}.mobile-calendar-grid{grid-template-columns:repeat(7,minmax(108px,1fr));gap:5px;padding-bottom:4px;display:grid;overflow-x:auto}.mobile-calendar-cell{background:#ffffffc7;border:1px solid #1d2f2a14;border-radius:16px;align-content:start;gap:6px;min-height:144px;padding:7px;display:grid}.mobile-calendar-cell.muted{background:#ffffff47}.mobile-calendar-datebar{justify-content:space-between;align-items:baseline;gap:6px;display:flex}.mobile-calendar-datebar strong{font-size:.88rem}.mobile-calendar-datebar span{color:var(--text-soft);font-size:.64rem}.mobile-calendar-members{gap:4px;display:grid}.mobile-calendar-member{background:#f5f7f3eb;border-radius:10px;justify-content:space-between;align-items:center;gap:4px;padding:4px 5px;display:flex}.mobile-calendar-member-name{min-width:0;color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:.64rem;font-weight:700;line-height:1;overflow:hidden}.mobile-calendar-member-status{white-space:nowrap;text-overflow:ellipsis;border-radius:999px;flex:none;max-width:52%;padding:3px 6px;font-size:.58rem;font-weight:700;line-height:1;overflow:hidden}.mobile-calendar-member-status.working{color:var(--text-main);background:#1d2f2a14}.mobile-calendar-member-status.leave{color:#166b45;background:#19875424}.mobile-calendar-member-status.pending{color:#9a6700;background:#e0a72224}.mobile-calendar-member-status.outing{color:#2450b5;background:#2962ff1f}.mobile-calendar-member-status.sick{color:#9c2d2d;background:#b131311f}.mobile-calendar-member-status.half{color:#6b46c1;background:#8a5cf624}.mobile-calendar-member-status.offday{color:#6d4c41;background:#6d4c411f}@media (width<=768px){.schedule-table.mobile-hidden{display:none}.mobile-calendar-grid{grid-template-columns:repeat(7,minmax(98px,1fr));gap:4px}.mobile-calendar-cell{min-height:132px;padding:6px}.mobile-calendar-member{padding:3px 4px}.mobile-calendar-member-name{font-size:.6rem}.mobile-calendar-member-status{padding:3px 5px;font-size:.54rem}}
