:root{color:#102533;font-family:Segoe UI Variable,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;background:#f4f6f8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg: #f6f8fb;--panel: #ffffff;--panel-soft: #f8fbfe;--border: #d7e0ea;--text: #102533;--muted: #5e7387;--accent: #0f6c7a;--accent-strong: #0a5560;--nav: #13283a;--nav-strong: #0f2030;--shadow: 0 10px 30px rgba(14, 34, 51, .08)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;background:var(--bg);color:var(--text)}button,.button,select,input{font:inherit}button,.button{align-items:center;background:var(--accent);border:1px solid rgba(255,255,255,.08);border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;gap:8px;min-height:38px;padding:0 14px;text-decoration:none;transition:transform .12s ease,box-shadow .12s ease,background .12s ease;box-shadow:0 6px 16px #0f6c7a29}button:hover,.button:hover{transform:translateY(-1px);box-shadow:0 10px 20px #0f6c7a2e}button:focus-visible,.button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid rgba(15,108,122,.25);outline-offset:2px}.app{display:grid;grid-template-columns:220px minmax(0,1fr);min-height:100vh;transition:grid-template-columns .18s ease}.app.sidebar-collapsed{grid-template-columns:64px minmax(0,1fr)}aside{background:var(--nav);color:#edf5fa;overflow:hidden;padding:16px 12px;position:sticky;top:0;height:100vh;box-shadow:3px 0 18px #08141f29}.sidebar-collapsed aside{padding-inline:8px}.brand{align-items:center;border-bottom:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;margin-bottom:12px;min-height:52px;padding:2px 6px 12px}.brand span{display:block;font-size:22px;font-weight:800;letter-spacing:.01em}.brand small{color:#edf5fabf;display:block;margin-top:4px}.sidebar-collapsed .brand{justify-content:center;padding-inline:0}.sidebar-collapsed .brand-copy{display:none}nav{display:grid;gap:4px;max-height:calc(100vh - 82px);overflow-y:auto;padding-right:3px}nav a,.nav-parent{align-items:center;background:transparent;border:1px solid transparent;border-radius:8px;box-shadow:none;color:#edf5fa;display:flex;gap:8px;justify-content:flex-start;min-height:44px;padding:0 12px;position:relative;text-align:left;text-decoration:none;width:100%}nav a:hover,.nav-parent:hover,nav a.active,.nav-parent[aria-expanded=true]{background:#ffffff14;border-color:#ffffff14;box-shadow:none;transform:none}.nav-group{display:grid;gap:3px}.nav-parent{font:inherit}.nav-chevron{margin-left:auto;transition:transform .16s ease}.nav-group.expanded .nav-chevron{transform:rotate(180deg)}.nav-children{border-left:1px solid rgba(255,255,255,.14);display:grid;gap:2px;margin:0 0 5px 17px;padding-left:8px}.nav-children a{min-height:38px;padding-inline:10px}.sidebar-collapsed nav a,.sidebar-collapsed .nav-parent{justify-content:center;padding-inline:0}.sidebar-collapsed nav a span,.sidebar-collapsed .nav-parent span,.sidebar-collapsed .nav-chevron{display:none}.sidebar-collapsed nav a .nav-notification-badge{display:inline-flex;margin:0;position:absolute;right:6px;top:5px}.mobile-close,.nav-backdrop{display:none}.menu-toggle,.desktop-menu-icon{display:inline-flex}.phone-menu-icon{display:none}.workspace{display:flex;flex-direction:column;min-width:0}.topbar{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f6f8fbd1;border-bottom:1px solid rgba(215,224,234,.9);display:flex;justify-content:space-between;min-height:60px;padding:0 22px;position:sticky;top:0;z-index:5}.topbar strong{display:block;font-size:18px;font-weight:800;letter-spacing:.01em}.topbar-title{align-items:center;display:flex;gap:12px;min-width:0}.topbar-account{align-items:center;display:flex;gap:10px}.topbar-actions{align-items:center;display:flex;gap:12px}.announcement-notification-button{min-width:40px;position:relative}.notification-badge{align-items:center;background:#b42318;border:2px solid #fff;border-radius:999px;color:#fff;display:inline-flex;font-size:11px;font-weight:800;height:20px;justify-content:center;line-height:1;min-width:20px;padding:0 5px}.nav-notification-badge{margin-left:auto}.topbar-notification-badge{position:absolute;right:-7px;top:-7px}.announcement-toast{align-items:center;background:#fff;border:1px solid var(--border);border-left:5px solid var(--accent);border-radius:8px;box-shadow:0 18px 38px #08141f2e;display:flex;gap:12px;max-width:min(520px,calc(100vw - 32px));padding:12px;position:fixed;right:24px;top:76px;z-index:18}.announcement-toast>svg{color:var(--accent-strong);flex:0 0 auto}.announcement-toast>div{display:grid;flex:1 1 auto;gap:2px;min-width:0}.announcement-toast span{color:var(--muted);font-size:12px;font-weight:700}.announcement-toast strong{color:var(--text);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-account>span{color:var(--muted);font-size:13px;font-weight:600}.eyebrow{color:var(--muted);display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase}main{min-width:0;padding:20px 22px 28px}.page-shell{display:grid;gap:16px;margin:0;max-width:none;width:100%}.page-title{align-items:center;display:flex;justify-content:space-between;gap:12px}h1{font-size:24px;line-height:1.15;margin:0}.page-loading{color:var(--muted);padding:20px 0}h2{font-size:18px;margin:8px 0 0}.metric-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.metric,.filter-bar,.grid-shell,.form-panel,.placeholder-panel,.notice{background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow)}.metric{padding:16px 18px}.metric span{color:var(--muted);display:block;font-size:13px;margin-bottom:10px}.metric strong{color:var(--text);font-size:24px;letter-spacing:.01em}.filter-bar{display:grid;gap:14px;padding:14px}.filter-fields,.form-panel{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.filter-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.field{display:grid;gap:6px}.field span{color:var(--muted);font-size:13px}input,select{background:#fff;border:1px solid #c7d3df;border-radius:8px;min-height:38px;padding:8px 10px;width:100%}input[readonly]{background:#eef2f5;color:#526b7d;cursor:not-allowed}.searchable-field{min-width:0}.searchable-select{position:relative}.searchable-select input{padding-right:34px}.searchable-indicator{align-items:center;color:var(--muted);display:inline-flex;pointer-events:none;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.searchable-options{background:#fff;border:1px solid #c7d3df;border-radius:8px;box-shadow:0 12px 28px #08141f29;display:grid;left:0;max-height:260px;overflow-y:auto;padding:4px;position:absolute;right:0;top:calc(100% + 4px);z-index:40}.searchable-options button{align-items:center;background:transparent;border:0;border-radius:6px;box-shadow:none;color:#193344;display:flex;font-weight:500;justify-content:space-between;min-height:38px;padding:7px 9px;text-align:left;width:100%}.searchable-options button:hover,.searchable-options button.active{background:#eaf3f5;box-shadow:none;transform:none}.searchable-empty{color:var(--muted);font-size:13px;padding:10px}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.language-switcher{align-items:center;color:var(--muted);display:inline-flex;gap:10px}.language-switcher span{font-size:13px;font-weight:600}.language-switcher select{min-width:110px}.table-wrap{overflow:auto}table{border-collapse:collapse;min-width:100%}th,td{border-bottom:1px solid #e7eef5;padding:10px 12px;text-align:left;vertical-align:top;white-space:nowrap}th{background:var(--panel-soft);color:#315067;font-size:12px;font-weight:800;letter-spacing:.02em;text-transform:uppercase}thead tr:first-child th{position:sticky;top:0;z-index:2}thead tr:nth-child(2) th{position:sticky;top:42px;z-index:1}td{color:#193344;font-size:14px}th input{min-height:32px}.empty{color:var(--muted);padding:28px;text-align:center}.pager{align-items:center;display:flex;justify-content:space-between;gap:12px;padding:12px 14px}.pager>span{color:var(--muted);font-size:13px}.icon-btn{align-items:center;justify-content:center;min-height:34px;padding:0 10px}button.secondary,.button.secondary{background:#fff;border-color:#c7d3df;box-shadow:none;color:#29465a}button.secondary:hover,.button.secondary:hover{background:#f4f8fb;box-shadow:none}button:disabled{cursor:not-allowed;opacity:.6;transform:none}.toolbar-actions,.list-toolbar{align-items:center;display:flex;gap:10px}.segmented-control{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:4px;min-height:46px}.segmented-control button{background:transparent;border:0;border-bottom:2px solid transparent;border-radius:0;box-shadow:none;color:var(--muted);margin-bottom:-1px;min-height:46px;padding:0 14px}.segmented-control button:hover,.segmented-control button.active{border-bottom-color:var(--accent);box-shadow:none;color:var(--accent-strong);transform:none}.segmented-control button span{align-items:center;background:#e9eff4;border-radius:12px;color:#526b7d;display:inline-flex;font-size:12px;height:22px;justify-content:center;min-width:22px;padding:0 6px}.list-toolbar{justify-content:space-between}.search-field{max-width:360px;width:100%}.record-count{color:var(--muted);font-size:13px;white-space:nowrap}.actions-column{text-align:right;width:104px}.row-actions{display:inline-flex;gap:6px}.approve-btn{background:#247a45}.reject-btn{background:#b42318}.status-badge{border-radius:12px;display:inline-flex;font-size:12px;font-weight:700;line-height:24px;padding:0 9px}.status-badge.pending{background:#fff2cc;color:#765400}.status-badge.approved{background:#e4f5e9;color:#216e39}.status-badge.rejected{background:#fde8e7;color:#9d241c}.status-badge.active{background:#def3e5;color:#216e39}.status-badge.inactive,.status-badge.expired{background:#eef1f4;color:#526273}.status-badge.scheduled{background:#e5eefb;color:#245b9b}.small-modal{max-width:520px}.wide-modal{max-width:980px}.group-editor-fields{grid-template-columns:repeat(3,minmax(0,1fr))}.link-button{background:transparent;border:0;box-shadow:none;color:var(--accent);min-height:0;padding:0;text-decoration:underline}.link-button:hover{box-shadow:none;transform:none}.auth-page{align-items:center;background:#eef2f5;display:flex;justify-content:center;min-height:100vh;padding:24px}.auth-panel{background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 18px 50px #08172224;max-width:460px;overflow:hidden;width:100%}.auth-header{align-items:center;border-bottom:1px solid var(--border);display:grid;gap:12px;grid-template-columns:auto minmax(0,1fr) auto;padding:20px}.auth-header h1{font-size:22px}.auth-header p{color:var(--muted);margin:4px 0 0}.auth-mark{align-items:center;background:#e5f1f3;border-radius:8px;color:var(--accent-strong);display:flex;height:46px;justify-content:center;width:46px}.auth-panel form{display:grid;gap:16px;padding:20px}.auth-panel form>button{justify-content:center;width:100%}.auth-actions{display:flex;gap:10px;justify-content:flex-end}.attendance-start-form{max-width:820px}.attendance-result{align-items:center;background:#f0f9f3;border:1px solid #a9d8b8;border-radius:8px;color:#216e39;display:flex;gap:12px;max-width:820px;padding:14px 16px}.attendance-result div{display:grid;gap:3px}.attendance-result span{font-size:13px}.permission-toolbar{align-items:end;background:#fff;border:1px solid var(--border);border-radius:8px;display:grid;gap:16px;grid-template-columns:minmax(240px,1fr) minmax(240px,1fr);padding:14px 16px}.permission-section{background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}.permission-search{display:grid;gap:6px}.permission-search>span:first-child{color:#435469;font-size:13px;font-weight:700}.permission-search>span:last-child{align-items:center;border:1px solid #c7d3df;border-radius:6px;color:var(--muted);display:flex;gap:8px;padding:0 10px}.permission-search input{border:0;min-height:42px;padding:6px 0}.permission-matrices{display:grid;gap:16px;margin-top:16px}.permission-section>header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:14px 16px}.permission-section>header h2{margin:0}.permission-section>header>div{display:grid;gap:3px}.permission-section>header small,.permission-section>header span{color:var(--muted);font-size:13px}.permission-matrix{margin-top:16px}.permission-blocks{display:grid;gap:12px;max-height:58vh;overflow-y:auto;padding:12px}.permission-block{border:1px solid var(--border);border-radius:6px;overflow:hidden}.permission-block h3{background:#f5f8fa;border-bottom:1px solid var(--border);font-size:14px;margin:0;padding:9px 12px}.permission-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));padding:8px}.permission-item{align-items:flex-start;display:flex;gap:10px;min-width:0;padding:9px}.permission-item.permission-parent{background:#edf4f7;grid-column:1 / -1}.permission-item.permission-child{margin-left:18px}.permission-item input{accent-color:var(--accent);flex:0 0 auto;min-height:18px;width:18px}.permission-item>span{display:grid;gap:3px;min-width:0}.permission-item strong,.permission-item small{overflow-wrap:anywhere}.permission-item small{color:var(--muted)}.permission-save-bar{align-items:center;background:#fff;border:1px solid var(--border);border-radius:8px;bottom:12px;box-shadow:0 6px 18px #1f36461a;display:flex;justify-content:space-between;padding:10px 12px;position:sticky;z-index:3}.permission-save-bar span{color:var(--muted);font-size:13px}@media(max-width:900px){.permission-toolbar,.permission-grid{grid-template-columns:1fr}}textarea{background:#fff;border:1px solid #c7d3df;border-radius:8px;font:inherit;min-height:84px;padding:8px 10px;resize:vertical;width:100%}textarea:focus-visible{outline:3px solid rgba(15,108,122,.25);outline-offset:2px}.modal-backdrop{align-items:center;background:#08172275;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;padding:20px;position:fixed;z-index:20}.modal{background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 24px 70px #0817223d;max-height:calc(100vh - 40px);max-width:720px;overflow:auto;width:100%}.modal>header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 18px}.modal h2{margin-top:4px}.modal form{display:grid;gap:16px;padding:18px}.editor-fields{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.editor-fields .field:has(textarea){grid-column:1 / -1}.checkbox-field{align-items:center;display:flex;gap:10px;min-height:38px}.checkbox-field input{accent-color:var(--accent);min-height:18px;width:18px}.field-error{color:#b42318;font-size:12px}.notice.success{background:#f0f9f3;border-color:#a9d8b8;color:#216e39}.notice.error{background:#fff3f2;border-color:#efb4ae;color:#9d241c}.modal footer{border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;margin:0 -18px -18px;padding:14px 18px}.form-panel{padding:16px}.full-width-field,.form-actions{grid-column:1 / -1}.form-actions{display:flex;justify-content:flex-end}.file-input-shell{align-items:center;border:1px dashed #aebdca;border-radius:8px;color:var(--muted);display:flex;gap:10px;min-height:44px;padding:7px 10px}.file-input-shell input{border:0;min-height:30px;padding:0}.placeholder-panel,.notice{color:#314b5d;padding:18px}@media(max-width:767px){.app,.app.sidebar-collapsed{grid-template-columns:1fr}aside{bottom:0;height:100vh;left:0;max-width:320px;overflow:hidden;position:fixed;top:0;transform:translate(-102%);transition:transform .18s ease;width:86vw;z-index:30}aside.open{transform:translate(0)}.sidebar-collapsed .brand-copy,.sidebar-collapsed nav a span,.sidebar-collapsed .nav-parent span,.sidebar-collapsed .nav-chevron{display:block}.sidebar-collapsed nav a,.sidebar-collapsed .nav-parent{justify-content:flex-start;padding-inline:12px}.sidebar-collapsed nav a .nav-notification-badge{display:inline-flex;margin-left:auto;position:static}.mobile-close,.menu-toggle{display:inline-flex}.desktop-menu-icon{display:none}.phone-menu-icon{display:inline-flex}.mobile-close{background:transparent;border-color:#ffffff2e;box-shadow:none;color:#fff}button.nav-backdrop{background:#08172273;border:0;border-radius:0;box-shadow:none;display:block;top:0;right:0;bottom:0;left:0;min-height:0;opacity:0;padding:0;pointer-events:none;position:fixed;transition:opacity .18s ease;width:100%;z-index:25}button.nav-backdrop.visible{opacity:1;pointer-events:auto}.topbar{padding:0 16px}.filter-actions{justify-content:stretch}}.dual-list-layout{display:grid;grid-template-columns:minmax(0,1fr) 52px minmax(0,1fr);gap:12px;align-items:stretch}.member-list,.announcement-targets{border:1px solid var(--border);border-radius:6px;background:var(--panel);min-width:0}.member-list>header,.announcement-targets>header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}.member-list h2,.announcement-targets h3{margin:0;font-size:.95rem}.dual-list-actions{display:flex;flex-direction:column;justify-content:center;gap:8px}.dual-list-actions button{width:44px;height:44px;padding:0;justify-content:center}.shift-matrix th small{display:block;margin-top:4px;font-weight:400;color:var(--muted);white-space:nowrap}.shift-matrix td{min-width:190px;vertical-align:top}.shift-matrix td:first-child{min-width:112px;position:sticky;left:0;z-index:1;background:var(--panel)}.multi-search-select{position:relative}.multi-search-select summary{list-style:none;min-height:38px;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 9px;border:1px solid var(--border);border-radius:5px;cursor:pointer;background:var(--panel)}.multi-search-select summary::-webkit-details-marker{display:none}.multi-search-select summary span{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multi-search-popover{position:absolute;z-index:20;top:calc(100% + 4px);left:0;width:260px;max-height:280px;padding:8px;border:1px solid var(--border);border-radius:6px;background:var(--panel);box-shadow:0 10px 24px #00000024}.multi-search-popover>input{width:100%;margin-bottom:7px}.multi-search-popover>div{max-height:210px;overflow:auto}.multi-search-popover label{display:flex;align-items:center;gap:8px;padding:7px 4px}.camera-capture{display:grid;gap:10px}.camera-stage{width:min(100%,640px);aspect-ratio:4 / 3;background:#111;overflow:hidden;border-radius:6px}.camera-stage video,.camera-stage img{width:100%;height:100%;object-fit:cover;display:block;transform:none}.camera-actions{display:flex;flex-wrap:wrap;gap:8px}.leave-balance-summary,.leave-balance-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.leave-balance-summary>div,.leave-balance-card,.document-preview{background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow);padding:14px 16px}.leave-balance-summary span,.leave-balance-card small,.document-preview span,.document-preview small{color:var(--muted);font-size:13px}.leave-balance-summary strong,.leave-balance-card strong,.document-preview strong{display:block;font-size:24px;margin-top:6px}.leave-balance-card header{align-items:center;display:flex;gap:9px;font-weight:700}.document-preview{display:grid;gap:5px;grid-column:1 / -1}.ot-destination{grid-column:1 / -1;margin:0;padding:14px;border:1px solid var(--border);border-radius:6px}.ot-destination legend{padding:0 6px;font-weight:700}.ot-destination .checkbox-field{display:inline-flex;width:min(100%,330px);margin-right:12px;align-items:flex-start}.ot-destination .checkbox-field span{display:grid;gap:3px}.ot-destination small,.ot-destination p{color:var(--muted)}.target-row{display:grid;grid-template-columns:minmax(160px,.7fr) minmax(220px,1.3fr) 40px;gap:10px;align-items:end;padding:10px 12px}.target-row+.target-row{border-top:1px solid var(--border)}.target-row>.icon-btn{margin-bottom:2px}.announcement-feed{display:grid;gap:12px}.announcement-feed article{border:1px solid var(--border);border-radius:8px;padding:16px}.announcement-feed article.unread{border-left:4px solid var(--accent)}.announcement-feed article.acknowledged{background:#f8fafb}.announcement-feed article header{display:flex;gap:10px;align-items:flex-start}.announcement-feed article header>div{flex:1;min-width:0}.announcement-feed h2{margin:0;font-size:1.05rem}.announcement-feed time{color:var(--muted);font-size:.82rem}.announcement-feed p{margin:10px 0 0 28px;white-space:pre-wrap}.announcement-feed footer{display:flex;justify-content:flex-end;margin-top:14px}.announcement-detail{display:grid;gap:16px;padding:16px}.announcement-detail>p{margin:0;white-space:pre-wrap}.status-chip{border-radius:999px;flex:0 0 auto;font-size:12px;font-weight:700;padding:4px 9px}.status-chip.pending{background:#fff2cc;color:#795600}.status-chip.success{background:#def3e5;color:#216e39}.modal-grid{overflow-x:auto;padding:16px}@media(max-width:600px){.announcement-feed article header{flex-wrap:wrap}.announcement-feed article header .status-chip{margin-left:28px}.announcement-feed p{margin-left:0}.announcement-feed footer button{width:100%}}.payroll-preview>header>div{display:grid;gap:3px}.payroll-preview-toolbar{display:flex;align-items:end;justify-content:space-between;gap:16px;padding-bottom:12px}.amount-input{width:140px}.page-actions{display:flex;flex-wrap:wrap;gap:8px}@media(max-width:900px){.dual-list-layout{grid-template-columns:1fr}.dual-list-actions{flex-direction:row}.target-row{grid-template-columns:1fr 1fr 40px}}@media(max-width:600px){.target-row{grid-template-columns:1fr 40px}.target-row .field:first-child{grid-column:1 / -1}.payroll-preview-toolbar{align-items:stretch;flex-direction:column}}@media(min-width:768px)and (max-width:1199px){main{padding:16px}.topbar{padding-inline:16px}}@media(max-width:640px){button,.button,select,input{min-height:44px}.topbar{align-items:flex-start;flex-direction:column;gap:10px;min-height:0;padding:12px 14px}.topbar-title{width:100%}.language-switcher,.topbar-account{justify-content:space-between;width:100%}.topbar-actions{flex-wrap:wrap;width:100%}.announcement-toast{left:12px;right:12px;top:92px}main{padding:14px 12px 20px}.page-title{align-items:flex-start;flex-direction:column}h1{font-size:24px}.pager{align-items:flex-start;flex-direction:column}.editor-fields{grid-template-columns:1fr}.toolbar-actions{display:grid;grid-template-columns:1fr 1fr;width:100%}.toolbar-actions button{justify-content:center}.segmented-control{overflow-x:auto}.form-panel,.filter-fields{grid-template-columns:1fr}.form-actions button{justify-content:center;width:100%}.modal-backdrop{padding:0}.modal{border:0;border-radius:0;height:100vh;max-height:none;max-width:none}.auth-page{align-items:stretch;padding:0}.auth-panel{border:0;border-radius:0;box-shadow:none;max-width:none}.auth-header{grid-template-columns:auto minmax(0,1fr)}.auth-header .language-switcher{grid-column:1 / -1}.permission-grid{grid-template-columns:1fr}}:root{--brand-primary: #64B9BB;--brand-primary-strong: #4AA5A8;--brand-primary-soft: #E8F6F6;--brand-primary-ring: rgba(100, 185, 187, .35);--brand-secondary: #315862;--brand-secondary-strong: #25464F;--brand-secondary-soft: #EAF0F2;--bg: #F5F8F9;--panel: #FFFFFF;--panel-soft: #F8FBFC;--border: #D8E4E7;--border-strong: #B7C9CE;--text: #111827;--text-strong: #000000;--muted: #5E6F74;--accent: var(--brand-primary);--accent-strong: var(--brand-secondary);--nav: var(--brand-secondary);--nav-strong: var(--brand-secondary-strong);--shadow: 0 14px 34px rgba(49, 88, 98, .1);--shadow-soft: 0 6px 18px rgba(49, 88, 98, .08);--radius: 8px;--radius-sm: 6px;--content-gap: 18px;color:var(--text);font-family:Aptos,Segoe UI Variable,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}body{background:linear-gradient(180deg,#64b9bb1a 0,#64b9bb00 210px),var(--bg);color:var(--text)}button,.button{background:var(--brand-primary);border:1px solid var(--brand-primary-strong);border-radius:var(--radius-sm);box-shadow:var(--shadow-soft);color:#062c31;font-weight:700;min-height:40px}button:hover,.button:hover{background:#72c3c5;box-shadow:0 12px 24px #64b9bb38}button:focus-visible,.button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{outline:3px solid var(--brand-primary-ring);outline-offset:2px}button.secondary,.button.secondary,.icon-btn.secondary{background:#fff;border-color:var(--border-strong);color:var(--brand-secondary)}button.secondary:hover,.button.secondary:hover,.icon-btn.secondary:hover{background:var(--brand-secondary-soft);border-color:var(--brand-secondary)}.approve-btn{background:#2e7d57;border-color:#246846;color:#fff}.reject-btn{background:#ba3a34;border-color:#982b26;color:#fff}.link-button{color:var(--brand-secondary);font-weight:700;text-decoration-color:var(--brand-primary);text-underline-offset:3px}.app{background:transparent;grid-template-columns:236px minmax(0,1fr)}.app.sidebar-collapsed{grid-template-columns:68px minmax(0,1fr)}aside{background:linear-gradient(180deg,#ffffff14,#fff0),var(--brand-secondary);box-shadow:8px 0 24px #3158622e;padding:18px 12px}.brand{border-bottom-color:#ffffff29;min-height:58px;padding:4px 8px 16px}.brand span{color:#fff;font-size:21px;letter-spacing:0}.brand small{color:#ffffffc2;font-weight:600}nav{gap:5px;padding-right:2px}nav::-webkit-scrollbar,.permission-blocks::-webkit-scrollbar,.table-wrap::-webkit-scrollbar,.searchable-options::-webkit-scrollbar,.multi-search-popover>div::-webkit-scrollbar{height:10px;width:10px}nav::-webkit-scrollbar-thumb,.permission-blocks::-webkit-scrollbar-thumb,.table-wrap::-webkit-scrollbar-thumb,.searchable-options::-webkit-scrollbar-thumb,.multi-search-popover>div::-webkit-scrollbar-thumb{background:#31586247;border-radius:999px}nav a,.nav-parent{border-radius:var(--radius-sm);color:#ffffffe0;font-weight:700;min-height:42px}nav a svg,.nav-parent svg{color:#ffffffd1}nav a:hover,.nav-parent:hover,nav a.active,.nav-parent[aria-expanded=true]{background:#64b9bb2e;border-color:#64b9bb47;color:#fff}nav a.active{box-shadow:inset 3px 0 0 var(--brand-primary)}.nav-children{border-left-color:#64b9bb5c;gap:3px;margin-left:18px}.nav-children a{color:#ffffffd1;font-size:13px;min-height:36px}.topbar{background:#ffffffeb;border-bottom:1px solid var(--border);box-shadow:0 8px 22px #31586212;min-height:62px;padding:0 24px}.topbar strong{color:var(--brand-secondary);font-size:18px;letter-spacing:0}.topbar-account>span,.language-switcher span,.eyebrow{color:var(--muted)}main{padding:22px 24px 32px}.page-shell{gap:var(--content-gap)}.page-title{min-height:40px}h1{color:var(--brand-secondary);font-size:25px;font-weight:800;letter-spacing:0}h2{color:var(--brand-secondary);font-weight:800}.metric,.filter-bar,.grid-shell,.form-panel,.placeholder-panel,.notice,.permission-toolbar,.permission-section,.member-list,.announcement-targets,.leave-balance-summary>div,.leave-balance-card,.document-preview,.announcement-feed article{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-soft)}.metric{border-top:3px solid var(--brand-primary);min-height:118px;padding:18px}.metric span{color:var(--muted);font-weight:700}.metric strong{color:var(--text-strong);font-size:28px}.filter-bar,.form-panel,.permission-toolbar{padding:16px}.filter-fields,.form-panel{gap:14px;grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.filter-actions{align-items:center}.field{gap:7px}.field span,.permission-search>span:first-child{color:var(--brand-secondary);font-size:13px;font-weight:700}input,select,textarea,.multi-search-select summary{background:#fff;border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text);min-height:40px}input:hover,select:hover,textarea:hover,.multi-search-select summary:hover{border-color:var(--brand-primary-strong)}input[readonly]{background:#f0f5f6;color:var(--muted)}.searchable-indicator{color:var(--brand-secondary)}.searchable-options,.multi-search-popover{border-color:var(--border-strong);border-radius:var(--radius);box-shadow:0 18px 38px #3158622e}.searchable-options button{color:var(--text);min-height:40px}.searchable-options button:hover,.searchable-options button.active{background:var(--brand-primary-soft);color:var(--brand-secondary)}.grid-shell{overflow:hidden}.table-wrap{background:#fff}table{border-collapse:separate;border-spacing:0}th,td{border-bottom:1px solid #E7EEF0;padding:11px 13px}th{background:#f2f8f8;color:var(--brand-secondary);font-size:12px;letter-spacing:.01em}thead tr:nth-child(2) th{background:#fafdfd}th input{background:#fff;border-color:#dce8ea;min-height:34px}tbody tr:hover td{background:#f7fcfc}td{color:#1f2933;font-size:14px}.actions-column{width:118px}.pager{background:#fff;border-top:1px solid var(--border)}.pager>span{color:var(--muted);font-weight:700}.pager .icon-btn{min-width:38px}.status-badge,.status-chip{border-radius:999px;font-weight:800;letter-spacing:0}.status-badge.pending,.status-chip.pending{background:#fff4d8;color:#6a4a00}.status-badge.approved,.status-badge.active,.status-chip.success{background:#e7f6ed;color:#246847}.status-badge.rejected{background:#fce8e6;color:#982b26}.status-badge.cancelled,.status-badge.inactive,.status-badge.expired{background:#eef2f3;color:#4b5d63}.status-badge.scheduled{background:var(--brand-primary-soft);color:var(--brand-secondary)}.notice{border-left:5px solid var(--brand-primary);box-shadow:0 12px 28px #3158621a;font-weight:700}.notice.success{background:#f0faf5;border-color:#3f9d68;color:#1f6841}.notice.error{background:#fff2f1;border-color:#d84e45;color:#8f2823}.modal-backdrop{background:#14272c85;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 28px 80px #31586242}.modal>header{background:#f7fbfb;border-bottom-color:var(--border)}.modal footer{background:#fbfdfd;border-top-color:var(--border)}.auth-page{background:radial-gradient(circle at top left,rgba(100,185,187,.22),transparent 34%),linear-gradient(135deg,var(--brand-secondary),#183740)}.auth-panel{border:1px solid rgba(255,255,255,.34);box-shadow:0 28px 80px #00000038}.auth-header{background:#fff}.auth-mark{background:var(--brand-primary-soft);color:var(--brand-secondary)}.permission-block{border-color:var(--border);border-radius:var(--radius-sm)}.permission-block h3,.permission-item.permission-parent{background:#f2f8f8;color:var(--brand-secondary)}.permission-item input,.checkbox-field input{accent-color:var(--brand-primary)}.dual-list-layout{gap:14px}.member-list>header,.announcement-targets>header,.permission-section>header{background:#f9fcfc}.shift-matrix td:first-child{background:#fff;box-shadow:6px 0 12px #3158620f}.camera-stage{border:1px solid var(--border);border-radius:var(--radius)}.ot-destination{background:#fafdfd;border-color:var(--border);border-radius:var(--radius)}.announcement-feed article.unread{border-left-color:var(--brand-primary)}.announcement-feed article.acknowledged{background:#fafcfc}.payroll-preview-toolbar{border-bottom:1px solid var(--border)}.leave-balance-card{border-top:3px solid var(--brand-primary)}.leave-balance-card header,.document-preview span{color:var(--brand-secondary)}@media(max-width:1199px){.app{grid-template-columns:68px minmax(0,1fr)}.app:not(.sidebar-collapsed){grid-template-columns:236px minmax(0,1fr)}}@media(max-width:767px){aside{max-width:340px;padding:16px 12px;width:min(88vw,340px)}.topbar{background:#fff}.filter-actions button,.page-actions button{justify-content:center;width:100%}}@media(max-width:640px){main{padding:14px 12px 22px}.filter-bar,.form-panel,.permission-toolbar{padding:14px}.metric-grid{grid-template-columns:1fr}.auth-panel{border:0;border-radius:0}.modal{border-radius:0}}.auth-page{background:radial-gradient(circle at 18% 18%,rgba(100,185,187,.48),transparent 28%),radial-gradient(circle at 82% 12%,rgba(255,255,255,.2),transparent 24%),radial-gradient(circle at 72% 82%,rgba(100,185,187,.28),transparent 30%),linear-gradient(135deg,#315862,#244750 48%,#10272d)}.camera-stage video{transform:scaleX(-1)}.camera-stage img{transform:none}.status-badge.warning{background:#fff5d8;color:#6b4a00}.notice.warning{background:#fff8e6;border-color:#f1c75b;color:#5c4300}.notice.info{background:#eef6ff;border-color:#9ec5fe;color:#1e4e8c}.requested-days-preview{align-items:center;display:flex;min-height:44px}.single-cell-select{position:relative}.single-cell-trigger{align-items:center;background:#fff;border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text);display:flex;font:inherit;gap:8px;justify-content:space-between;min-height:40px;padding:7px 9px;width:100%}.single-cell-trigger:hover,.single-cell-trigger[aria-expanded=true]{border-color:var(--brand-primary-strong)}.single-cell-trigger span{overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.single-cell-popover{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);left:0;max-height:300px;min-width:280px;padding:8px;position:absolute;top:calc(100% + 6px);z-index:30}.single-cell-search{align-items:center;display:flex;gap:6px;margin-bottom:8px}.single-cell-search input{min-width:0;width:100%}.single-cell-options{display:grid;gap:3px;max-height:220px;overflow:auto}.single-cell-options button{align-items:center;background:transparent;border:0;border-radius:var(--radius-sm);color:var(--text);display:flex;font:inherit;justify-content:space-between;min-height:36px;padding:8px;text-align:left;width:100%}.single-cell-options button:hover,.single-cell-options button.active{background:#64b9bb29}.payroll-preview{height:min(860px,calc(100vh - 48px));max-width:min(1180px,calc(100vw - 48px));width:min(1180px,calc(100vw - 48px))}.payroll-preview>.table-wrap{max-height:calc(100vh - 285px);overflow:auto;padding-inline:18px}.payroll-preview>footer,.payslip-modal>footer{margin:0;position:sticky;bottom:0;background:#fff;z-index:2}.payslip-summary{display:grid;gap:10px 18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));padding:16px 18px}.payslip-summary span{color:var(--muted)}.payslip-summary strong{color:var(--text)}.toast-region{display:grid;gap:10px;left:50%;position:fixed;top:20px;transform:translate(-50%);width:min(560px,calc(100vw - 32px));z-index:1200}.toast{align-items:flex-start;background:#fff;border:1px solid var(--border);border-left:5px solid #2563EB;border-radius:var(--radius);box-shadow:0 18px 50px #1025332e;color:var(--text);display:grid;gap:10px;grid-template-columns:auto minmax(0,1fr) auto;padding:13px 14px}.toast-body{display:grid;gap:4px}.toast p{line-height:1.45;margin:0}.toast-meta{color:var(--muted);display:flex;flex-wrap:wrap;font-size:11px;gap:6px 10px;line-height:1.35}.toast-icon{display:inline-flex;margin-top:1px}.toast-success{border-left-color:#15803d}.toast-success .toast-icon{color:#15803d}.toast-error{border-left-color:#b91c1c}.toast-error .toast-icon{color:#b91c1c}.toast-warning{border-left-color:#d97706}.toast-warning .toast-icon{color:#b45309}.toast-info{border-left-color:#2563eb}.toast-info .toast-icon{color:#2563eb}.toast-close{background:transparent;border:0;box-shadow:none;color:var(--muted);min-height:28px;padding:4px}.toast-close:hover{background:#31586214;box-shadow:none;transform:none}.confirm-backdrop{align-items:center;background:#0b1c267a;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;padding:18px;position:fixed;z-index:1100}.confirm-dialog{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 28px 80px #10253347;max-width:460px;overflow:hidden;width:100%}.confirm-dialog header{align-items:flex-start;display:grid;gap:12px;grid-template-columns:auto minmax(0,1fr);padding:22px 22px 16px}.confirm-dialog h2{color:var(--brand-secondary, #315862);font-size:20px;line-height:1.2;margin:0 0 8px}.confirm-dialog p{color:var(--muted);line-height:1.5;margin:0}.confirm-icon{align-items:center;background:#64b9bb2e;border-radius:999px;color:var(--brand-secondary, #315862);display:inline-flex;height:42px;justify-content:center;width:42px}.confirm-danger .confirm-icon{background:#fee2e2;color:#b91c1c}.confirm-warning .confirm-icon{background:#fef3c7;color:#b45309}.confirm-dialog footer{align-items:center;background:#f8fbfb;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;padding:14px 22px}.warning-btn{background:#d97706;color:#fff}.button-spinner{animation:feedback-spin .8s linear infinite}@keyframes feedback-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:640px){.toast-region{left:50%;top:12px;width:calc(100vw - 24px)}.confirm-dialog footer{align-items:stretch;flex-direction:column-reverse}.confirm-dialog footer button{justify-content:center;width:100%}}
