html,body,#root{margin:0;min-height:100%}body{font-family:Noto Sans KR,Pretendard,Apple SD Gothic Neo,Arial,sans-serif;background:linear-gradient(180deg,#f9fbfc,#edf3f5)}:root{--bg-top: #f6f9fc;--bg-bottom: #edf2f8;--surface: #f8fbff;--card: #ffffff;--card-muted: #f3f7fc;--line: #dbe3ef;--text: #16314f;--muted: #5f7391;--primary: #2f6db1;--primary-strong: #24568f;--primary-soft: #e4eefb;--danger: #b54747;--danger-soft: #fdeeee}*{box-sizing:border-box}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px 1fr;background:radial-gradient(circle at top left,#ffffff 0%,var(--bg-top) 35%,var(--bg-bottom) 100%)}.sidebar{border-right:1px solid #e2eaf4;padding:28px 18px;color:#183554;background:linear-gradient(180deg,#fbfdff,#f2f7fe)}.sidebar h1{margin:0;font-size:1.4rem}.subtitle{margin:8px 0 22px;color:#607490;font-size:.9rem;display:flex;flex-direction:column;gap:4px}.management-tag{font-size:.78rem;color:#6d82a0;white-space:nowrap;display:inline-block}nav{display:grid;gap:10px}.nav-btn{border:1px solid #d4e0ee;background:#fff;color:#1f3f61;padding:10px 12px;border-radius:10px;cursor:pointer;text-align:left;transition:all .15s ease}.nav-btn.active{background:#e7f1ff;border-color:#9dbce6;color:#1a4f85}.nav-btn:disabled{opacity:.45;cursor:not-allowed}.content{padding:28px;color:var(--text)}.section-head{margin-bottom:16px}.section-head h2{margin:0;color:#173756;font-size:1.7rem}.section-head p{margin:8px 0 0;color:#5f7391}.top-actions{display:flex;justify-content:flex-end;margin-bottom:14px}.panel{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;margin-bottom:14px;box-shadow:0 10px 28px #1430540f}.create-panel h3,.panel h3{margin:0 0 12px}.field-grid{display:grid;gap:12px}.field-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.field-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.form-actions{margin-top:16px}label{display:flex;flex-direction:column;gap:6px;font-size:.9rem;font-weight:700;color:#264868}.label-head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.impact-badge{display:inline-flex;align-items:center;border:1px solid #d1deef;border-radius:999px;padding:2px 8px;font-size:.74rem;font-weight:700;line-height:1.3;white-space:nowrap}.impact-badge.applies{background:#e8f4ea;border-color:#b9dec0;color:#2a6a38}.impact-badge.indirect{background:#f3f6fb;border-color:#d4dfef;color:#5f7391}input,select,textarea{width:100%;border:1px solid var(--line);background:var(--surface);color:var(--text);border-radius:10px;padding:9px 10px}input:focus,select:focus,textarea:focus{outline:2px solid #8fb4f0;border-color:var(--primary)}.primary,.ghost,.danger{border:1px solid transparent;border-radius:10px;padding:9px 12px;cursor:pointer;font-weight:700}.primary{background:var(--primary);color:#fff}.ghost{background:var(--primary-soft);color:var(--primary-strong);border-color:#cfe0f6}.danger{background:var(--danger-soft);color:var(--danger)}.card-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.company-card{border:1px solid var(--line);border-radius:14px;padding:15px;background:linear-gradient(180deg,#fff,#f7fbff);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.company-card:hover{transform:translateY(-1px);box-shadow:0 10px 20px #1a395d14}.company-card h3{margin:0}.company-card p{margin:4px 0 10px;color:var(--muted)}.company-card dl{margin:0;display:grid;gap:8px}.company-card dt{color:var(--muted);font-size:.85rem}.company-card dd{margin:2px 0 0;font-size:1rem;font-weight:700}.board-grid{margin-top:16px;display:grid;gap:14px}.board-panel h3{margin:0}.kpi-row{display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:12px}.kpi-row.compact,.kpi-row.compact-4{grid-template-columns:repeat(4,minmax(0,1fr))}.kpi-card{border:1px solid var(--line);border-radius:14px;background:var(--card);padding:13px}.kpi-card h4{margin:0;color:var(--muted);font-size:.85rem}.kpi-card strong{display:block;margin-top:8px;font-size:1.35rem}.bulk-actions{display:flex;gap:8px;flex-wrap:wrap}.employee-table,.attendance-table,.ledger-table{border:1px solid var(--line);border-radius:10px;overflow:hidden}.employee-row,.attendance-row,.ledger-row{display:grid;gap:8px;padding:8px 10px;border-top:1px solid var(--line)}.employee-row{grid-template-columns:1.2fr 1.4fr 1fr .8fr .8fr}.employee-row.board{grid-template-columns:1.1fr 1.2fr .8fr 1fr .8fr .8fr}.attendance-row{grid-template-columns:1fr .6fr .9fr .8fr .8fr .9fr 1.1fr;align-items:center}.attendance-row>span{display:flex;align-items:center;min-height:38px}.attendance-status-cell{flex-direction:column;align-items:stretch!important;justify-content:center;gap:4px}.attendance-edit-badge{display:inline-flex;align-items:center;width:fit-content;padding:2px 8px;border:1px solid #d8e2f0;border-radius:999px;background:#f5f9ff;color:#3d5f86;font-size:.72rem;line-height:1.3;font-weight:700}.employee-name{display:inline-flex;flex-direction:column;align-items:flex-start;gap:2px}.employee-name.risk{color:#a13b3b;font-weight:800}.risk-badge{display:inline-flex;align-items:center;border:1px solid #f0c9c9;border-radius:999px;padding:1px 7px;background:#fff3f3;color:#a13b3b;font-size:.7rem;font-weight:800;line-height:1.35}.ledger-row{grid-template-columns:1.1fr .6fr .6fr .6fr 1.8fr}.employee-row.header,.attendance-row.header,.ledger-row.header{border-top:0;background:var(--card-muted);font-weight:700;color:#233e5a}.mobile-more{display:none}.action-cell .ghost{width:100%}.row-between{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;flex-wrap:nowrap}.row-between h3{margin:0;white-space:nowrap}.employee-head h2{margin:0}.employee-head-actions{display:inline-flex;align-items:center;gap:8px}.print-only{display:none}.print-summary-grid{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.print-summary-grid p{margin:0;display:grid;gap:2px}.print-summary-grid strong{font-size:.82rem;color:var(--muted)}.row-between input[type=month]{max-width:170px}.panel-inline-control{display:grid;align-content:start;gap:10px;border:1px dashed #cbd9ec;border-radius:12px;padding:12px;background:#f8fbff}.panel-inline-control span{color:#357;font-weight:700;font-size:.9rem}.search-inline{min-width:280px}.company-picker-grid{margin-top:12px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.picker-card{border:1px solid var(--line);background:#fff;border-radius:12px;padding:12px;text-align:left;cursor:pointer;display:grid;gap:4px;color:var(--text)}.picker-card strong{font-size:1rem}.picker-card span{color:var(--muted);font-size:.85rem}.picker-card.active{border-color:#8eb1de;background:#eef5ff}.attendance-row .muted{grid-column:1 / -1}details{margin-top:12px}summary{cursor:pointer;color:var(--primary-strong);font-weight:700}.expiry-list{display:grid;gap:8px}.expiry-item{border:1px solid var(--line);border-radius:9px;padding:8px 10px;display:grid;grid-template-columns:1fr 1.2fr auto;gap:8px;align-items:center}.muted{color:var(--muted)}.manual-adjust-help{margin-top:12px;border:1px dashed #cfdcf0;border-radius:12px;padding:10px 12px;background:#f8fbff;display:grid;gap:8px}.manual-adjust-help p{margin:0}.manual-chip-row{display:flex;flex-wrap:wrap;gap:8px}.manual-chip{display:inline-flex;align-items:center;border:1px solid #d3e1f4;border-radius:999px;padding:4px 10px;background:#fff;color:#214466;font-size:.85rem;font-weight:700}.calc-explain{margin:10px 0 12px;display:grid;gap:10px}.calc-explain h4{margin:0}.calc-grid{display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.calc-card{border:1px solid var(--line);border-radius:10px;background:#f8fbff;padding:10px;display:grid;gap:6px}.calc-card h5{margin:0;color:#2a4f73;font-size:.86rem}.calc-card p{margin:0;color:#5a6f8b;font-size:.85rem;line-height:1.4}.calc-card strong{color:#1f3f60;font-size:1rem}.monthly-report{display:grid;gap:14px}.report-kpi-grid{display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr))}.stacked-chart{border:1px solid var(--line);border-radius:10px;background:linear-gradient(180deg,#f9fcff,#eef4fc);padding:14px;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;align-items:end}.stacked-item{display:grid;gap:8px;justify-items:center}.stacked-bar{width:36px;height:150px;border-radius:8px;overflow:hidden;display:flex;flex-direction:column-reverse;border:1px solid #cfdcf1;background:#fff}.seg{width:100%}.seg.present{background:#6a97d3}.seg.vacation{background:#d6a24f}.seg.absent{background:#ce6b6b}.monthly-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:10px}.monthly-table{width:100%;border-collapse:collapse;min-width:920px}.monthly-table th,.monthly-table td{border-top:1px solid var(--line);padding:8px 10px;text-align:right;font-size:.9rem}.monthly-table th:first-child,.monthly-table td:first-child{text-align:left}.monthly-table thead th{border-top:0;background:var(--card-muted);color:#233e5a}.insight-list{border:1px solid var(--line);border-radius:10px;background:#f8fbff;padding:10px 12px}.insight-list p{margin:6px 0}.legend-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px}.legend-item{display:inline-flex;align-items:center;gap:6px;color:#31506f;font-size:.9rem}.dot{width:10px;height:10px;border-radius:999px;display:inline-block}.dot.present{background:#6a97d3}.dot.vacation{background:#d6a24f}.dot.absent{background:#ce6b6b}@media(max-width:1100px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid #e2eaf4}.section-head h2{font-size:1.45rem}.field-grid.two,.field-grid.three,.kpi-row,.kpi-row.compact,.kpi-row.compact-4,.report-kpi-grid,.calc-grid{grid-template-columns:1fr}.employee-row,.employee-row.board,.attendance-row,.ledger-row,.expiry-item{grid-template-columns:1fr 1fr}.stacked-chart{grid-template-columns:repeat(3,1fr)}.row-between{flex-wrap:wrap;align-items:flex-start}.row-between h3{white-space:normal}.row-between .bulk-actions{width:100%}.bulk-actions button{flex:1 1 180px}.search-inline{min-width:100%;width:100%}}@media(max-width:680px){.sidebar{padding:18px 14px}.content{padding:16px}.section-head h2{font-size:1.3rem;line-height:1.25}.section-head p{font-size:.9rem;line-height:1.45}.employee-table,.attendance-table,.ledger-table{border:0;overflow:visible;display:grid;gap:10px}.employee-row.header,.attendance-row.header,.ledger-row.header{display:none}.employee-row,.employee-row.board,.attendance-row,.ledger-row{grid-template-columns:1fr;border:1px solid var(--line);border-radius:12px;background:#fff;padding:12px;gap:10px;box-shadow:0 4px 12px #1430540d}.employee-row>span,.attendance-row>span,.ledger-row>span{min-width:0}.employee-row,.employee-row.board,.attendance-row,.ledger-row,.expiry-item{border-top:1px solid var(--line)}.employee-row>span[data-label],.attendance-row>span[data-label],.ledger-row>span[data-label],.expiry-item>span[data-label],.expiry-item>strong[data-label],.mobile-more-grid>span[data-label]{display:grid;grid-template-columns:minmax(80px,92px) 1fr;align-items:center;gap:8px;min-width:0;word-break:break-word}.employee-row>span[data-label=이름],.employee-row.board>span[data-label=직원]{font-weight:700;color:#1b3d62}.employee-row>span[data-label=상태],.employee-row.board>span[data-label="오늘 상태"]{color:#234c79;font-weight:700}.employee-row>span[data-label]:before,.attendance-row>span[data-label]:before,.ledger-row>span[data-label]:before,.expiry-item>span[data-label]:before,.expiry-item>strong[data-label]:before,.mobile-more-grid>span[data-label]:before{content:attr(data-label);color:var(--muted);font-size:.82rem;font-weight:700;line-height:1.2}.employee-row>span[data-label]>button,.attendance-row>span[data-label] input,.attendance-row>span[data-label] select{width:100%;min-height:40px;font-size:16px}.attendance-row .muted{grid-column:auto}.mobile-hide{display:none}.mobile-more{display:block;margin-top:2px;border-top:1px dashed #d7e3f2;padding-top:8px}.mobile-more summary{font-size:.85rem;line-height:1.3;padding:4px 0;min-height:36px;display:flex;align-items:center}.mobile-more-grid{margin-top:8px;display:grid;gap:8px}.expiry-item{grid-template-columns:1fr;border-radius:12px;padding:12px;gap:10px}.company-card dl{gap:10px}.company-picker-grid{grid-template-columns:1fr}.picker-card{padding:14px;gap:6px}.kpi-card{padding:12px}.kpi-card h4{font-size:.82rem;line-height:1.3}.top-actions{justify-content:stretch}.top-actions .ghost{width:100%}.label-head{align-items:flex-start}.impact-badge{font-size:.7rem;padding:2px 7px}.manual-chip{width:100%;justify-content:center}.row-between .ghost,.row-between .primary,.row-between .danger{min-height:40px}.row-between input[type=month]{max-width:100%;width:100%;min-height:40px;font-size:16px}.monthly-table{min-width:760px}.kpi-card strong{font-size:1.2rem;line-height:1.2;overflow-wrap:anywhere}.panel{padding:14px}}@media(max-width:430px){.sidebar{padding:14px 12px}.content{padding:14px}.panel{padding:12px}.employee-row,.employee-row.board,.attendance-row,.ledger-row,.expiry-item{padding:10px;gap:8px}.employee-row>span[data-label],.attendance-row>span[data-label],.ledger-row>span[data-label],.expiry-item>span[data-label],.expiry-item>strong[data-label],.mobile-more-grid>span[data-label]{grid-template-columns:minmax(74px,86px) 1fr;gap:6px}.attendance-row>span[data-label=출근],.attendance-row>span[data-label=퇴근]{grid-template-columns:1fr;gap:4px;align-items:stretch}.attendance-row>span[data-label=출근]:before,.attendance-row>span[data-label=퇴근]:before{margin-bottom:2px}.company-card,.picker-card{padding:12px}.kpi-card strong{font-size:1.1rem}}@media(max-width:390px){.subtitle{font-size:.82rem}.section-head h2{font-size:1.2rem}.section-head p{font-size:.86rem}.employee-row>span[data-label],.attendance-row>span[data-label],.ledger-row>span[data-label],.expiry-item>span[data-label],.expiry-item>strong[data-label],.mobile-more-grid>span[data-label]{grid-template-columns:minmax(70px,78px) 1fr}.employee-row>span[data-label]:before,.attendance-row>span[data-label]:before,.ledger-row>span[data-label]:before,.expiry-item>span[data-label]:before,.expiry-item>strong[data-label]:before,.mobile-more-grid>span[data-label]:before{font-size:.78rem}.employee-row>span[data-label=이름],.employee-row.board>span[data-label=직원]{font-size:.95rem}.kpi-card h4{font-size:.78rem}}@media(max-width:360px){.content{padding:12px}.panel{padding:10px}.employee-row,.employee-row.board,.attendance-row,.ledger-row,.expiry-item{padding:9px}.kpi-card strong{font-size:1.02rem}.mobile-more summary{font-size:.8rem}}@media print{:root{color-scheme:light}*{-webkit-print-color-adjust:exact;print-color-adjust:exact}.app-shell{display:block;min-height:auto;background:#fff}.sidebar{display:none!important}.content{padding:0;color:#111}.content>section{display:none!important}.content>section.employee-print-root{display:block!important}.print-hide{display:none!important}.print-only{display:block!important}.panel,.kpi-card,.calc-card,.expiry-item,.ledger-row,.monthly-table tr{break-inside:avoid;page-break-inside:avoid}.panel,.kpi-card,.calc-card{box-shadow:none;background:#fff;border-color:#d0d7e2}.employee-print-summary{margin-top:12px}.print-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.monthly-table-wrap{overflow:visible}}
