@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css";@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css";@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css";@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css";:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif}html,body{background-color:#fafafa;width:100%;height:100%;margin:0;padding:0}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}*{box-sizing:border-box}h1,h2,h3,h4,p{margin:0}.bs-modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:9999;background-color:#00000080;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.bs-modal-dialog{background-color:#fff;border:1px solid #e0e6ed;border-radius:24px;flex-direction:column;width:100%;max-width:420px;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif;animation:.3s ease-out slideUp;display:flex;box-shadow:0 12px 32px #00000026}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.bs-modal-header{justify-content:space-between;align-items:center;padding:24px 24px 16px;display:flex}.bs-modal-title{color:#111;letter-spacing:-.5px;margin:0;font-size:1.25rem;font-weight:800}.bs-modal-close{color:#868e96;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.4rem;transition:color .2s}.bs-modal-close:hover{color:#111}.bs-modal-body{color:#444746;word-break:keep-all;padding:0 24px 24px;font-size:1.05rem;font-weight:500;line-height:1.5}.bs-modal-body p{margin:0}.bs-modal-footer{background-color:#0000;justify-content:flex-end;gap:12px;padding:16px 24px 24px;display:flex}.bs-btn{cursor:pointer;border:none;border-radius:30px;padding:10px 24px;font-size:.95rem;font-weight:700;transition:all .2s ease-in-out}.bs-btn-primary{color:#fff;background-color:#0b57d0;box-shadow:0 1px 2px #0000001a}.bs-btn-primary:hover{background-color:#084298;transform:translateY(-1px);box-shadow:0 4px 10px #0b57d040}.bs-btn-secondary{color:#444746;background-color:#f0f4f9}.bs-btn-secondary:hover{color:#111;background-color:#e3e7eb}html,body{background-color:#f0f4f9;width:100%;height:100%;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif;margin:0!important;padding:0!important}.login-wrapper{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-wrapper *{box-sizing:border-box!important}.login-card{background-color:#fff;border:1px solid #e0e6ed;border-radius:24px;width:100%;max-width:440px;padding:3.5rem 3rem;box-shadow:0 4px 12px #0000000a,0 1px 2px #00000014}.login-header{text-align:center;margin-bottom:2.5rem}.logo-container{color:#0b57d0;background-color:#e8f0fe;border-radius:18px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:1.5rem;display:inline-flex}.login-header h2{color:#111;letter-spacing:-.5px;margin:0;font-size:1.6rem;font-weight:800}.input-group{width:100%;margin-bottom:1.5rem}.input-group label{color:#444746;margin-bottom:.5rem;font-size:.9rem;font-weight:700;display:block}.input-group input{color:#111!important;background-color:#fff!important;border:1px solid #747775!important;border-radius:8px!important;width:100%!important;height:3.5rem!important;padding:.75rem 1.2rem!important;font-family:inherit!important;font-size:1rem!important;font-weight:500!important;transition:all .2s ease-in-out!important;display:block!important}.input-group input:focus{border-color:#0b57d0!important;outline:none!important;box-shadow:inset 0 0 0 1px #0b57d0!important}.input-group input::placeholder{color:#868e96!important;font-weight:400!important}.form-actions{justify-content:space-between;align-items:center;margin-top:.5rem;margin-bottom:2rem;display:flex}.form-actions a{color:#0b57d0;font-size:.9rem;font-weight:600;text-decoration:none}.form-actions a:hover{color:#084298;text-decoration:underline}.btn-login{color:#fff!important;cursor:pointer!important;background-color:#0b57d0!important;border:none!important;border-radius:30px!important;width:100%!important;height:3.5rem!important;font-size:1.05rem!important;font-weight:700!important;transition:all .2s ease-in-out!important;display:block!important}.btn-login:hover:not(:disabled){transform:translateY(-1px);background-color:#084298!important;box-shadow:0 1px 3px #3c40434d,0 4px 8px 3px #3c404326!important}.btn-login:disabled{color:#868e96!important;cursor:not-allowed!important;box-shadow:none!important;background-color:#e0e6ed!important}.public-qr-container{box-sizing:border-box;background:linear-gradient(135deg,#111827 0%,#1c2e4a 100%);flex-direction:column;justify-content:center;align-items:center;height:100dvh;padding:16px;font-family:Pretendard,sans-serif;display:flex;overflow:hidden}.public-qr-card{box-sizing:border-box;-ms-overflow-style:none;scrollbar-width:none;background-color:#fff;border-radius:20px;flex-direction:column;width:100%;max-width:380px;max-height:100%;padding:20px 20px 24px;display:flex;overflow-y:auto;box-shadow:0 16px 32px #0000004d}.public-qr-card::-webkit-scrollbar{display:none}.digital-clock-panel{text-align:center;background-color:#f1f3f5;border:1px solid #e9ecef;border-radius:12px;flex-shrink:0;margin-bottom:20px;padding:12px}.clock-text{color:#343a40;letter-spacing:.5px;font-variant-numeric:tabular-nums;font-size:1.1rem;font-weight:800}.attendance-step-content{flex-direction:column;flex:1;align-items:center;display:flex}.step-header{color:#111;align-items:center;gap:8px;margin-bottom:6px;display:flex}.step-header h2{margin:0;font-size:1.4rem;font-weight:800}.step-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:16px;display:flex}.step-icon.success{color:#0ca678;background-color:#e6fcf5}.step-icon.error{color:#fa5252;background-color:#ffe3e3}.step-desc{color:#555;text-align:center;margin:0 0 16px;font-size:.9rem;font-weight:600}.scanner-wrapper{aspect-ratio:1;background-color:#f8f9fa;border:2px solid #e9ecef;border-radius:16px;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}#public-qr-reader{width:100%;border:none!important}.kiosk-form{box-sizing:border-box;background-color:#f8f9fa;border-radius:12px;width:100%;margin-bottom:16px;padding:16px}.login-form-group{text-align:left;margin-bottom:12px}.login-form-group:last-child{margin-bottom:0}.login-form-group label{color:#495057;margin-bottom:6px;font-size:.85rem;font-weight:800;display:block}.login-form-group input{box-sizing:border-box;background-color:#fff;border:1px solid #ced4da;border-radius:8px;width:100%;padding:12px 14px;font-size:1rem;font-weight:600}.login-form-group input:focus{border-color:#0b57d0;outline:none}.action-buttons{gap:10px;width:100%;margin-top:auto;display:flex}.btn-punch{color:#fff;cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 0;font-size:1.05rem;font-weight:800;transition:transform .1s;display:flex}.btn-punch:active{transform:scale(.98)}.btn-checkin{background-color:#0b57d0}.btn-checkout{background-color:#495057}.btn-reset{color:#343a40;background-color:#f1f3f5;width:100%}.result-message{text-align:center;box-sizing:border-box;border-radius:12px;width:100%;padding:16px;font-size:1rem;font-weight:700}.result-success{color:#087f5b;background-color:#e6fcf5;border:1px solid #b2f2bb}.result-error{color:#c92a2a;background-color:#fff5f5;border:1px solid #ffc9c9}.retry-action{color:#868e96;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-top:16px;padding:8px;font-size:.9rem;font-weight:700;display:flex}.kiosk-footer{color:#ffffff80;letter-spacing:1px;margin-top:16px;font-size:.8rem;font-weight:600}.loading-status{flex-direction:column;align-items:center;gap:12px;padding:16px 0;display:flex}.loading-status p{color:#0b57d0;margin:0;font-size:.9rem;font-weight:700}.spinner{border:3px solid #e7f1ff;border-top-color:#0b57d0;border-radius:50%;width:28px;height:28px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tablet-qr-container{box-sizing:border-box;background-color:#0b57d0;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:20px;font-family:Pretendard,-apple-system,sans-serif;display:flex}.tablet-qr-card{text-align:center;background-color:#fff;border-radius:32px;width:100%;max-width:550px;padding:60px 80px;box-shadow:0 24px 64px #0003}.tablet-header{margin-bottom:32px}.badge-kiosk{color:#0b57d0;letter-spacing:.5px;background-color:#e7f1ff;border-radius:30px;margin-bottom:16px;padding:8px 20px;font-size:1.1rem;font-weight:800;display:inline-block}.tablet-header h1{color:#111;letter-spacing:-1px;margin:0 0 12px;font-size:2.2rem;font-weight:800}.tablet-header p{color:#555;margin:0;font-size:1.15rem;font-weight:500;line-height:1.5}.qr-box{background-color:#f8f9fa;border:2px solid #e9eef6;border-radius:24px;margin-bottom:32px;padding:32px;display:inline-block}.timer-container{background-color:#e9eef6;border-radius:6px;width:100%;height:12px;margin-bottom:16px;overflow:hidden}.timer-bar{height:100%;transition:width 1s linear,background-color .3s}.timer-text{font-size:1.1rem;font-weight:700}.safe-time{color:#444746}.warn-time{color:#d93025}.building-container{align-items:flex-start;gap:24px;width:100%;display:flex}.card-shadow{background:#fff;border:1px solid #e0e6ed;border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000a,0 1px 2px #00000014}.btn-base{cursor:pointer;box-sizing:border-box;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:1rem;font-weight:800;transition:all .2s;display:flex}.btn-primary{color:#fff;background-color:#0b57d0}.btn-primary:hover{background-color:#0842a0;transform:translateY(-1px);box-shadow:0 4px 12px #0b57d04d}.btn-success{color:#fff;background-color:#20c997}.btn-success:hover{background-color:#17a97e;transform:translateY(-1px);box-shadow:0 4px 12px #20c9974d}.btn-danger{color:#fff;background-color:#fa5252}.btn-danger:hover{background-color:#e03131;transform:translateY(-1px);box-shadow:0 4px 12px #fa52524d}.btn-secondary{color:#495057;background-color:#f1f3f5;border:1px solid #dee2e6}.btn-secondary:hover{color:#212529;background-color:#e9ecef}.grid-view{scrollbar-width:thin;flex:1;overflow-x:auto}.grid-header{border-bottom:2px solid #e9eef6;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;display:flex}.grid-header h2{color:#111;letter-spacing:-.5px;margin:0;font-size:1.25rem;font-weight:700}.legend{color:#444746;gap:16px;font-size:.85rem;font-weight:600;display:flex}.legend-item{align-items:center;gap:6px;display:flex}.dot{border-radius:50%;width:10px;height:10px;display:inline-block;box-shadow:0 1px 2px #00000026}.matrix-container{flex-direction:column;gap:6px;display:flex}.floor-row{align-items:stretch;gap:8px;display:flex}.floor-label{color:#555;background-color:#f0f4f9;border:1px solid #d7e0ea;border-radius:6px;justify-content:center;align-items:center;width:40px;font-size:.8rem;font-weight:700;display:flex}.units-container{flex:1;gap:6px;display:grid}.unit-cell{cursor:pointer;background-color:#fff;border:2px solid #c2cbd4;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;height:44px;padding:2px 4px;transition:all .15s;display:flex;position:relative}.unit-cell:active{transform:scale(.96)}.unit-type{color:#fff;z-index:1;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:800;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000026}.unit-num{color:#111;z-index:1;margin-top:6px;font-size:.95rem;font-weight:800}.empty-cell{background-color:#0000;border:none}.unit-cell.empty-data-cell{color:#adb5bd;cursor:not-allowed;pointer-events:none;background-color:#f8f9fa;border:1px dashed #ced4da}.status-Available{border-color:#0d6efd}.status-Available .unit-num{color:#0d6efd}.status-Available:hover{z-index:2;background-color:#f0f6ff;transform:translateY(-2px);box-shadow:0 4px 10px #0d6efd33}.status-Holding{background-color:#fff9db;border-color:#fcc419}.status-Holding .unit-num{color:#856404}.status-Holding:hover{filter:brightness(.95);z-index:2;transform:translateY(-2px);box-shadow:0 4px 10px #fcc41933}.unit-cell.status-Contracted{background-color:#fa5252;border-color:#e03131}.unit-cell.status-Contracted .unit-num,.unit-cell.status-Contracted .unit-type{text-shadow:0 1px 2px #0003;color:#fff!important}.unit-cell.status-Contracted:hover{z-index:2;background-color:#e03131;transform:translateY(-2px);box-shadow:0 4px 10px #e031314d}.refuge-cell{cursor:default;background:repeating-linear-gradient(45deg,#f0f4f9,#f0f4f9 10px,#e3e7eb 10px 20px);border:1px solid #c2cbd4;justify-content:center;align-items:center;display:flex;box-shadow:inset 0 1px 3px #0000000d}.refuge-text{color:#333;background-color:#fffffff2;border-radius:6px;padding:4px 12px;font-size:.85rem;font-weight:800;box-shadow:0 1px 2px #0000001a}.side-panel{width:340px;animation:.2s ease-out fadeIn;position:sticky;top:24px}.panel-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.panel-header h3{color:#111;margin:0;font-size:1.3rem;font-weight:800}.status-badge{border-radius:20px;padding:6px 12px;font-size:.8rem;font-weight:700;box-shadow:0 1px 2px #0000000d}.badge-Available{color:#0b57d0;background-color:#e7f1ff;border:1px solid #c2e7ff}.badge-Holding{color:#856404;background-color:#fff3cd;border:1px solid #ffeeba}.badge-Contracted{color:#842029;background-color:#f8d7da;border:1px solid #f5c2c7}.info-list{flex-direction:column;gap:8px;margin-bottom:24px;display:flex}.info-item{border-bottom:1px solid #e9eef6;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.info-label{color:#555;font-size:.85rem;font-weight:700}.info-value{color:#111;font-size:.95rem;font-weight:700}.price-text{color:#d93025;font-size:1.15rem}.highlight-item{background-color:#fff9db;border:1px solid #fcc419;border-radius:8px;padding:14px}.action-buttons{flex-direction:column;gap:10px;margin-top:10px;padding-top:10px;display:flex}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background-color:#fff;border-radius:16px;flex-direction:column;width:400px;max-height:85vh;padding:28px;animation:.3s ease-out slideUp;display:flex;box-shadow:0 12px 32px #00000026}.modal-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.modal-header h3{color:#111;margin:0;font-size:1.3rem;font-weight:800}.modal-close-btn{cursor:pointer;color:#868e96;background:0 0;border:none;padding:4px;font-size:1.4rem;transition:color .2s}.modal-desc{color:#555;margin-bottom:24px;font-size:.95rem;line-height:1.4}.modal-content.org-modal{width:90vw;max-width:1200px;padding:32px}.org-chart-container{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;padding-bottom:20px;padding-right:8px;display:grid;overflow-y:auto}.team-section{background-color:#fff;border:1px solid #e0e6ed;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000a}.team-header{color:#111;border-bottom:2px solid #e9eef6;margin-bottom:16px;padding-bottom:12px;font-size:1.15rem;font-weight:800}.team-members{flex-direction:column;gap:10px;display:flex}.staff-item-btn{cursor:pointer;text-align:left;background-color:#f8f9fa;border:1px solid #e0e6ed;border-radius:8px;align-items:center;gap:12px;padding:14px 16px;transition:all .2s;display:flex}.staff-item-btn:hover{background-color:#fff;border-color:#0b57d0;transform:translateY(-2px);box-shadow:0 4px 12px #0b57d026}.staff-avatar{color:#fff;background-color:#0b57d0;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-weight:800;display:flex}.staff-name{color:#111;font-size:1.05rem;font-weight:700}.staff-role{color:#555;align-items:center;gap:4px;margin-top:4px;font-size:.8rem;display:flex}.agent-page-container{max-width:1400px;margin:0 auto;padding:0;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif}.page-title{color:#111;letter-spacing:-.5px;margin-bottom:24px;font-size:1.6rem;font-weight:800}.dashboard-cards{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:32px;display:grid}.stat-card{background-color:#fff;border:1px solid #e0e6ed;border-left-width:6px;border-radius:16px;align-items:center;gap:20px;padding:24px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 12px #0000000a,0 1px 2px #00000014}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.stat-card.holding-card{border-left-color:#fcc419}.stat-card.contracted-card{border-left-color:#fa5252}.stat-card.sales-card{border-left-color:#0b57d0}.stat-icon{background-color:#f0f4f9;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:2.2rem;display:flex}.stat-info{flex-direction:column;display:flex}.stat-label{color:#555;margin-bottom:6px;font-size:.9rem;font-weight:700}.stat-value{color:#111;font-size:1.8rem;font-weight:800}.stat-value span{color:#444746;margin-left:6px;font-size:1.05rem;font-weight:600}.recent-activity,.table-container{background-color:#fff;border:1px solid #e0e6ed;border-radius:16px;padding:24px;box-shadow:0 4px 12px #00000008}.recent-activity h3{color:#111;margin-top:0;margin-bottom:20px;font-size:1.2rem;font-weight:800}.activity-list{margin:0;padding:0;list-style:none}.activity-item{border-bottom:1px solid #e9eef6;align-items:center;gap:12px;padding:14px 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-unit{color:#111;font-size:1.05rem;font-weight:700}.activity-time{color:#868e96;margin-left:auto;font-size:.85rem;font-weight:500}.empty-msg{text-align:center;color:#868e96;padding:30px 0;font-weight:500}.agent-table{border-collapse:collapse;width:100%}.agent-table th{color:#444746;text-align:left;background-color:#f0f4f9;border-bottom:2px solid #d7e0ea;padding:14px;font-weight:700}.agent-table td{vertical-align:middle;color:#111;border-bottom:1px solid #e9eef6;padding:14px;font-weight:500}.action-flex{gap:8px;display:flex}.btn-sm{cursor:pointer;border-radius:6px;padding:8px 14px;font-size:.9rem;font-weight:600;transition:all .2s}.btn-outline{color:#444746;background-color:#0000;border:1px solid #c2cbd4}.btn-outline:hover{color:#111;background-color:#f0f4f9;border-color:#111}.org-container{flex-direction:column;gap:24px;width:100%;min-height:calc(100vh - 100px);font-family:Pretendard,sans-serif;display:flex}.org-top-section{flex-direction:column;gap:16px;display:flex}.org-page-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.org-page-header h2{color:#111;margin:0;font-size:1.5rem;font-weight:800}.dept-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.dept-card{cursor:pointer;background-color:#fff;border:1px solid #e0e6ed;border-radius:16px;flex-direction:column;padding:20px;transition:all .2s;display:flex;box-shadow:0 4px 12px #00000005}.dept-card:hover{border-color:#c2cbd4;transform:translateY(-2px);box-shadow:0 8px 20px #0000000f}.dept-card.active{background-color:#f8faff;border-color:#0b57d0;box-shadow:0 4px 16px #0b57d01a}.dept-card-header{margin-bottom:12px}.dept-title{color:#111;margin:0;font-size:1.15rem;font-weight:800}.dept-card.active .dept-title{color:#0b57d0}.team-chips{flex-wrap:wrap;gap:8px;display:flex}.team-chip{color:#495057;cursor:pointer;background-color:#f0f4f9;border:1px solid #0000;border-radius:20px;padding:6px 14px;font-size:.85rem;font-weight:600;transition:all .2s}.team-chip:hover{color:#111;background-color:#e3e7eb}.team-chip.active{color:#fff;background-color:#0b57d0;border-color:#0b57d0;box-shadow:0 2px 8px #0b57d04d}.empty-state-selection{color:#868e96;text-align:center;background-color:#f8f9fa;border:2px dashed #d7e0ea;border-radius:16px;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state-selection .empty-icon{opacity:.8;margin-bottom:16px;font-size:3.5rem}.empty-state-selection h3{color:#343a40;margin-bottom:8px;font-size:1.3rem;font-weight:800}.empty-state-selection p{color:#6c757d;margin:0;font-size:1rem}.org-content{background-color:#fff;border:1px solid #e0e6ed;border-radius:16px;flex-direction:column;flex:1;animation:.3s ease-out fadeIn;display:flex;overflow:hidden;box-shadow:0 4px 12px #0000000a}.content-header{background-color:#fff;border-bottom:2px solid #e9eef6;justify-content:space-between;align-items:center;padding:24px 32px;display:flex}.content-title{color:#111;margin:0 0 6px;font-size:1.4rem;font-weight:800}.content-subtitle{color:#0b57d0;font-size:.95rem;font-weight:600}.search-container{background-color:#f8f9fa;border:1px solid #ced4da;border-radius:8px;align-items:center;width:300px;padding:8px 16px;transition:all .2s;display:flex}.search-container:focus-within{background-color:#fff;border-color:#0b57d0;box-shadow:0 0 0 3px #0b57d01a}.search-input{color:#111;background:0 0;border:none;outline:none;flex:1;padding-left:8px;font-size:.95rem}.search-input::placeholder{color:#adb5bd}.table-wrapper{flex:1;min-height:400px;padding:0;overflow-x:auto}.modern-table{border-collapse:collapse;text-align:left;width:100%}.modern-table th{color:#495057;z-index:10;background-color:#f8f9fa;border-bottom:1px solid #dee2e6;padding:14px 20px;font-size:.9rem;font-weight:700;position:sticky;top:0}.modern-table td{color:#343a40;vertical-align:middle;border-bottom:1px solid #e9ecef;padding:16px 20px;font-size:.95rem}.modern-table tbody tr:hover{background-color:#f4f6f8}.role-badge{border-radius:20px;padding:6px 12px;font-size:.75rem;font-weight:700}.role-badge.admin{color:#e03131;background-color:#ffe3e3}.role-badge.agent{color:#0b57d0;background-color:#e7f1ff}.role-badge.owner{color:#0ca678;background-color:#e6fcf5}.role-badge.contractor{color:#f03e3e;background-color:#fff4e6}.action-flex-center{justify-content:center;gap:12px;display:flex}.btn-text-edit,.btn-text-delete{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 10px;font-size:.9rem;font-weight:700;transition:background-color .2s}.btn-text-edit{color:#0b57d0}.btn-text-edit:hover{background-color:#e8f0fe}.btn-text-delete{color:#fa5252}.btn-text-delete:hover{background-color:#ffe3e3}.pagination-container{background-color:#fff;border-top:1px solid #e9eef6;justify-content:center;align-items:center;gap:8px;padding:20px;display:flex}.page-btn{color:#495057;cursor:pointer;background-color:#fff;border:1px solid #dee2e6;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.page-btn:hover:not(:disabled){color:#111;background-color:#f1f3f5}.page-btn.active{color:#fff;background-color:#0b57d0;border-color:#0b57d0;font-weight:800}.page-btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary-pill{color:#fff;cursor:pointer;background-color:#0b57d0;border:none;border-radius:30px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:800;transition:all .2s;display:flex;box-shadow:0 2px 6px #0b57d033}.btn-primary-pill:hover{background-color:#0842a0;transform:translateY(-1px);box-shadow:0 4px 12px #0b57d04d}.btn-secondary-pill{color:#495057;cursor:pointer;background-color:#f1f3f5;border:none;border-radius:30px;padding:12px 24px;font-size:1rem;font-weight:800;transition:all .2s}.btn-secondary-pill:hover{color:#111;background-color:#e9ecef}.form-grid{flex-wrap:wrap;gap:16px;padding-top:10px;display:flex}.form-group{flex-direction:column;width:100%;display:flex}.form-group label{color:#444746;margin-bottom:6px;font-size:.85rem;font-weight:700}.form-group label span{color:#fa5252}.form-group input,.form-group select{color:#111;border:1px solid #ced4da;border-radius:8px;padding:12px;font-size:.95rem;font-weight:600;transition:all .2s}.form-group input:focus,.form-group select:focus{border-color:#0b57d0;outline:none;box-shadow:0 0 0 3px #0b57d01a}.form-group input:disabled{color:#adb5bd;cursor:not-allowed;background-color:#f8f9fa}.modal-actions{justify-content:flex-end;gap:12px;display:flex}.attendance-manager-container{box-sizing:border-box;color:#333;max-width:100%;padding:24px;font-family:Pretendard,sans-serif}.manager-header{margin-bottom:24px}.manager-header h2{color:#111;margin:0 0 8px;font-size:1.8rem}.manager-header p{color:#666;margin:0}.filter-card{background:#fff;border:1px solid #e0e6ed;border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:20px;margin-bottom:24px;padding:20px;display:flex;box-shadow:0 2px 8px #0000000d}.filter-group{flex-direction:column;gap:8px;display:flex}.filter-group label{color:#555;font-size:.85rem;font-weight:700}.filter-group input,.filter-group select{box-sizing:border-box;background-color:#fff;border:1px solid #c2cbd4;border-radius:8px;outline:none;height:42px;padding:10px 14px;font-size:.95rem;transition:border-color .2s}.filter-group input:focus,.filter-group select:focus{border-color:#0b57d0}.filter-group select:disabled{color:#888;cursor:not-allowed;background-color:#f1f3f5}.btn-search{color:#fff;cursor:pointer;background-color:#0b57d0;border:none;border-radius:8px;height:42px;padding:0 24px;font-weight:600;transition:background-color .2s}.btn-search:hover:not(:disabled){background-color:#0842a0}.status-message{text-align:center;color:#888;background:#fff;border:1px solid #e0e6ed;border-radius:12px;padding:40px}.staff-card{background:#fff;border:1px solid #d7e0ea;border-radius:12px;padding:20px;box-shadow:0 2px 6px #00000008}.staff-info{border-bottom:1px dashed #e0e6ed;align-items:baseline;gap:12px;margin-bottom:16px;padding-bottom:12px;display:flex}.monthly-grid{flex-direction:column;gap:10px;display:flex}.grid-row{grid-template-columns:repeat(16,1fr);gap:6px;display:grid}.grid-cell{text-align:center;background:#fafbfc;border:1px solid #e0e6ed;border-radius:6px;overflow:hidden}.grid-cell.empty-placeholder{background:0 0;border:none}.cell-date{color:#444;background:#eef2f6;border-bottom:1px solid #e0e6ed;padding:6px 0;font-size:.75rem;font-weight:700}.cell-date.weekend{color:#d93025;background:#fce8e6}.cell-record{color:#0b57d0;letter-spacing:-.5px;justify-content:center;align-items:center;min-height:20px;padding:8px 0;font-size:.75rem;font-weight:700;display:flex}.cell-record .tilde{color:#888;margin:0 2px;font-weight:400}.cell-record.empty{color:#adb5bd;font-weight:400}.cell-record.warning{color:#d93025}.animation-fade-in{animation:.4s ease-out forwards fadeIn}@media (width<=1024px){.grid-row{min-width:800px;overflow-x:auto}}.hierarchy-container{flex-direction:column;gap:32px;display:flex}.department-section{background:#f8f9fa;border:1px solid #e0e6ed;border-radius:16px;padding:24px}.dept-title{color:#111;border-bottom:2px solid #111;margin:0 0 20px;padding-bottom:8px;font-size:1.4rem;font-weight:800;display:inline-block}.team-section{margin-bottom:24px;padding-left:12px}.team-section:last-child{margin-bottom:0}.team-title{color:#0b57d0;margin:0 0 16px;font-size:1.15rem;font-weight:700}.cards-container{flex-direction:column;gap:16px;display:flex}.tabs-wrapper{background:#fff;border:1px solid #e0e6ed;border-radius:12px;flex-direction:column;gap:12px;margin-bottom:24px;padding:16px 20px;display:flex;box-shadow:0 2px 8px #0000000d}.tab-container{flex-wrap:nowrap;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.tab-container::-webkit-scrollbar{height:6px}.tab-container::-webkit-scrollbar-thumb{background-color:#c2cbd4;border-radius:4px}.tab-btn{color:#555;cursor:pointer;white-space:nowrap;background-color:#f8f9fa;border:1px solid #e0e6ed;border-radius:24px;padding:10px 18px;font-size:.95rem;font-weight:600;transition:all .2s}.tab-btn:hover{color:#111;background-color:#eef2f6}.primary-tabs .tab-btn.active{color:#fff;background-color:#111;border-color:#111}.secondary-tabs .tab-btn{border-radius:8px;padding:8px 16px;font-size:.85rem}.secondary-tabs .tab-btn.active{color:#0b57d0;background-color:#e8f0fe;border-color:#0b57d0}.staff-header{border-bottom:1px dashed #e0e6ed;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.staff-info{align-items:baseline;gap:12px;display:flex}.staff-info .name{color:#111;font-size:1.25rem;font-weight:800}.staff-info .phone{color:#666;font-size:.9rem}.attendance-summary{align-items:center;display:flex}.summary-badge{color:#0b57d0;background-color:#e8f0fe;border-radius:20px;padding:6px 12px;font-size:.85rem;font-weight:600;display:inline-block}.summary-badge strong{margin:0 2px;font-size:1rem;font-weight:800}.grid-cell.clickable{cursor:pointer;transition:all .2s}.grid-cell.clickable:hover{background-color:#e8f0fe;border-color:#0b57d0;transform:translateY(-1px);box-shadow:0 2px 4px #0b57d026}.grid-cell.clickable:hover .cell-date{background-color:#d3e3fd}.grid-cell.clickable:hover .cell-date.weekend{background-color:#fad2cf}.detail-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.detail-modal-content{background:#fff;border-radius:16px;width:90%;max-width:420px;overflow:hidden}.modal-header{background-color:#f8f9fa;border-bottom:1px solid #e0e6ed;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{color:#111;margin:0;font-size:1.25rem}.modal-close-btn{cursor:pointer;color:#888;background:0 0;border:none;padding:4px;font-size:1.2rem}.modal-close-btn:hover{color:#111}.modal-body{flex-direction:column;gap:16px;padding:24px;display:flex}.detail-row{justify-content:space-between;align-items:center;font-size:1rem;display:flex}.detail-label{color:#666;font-weight:600}.detail-value{color:#222;text-align:right}.detail-divider{background-color:#e0e6ed;height:1px;margin:4px 0}.font-bold{font-weight:800}.text-danger{color:#d93025}.text-primary{color:#0b57d0;font-weight:700}.modal-footer{padding:16px 24px 24px}.btn-close-full{color:#444;cursor:pointer;background-color:#f1f3f5;border:none;border-radius:12px;width:100%;padding:14px;font-size:1rem;font-weight:700;transition:background-color .2s}.btn-close-full:hover{background-color:#e2e6ea}.summary-badge.valid-badge{color:#137333;background-color:#e6f4ea;margin-left:8px}.attendance-summary{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.layout-wrapper{background-color:#e9eef6;width:100vw;height:100vh;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,sans-serif;display:flex;overflow:hidden}.sidebar{z-index:10;background-color:#0000;border-right:1px solid #d7e0ea;flex-direction:column;width:256px;display:flex}.sidebar-header{color:#111;letter-spacing:-.5px;align-items:center;gap:12px;height:64px;padding:0 16px 0 24px;font-size:1.35rem;font-weight:800;display:flex}.sidebar-menu{flex-direction:column;gap:6px;padding:16px 0;display:flex;overflow-y:auto}.menu-item{color:#333;cursor:pointer;border-radius:12px;align-items:center;gap:12px;margin:0 16px;padding:14px 18px;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.menu-item:hover{background-color:#d7e0ea}.menu-item.active{color:#fff;background-color:#0b57d0;font-weight:700;box-shadow:0 2px 4px #0b57d033}.content-wrapper{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{z-index:5;background-color:#0000;justify-content:flex-end;align-items:center;height:64px;padding:0 24px;display:flex}.user-profile-container{position:relative}.user-profile{cursor:pointer;background-color:#fff;border:1px solid #d7e0ea;border-radius:30px;align-items:center;gap:12px;padding:6px 12px;transition:all .2s;display:flex;box-shadow:0 1px 2px #0000000d}.user-profile:hover{background-color:#f8f9fa;border-color:#c2e7ff}.user-avatar{color:#fff;background-color:#004a77;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;font-weight:600;display:flex}.user-info{text-align:right;flex-direction:column;display:flex}.user-name{color:#111;font-size:.9rem;font-weight:700}.user-role{color:#555;font-size:.75rem;font-weight:500}.dropdown-menu{z-index:1000;background-color:#fff;border:1px solid #d7e0ea;border-radius:12px;width:240px;padding:12px 0;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 8px 24px #0000001f}.dropdown-item{color:#111;cursor:pointer;padding:12px 24px;font-size:.95rem;font-weight:500;transition:background-color .2s;display:block}.dropdown-item:hover{color:#0b57d0;background-color:#f0f4f9}.dropdown-divider{background-color:#d7e0ea;height:1px;margin:8px 0}.page-content{flex-direction:column;flex:1;padding:0 24px 24px 0;display:flex;overflow-y:auto}.workspace-card{background-color:#fff;border:1px solid #e0e6ed;border-radius:16px;flex:1;padding:36px;overflow-y:auto;box-shadow:0 4px 12px #0000000a,0 1px 2px #00000014}.complex-title{color:#111;letter-spacing:-.5px;margin-bottom:28px;font-size:1.6rem;font-weight:700}.building-tabs{border-bottom:2px solid #e9eef6;flex-wrap:wrap;gap:10px;margin-bottom:32px;padding-bottom:16px;display:flex}.tab-button{color:#555;cursor:pointer;background-color:#fff;border:1px solid #c2cbd4;border-radius:8px;padding:10px 24px;font-size:1rem;font-weight:600;transition:all .2s}.tab-button:hover{color:#111;background-color:#f0f4f9;border-color:#111}.tab-button.active{color:#fff;background-color:#0b57d0;border-color:#0b57d0;box-shadow:0 4px 8px #0b57d040}.empty-state,.loading-state{color:#555;flex-direction:column;justify-content:center;align-items:center;height:300px;font-size:1.1rem;font-weight:600;display:flex}.active-grid-container{width:100%;animation:.3s ease-in-out fadeIn}@media screen and (width<=1024px){.layout-wrapper{flex-direction:column}.sidebar{background-color:#fff;border-bottom:1px solid #d7e0ea;border-right:none;width:100%;height:auto}.sidebar-header{border-bottom:1px solid #f1f3f5;height:56px;padding:0 16px}.sidebar-menu{white-space:nowrap;-webkit-overflow-scrolling:touch;flex-direction:row;padding:8px 12px;overflow-x:auto}.menu-item{margin:0 8px 0 0;padding:10px 16px;font-size:.9rem}.topbar{background-color:#fff;border-bottom:1px solid #f1f3f5;height:56px;padding:0 16px}.page-content{padding:12px}.workspace-card{border-radius:12px;padding:16px}.complex-title{margin-bottom:20px;font-size:1.3rem}.building-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:12px;overflow-x:auto}.tab-button{white-space:nowrap;padding:8px 16px;font-size:.9rem}.modal-content{max-height:90vh;margin:20px auto;overflow-y:auto;width:90%!important}}
