@font-face{font-family:Spoqa Han Sans;src:url(/assets/SpoqaHanSans-Light-HodYGE71.woff2) format("woff2");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:Spoqa Han Sans;src:url(/assets/SpoqaHanSans-Regular-BZ1T8BcG.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Spoqa Han Sans;src:url(/assets/SpoqaHanSans-Bold-aZA96Oz1.woff2) format("woff2");font-weight:700 900;font-style:normal;font-display:swap}@font-face{font-family:Futura;src:url(/assets/Futura-Medium-CeLzMToP.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Futura;src:url(/assets/Futura-Bold-FGzM2tLl.woff2) format("woff2");font-weight:700 900;font-style:normal;font-display:swap}:root{--gamja-blue: #0064ac;--gamja-yellow: #fdc300;--gamja-orange: #ea5b0a;--bg: #f6f7f8;--surface: #ffffff;--surface-soft: #f0f3f6;--text: #18202a;--muted: #687386;--line: #d9e0e7;--line-strong: #b8c3cf;--success: #25855a;--warning: #9a6a00;--danger: #bd3a22;--shadow: 0 8px 20px rgba(20, 32, 46, .07)}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:Spoqa Han Sans;letter-spacing:0;-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit}button{white-space:nowrap}.login-page{min-height:100vh;display:flex;flex-direction:column;background:#fff}.site-login-header{min-height:95px;padding:0 30px;background:var(--gamja-yellow);border-bottom:1px solid rgba(0,100,172,.18);display:flex;align-items:center;justify-content:space-between;gap:28px}.site-login-logo{display:flex;align-items:center}.site-login-logo img{display:block;width:244px;max-width:100%;height:auto}.site-login-header nav{display:flex;align-items:center;gap:24px;color:var(--gamja-blue);font-family:Futura,Spoqa Han Sans;font-size:14px;font-weight:700}.site-login-header nav span{color:#0064acb8}.site-login-content{flex:1;min-height:calc(100vh - 95px);padding:72px 20px 88px;display:flex;flex-direction:column;align-items:center;justify-content:center}.login-form-card{width:min(100%,360px);background:transparent;border:0;border-radius:0;box-shadow:none;padding:0}.login-form-head{display:grid;justify-items:center;padding-top:56px;margin-bottom:52px;text-align:center}.login-illustration-logo{display:block;width:208px;max-width:100%;height:auto;margin-bottom:20px}.login-wordmark{display:block;width:192px;max-width:100%;height:auto}.login-form-head h2{margin:18px 0 0;color:var(--muted);font-size:14px;font-weight:400}.login-form-card form{display:grid;gap:14px}.login-form-card label{display:grid;gap:8px}.login-form-card label span{color:var(--text);font-size:14px;font-weight:700}.login-form-card input{width:100%;min-height:48px;border:1px solid #dadada;border-radius:3px;padding:0 13px;color:var(--text);background:#fff}.login-form-card input:focus{outline:2px solid rgba(0,100,172,.18);border-color:var(--gamja-blue)}.password-input-wrap{position:relative;width:100%}.password-input-wrap input{padding-right:48px}.password-toggle{position:absolute;top:50%;right:9px;width:34px;height:34px;transform:translateY(-50%);border:0;background:transparent;color:var(--muted);display:grid;place-items:center;cursor:pointer}.remember-row{display:inline-flex!important;width:fit-content;grid-template-columns:none;align-items:center;gap:8px!important;margin:2px 0 4px;cursor:pointer}.remember-row input{width:16px;min-height:16px;accent-color:var(--gamja-blue)}.remember-row span{color:var(--text);font-size:14px;font-weight:400}.login-error{margin:0;color:var(--danger);font-size:13px;font-weight:700}.login-submit{width:100%;min-height:48px;border:1px solid var(--gamja-blue);border-radius:3px;background:var(--gamja-blue);color:#fff;cursor:pointer;font-size:14px;font-weight:700}.login-note{margin:18px 0 0;color:var(--text);text-align:center;font-size:13px}.app-shell{display:flex;min-height:100vh}.sidebar{width:256px;min-height:100vh;background:#111820;color:#fff;display:flex;flex-direction:column;padding:20px 14px;position:sticky;top:0}.brand-row{display:flex;align-items:center;gap:12px;padding:0 8px 24px}.brand-row strong{display:block}.brand-mark{width:46px;height:46px;border-radius:8px;display:grid;place-items:center;overflow:hidden}.brand-mark img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}.sidebar nav{display:grid;gap:4px}.nav-item{width:100%;border:0;border-radius:8px;color:#ffffffc2;background:transparent;display:flex;align-items:center;gap:10px;padding:11px 12px;cursor:pointer;text-align:left}.nav-item.active{color:#fff;background:#ffffff1f;box-shadow:inset 3px 0 0 var(--gamja-yellow)}.nav-item.subtle{color:#fff9}.sidebar-footer{margin-top:auto;display:grid;gap:4px;padding-top:20px}.sidebar-close,.mobile-menu{display:none}.main-area{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{min-height:74px;background:#f6f7f8f0;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 28px;position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar h1,.hero-panel h2,.toolbar-panel h2,.panel h2,.detail-card h2{margin:0}.topbar h1{font-size:22px}.eyebrow{color:var(--muted);font-size:12px;font-weight:700;margin:0 0 4px}.topbar-actions{display:flex;align-items:center;gap:12px}.icon-button{width:38px;height:38px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--text);display:inline-grid;place-items:center;position:relative;cursor:pointer}.notification-dot{width:8px;height:8px;background:var(--gamja-orange);border-radius:50%;position:absolute;top:8px;right:8px}.user-chip{display:flex;align-items:center;gap:10px;padding:6px 10px 6px 6px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.user-chip>span,.avatar{width:32px;height:32px;border-radius:50%;background:var(--surface-soft);color:var(--gamja-blue);display:grid;place-items:center;font-weight:800}.user-chip strong,.user-chip small{display:block}.user-chip small{color:var(--muted);font-size:11px}.content{padding:28px}.screen-grid{display:grid;gap:18px}.hero-panel,.toolbar-panel,.attendance-strip,.panel,.check-panel{background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.hero-panel{min-height:150px;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px;border-top:5px solid var(--gamja-blue)}.hero-panel h2{font-size:26px}.hero-panel p{color:var(--muted);margin:8px 0 0}.primary-button,.secondary-button,.orange-button{border:1px solid transparent;border-radius:8px;min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;cursor:pointer;font-weight:700}.primary-button{background:var(--gamja-blue);color:#fff}.orange-button{background:var(--gamja-orange);color:#fff}.secondary-button{background:var(--surface);color:var(--text);border-color:var(--line-strong)}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.metric-grid.six{grid-template-columns:repeat(6,minmax(0,1fr))}.team-attendance-metrics{grid-template-columns:repeat(7,minmax(0,1fr))}.metric-card{min-height:124px;border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:16px;display:grid;align-content:space-between;box-shadow:var(--shadow)}.metric-card>span{color:var(--muted);font-size:12px;font-weight:700}.metric-card div{display:flex;align-items:baseline;gap:5px}.metric-card strong{font-size:34px;font-variant-numeric:tabular-nums}.metric-card small,.metric-card p{color:var(--muted)}.metric-card p{margin:0;font-size:12px}.team-attendance-metrics .metric-card{min-height:124px;padding:18px 14px;align-content:center;justify-items:center;text-align:center;gap:8px}.team-attendance-metrics .metric-card>span{line-height:1.4}.team-attendance-metrics .metric-card div{align-items:flex-end;justify-content:center;min-height:38px}.team-attendance-metrics .metric-card strong{font-size:30px;line-height:1}.team-attendance-metrics .metric-card small{font-size:12px;line-height:1}.team-attendance-metrics .metric-card p{font-size:12px;line-height:1.35;text-align:center}.tone-blue{border-top:4px solid var(--gamja-blue)}.tone-yellow{border-top:4px solid var(--gamja-yellow)}.tone-orange{border-top:4px solid var(--gamja-orange)}.tone-purple{border-top:4px solid #7c5bbf}.tone-neutral{border-top:4px solid var(--line-strong)}.attendance-strip{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:18px;padding:18px}.status-line,.location-ok{display:inline-flex;align-items:center;gap:8px;color:var(--success);font-weight:800}.strip-data{display:grid;gap:3px;color:var(--muted);font-size:13px}.strip-data strong{color:var(--text)}.two-column,.approval-layout,.request-layout,.attendance-layout{display:grid;gap:18px}.two-column{grid-template-columns:minmax(0,1.6fr) minmax(280px,.8fr)}.hr-overview-grid{display:grid;gap:18px;grid-template-columns:minmax(0,2.2fr) minmax(220px,.6fr);align-items:start}.approval-layout{grid-template-columns:360px minmax(0,1fr)}.request-layout{grid-template-columns:minmax(0,1fr) 340px;align-items:start}.attendance-layout{grid-template-columns:minmax(320px,420px) minmax(0,1fr);align-items:start}.panel{min-width:0;padding:18px}.panel-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.panel-head h2{font-size:18px}.panel-head button{border:0;background:transparent;color:var(--gamja-blue);display:inline-flex;align-items:center;gap:4px;cursor:pointer;font-weight:700}.table-wrap{width:100%;overflow-x:auto}.table-action-button{min-height:30px;border:1px solid var(--line-strong);border-radius:999px;background:var(--surface);color:var(--gamja-blue);padding:0 10px;cursor:pointer;font-size:12px;font-weight:700}.muted-inline{color:var(--muted);font-size:12px}.leave-adjust-controls{display:inline-flex;align-items:center;gap:8px}.leave-adjust-controls input{width:88px;min-height:32px;border:1px solid var(--line-strong);border-radius:8px;padding:0 10px;background:var(--surface);color:var(--text)}.log-subline{display:block;margin-top:4px;color:var(--muted);font-size:12px}.log-detail{display:block;color:var(--text);line-height:1.45;white-space:normal;word-break:keep-all}table{width:100%;border-collapse:collapse;min-width:520px}th,td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line);font-size:13px}th{color:var(--muted);font-size:12px}.status-badge,.attendance-badge,.employment-badge{display:inline-flex;align-items:center;justify-content:center;min-height:24px;border-radius:999px;padding:0 9px;font-size:12px;font-weight:800}.employment-재직{color:var(--success);background:#25855a1c}.employment-휴직{color:#7c5bbf;background:#7c5bbf21}.employment-퇴직{color:var(--muted);background:#68738624}.status-승인,.attendance-정상{color:var(--success);background:#25855a1c}.status-대기,.attendance-재택,.attendance-외근{color:var(--warning);background:#fdc30038}.status-반려,.attendance-지각{color:var(--danger);background:#ea5b0a21}.status-취소,.status-회수{color:var(--muted);background:#68738624}.status-팀장승인,.attendance-출근대기{color:#7c5bbf;background:#7c5bbf21}.attendance-휴가,.attendance-미체크{color:var(--muted);background:var(--surface-soft)}.empty-state{display:grid;gap:12px;justify-items:start}.empty-state p{margin:0;color:var(--muted)}.stack-list{display:grid;gap:10px}.person-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}.person-row:last-child{border-bottom:0}.person-row strong,.person-row span,.person-top strong,.person-top span{display:block}.person-row span,.person-top span{color:var(--muted);font-size:12px;margin-top:2px}.person-top .attendance-badge{display:inline-flex;align-items:center;justify-content:center;min-width:56px;min-height:26px;margin-top:0;padding:0 10px;line-height:1;text-align:center;white-space:nowrap;flex-shrink:0}.person-row b{color:var(--gamja-blue)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid label{display:grid;gap:7px;color:var(--muted);font-size:12px;font-weight:700}.form-grid input,.form-grid select,.form-grid textarea,.select-inline select{width:100%;border:1px solid var(--line-strong);border-radius:8px;background:var(--surface);color:var(--text);padding:11px 12px;min-height:42px}.form-grid textarea{resize:vertical}.select-with-meta{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}.field-meta-chip{min-height:42px;border:1px solid rgba(0,100,172,.18);border-radius:8px;background:#0064ac0f;color:var(--gamja-blue);display:inline-flex;align-items:center;justify-content:center;padding:0 12px;font-size:12px;font-weight:700;white-space:nowrap}.field-hint{color:var(--muted);font-size:12px;font-weight:400;line-height:1.4}.full-span{grid-column:1 / -1}.summary-note,.alert-box,.policy-row{display:flex;gap:12px;align-items:flex-start}.summary-note,.alert-box{border:1px solid var(--line);border-radius:8px;padding:14px;background:var(--surface-soft)}.summary-note strong,.summary-note span{display:block}.summary-note span,.alert-box p,.policy-row span{color:var(--muted);margin:2px 0 0;font-size:13px}.side-stack{display:grid;gap:18px}.support-copy{margin:12px 0 0;color:var(--muted);font-size:13px;line-height:1.5}.support-banner{display:grid;gap:3px;margin-bottom:14px;padding:12px 14px;border:1px solid rgba(0,100,172,.14);border-radius:8px;background:#0064ac0d}.support-banner strong{color:var(--gamja-blue)}.support-banner span{color:var(--muted);font-size:13px}.google-calendar-banner{gap:10px}.google-calendar-controls{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.google-calendar-toggle{display:inline-flex;align-items:center;gap:8px;color:var(--text);font-size:13px;font-weight:600}.google-calendar-toggle input{margin:0}.integration-message{margin:0;color:var(--text);font-size:13px}.calendar-sync-card{display:grid;gap:10px;margin-top:14px;padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft)}.calendar-sync-card strong,.calendar-sync-card span{display:block}.calendar-sync-card span{margin-top:3px;color:var(--muted);font-size:13px}.calendar-link-button{text-decoration:none}.spin-icon{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.request-manage-list{display:grid;gap:10px}.request-manage-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:10px;border-bottom:1px solid var(--line)}.request-manage-row:last-child{padding-bottom:0;border-bottom:0}.request-manage-row strong,.request-manage-row span{display:block}.request-manage-row span{color:var(--muted);font-size:12px;margin-top:3px}.request-manage-actions{display:flex;align-items:center;gap:8px}.approval-route{display:grid;gap:10px}.approval-route-progress{margin-top:12px}.approval-section-list{display:grid;gap:16px}.approval-section{display:grid;gap:10px}.approval-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.approval-section-head strong{font-size:14px}.approval-section-head span{color:var(--muted);font-size:12px;font-weight:700}.route-step{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--line);border-radius:8px}.route-step-copy{display:grid;gap:2px}.route-step-copy strong,.route-step-copy small{display:block}.route-step-copy small{color:var(--muted);font-size:12px}.route-step-done{border-color:#25855a3d;background:#25855a0d}.route-step-done span{background:var(--success)}.route-step-current{border-color:#0064ac3d;background:#0064ac0d}.route-step-pending{background:#fafbfd}.route-step-pending span{background:var(--line-strong)}.route-step span{width:26px;height:26px;border-radius:50%;background:var(--gamja-blue);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:800}.approval-progress-card{border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);padding:14px}.approval-progress-card>strong{display:block;font-size:14px}.toolbar-panel{min-height:92px;padding:18px;display:flex;align-items:center;justify-content:space-between;gap:16px}.toolbar-actions{display:flex;gap:8px}.calendar-summary-board{display:grid;gap:16px;padding:20px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.calendar-summary-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px}.calendar-summary-head h3,.calendar-summary-head span,.calendar-week-alert p{margin:0}.calendar-summary-head h3{font-size:20px}.calendar-summary-head span,.calendar-summary-note,.calendar-week-card-head span,.calendar-week-count span,.calendar-week-item span,.calendar-week-alert li,.calendar-week-empty,.calendar-week-alert p{color:var(--muted);font-size:12px}.calendar-summary-meta{display:grid;justify-items:end;gap:8px}.calendar-summary-meta .field-meta-chip{color:var(--gamja-blue)}.calendar-summary-note{font-weight:700}.calendar-week-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.calendar-week-card{display:grid;align-content:start;gap:12px;min-height:264px;padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.calendar-week-card.alert{border-color:#ea5b0a59;box-shadow:inset 0 0 0 1px #ea5b0a29}.calendar-week-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.calendar-week-card-head strong{display:block;font-size:16px}.calendar-week-count{text-align:right}.calendar-week-count b{display:block;font-size:24px;line-height:1}.calendar-week-bar{height:4px;border-radius:999px;background:var(--surface-soft);overflow:hidden}.calendar-week-bar span{display:block;height:100%;border-radius:inherit;background:var(--gamja-blue)}.calendar-week-card.alert .calendar-week-bar span{background:var(--danger)}.calendar-week-list{display:grid;gap:8px}.calendar-week-item{display:grid;gap:4px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff}.calendar-week-item.pending{border-color:#fdc30073}.calendar-week-item.executive{border-color:#7c5bbf59}.calendar-week-item.approved{border-color:#25855a33}.calendar-week-item-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.calendar-week-item-head strong{font-size:13px}.calendar-week-status{display:inline-flex;align-items:center;justify-content:center;min-height:22px;border-radius:999px;padding:0 8px;font-size:11px;font-weight:800;white-space:nowrap}.calendar-week-item-detail{line-height:1.45}.calendar-week-empty{min-height:128px;display:grid;place-items:center;border:1px dashed var(--line);border-radius:8px}.calendar-week-alert{display:grid;gap:8px;padding:16px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.calendar-week-alert.alert{border-color:#ea5b0a59;background:#ea5b0a0d}.calendar-week-alert strong{font-size:13px}.calendar-week-alert ul{display:grid;gap:4px;margin:0;padding-left:18px}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));background:var(--surface);border:1px solid var(--line);border-radius:8px;overflow:hidden;box-shadow:var(--shadow)}.calendar-head,.calendar-cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-width:0}.calendar-head{background:var(--surface-soft);padding:10px;color:var(--muted);font-weight:800;text-align:center;font-size:12px}.calendar-cell{min-height:108px;padding:10px;display:grid;align-content:start;gap:6px}.calendar-cell.muted{background:#fafafa}.calendar-cell strong{font-size:13px}.calendar-event{display:block;padding:4px 6px;border-left:3px solid var(--gamja-blue);background:#0064ac14;font-size:12px;overflow:hidden;text-overflow:ellipsis}.approval-item{border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:14px;text-align:left;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;cursor:pointer}.approval-item.selected{border-color:var(--gamja-blue);box-shadow:inset 3px 0 0 var(--gamja-blue)}.approval-item strong,.approval-item span,.approval-meta span,.approval-meta b{display:block}.approval-item span,.approval-meta span{color:var(--muted);font-size:12px;margin-top:2px}.approval-meta{text-align:right}.detail-card{display:grid;gap:18px}.detail-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding-bottom:16px;border-bottom:1px solid var(--line)}.detail-header span{color:var(--muted);font-size:13px}.detail-list{display:grid;gap:10px;margin:0}.detail-list div{display:grid;grid-template-columns:120px 1fr;gap:12px}.detail-list dt{color:var(--muted)}.detail-list dd{margin:0;font-weight:700}.button-row{display:flex;justify-content:flex-end;gap:10px}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#1118206b;display:grid;place-items:center;padding:20px}.dialog-card{width:min(100%,360px);background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:20px}.dialog-card h2,.dialog-card p{margin:0}.dialog-card p{color:var(--muted);margin-top:8px;line-height:1.5}.dialog-card .button-row{margin-top:18px}.check-panel{padding:22px;display:grid;gap:16px}.check-panel time{font-size:38px;font-weight:800;font-variant-numeric:tabular-nums}.check-panel>span{color:var(--muted)}.attendance-mode-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.attendance-mode-button{min-height:44px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--text);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700}.attendance-mode-button.is-active{border-color:var(--gamja-blue);color:var(--gamja-blue);box-shadow:inset 0 0 0 1px var(--gamja-blue)}.map-box{height:240px;border:1px solid var(--line);border-radius:8px;background:repeating-linear-gradient(0deg,transparent 0 23px,rgba(24,32,42,.07) 23px 24px),repeating-linear-gradient(90deg,transparent 0 23px,rgba(24,32,42,.07) 23px 24px),#edf1f4;position:relative;overflow:hidden}.map-box:before,.map-box:after{content:"";position:absolute;background:#fff;border:1px solid var(--line)}.map-box:before{left:0;right:0;top:44%;height:16px}.map-box:after{top:0;bottom:0;left:58%;width:16px}.map-radius{width:136px;height:136px;border:2px dashed var(--gamja-blue);background:#0064ac14;border-radius:50%;position:absolute;left:58%;top:45%;transform:translate(-50%,-50%);z-index:1}.map-pin{position:absolute;z-index:2;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800}.map-pin.office{left:58%;top:34%;transform:translate(-50%,-50%);background:var(--text);color:#fff}.map-pin.user{left:53%;top:49%;transform:translate(-50%,-50%);background:var(--success);color:#fff;box-shadow:0 0 0 8px #25855a33}.map-pin.user.is-offsite{background:var(--gamja-orange);box-shadow:0 0 0 8px #ea5b0a2e}.timeline{display:grid;gap:12px}.timeline-bar{height:32px;background:var(--surface-soft);border:1px solid var(--line);border-radius:8px;position:relative;overflow:hidden}.timeline-range{position:absolute;top:0;bottom:0;background:var(--gamja-blue);border-radius:8px}.timeline-bar span{position:absolute;top:0;bottom:0;width:2px;background:var(--gamja-orange)}.timeline-labels{display:flex;justify-content:space-between;gap:8px;color:var(--muted);font-size:12px;font-variant-numeric:tabular-nums}.week-list{display:grid;gap:8px;margin-top:18px}.week-list span{border-bottom:1px solid var(--line);padding-bottom:8px;color:var(--muted)}.attendance-week-list strong{display:inline-block;min-width:84px;color:var(--text)}.field-reason{display:grid;gap:8px}.field-reason span{color:var(--muted);font-size:12px;font-weight:800}.field-reason textarea{width:100%;border:1px solid var(--line-strong);border-radius:8px;padding:12px 14px;background:var(--surface);color:var(--text);resize:vertical;min-height:92px}.attendance-support-copy{margin:0;color:var(--muted);line-height:1.5}.attendance-state-card{display:grid;gap:16px}.attendance-meta-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.attendance-meta-grid div{border:1px solid var(--line);border-radius:8px;padding:12px;background:var(--surface-soft)}.attendance-meta-grid dt{color:var(--muted);font-size:12px;margin-bottom:6px}.attendance-meta-grid dd{margin:0;color:var(--text);font-weight:700}.attendance-pending-list{display:grid;gap:10px}.attendance-pending-item{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;border:1px solid var(--line);border-radius:8px;padding:14px;background:var(--surface)}.attendance-pending-item strong,.attendance-pending-item span{display:block}.attendance-pending-item span{margin-top:4px;color:var(--muted);line-height:1.45}.location-success{color:var(--success)}.location-warning{color:var(--danger)}.location-neutral{color:var(--muted)}.select-inline{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12px;font-weight:800}.select-inline select{width:160px}.people-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.org-chart-board{display:grid;gap:24px;padding:24px;border:1px solid var(--line);border-radius:8px;background:radial-gradient(circle at 1px 1px,rgba(0,100,172,.08) 1px,transparent 0) 0 0 / 18px 18px,linear-gradient(180deg,#fff,#fbfdff)}.org-chart-node{display:grid;gap:20px;justify-items:center}.org-chart-card{width:min(100%,320px);border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:var(--shadow);padding:16px;display:grid;gap:14px}.org-chart-card.root{width:min(100%,420px);border-color:#0064ac47;box-shadow:0 16px 30px #0064ac14}.org-chart-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--line)}.org-chart-card-head h3,.org-chart-summary,.org-chart-empty{margin:0}.org-chart-card-head h3{font-size:20px}.org-chart-summary{margin-top:4px;color:var(--muted);font-size:12px}.org-chart-count{min-height:28px;padding:0 11px;border-radius:999px;background:#0064ac14;color:var(--gamja-blue);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}.org-chart-member-list{display:grid}.org-chart-member{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:start;padding:10px 0;border-bottom:1px solid var(--line)}.org-chart-member:last-child{padding-bottom:0;border-bottom:0}.org-chart-member-copy{display:grid;gap:3px}.org-chart-member-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.org-chart-member-head strong,.org-chart-member-copy span,.org-chart-member-copy small{display:block}.org-chart-member-copy span,.org-chart-member-copy small{color:var(--muted);font-size:12px;line-height:1.4}.org-chart-empty{min-height:56px;display:grid;place-items:center;border:1px dashed var(--line);border-radius:8px;color:var(--muted);font-size:12px}.org-chart-children{width:100%;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));align-items:start}.person-card{border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:14px;box-shadow:var(--shadow)}.person-top{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding-bottom:12px;border-bottom:1px solid var(--line)}.person-card dl{display:grid;gap:7px;margin:12px 0 0}.person-card dl div{display:flex;justify-content:space-between;gap:10px}.person-card dt{color:var(--muted)}.person-card dd{margin:0;font-weight:700}.policy-list{display:grid;gap:14px}.policy-list.compact{gap:8px}.policy-list.compact .policy-row{padding:8px 0;gap:10px}.policy-list.compact .policy-row span{font-size:12px}.policy-row{padding:12px 0;border-bottom:1px solid var(--line)}.policy-row:last-child{border-bottom:0}.policy-row svg{color:var(--gamja-blue);flex:0 0 auto}.attendance-master-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;margin-top:18px}.master-card{border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:16px;display:grid;gap:14px}.master-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.master-card-head strong,.office-policy-copy strong{display:block}.master-card-head span,.office-policy-copy span,.office-policy-copy small,.policy-save-note{color:var(--muted);font-size:12px}.master-badge{min-height:26px;padding:0 10px;border-radius:999px;border:1px solid rgba(0,100,172,.18);background:#0064ac0f;color:var(--gamja-blue);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;white-space:nowrap}.office-policy-list{display:grid;gap:10px}.office-policy-item{border:1px solid var(--line);border-radius:8px;background:#fff;padding:12px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center}.office-policy-item.active{border-color:var(--gamja-blue);box-shadow:inset 3px 0 0 var(--gamja-blue)}.office-policy-copy{display:grid;gap:3px}.office-policy-actions{display:flex;gap:6px}.office-add-button{justify-self:start}.policy-map-box{height:210px}.office-policy-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.office-policy-editor label,.attendance-rule-grid label{display:grid;gap:6px}.office-policy-editor span,.attendance-rule-grid span,.radius-control span{color:var(--muted);font-size:12px;font-weight:700}.radius-control{display:grid;gap:8px}.radius-control>div{display:flex;justify-content:space-between;align-items:center;gap:12px}.attendance-rule-card{margin-top:16px}.attendance-rule-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.attendance-rule-checks{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px}.attendance-rule-checks label{display:flex;align-items:center;gap:8px;min-width:0}.attendance-rule-checks input{margin:0}.policy-save-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding-top:4px}.scrim{display:none}@media(max-width:1180px){.site-login-content{padding-top:56px}.metric-grid,.metric-grid.six,.people-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.two-column,.request-layout,.approval-layout,.attendance-layout{grid-template-columns:1fr}}.notif-wrap{position:relative}.notif-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:19;border:0;background:transparent;cursor:default}.notif-popover{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);z-index:20;padding:14px}.notif-popover-title{margin:0 0 10px;font-size:13px;font-weight:700;color:var(--muted)}.notif-list{display:grid;gap:2px}.notif-item{padding:8px 0;border-bottom:1px solid var(--line)}.notif-item:last-child{border-bottom:0;padding-bottom:0}.notif-item strong,.notif-item span{display:block}.notif-item span{color:var(--muted);font-size:12px;margin-top:2px}.notif-empty{margin:0;color:var(--muted);font-size:13px}.tab-bar{display:flex;gap:8px}.employee-status-tabs{margin-bottom:12px}.hr-tab-bar{margin-top:-2px}.tab-btn{border:1px solid var(--line-strong);border-radius:8px;background:var(--surface);color:var(--muted);min-height:38px;padding:0 18px;cursor:pointer;font-weight:700;font-size:14px}.tab-btn.active{background:var(--gamja-blue);color:#fff;border-color:var(--gamja-blue)}.tab-count{color:inherit;font-size:12px;font-weight:800;margin-left:6px}.employee-table-note{margin:0 0 12px}.filter-select{border:1px solid var(--line-strong);border-radius:8px;background:var(--surface);color:var(--text);padding:0 12px;height:40px;min-width:130px;font:inherit}.search-input-wrap{display:flex;align-items:center;gap:8px;border:1px solid var(--line-strong);border-radius:8px;background:var(--surface);padding:0 12px;height:40px;color:var(--muted)}.search-input-wrap input{border:0;background:transparent;color:var(--text);min-width:160px}.search-input-wrap input:focus{outline:none}.add-emp-dialog,.employee-edit-dialog{width:min(100%,560px)}.add-emp-form{display:grid;gap:12px;margin-top:16px}.add-emp-form label{display:grid;gap:6px}.add-emp-form label span{font-size:13px;font-weight:700;color:var(--muted)}.add-emp-form input,.add-emp-form select{border:1px solid var(--line-strong);border-radius:8px;background:var(--surface);color:var(--text);padding:0 12px;height:40px;width:100%;font:inherit}.add-emp-form .button-row{margin-top:6px}.submit-success-panel{display:flex;align-items:center;gap:16px;padding:20px;border:1px solid rgba(37,133,90,.3);border-radius:8px;background:#25855a0f;color:var(--success)}.submit-success-panel strong,.submit-success-panel span{display:block}.submit-success-panel span{color:var(--muted);font-size:13px;margin-top:3px}.submit-success-panel .secondary-button{margin-left:auto;flex-shrink:0}@media(max-width:760px){.site-login-header{min-height:70px;padding:0 16px}.site-login-logo{max-width:168px}.site-login-header nav span{display:none}.site-login-header nav{font-size:13px}.site-login-content{min-height:calc(100vh - 70px);padding:44px 18px 64px}.login-form-head{padding-top:40px;margin-bottom:40px}.login-illustration-logo{width:176px;margin-bottom:16px}.login-wordmark{width:172px}.login-form-card{width:100%}.app-shell{display:block}.sidebar{position:fixed;inset:0 auto 0 0;z-index:30;transform:translate(-100%);transition:transform .18s ease}.sidebar.open{transform:translate(0)}.sidebar-close,.mobile-menu{display:inline-grid}.brand-row{padding-right:0}.brand-row .sidebar-close{margin-left:auto;background:#ffffff1a;color:#fff;border-color:#ffffff29}.scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;border:0;background:#00000047}.topbar{padding:12px 16px}.topbar h1{font-size:18px}.topbar-actions .user-chip{display:none}.content{padding:16px}.hero-panel,.toolbar-panel,.attendance-strip{display:grid;grid-template-columns:1fr}.hero-panel h2{font-size:22px}.metric-grid,.metric-grid.six,.people-grid,.attendance-master-layout,.org-chart-children,.hr-overview-grid,.form-grid,.attendance-rule-grid,.attendance-rule-checks,.office-policy-editor,.select-with-meta{grid-template-columns:1fr}.toolbar-actions,.button-row{flex-wrap:wrap;justify-content:flex-start}.policy-save-row{flex-wrap:wrap}.office-policy-item{grid-template-columns:1fr}.calendar-summary-head{display:grid;align-items:start}.calendar-summary-meta{justify-items:start}.calendar-week-grid{grid-template-columns:1fr}.calendar-week-card{min-height:0}.calendar-grid{overflow-x:auto;grid-template-columns:repeat(7,minmax(112px,1fr))}.calendar-cell{min-height:96px}.detail-list div{grid-template-columns:1fr;gap:4px}.timeline-labels{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}}
