:root{--primary:#5146e5;--primary-2:#6658f1;--muted:#94a0b5;--text:#273043;--line:#e7ebf3;--panel:#ffffff;--bg:#f4f7fb;--green:#49b07b;--red:#e74e66;--orange:#eea52d;--purple-soft:#eef0ff}*{box-sizing:border-box}body,html{min-height:100%;margin:0}body{color:var(--text);background:var(--bg);font-family:var(--font-jakarta),ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-weight:500;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.01em}b,h1,h2,h3,strong,th{font-weight:700}h1,h2{letter-spacing:-.02em}button,input,select{font:inherit}button{border:0;cursor:pointer}input,select{min-height:40px;border:1.5px solid #e2e7f0;border-radius:10px;background:#fff;color:var(--text);font-size:13px;font-weight:600;outline:none;padding:0 14px}select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:38px;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237a8398' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;cursor:pointer;text-overflow:ellipsis}input:focus,select:focus{border-color:var(--primary-2);box-shadow:0 0 0 3px rgba(101,88,241,.12)}.admin-shell{display:grid;grid-template-columns:238px minmax(0,1fr);min-height:100vh}.sidebar{position:-webkit-sticky;position:sticky;top:0;height:100vh;background:#fff;border-right:1px solid var(--line)}.brand,.sidebar{display:flex;flex-direction:column}.brand{align-items:center;gap:7px;padding:16px 14px 14px;background:var(--primary);color:#fff}.brand-lockups{justify-content:center;gap:10px}.brand-lockups,.brand-side{display:flex;align-items:center}.brand-side{gap:9px}.pertamina-mark{width:24px;height:24px;flex-shrink:0;background:#fff;-webkit-clip-path:polygon(20% 18%,74% 18%,98% 45%,76% 45%,56% 75%,0 75%,24% 45%,0 45%);clip-path:polygon(20% 18%,74% 18%,98% 45%,76% 45%,56% 75%,0 75%,24% 45%,0 45%)}.brand-left,.brand-right{display:flex;flex-direction:column;line-height:1.12}.brand-left strong{font-size:12px;letter-spacing:.2px;white-space:nowrap}.brand-right strong{font-size:14px;letter-spacing:.2px;white-space:nowrap}.brand small,.brand-left span,.brand-right span{color:rgba(255,255,255,.72);font-size:8px;font-weight:600;letter-spacing:1px;white-space:nowrap}.brand-divider{width:1px;height:30px;flex-shrink:0;background:rgba(255,255,255,.34)}.brand-logo,.mobile-logo,.sidebar-logo{height:32px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}.mobile-logo{height:28px}.brand small{font-size:8px;letter-spacing:2.5px}.profile{display:flex;gap:12px;align-items:center;padding:22px 18px;border-bottom:1px solid #f0f2f7}.avatar,.profile .avatar{display:grid;width:40px;height:40px;place-items:center;border-radius:12px;background:#e5e8ff;color:var(--primary);font-size:20px;font-weight:900}.profile small{display:block;color:var(--muted);font-size:11px;text-transform:uppercase}.profile strong{display:block;margin-top:3px;font-size:14px}.nav{display:flex;flex-direction:column;gap:6px;padding:16px 10px}.logout,.nav a,.nav button{display:flex;align-items:center;gap:11px;min-height:42px;padding:0 18px;border-radius:11px;background:transparent;color:#6f7c91;font-size:14px;font-weight:700;text-align:left;text-decoration:none}.logout svg,.nav a svg,.nav button svg{width:19px;height:19px;flex-shrink:0}.nav a.active,.nav button.active{background:#edf0ff;color:var(--primary)}.nav .self-button{margin-bottom:2px;border:1px solid #c9f4dc;color:#47a872}.logout{width:calc(100% - 28px);justify-content:center;margin:auto 14px 14px;background:#fff0f2;color:#df3f58}.main-panel{min-width:0}.topbar{position:-webkit-sticky;position:sticky;z-index:5;top:0;display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 22px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.96);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.topbar h1{margin:0;font-size:20px;line-height:1.1;letter-spacing:-.02em}.topbar-left{display:flex;align-items:center;gap:14px;min-width:0}.menu-toggle{display:none;width:44px;height:44px;flex-shrink:0;place-items:center;border-radius:12px;background:#f1f3ff;color:var(--primary)}.sidebar-overlay{position:fixed;inset:0;z-index:18;background:rgba(31,38,53,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.topbar p{margin:3px 0 0;color:#6d788d;font-size:12px}.live-pill{display:flex;align-items:center;gap:8px;height:34px;padding:0 15px;border:1px solid #dfe3f7;border-radius:9px;background:#f1f3ff;color:var(--primary);font-size:13px}.live-pill span{width:8px;height:8px;border-radius:50%;background:var(--primary-2)}.content{padding:22px}.card,.filter-card,.metric,.panel-card{border:1px solid var(--line);border-radius:18px;background:var(--panel);box-shadow:0 2px 7px rgba(38,48,67,.06)}.filter-card{display:flex;align-items:center;gap:16px;min-height:60px;margin-bottom:18px;padding:14px 22px}.filter-card label,.report-filters label{display:flex;align-items:center;gap:10px;color:#9aa6bb;font-size:10px;text-transform:uppercase}.filter-card select{width:190px}.filter-card button:not(.ss-trigger),.form-filters button:not(.ss-trigger),.panel-head button:not(.ss-trigger),.report-filters button:not(.ss-trigger){display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border-radius:10px;background:var(--primary);color:#fff;font-size:13px;padding:0 20px;box-shadow:0 8px 18px rgba(81,70,229,.22);cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.filter-card button:not(.ss-trigger):hover,.form-filters button:not(.ss-trigger):hover,.panel-head button:not(.ss-trigger):hover,.report-filters button:not(.ss-trigger):hover{background:var(--primary-2);transform:translateY(-2px);box-shadow:0 14px 26px rgba(81,70,229,.34)}.filter-card button:not(.ss-trigger):active,.form-filters button:not(.ss-trigger):active,.panel-head button:not(.ss-trigger):active,.report-filters button:not(.ss-trigger):active{transform:translateY(0);box-shadow:0 6px 14px rgba(81,70,229,.22)}.filter-card button:not(.ss-trigger) svg{transition:transform .4s ease}.filter-card button:not(.ss-trigger):hover svg{transform:rotate(180deg)}.filter-card>button{margin-left:auto}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));grid-gap:16px;gap:16px;margin-bottom:18px}.metric{display:flex;align-items:center;justify-content:space-between;min-height:92px;padding:18px 22px}.card h2+p,.metric small,.panel-head p{display:block;color:#9aa6ba;font-size:11px;line-height:1.4;text-transform:uppercase}.metric strong{display:block;margin-top:6px;font-size:25px;font-weight:800;line-height:1;letter-spacing:-.02em}.metric span{display:block;margin-top:10px;color:#9ba6ba;font-size:10px}.green,.green-text{color:var(--green)}.red,.red-text{color:var(--red)}.orange,.orange-text{color:#cc7625}.link-text,.purple{color:var(--primary)}.metric-icon{display:grid;width:46px;height:46px;place-items:center;border-radius:50%}.metric-icon svg{width:24px;height:24px}.metric-icon.green{background:#e9fbf1}.metric-icon.red{background:#fff0f2}.metric-icon.purple{background:#eef0ff}.metric-icon.orange{background:#fff8e8}.dashboard-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);grid-gap:16px;gap:16px}.card{position:relative;min-height:180px;padding:20px;overflow:hidden}.card h2,.history-section h2,.panel-head h2{display:flex;align-items:center;gap:9px;margin:0 0 16px;font-size:16px;letter-spacing:-.01em}.card h2 svg,.history-section h2 svg,.panel-head h2 svg{width:19px;height:19px;color:var(--primary-2)}.gold{color:var(--orange)!important}.line-chart{height:300px}.line-chart svg{display:block;width:100%;height:265px}.line-chart line{stroke:#d6d9e3;stroke-width:1}.line-chart .dot{transition:r .15s ease,stroke-width .15s ease}.line-chart .guide{stroke:#655eea;stroke-width:1.5;stroke-dasharray:5 5;opacity:.45}.line-chart .tooltip rect{fill:#1f2333;filter:drop-shadow(0 6px 14px rgba(0,0,0,.25))}.line-chart .tooltip .tt-val{fill:#fff;font-size:15px;font-weight:700;text-anchor:middle}.line-chart .tooltip .tt-lbl{fill:#c9cbe0;font-size:12px;text-anchor:middle}.axis{display:grid;grid-template-columns:repeat(7,1fr);color:#666;font-size:13px;font-weight:600}.axis span{text-align:center;transition:color .15s ease}.axis span.on{color:#655eea}.donut-card{justify-content:center}.donut-card,.donut-wrap{display:flex;flex-direction:column;align-items:center}.donut-wrap{gap:14px;width:100%}.donut-svg{width:230px;height:230px;max-width:100%}.donut-seg{cursor:pointer;transition:opacity .18s ease}.donut-svg:hover .donut-seg{opacity:.55}.donut-svg .donut-seg:hover{opacity:1}.donut-value{font-size:40px;font-weight:800;text-anchor:middle;letter-spacing:-.02em}.donut-label{fill:#6a6f85;font-size:15px;font-weight:600;text-anchor:middle}.donut-sub{fill:#9aa0b4;font-size:12px;text-anchor:middle}.legend{display:flex;justify-content:center;gap:10px;font-size:12px}.legend button{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border:1px solid var(--line,#e6e8f0);border-radius:999px;background:#fff;color:#5a5f73;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease}.legend button.on{border-color:#655eea;background:#f4f3ff;color:#1f2333}.legend span{width:9px;height:9px;align-self:center;border-radius:50%}.green-dot{background:var(--green)}.red-dot{background:var(--red)}.leader-card,.list-card{margin-top:18px;height:384px;display:flex;flex-direction:column}.leader-card .leaderboard,.list-card .progress-list{flex:1 1;min-height:0;overflow-y:auto;padding-right:6px}.chart-card,.donut-card{height:384px}.progress-list{display:grid;grid-gap:17px;gap:17px}.mini-row>div,.progress-row>div{display:flex;justify-content:space-between;gap:12px}.mini-row strong,.progress-row strong{min-width:0;overflow:hidden;color:#3b4458;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.mini-row span,.progress-row span{color:#9aa6ba}.mini-row i,.progress-row i{display:block;height:6px;margin-top:8px;border-radius:999px;background:var(--primary-2)}.leaderboard{display:grid;grid-gap:16px;gap:16px}.leader{display:grid;grid-template-columns:32px 1fr auto;align-items:center;grid-gap:12px;gap:12px;padding-bottom:14px;border-bottom:1px solid #f0f2f6}.leader:last-child{border-bottom:0}.leader small,.person small,.score-table small{display:block;margin-top:3px;color:#9aa6ba}.leader aside{display:grid;grid-gap:6px;gap:6px;justify-items:end}.leader b{color:var(--primary);font-size:12px}.leader em{border-radius:8px;background:#e7f9ef;color:var(--green);font-size:11px;font-style:normal;padding:4px 8px}.rank{color:#9ba6ba}.medal svg{color:var(--orange)}.quad-grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));grid-gap:16px;gap:16px;margin-top:16px}.small-ranking{height:320px;display:flex;flex-direction:column}.small-ranking .mini-rows{flex:1 1;min-height:0;overflow-y:auto;display:grid;grid-gap:14px;gap:14px;align-content:start;padding-right:6px}.mini-row{margin-top:18px}.mini-row i.violet{background:#ac57ed}.mini-row i.green{background:#52b98b}.mini-row i.orange{background:#eea52d}.mini-row i.red{background:#ef5369}.corner-badge{position:absolute;right:18px;top:24px;color:#f5b83e}.panel-card{overflow:hidden}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding:26px 28px 18px}.panel-head h2{margin-bottom:6px;font-size:19px}.panel-head p{max-width:880px;font-size:13px;font-weight:500;text-transform:none}.panel-head button{min-width:150px;min-height:44px;margin-top:4px}.form-filters,.report-filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px;padding:0 28px 24px}.form-filters select{min-width:180px}.form-filters select:nth-child(2){min-width:300px}.table-toolbar{justify-content:space-between;gap:20px;padding:18px 28px 14px;border-top:1px solid var(--line)}.show-entries,.table-toolbar{display:flex;align-items:center}.show-entries{gap:9px;color:#6f7c91}.show-entries select{min-width:78px}.search-box{display:flex;align-items:center;gap:12px;color:#a2adbf}.search-box input{width:190px}.table-wrap{width:100%;overflow:auto}table{width:100%;border-collapse:collapse}th{color:#9aa6ba;font-size:12px;text-align:left;text-transform:uppercase}td,th{padding:11px 16px;white-space:nowrap}tbody tr{border-top:1px solid #edf0f5}.employee-table thead th,.report-table thead th,.score-table thead th{background:#fafbfe;border-bottom:1px solid #e7ebf3}.employee-table tbody tr:first-child,.report-table tbody tr:first-child,.score-table tbody tr:first-child{border-top:0}.employee-table tbody tr:hover td,.report-table tbody tr:hover td,.score-table tbody tr:hover td{background:#f8f9ff}.person{display:flex;align-items:center;gap:13px}.person span{display:grid;width:44px;height:44px;place-items:center;border-radius:50%;background:#e4e9ff;color:var(--primary);font-size:17px;font-weight:900}.mono{color:#6f7c91;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.mono.small,.status{font-size:11px}.status{border-radius:9px;padding:6px 11px}.status.ok{background:#dff8ea;color:var(--green)}.status.bad{background:#ffe8ec;color:var(--red)}.status.neutral{background:#eef2f8;color:#667289}.circle-btn{display:grid;width:38px;height:38px;place-items:center;border-radius:50%;background:#fff;color:#667289;box-shadow:0 2px 7px rgba(38,48,67,.16)}.actions{display:flex;gap:8px}.actions button{display:grid;width:36px;height:36px;place-items:center;border-radius:9px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}.actions button:hover{transform:translateY(-1px);filter:brightness(.97)}.actions .detail:hover{box-shadow:0 6px 14px rgba(81,70,229,.25)}.actions .edit:hover{box-shadow:0 6px 14px rgba(238,165,45,.28)}.actions .delete:hover{box-shadow:0 6px 14px rgba(231,78,102,.28)}.actions .edit{border:1px solid #ffd770;background:#fff9e8;color:#dc8422}.actions .delete{border:1px solid #ffc4cf;background:#fff0f3;color:var(--red)}.export-btn{background:#52bc88!important;box-shadow:0 12px 22px rgba(82,188,136,.22)!important}.export-btn:hover{background:#45ad7a!important;box-shadow:0 16px 30px rgba(82,188,136,.36)!important}.export-btn:disabled{background:#9dd4b9!important;box-shadow:0 6px 12px rgba(82,188,136,.15)!important;cursor:not-allowed;opacity:.7;transform:none!important}.report-filters{padding-top:0;border-bottom:1px solid var(--line)}.report-filters label{align-items:flex-start;flex-direction:column;gap:8px}.report-filters input,.report-filters select{min-width:170px}.report-filters label:nth-child(3) select{min-width:240px}.report-filters button{min-width:170px;min-height:44px}.report-filters.compact label:nth-child(3) select,.report-filters.score label:nth-child(3) select{min-width:290px}.monthly-grid-wrap{width:calc(100% - 28px);margin:18px 14px 26px;overflow:auto;border:1px solid var(--line);border-radius:14px}.monthly-table td,.monthly-table th{border:0;border-bottom:1px solid #f0f2f6;padding:9px 8px;text-align:center}.monthly-table thead th{background:#fafbfe;border-bottom:1px solid #e7ebf3}.monthly-table tbody tr{border-top:0}.monthly-table tbody tr:last-child td{border-bottom:0}.monthly-table tbody tr:hover td{background:#f8f9ff}.monthly-table td:nth-child(2),.monthly-table td:nth-child(3),.monthly-table th:nth-child(2),.monthly-table th:nth-child(3){text-align:left}.monthly-table th small{display:block;margin-top:4px;color:#9aa6ba;font-size:9px}.cell-a{background:#ffe0e5;color:var(--red)}.cell-h{background:#d9f6e7;color:#318c63}.score-table td,.score-table th{padding:13px 18px}.score-table small{font-size:11px}.score-table .score{color:var(--primary)}.score-table .podium{color:var(--orange)}.modal-backdrop{position:fixed;z-index:20;inset:0;display:grid;place-items:center;background:rgba(31,38,53,.58);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:24px}.modal-backdrop.confirm-backdrop{z-index:99999!important}.employee-modal{width:min(840px,94vw);max-height:90vh;overflow:hidden;border-radius:34px;background:#fff;box-shadow:0 30px 80px rgba(0,0,0,.28)}.employee-modal header{display:grid;grid-template-columns:52px 1fr 58px;grid-gap:14px;gap:14px;align-items:center;min-height:92px;padding:22px 26px;background:linear-gradient(120deg,#5146e5,#9a35e8);color:#fff}.employee-modal h2{margin:0;font-size:23px}.employee-modal header p{margin:2px 0 0;color:rgba(255,255,255,.78);font-size:12px}.employee-modal header button,.modal-icon{display:grid;place-items:center;border-radius:18px;background:rgba(255,255,255,.16)}.modal-icon{width:52px;height:52px}.employee-modal header button{width:48px;height:48px;color:#fff}.modal-body{display:grid;grid-template-columns:1fr 1fr;align-items:start;grid-gap:18px;gap:18px;max-height:calc(90vh - 184px);overflow:auto;padding:30px 26px 24px}.field{display:grid;grid-gap:8px;gap:8px;color:#8a94a8;font-size:11.5px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}.employee-modal footer b,.field b{color:var(--red)}.field-control{position:relative;display:flex;align-items:center}.field .manual,.field-control input,.field-control select{width:100%;min-height:44px}.field-control.has-icon input{padding-right:44px}.field-control svg{position:absolute;right:14px;color:#9aa6ba;pointer-events:none}.field-control.focus select{border-color:var(--primary-2);box-shadow:0 0 0 3px rgba(101,88,241,.12)}.field .manual{margin-top:2px;font-weight:600;text-transform:none}.employee-modal footer{display:flex;justify-content:space-between;align-items:center;gap:16px;min-height:92px;padding:18px 26px;border-top:1px solid var(--line);background:#fbfcff}.employee-modal footer small{color:#9aa6ba}.employee-modal footer div{display:flex;gap:10px}.employee-modal footer button{min-width:96px;min-height:46px;border-radius:13px}.employee-modal .cancel{border:2px solid #e2e7f0;background:#fff;color:#5f6a7d}.employee-modal .save{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-width:148px;background:var(--primary);color:#fff}.user-shell{min-height:100vh;padding-bottom:calc(108px + env(safe-area-inset-bottom));background:linear-gradient(90deg,#eef1ff,#fff 28%,#fff 72%,#eef1ff)}.mobile-top{position:-webkit-sticky;position:sticky;top:0;z-index:50;gap:10px;height:64px;padding:0 16px;border-bottom-left-radius:28px;border-bottom-right-radius:28px;background:var(--primary);box-shadow:0 14px 28px rgba(44,40,129,.24);color:#fff}.mobile-brand,.mobile-top{display:flex;align-items:center}.mobile-brand{gap:8px;margin-right:auto;min-width:0}.mobile-app-name{display:flex;flex-direction:column;gap:0!important;padding-left:10px!important;border-left:0!important;line-height:1!important}.mobile-app-name strong{font-size:11.5px!important;font-weight:700!important;letter-spacing:.1px!important;white-space:nowrap!important}.mobile-app-name span{font-size:8px!important;font-weight:600!important;letter-spacing:1px!important;opacity:.75!important;white-space:nowrap!important;margin-top:1px!important}.mobile-brand strong{font-size:14px;white-space:nowrap}.mobile-brand>span{padding-left:10px;border-left:1px solid rgba(255,255,255,.38);font-size:12px;font-weight:600;white-space:nowrap}.mobile-top a,.mobile-top button{display:inline-flex;align-items:center;gap:6px;min-height:34px;flex-shrink:0;border-radius:9px;background:var(--orange);color:#fff;font-size:12px;font-weight:700;white-space:nowrap;text-decoration:none;padding:0 12px}.mobile-top .power{width:38px;height:38px;padding:0;justify-content:center;background:rgba(255,255,255,.13);transition:all .2s ease}.mobile-top .power:hover{background:linear-gradient(135deg,rgba(255,255,255,.25),rgba(255,255,255,.15));transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.mobile-top .power:active{transform:translateY(0);box-shadow:0 2px 6px rgba(0,0,0,.1)}.phone-page{width:min(445px,calc(100vw - 28px));margin:32px auto 0}.mobile-profile{display:flex;align-items:center;gap:14px;margin-bottom:28px}.mobile-profile span{display:grid;width:48px;height:48px;place-items:center;border-radius:16px;background:#e6e9ff;color:var(--primary);font-size:23px}.mobile-profile small{display:block;color:#9aa6ba}.mobile-profile strong{font-size:18px}.history-card,.presence-card{border:1px solid var(--line);border-radius:30px;background:#fff;box-shadow:0 2px 8px rgba(38,48,67,.08)}.presence-card{padding:24px 24px 28px;text-align:center}.clock-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px;margin-bottom:22px}.clock-row button{display:grid;grid-gap:6px;gap:6px;min-height:88px;place-items:center;border-radius:16px;background:#f5f6fb;color:#9aa6ba;font-size:15px;font-weight:700;box-shadow:inset 0 0 0 1.5px #eceef5;cursor:default}.clock-row button.in.active{background:var(--green);color:#fff;box-shadow:0 8px 18px rgba(73,176,123,.28)}.clock-row button.out.active{background:var(--red);color:#fff;box-shadow:0 8px 18px rgba(231,78,102,.28)}.presence-field{display:grid;grid-gap:8px;gap:8px;margin-bottom:16px;text-align:left;color:#8a94a8;font-size:11px;font-weight:700;letter-spacing:.3px}.presence-field .ss{width:100%}.presence-card>strong{display:block;color:var(--primary);line-height:1.35}.plan-field{display:grid;grid-gap:9px;gap:9px;margin-bottom:16px;text-align:left}.plan-field>span{color:#8a94a8;font-size:12px;font-weight:800;letter-spacing:.3px}.plan-field textarea{width:100%;min-height:78px;padding:13px 15px;border:1.5px solid #e2e7f0;border-radius:14px;background:#fff;color:var(--text);font-family:inherit;font-size:15px;font-weight:500;line-height:1.45;resize:vertical}.plan-field textarea::placeholder{color:#aab2c4;font-weight:500}.plan-field textarea:focus{border-color:var(--primary-2);box-shadow:0 0 0 3px rgba(101,88,241,.12);outline:none}.session-message{margin:18px 0;padding:14px 16px;border-radius:12px;background:linear-gradient(135deg,#e8e6ff,#f0edff);color:#5146e5;font-size:13px;font-weight:600;text-align:center;line-height:1.4}.category-section{margin:20px 0;text-align:left}.category-header{display:flex;align-items:center;gap:8px;margin-bottom:6px;color:#8a94a8;font-size:12px;font-weight:800;letter-spacing:.3px}.category-subtitle{margin:0 0 16px;color:#9aa6ba;font-size:13px;font-weight:500;line-height:1.35}.category-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px}.category-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 8px;border:2px solid #e8ebf3;border-radius:14px;background:#fff;color:var(--text);font-size:11px;font-weight:600;text-align:center;line-height:1.25;transition:all .2s ease;cursor:pointer}.category-option:hover{border-color:#d0d5e0;transform:translateY(-1px);box-shadow:0 3px 10px rgba(38,48,67,.08)}.category-option.selected{border-color:var(--primary);background:#f7f6ff;box-shadow:0 0 0 3px rgba(81,70,229,.12)}.category-option:disabled{opacity:.5;cursor:not-allowed}.category-option-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:#f5f6fb}.category-option-icon svg{width:20px;height:20px}.category-option.selected .category-option-icon{transform:scale(1.05)}.category-option-label{min-height:28px;display:flex;align-items:center;justify-content:center}.category-icon-blue{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1976d2}.category-icon-purple{background:linear-gradient(135deg,#f3e5f5,#e1bee7);color:#7b1fa2}.category-icon-orange{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#f57c00}.category-icon-red{background:linear-gradient(135deg,#ffebee,#ffcdd2);color:#c62828}.category-icon-indigo{background:linear-gradient(135deg,#e8eaf6,#c5cae9);color:#3f51b5}.category-icon-pink{background:linear-gradient(135deg,#fce4ec,#f8bbd0);color:#c2185b}.gps{display:flex;align-items:center;justify-content:center;gap:8px;min-height:46px;margin:18px 0;padding:0 14px;border:1px solid var(--line);border-radius:14px;background:#f7f8ff;color:var(--primary);font-weight:700;font-size:15px}.gps.ok{color:#2f9e63;background:#f1faf5;border-color:#d9f0e3}.gps.ok svg{color:var(--green)}.gps.loading,.gps.loading svg{color:var(--primary)}.gps.error{background:#fff0f3;border-color:#fad9e0;cursor:pointer}.gps.error,.gps.error svg{color:var(--red)}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.submit{display:inline-flex;align-items:center;justify-content:center;gap:12px;width:100%;min-height:56px;border-radius:16px;background:var(--green);color:#fff;font-size:17px}.submit:disabled{opacity:.55;cursor:default}.mobile-tabs{position:fixed;left:50%;bottom:0;display:grid;grid-template-columns:1fr 1fr;width:min(490px,100vw);height:92px;padding-bottom:env(safe-area-inset-bottom);transform:translateX(-50%);border-top-left-radius:28px;border-top-right-radius:28px;background:#fff;box-shadow:0 -12px 30px rgba(42,48,67,.12)}.mobile-tabs button{display:grid;place-items:center;grid-gap:4px;gap:4px;background:transparent;color:#9aa6ba}.mobile-tabs button.active{color:var(--primary)}.mobile-tabs button.active:before{content:"";width:44px;height:4px;border-radius:99px;background:var(--primary)}.history-section h2{font-size:20px}.history-card{overflow:hidden;border-radius:24px}.history-card header,.history-times,.location-box,.todo-box{padding:18px}.history-card header{border-bottom:1px solid var(--line)}.history-card header span{display:inline-flex;align-items:center;gap:4px;margin-top:6px;border-radius:8px;background:#efe5ff;color:#6b35e8;padding:5px 8px;font-size:11px}.history-times{display:grid;grid-gap:15px;gap:15px}.history-times p{display:grid;grid-template-columns:42px 1fr auto;align-items:center;grid-gap:14px;gap:14px;margin:0}.green-circle,.red-circle{display:grid;width:38px;height:38px;place-items:center;border-radius:50%}.green-circle{background:#d7f8e6;color:var(--green)}.red-circle{background:#ffe4e9;color:var(--red)}.history-times strong:first-of-type{color:var(--green)}.history-times p:nth-child(2) strong{color:var(--red)}.location-box{margin:0 18px 14px;border:1px solid #d4f3e2;border-radius:14px;background:#f2fff8}.location-box h3{display:flex;align-items:center;gap:7px;margin:0 0 8px;color:var(--green);font-size:12px;text-transform:uppercase}.location-box h3 a{margin-left:auto;color:var(--primary);text-transform:none}.location-box p{margin:0 0 8px;color:#435066;font-size:12px;line-height:1.55}.location-box span{display:inline-block;border-radius:7px;background:#fff;color:#9aa6ba;font-size:10px;padding:5px 9px}.todo-box{margin:0 18px 22px;border:1px solid var(--line);border-radius:14px;background:#fbfcff}.todo-box small{color:#9aa6ba}.todo-box p{margin:10px 0 0;color:#667289;font-weight:600;line-height:1.55}@media (max-width:1180px){.quad-grid,.stats-grid{grid-template-columns:repeat(2,minmax(200px,1fr))}.dashboard-grid{grid-template-columns:1fr}}@media (max-width:1024px){.admin-shell{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:0;z-index:19;width:256px;height:100vh;transform:translateX(-100%);transition:transform .28s ease;box-shadow:0 24px 60px rgba(20,24,48,.26)}.sidebar.open{transform:translateX(0)}.menu-toggle{display:grid}}@media (max-width:768px){.content{padding:16px}.filter-card{flex-wrap:wrap;align-items:stretch}.filter-card label{flex:1 1 100%;justify-content:space-between}.filter-card .ss,.filter-card select{width:auto;flex:1 1;min-width:0}.filter-card button{margin-left:0;width:100%}.panel-head{flex-direction:column;align-items:stretch}.panel-head button{width:100%}.form-filters,.report-filters label{flex:1 1 100%}.form-filters .ss,.form-filters select,.form-filters select:nth-child(2),.report-filters .ss,.report-filters input,.report-filters label:nth-child(3) select,.report-filters select{width:100%;min-width:0}.report-filters button{width:100%}}@media (max-width:560px){.content{padding:13px}.quad-grid,.stats-grid{grid-template-columns:1fr}.table-toolbar{flex-direction:column;align-items:stretch;gap:12px}.search-box,.search-box input{width:100%}.form-filters,.panel-head,.report-filters{padding-left:18px;padding-right:18px}.modal-body{grid-template-columns:1fr}.employee-modal footer{flex-direction:column;align-items:stretch}.employee-modal footer div{width:100%}.employee-modal footer button{flex:1 1}}th.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}th.sortable:hover{color:var(--primary)}.th-sort{display:inline-flex;align-items:center;gap:6px}.th-sort svg{color:#b4bdcd}th.sortable:hover .th-sort svg{color:var(--primary)}.th-sort .th-dim{opacity:.55}.table-empty{padding:34px 18px;color:#9aa6ba;text-align:center;white-space:normal}.pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;padding:16px 28px 22px}.pagination .info{color:#6f7c91;font-size:13px;font-weight:600}.pagination .pages{display:flex;align-items:center;gap:6px}.pagination .pages button{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1.5px solid #e2e7f0;border-radius:9px;background:#fff;color:#5f6a7d;font-size:13px;font-weight:700}.pagination .pages button:hover:not(:disabled):not(.active){border-color:var(--primary-2);color:var(--primary)}.pagination .pages button.active{border-color:var(--primary);background:var(--primary);color:#fff}.pagination .pages button:disabled{opacity:.45;cursor:default}.pagination .pages .dots{padding:0 4px;color:#9aa6ba}@media (max-width:560px){.pagination{justify-content:center}}.actions .detail{border:1px solid #d7dcff;background:#f1f3ff;color:var(--primary)}.confirm-dialog{width:min(420px,94vw);padding:34px 28px 24px}.confirm-dialog,.export-dialog{position:relative;z-index:100000;border-radius:24px;background:#fff;box-shadow:0 30px 80px rgba(0,0,0,.28);text-align:center}.export-dialog{width:min(480px,94vw);padding:40px 32px 28px}.export-dialog-icon{display:grid;place-items:center;width:88px;height:88px;margin:0 auto 24px;border-radius:50%;border:3px solid #93b5d1;color:#93B5D1}.export-dialog-icon svg{width:48px;height:48px}.export-dialog-title{margin:0 0 16px;font-size:21px;font-weight:700;color:#273043;letter-spacing:-.02em}.export-dialog-message{margin-bottom:28px}.export-dialog-message p{margin:0 0 12px;font-size:14px;color:#667289;line-height:1.6}.export-dialog-message p strong{color:#273043;font-weight:700}.export-dialog-message .export-dialog-hint{font-size:13px;color:#94a0b5;font-style:italic;line-height:1.5}.export-dialog-actions{display:flex;flex-direction:column;gap:12px}.export-dialog-main-buttons{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.export-btn-cancel,.export-btn-no,.export-btn-yes{display:flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 20px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease}.export-btn-yes{background:#5146e5;color:#fff;border:none}.export-btn-yes:hover:not(:disabled){background:#6658f1;transform:translateY(-1px);box-shadow:0 4px 12px rgba(81,70,229,.3)}.export-btn-no{background:#5f6a7d;color:#fff;border:none}.export-btn-no:hover:not(:disabled){background:#6b7788;transform:translateY(-1px);box-shadow:0 4px 12px rgba(95,106,125,.3)}.export-btn-cancel{background:#e74e66;color:#fff;border:none;width:auto;align-self:center;min-width:140px}.export-btn-cancel:hover:not(:disabled){background:#ea5a70;transform:translateY(-1px);box-shadow:0 4px 12px rgba(231,78,102,.3)}.export-btn-cancel:disabled,.export-btn-no:disabled,.export-btn-yes:disabled{opacity:.6;cursor:not-allowed;transform:none}.confirm-close{position:absolute;top:16px;right:16px;display:grid;place-items:center;width:36px;height:36px;border-radius:10px;background:#f3f5fa;color:#8a94a8}.confirm-icon{display:grid;place-items:center;width:64px;height:64px;margin:0 auto 16px;border-radius:50%}.confirm-dialog.danger .confirm-icon{background:#ffe8ec;color:var(--red)}.confirm-dialog.primary .confirm-icon{background:#eef0ff;color:var(--primary)}.confirm-dialog h2{margin:0 0 10px;font-size:19px}.confirm-message{color:#667289;font-size:14px;font-weight:500;line-height:1.55}.confirm-message b{color:var(--text);font-weight:700}.confirm-actions{display:flex;gap:12px;margin-top:24px}.confirm-actions button{flex:1 1;min-height:46px;border-radius:13px;font-size:14px;font-weight:700}.confirm-actions .cancel{border:1.5px solid #e2e7f0;background:#fff;color:#5f6a7d}.confirm-actions .confirm{color:#fff}.confirm-dialog.danger .confirm-actions .confirm{background:var(--red)}.confirm-dialog.primary .confirm-actions .confirm{background:var(--primary)}.confirm-actions button:disabled{opacity:.6;cursor:default}.forbidden{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:100vh;padding:32px;text-align:center}.forbidden-icon{display:grid;place-items:center;width:84px;height:84px;margin-bottom:6px;border-radius:50%;background:#ffe8ec;color:var(--red)}.forbidden h1{margin:0;font-size:24px}.forbidden p{max-width:420px;margin:0;color:#667289;font-size:14px;font-weight:500;line-height:1.6}.forbidden a{margin-top:14px;padding:12px 22px;border-radius:12px;background:var(--primary);color:#fff;font-size:14px;font-weight:700;text-decoration:none;box-shadow:0 10px 22px rgba(81,70,229,.24)}.login-shell{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:linear-gradient(135deg,#f0f2f8,#fafbff)}.login-card{width:min(440px,100%);overflow:hidden;border-radius:28px;background:#fff;box-shadow:0 30px 70px rgba(30,25,80,.22)}.login-head{padding:28px 26px 24px;background:linear-gradient(135deg,#5146e5,#6a3fe6);color:#fff;text-align:center}.login-brand{display:flex;align-items:center;justify-content:center;gap:12px}.login-brand .brand-logo{height:38px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}.login-brand .brand-side{display:flex;align-items:center;gap:9px}.login-brand .brand-left{display:flex;flex-direction:column;line-height:1.12;text-align:left}.login-brand .brand-left strong{font-size:13px;letter-spacing:.2px;white-space:nowrap}.login-brand .brand-left span{color:rgba(255,255,255,.72);font-size:8px;font-weight:600;letter-spacing:1px;white-space:nowrap}.login-brand .brand-divider{width:1px;height:34px;flex-shrink:0;background:rgba(255,255,255,.34)}.login-product{display:flex;flex-direction:column;line-height:1.1;text-align:left}.login-product strong{font-size:19px;letter-spacing:-.01em;white-space:nowrap}.login-product span{margin-top:2px;color:rgba(255,255,255,.75);font-size:8px;font-weight:600;letter-spacing:1.5px;white-space:nowrap}.login-tagline{margin:20px 0 0;color:rgba(255,255,255,.82);font-size:9.5px;font-weight:700;letter-spacing:1.6px}.login-body{display:flex;flex-direction:column;gap:18px;padding:30px 28px 32px}.login-field{display:grid;grid-gap:9px;gap:9px;color:#8a94a8;font-size:11.5px;font-weight:700;letter-spacing:.4px}.login-input{position:relative;display:flex;align-items:center}.login-input svg{position:absolute;left:15px;color:#aab2c4;pointer-events:none}.password-toggle{position:absolute;right:12px;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:transparent;color:#9aa6ba;cursor:pointer;transition:all .2s ease;pointer-events:auto}.password-toggle:hover{background:#f5f7fa;color:var(--primary)}.login-input input{width:100%;min-height:52px;padding:0 48px 0 44px;border:1.5px solid #e6e9f2;border-radius:14px;background:#fff;color:var(--text);font-size:14.5px;font-weight:600}.login-input input::placeholder{color:#aab2c4;font-weight:500}.login-input input:focus{border-color:var(--primary-2);box-shadow:0 0 0 3px rgba(101,88,241,.12);outline:none}.login-error{display:flex;align-items:center;gap:8px;margin:-6px 0 0;padding:12px 16px;border-radius:10px;background:linear-gradient(135deg,#fff0f2,#ffe8ec);border:1px solid #ffc4cf;color:#d42f48;font-size:13px;font-weight:600;line-height:1.5;box-shadow:0 2px 8px rgba(231,78,102,.12)}.login-error:before{content:"⚠";display:flex;width:22px;height:22px;flex-shrink:0;border-radius:50%;background:#ffe8ec;color:var(--red);font-size:14px}.login-error:before,.login-submit{align-items:center;justify-content:center;font-weight:700}.login-submit{display:inline-flex;gap:10px;width:100%;min-height:54px;margin-top:6px;border-radius:14px;background:var(--primary);color:#fff;font-size:15px;box-shadow:0 4px 12px rgba(81,70,229,.28);transition:all .2s ease}.login-submit:hover:not(:disabled){background:var(--primary-2);transform:translateY(-1px);box-shadow:0 6px 16px rgba(81,70,229,.36)}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.7;cursor:default}.sticky-cols td:first-child,.sticky-cols td:nth-child(2),.sticky-cols th:first-child,.sticky-cols th:nth-child(2){position:-webkit-sticky;position:sticky;z-index:1;background:#fff}.sticky-cols thead th:first-child,.sticky-cols thead th:nth-child(2){z-index:3;background:#fafbfe}.sticky-cols td:first-child,.sticky-cols th:first-child{left:0;width:var(--col1-w,210px);min-width:var(--col1-w,210px);max-width:var(--col1-w,210px);overflow:hidden;text-overflow:ellipsis}.sticky-cols td:nth-child(2),.sticky-cols th:nth-child(2){left:var(--col1-w,210px);width:var(--col2-w,160px);min-width:var(--col2-w,160px);max-width:var(--col2-w,160px);overflow:hidden;text-overflow:ellipsis}.report-table.sticky-cols tbody tr:hover td:first-child,.report-table.sticky-cols tbody tr:hover td:nth-child(2),.score-table.sticky-cols tbody tr:hover td:first-child,.score-table.sticky-cols tbody tr:hover td:nth-child(2){background:#f8f9ff}.monthly-table .day-col{min-width:40px}.monthly-table td.day-cell{padding:5px 4px}.mark{display:inline-grid;place-items:center;min-width:25px;height:25px;padding:0 5px;border-radius:8px;font-size:11px;font-weight:700}.monthly-table .day-col small{display:block;margin-top:4px;color:#9aa6ba;font-size:9px}.cell-c{background:#fff1dd;color:#cc7625}.cell-s{background:#e7ecfb;color:#4a5ed0}.cell-off{background:#eef1f5;color:#9aa6ba}.monthly-table .sum-col{min-width:42px;font-weight:700}.monthly-table th.sum-col{background:#f1f3ff;color:var(--primary)}.monthly-table td.sum-h{color:#318c63}.monthly-table td.sum-a{color:var(--red)}.monthly-table td.sum-c{color:#cc7625}.monthly-table td.sum-s{color:#4a5ed0}.monthly-table.sticky-cols td:first-child,.monthly-table.sticky-cols td:nth-child(2),.monthly-table.sticky-cols td:nth-child(3),.monthly-table.sticky-cols th:first-child,.monthly-table.sticky-cols th:nth-child(2),.monthly-table.sticky-cols th:nth-child(3){position:-webkit-sticky;position:sticky;z-index:1;background:#fff}.monthly-table.sticky-cols thead th:first-child,.monthly-table.sticky-cols thead th:nth-child(2),.monthly-table.sticky-cols thead th:nth-child(3){z-index:3;background:#fafbfe}.monthly-table.sticky-cols tbody tr:hover td:first-child,.monthly-table.sticky-cols tbody tr:hover td:nth-child(2),.monthly-table.sticky-cols tbody tr:hover td:nth-child(3){background:#f8f9ff}.monthly-table.sticky-cols td:first-child,.monthly-table.sticky-cols th:first-child{left:0;width:48px;min-width:48px;max-width:48px}.monthly-table.sticky-cols td:nth-child(2),.monthly-table.sticky-cols th:nth-child(2){left:48px;width:190px;min-width:190px;max-width:190px;overflow:hidden;text-overflow:ellipsis}.monthly-table.sticky-cols td:nth-child(3),.monthly-table.sticky-cols th:nth-child(3){left:238px;width:160px;min-width:160px;max-width:160px;overflow:hidden;text-overflow:ellipsis}.monthly-legend{display:flex;flex-wrap:wrap;gap:16px;padding:0 14px 6px}.monthly-legend span{display:inline-flex;align-items:center;gap:7px;color:#667289;font-size:12px;font-weight:600}.monthly-legend i{display:grid;place-items:center;width:22px;height:22px;border-radius:6px;font-style:normal;font-size:11px;font-weight:700}.ss{display:inline-block;vertical-align:top;position:relative}.ss-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;min-height:40px;padding:0 12px 0 14px;border:1.5px solid #e2e7f0;border-radius:10px;background:#fff;color:var(--text);font-size:13px;font-weight:600;text-align:left}.ss.open .ss-trigger{border-color:var(--primary-2);box-shadow:0 0 0 3px rgba(101,88,241,.12)}.ss-trigger:disabled{background:#f3f5fa;color:#9aa6ba;cursor:default}.ss-value{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.ss-placeholder{color:#aab2c4;font-weight:500}.ss-chevron{flex-shrink:0;color:#7a8398;transition:transform .15s ease}.ss.open .ss-chevron{transform:rotate(180deg)}.ss-panel{z-index:80;border:1px solid #e2e7f0;border-radius:12px;background:#fff;box-shadow:0 18px 40px rgba(38,48,67,.18);overflow:hidden}.ss-search{display:flex;align-items:center;gap:8px;padding:9px 12px;border-bottom:1px solid #eef1f6;color:#9aa6ba}.ss-search input{width:100%;min-height:auto;border:0;border-radius:0;padding:0;background:transparent;font-size:13px;font-weight:600}.ss-search input:focus{box-shadow:none}.ss-list{max-height:240px;margin:0;padding:6px;overflow-y:auto;list-style:none}.ss-option{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 11px;border-radius:8px;color:#3b4458;font-size:13px;font-weight:600;cursor:pointer}.ss-option span{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.ss-option.active{background:#f1f3ff}.ss-option svg,.ss-option.selected{color:var(--primary)}.ss-option svg{flex-shrink:0}.ss-empty{padding:16px;color:#9aa6ba;font-size:13px;text-align:center}.filter-card .ss{width:190px}.form-filters .ss{min-width:180px}.show-entries .ss{width:96px}.report-filters .ss{width:100%;min-width:170px}.field-control .ss{width:100%}.field-control .ss-trigger{min-height:44px}.settings-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:18px;gap:18px}.settings-card{display:flex;align-items:center;gap:16px;padding:24px;border:1px solid var(--line);border-radius:18px;background:var(--panel);box-shadow:0 2px 7px rgba(38,48,67,.06);text-decoration:none;color:inherit}.settings-card:hover{border-color:var(--primary-2);box-shadow:0 10px 26px rgba(81,70,229,.12)}.settings-card-icon{display:grid;place-items:center;width:56px;height:56px;flex-shrink:0;border-radius:16px}.settings-card-icon.purple{background:#eef0ff;color:var(--primary)}.settings-card-icon.green{background:#e9fbf1;color:var(--green)}.settings-card h2{margin:0 0 4px;font-size:17px}.settings-card p{margin:0;color:#6f7c91;font-size:13px;font-weight:500;line-height:1.5}.rbac-layout{display:grid;grid-template-columns:240px minmax(0,1fr);grid-gap:22px;gap:22px;padding:0 28px 28px}.role-list{display:flex;flex-direction:column;gap:8px}.role-list button{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:46px;padding:0 16px;border:1.5px solid var(--line);border-radius:12px;background:#fff;color:#3b4458;font-size:14px;font-weight:700;text-align:left}.role-list button.active{border-color:var(--primary);background:#f1f3ff;color:var(--primary)}.role-list button em{font-size:10px;font-style:normal;font-weight:600;color:#9aa6ba;text-transform:uppercase}.role-list button.ghost{border-style:dashed;color:var(--primary)}.role-editor{min-width:0}.role-meta{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px;margin-bottom:18px}.perm-matrix td,.perm-matrix th{padding:11px 12px;text-align:center;border-bottom:1px solid #f0f2f6}.perm-matrix thead th{background:#fafbfe;border-bottom:1px solid #e7ebf3}.perm-matrix td:first-child,.perm-matrix th:first-child{text-align:left;font-weight:700;color:#3b4458;white-space:nowrap}.check{display:inline-grid;place-items:center;cursor:pointer}.check input{position:absolute;opacity:0;width:0;height:0}.check span{display:grid;place-items:center;width:22px;height:22px;border:1.5px solid #d4dae6;border-radius:7px;background:#fff;transition:all .12s ease}.check input:checked+span{border-color:var(--primary);background:var(--primary)}.check input:checked+span:after{content:"";width:6px;height:11px;margin-top:-2px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}.role-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.danger-btn,.primary-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 22px;border-radius:12px;font-size:14px;font-weight:700}.primary-btn{background:var(--primary);color:#fff;box-shadow:0 8px 18px rgba(81,70,229,.22)}.primary-btn.sm{min-height:36px;padding:0 14px;font-size:13px}.primary-btn:disabled{opacity:.6;cursor:default}.danger-btn{border:1.5px solid #ffc4cf;background:#fff0f3;color:var(--red)}.settings-error{margin:14px 0 0;color:var(--red)}.company-chip,.settings-error{font-size:13px;font-weight:600}.company-chip{display:inline-flex;align-items:center;gap:7px;min-height:36px;padding:0 14px;border:1.5px solid #e2e7f0;border-radius:10px;background:#fff;color:#4a5568}.company-chip:hover{border-color:var(--primary-2)}.company-chip svg,.company-chip:hover{color:var(--primary)}.access-modal{width:min(460px,94vw);overflow:hidden;border-radius:22px;background:#fff;box-shadow:0 30px 80px rgba(0,0,0,.28)}.access-modal header{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;background:linear-gradient(120deg,#5146e5,#6a3fe6);color:#fff}.access-modal header h2{margin:0;font-size:18px}.access-modal header p{margin:2px 0 0;color:rgba(255,255,255,.8);font-size:12px}.access-modal header button{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.16);color:#fff}.access-body{padding:20px 22px}.access-all{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;cursor:pointer}.access-all input{width:18px;height:18px;min-height:auto}.access-all strong{display:block;font-size:14px}.access-all small{color:#9aa6ba}.company-options{display:flex;flex-direction:column;gap:8px;margin-top:14px}.company-options.disabled{opacity:.45;pointer-events:none}.company-option{display:flex;align-items:center;gap:11px;min-height:46px;padding:0 14px;border:1.5px solid var(--line);border-radius:12px;background:#fff;color:#3b4458;font-size:13px;font-weight:600;text-align:left}.company-option.active{border-color:var(--primary);background:#f1f3ff;color:var(--primary)}.company-check{display:grid;place-items:center;width:22px;height:22px;flex-shrink:0;border:1.5px solid #d4dae6;border-radius:7px}.company-option.active .company-check{border-color:var(--primary);background:var(--primary);color:#fff}.access-modal footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--line);background:#fbfcff}.access-modal footer .cancel{min-height:44px;padding:0 20px;border:1.5px solid #e2e7f0;border-radius:12px;background:#fff;color:#5f6a7d;font-size:14px;font-weight:700}@media (max-width:860px){.rbac-layout,.role-meta{grid-template-columns:1fr}}.toast-wrap{position:fixed;top:16px;right:16px;z-index:100;display:flex;flex-direction:column;gap:10px;max-width:calc(100vw - 32px)}.toast{display:flex;align-items:center;gap:11px;width:340px;max-width:100%;padding:13px 14px;border:1px solid var(--line);border-left-width:4px;border-radius:12px;background:#fff;box-shadow:0 14px 34px rgba(38,48,67,.16);animation:toast-in .22s ease}.toast p{flex:1 1;margin:0;font-size:13px;font-weight:600;color:var(--text)}.toast button,.toast-icon{display:grid;place-items:center;flex-shrink:0}.toast button{width:26px;height:26px;border-radius:8px;background:transparent;color:#9aa6ba}.toast button:hover{background:#f1f3f8}.toast.success{border-left-color:var(--green)}.toast.success .toast-icon{color:var(--green)}.toast.error{border-left-color:var(--red)}.toast.error .toast-icon{color:var(--red)}.toast.info{border-left-color:var(--primary)}.toast.info .toast-icon{color:var(--primary)}@keyframes toast-in{0%{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}.back-link{display:inline-flex;align-items:center;gap:7px;margin-bottom:16px;color:#6f7c91;font-size:13px;font-weight:700;text-decoration:none}.back-link:hover,.nav a:hover{color:var(--primary)}.nav a:hover{background:#f4f6ff}.nav a.active:hover{background:#edf0ff}.nav .self-button:hover{background:#52bc88;border-color:#52bc88;color:#fff}.modal-body .field-full{grid-column:1/-1}.company-picker{border:1.5px solid #e2e7f0;border-radius:12px;padding:12px 14px;text-transform:none}.company-all-inline{display:flex;align-items:center;gap:10px;padding-bottom:10px;margin-bottom:10px;border-bottom:1px solid #eef1f6;text-transform:none;font-size:13px;font-weight:700;color:var(--text);cursor:pointer}.company-all-inline input{width:18px;height:18px;min-height:auto}.company-picker .company-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:8px;gap:8px;margin-top:0}.todo-input{display:flex;gap:8px;margin:10px 0 12px}.todo-input input{flex:1 1;min-height:42px;border:1.5px solid #e2e7f0;border-radius:11px;background:#fff;padding:0 14px;font-size:13px;font-weight:500}.todo-input input:focus{border-color:var(--primary-2);box-shadow:0 0 0 3px rgba(101,88,241,.12);outline:none}.todo-input button{display:grid;place-items:center;width:42px;height:42px;flex-shrink:0;border-radius:11px;background:var(--primary);color:#fff}.todo-items{display:flex;flex-direction:column;gap:8px;margin:0;padding:0;list-style:none}.todo-items li{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:11px;background:#fff;color:#435066;font-size:13px;font-weight:500;line-height:1.45}.todo-items li span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.todo-items li b{color:var(--primary);font-weight:700}.todo-items li button{display:grid;place-items:center;width:26px;height:26px;flex-shrink:0;border-radius:8px;background:#fff0f3;color:var(--red)}.todo-empty{margin:10px 0 0;color:#9aa6ba;font-size:12px;font-weight:500}.app-loading{display:grid;place-items:center;min-height:100vh;color:#9aa6ba;font-size:14px;font-weight:600}.access-modal footer .cancel,.confirm-actions .cancel,.confirm-actions .confirm,.danger-btn,.employee-modal .cancel,.employee-modal .save,.login-submit,.primary-btn,.role-list button{cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease,filter .18s ease}.confirm-dialog.primary .confirm-actions .confirm:hover,.employee-modal .save:hover:not(:disabled),.login-submit:hover:not(:disabled),.primary-btn:hover:not(:disabled){background:var(--primary-2);transform:translateY(-2px);box-shadow:0 14px 28px rgba(81,70,229,.32)}.employee-modal .save:active:not(:disabled),.login-submit:active:not(:disabled),.primary-btn:active:not(:disabled){transform:translateY(0)}.confirm-actions .confirm:hover,.danger-btn:hover:not(:disabled){background:var(--red);color:#fff;border-color:var(--red);transform:translateY(-2px);box-shadow:0 14px 28px rgba(231,78,102,.32)}.access-modal footer .cancel:hover,.confirm-actions .cancel:hover,.employee-modal .cancel:hover{border-color:var(--primary-2);color:var(--primary);transform:translateY(-2px);box-shadow:0 10px 20px rgba(38,48,67,.1)}.role-list button:hover:not(.active){border-color:var(--primary-2);transform:translateX(3px);box-shadow:0 6px 16px rgba(81,70,229,.12)}.forbidden a{transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.forbidden a:hover{background:var(--primary-2);transform:translateY(-2px);box-shadow:0 16px 30px rgba(81,70,229,.32)}.ss-create{display:flex;align-items:center;gap:8px;width:100%;padding:11px 14px;border:0;border-top:1px solid #eef1f6;background:#fff;color:var(--primary);font-size:13px;font-weight:700;cursor:pointer;transition:background .15s ease}.ss-create:hover{background:#f4f3ff}.ref-modal{position:relative;display:flex;flex-direction:column;width:min(480px,94vw);max-height:90vh;border-radius:20px;background:#fff;overflow:hidden;box-shadow:0 30px 70px rgba(38,48,67,.28)}.ref-modal header{display:flex;align-items:center;gap:14px;padding:22px 24px;border-bottom:1px solid #eef1f6}.ref-modal header .modal-icon{display:grid;place-items:center;width:48px;height:48px;flex-shrink:0;border-radius:14px;background:#eef0ff;color:var(--primary)}.ref-modal header h2{margin:0;font-size:18px}.ref-modal header p{margin:2px 0 0;color:#8a94a8;font-size:12px;font-weight:500}.ref-modal header>button{margin-left:auto;display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:#f4f6fa;color:#7a8398;cursor:pointer;transition:background .15s ease,color .15s ease}.ref-modal header>button:hover{background:#ffe8ec;color:var(--red)}.ref-modal-body{display:grid;grid-gap:16px;gap:16px;padding:22px 24px;overflow-y:auto}.ref-modal-body .field span{display:block;margin-bottom:8px;color:#5a6478;font-size:13px;font-weight:700}.ref-modal-body .field-control input{width:100%;min-height:44px;padding:0 14px;border:1.5px solid #e2e7f0;border-radius:11px;background:#fff;color:var(--text);font-size:14px;font-weight:600}.ref-modal-body .field-control input:focus{border-color:var(--primary-2);box-shadow:0 0 0 3px rgba(101,88,241,.12);outline:none}.ref-switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer}.ref-switch input{position:absolute;opacity:0;width:0;height:0}.ref-switch>span{position:relative;width:46px;height:26px;border-radius:999px;background:#d4dae6;transition:background .18s ease}.ref-switch>span:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:transform .18s ease}.ref-switch input:checked+span{background:var(--green)}.ref-switch input:checked+span:after{transform:translateX(20px)}.ref-switch em{font-style:normal;font-size:13px;font-weight:700;color:#5a6478}.ref-modal-error{margin:0;padding:10px 12px;border-radius:10px;background:#fff0f3;color:var(--red);font-size:13px;font-weight:600}.ref-modal footer{display:flex;justify-content:flex-end;gap:10px;padding:18px 24px;border-top:1px solid #eef1f6}.ref-modal footer button{min-width:100px;min-height:44px;border-radius:12px;font-size:14px;font-weight:700}.ref-modal footer .cancel{border:1.5px solid #e2e7f0;background:#fff;color:#5f6a7d}.ref-modal footer .save{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--primary);color:#fff}.ref-layout{display:grid;grid-template-columns:248px minmax(0,1fr);grid-gap:22px;gap:22px}.ref-types{display:flex;flex-direction:column;gap:6px}.ref-types button{display:flex;align-items:center;gap:11px;width:100%;padding:11px 14px;border:1.5px solid transparent;border-radius:12px;background:transparent;color:#4a5468;font-size:14px;font-weight:600;text-align:left;cursor:pointer;transition:all .15s ease}.ref-types button svg{flex-shrink:0;color:#8a94a8}.ref-types button:hover{background:#f4f6fb}.ref-types button.active{border-color:var(--primary);background:#f1f3ff;color:var(--primary)}.ref-types button.active svg{color:var(--primary)}.ref-panel-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px}.ref-panel-head h2{margin:0;font-size:18px}.ref-panel-head p{margin:3px 0 0;color:#8a94a8;font-size:13px;font-weight:500}.ref-panel-head button{margin-left:auto;display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:0 18px;border-radius:11px;background:var(--primary);color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;box-shadow:0 8px 18px rgba(81,70,229,.22)}.ref-panel-head button:hover{background:var(--primary-2);transform:translateY(-2px);box-shadow:0 14px 26px rgba(81,70,229,.32)}.ref-badge{display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 8px;border-radius:999px;background:#eef0ff;color:var(--primary);font-size:11px;font-weight:700}.ref-badge.muted{background:#eef1f5;color:#9aa6ba}.ref-table td:first-child,.ref-table th:first-child{padding-left:28px}.ref-table td:last-child,.ref-table th:last-child{padding-right:28px}.ref-table .ref-no{width:56px}.ref-table .ref-act{width:110px}.report-table .strong-cell{font-weight:700;color:#2a3344}.muted-text{color:#b3bcca}.audit-tag{display:inline-block;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;font-family:var(--font-mono,ui-monospace,monospace)}.audit-tag.ok{background:#e9fbf1;color:#2f9e63}.audit-tag.warn{background:#fff3dd;color:#cc7625}.audit-tag.bad{background:#ffe9ee;color:var(--red)}.audit-tag.info{background:#eef0ff;color:var(--primary)}.audit-tag.muted{background:#eef1f5;color:#6f7c91}.audit-role{display:inline-block;padding:3px 9px;border-radius:7px;background:#f1f3ff;color:var(--primary);font-size:11px;font-weight:700;text-transform:capitalize}.audit-modal{position:relative;display:flex;flex-direction:column;width:min(720px,95vw);max-height:92vh;border-radius:20px;background:#fff;overflow:hidden;box-shadow:0 30px 70px rgba(38,48,67,.28)}.audit-modal header{display:flex;align-items:center;gap:14px;padding:20px 24px;border-bottom:1px solid #eef1f6}.audit-modal header .modal-icon{display:grid;place-items:center;width:46px;height:46px;flex-shrink:0;border-radius:13px;background:#eef0ff;color:var(--primary)}.audit-modal header h2{margin:0;font-size:17px;font-family:var(--font-mono,ui-monospace,monospace)}.audit-modal header p{margin:2px 0 0;color:#8a94a8;font-size:12px;font-weight:600}.audit-modal header>button{margin-left:auto;display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:#f4f6fa;color:#7a8398;cursor:pointer;transition:background .15s ease,color .15s ease}.audit-modal header>button:hover{background:#ffe8ec;color:var(--red)}.audit-modal-body{display:grid;grid-gap:18px;gap:18px;padding:22px 24px;overflow-y:auto}.audit-meta-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px 22px;gap:12px 22px}.audit-meta-row{display:flex;flex-direction:column;gap:4px;min-width:0}.audit-meta-row>span{color:#8a94a8;font-size:11px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}.audit-meta-row>div{font-size:13px;font-weight:600;color:var(--text);word-break:break-word}.audit-meta-row code{font-size:12px;color:#4a5468;word-break:break-all}.audit-ua{font-size:12px;color:#4a5468;word-break:break-word}.audit-diff-col h4,.audit-section h4{margin:0 0 8px;font-size:13px;color:#5a6478}.audit-json{margin:0;padding:14px;max-height:280px;overflow:auto;border:1px solid #e7ebf3;border-radius:12px;background:#0f1729;color:#d7e0f4;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.6;white-space:pre}.audit-diff{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.audit-diff-col.before .audit-json{background:#20131a;color:#f3c9d3}.audit-diff-col.after .audit-json{background:#0e1d16;color:#c5f0d6}.audit-modal footer{display:flex;justify-content:flex-end;padding:16px 24px;border-top:1px solid #eef1f6}.audit-modal footer .cancel{min-width:110px;min-height:44px;border:1.5px solid #e2e7f0;border-radius:12px;background:#fff;color:#5f6a7d;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s ease}.audit-modal footer .cancel:hover{border-color:var(--primary-2);color:var(--primary);transform:translateY(-2px)}@media (max-width:620px){.audit-diff,.audit-meta-grid{grid-template-columns:1fr}}.emp-att-modal{position:relative;display:flex;flex-direction:column;width:min(720px,95vw);max-height:90vh;border-radius:24px;background:#fff;overflow:hidden;box-shadow:0 30px 80px rgba(38,48,67,.3)}.emp-att-modal header{display:flex;align-items:center;gap:16px;padding:22px 26px;border-bottom:1px solid #eef1f6}.emp-att-avatar{display:grid;place-items:center;width:56px;height:56px;flex-shrink:0;border-radius:18px;background:linear-gradient(135deg,#6a5cf0,#8a6bf2);color:#fff;font-size:24px;font-weight:800}.emp-att-head{flex:1 1;min-width:0}.emp-att-head h2{margin:0;font-size:24px;letter-spacing:-.01em}.emp-att-head p{margin:2px 0 0;color:#8a94a8;font-size:14px;font-weight:600}.emp-att-modal header>button{display:grid;place-items:center;width:44px;height:44px;flex-shrink:0;border-radius:50%;background:#f1f3f8;color:#6f7c91;cursor:pointer;transition:background .15s ease,color .15s ease}.emp-att-modal header>button:hover{background:#ffe8ec;color:var(--red)}.emp-att-body{display:flex;flex-direction:column;gap:16px;padding:20px 22px 26px;overflow-y:auto;background:#fafbfe}.emp-att-empty{padding:40px 0;text-align:center;color:#9aa6ba;font-weight:600}.att-day{border:1px solid #e9edf5;border-radius:18px;background:#fff;padding:16px 18px;box-shadow:0 2px 6px rgba(38,48,67,.04)}.att-day-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:14px;border-bottom:1px solid #f0f2f7}.att-day-head strong{display:block;font-size:16px;color:#2a3344}.att-cat{gap:5px;margin-top:5px}.att-cat,.att-dur{display:inline-flex;align-items:center;color:var(--primary);font-size:12px;font-weight:700}.att-dur{gap:6px;flex-shrink:0;padding:6px 12px;border-radius:999px;background:#eef0ff;white-space:nowrap}.att-times{display:grid;grid-gap:10px;gap:10px;padding:14px 0}.att-times>div{display:flex;align-items:center;gap:12px}.att-times b{flex:1 1;font-size:15px;font-weight:700;color:#3b4458}.att-times strong{font-size:17px;font-weight:800;letter-spacing:.5px}.att-ic{display:grid;place-items:center;width:38px;height:38px;border-radius:12px}.att-ic.green{background:#e7f7ef;color:var(--green)}.att-ic.red{background:#ffe9ee;color:var(--red)}.att-loc{margin-top:10px;padding:12px 14px;border-radius:14px}.att-loc.in{background:#f1faf5;border:1px solid #d9f0e3}.att-loc.out{background:#fdf2f4;border:1px solid #fad9e0}.att-loc h4{display:flex;align-items:center;gap:6px;margin:0 0 6px;font-size:12px;font-weight:800;letter-spacing:.4px}.att-loc.in h4{color:#2f9e63}.att-loc.out h4{color:var(--red)}.att-loc h4 .att-peta,.att-loc h4 a{display:inline-flex;align-items:center;gap:4px;margin-left:auto;border:0;background:transparent;color:var(--primary);font-size:12px;font-weight:700;text-decoration:none;cursor:pointer}.att-loc h4 .att-peta:hover,.att-loc h4 a:hover{text-decoration:underline}.att-loc p{margin:0;font-size:13px;font-weight:500;color:#3b4458;line-height:1.5}.att-loc span{display:block;margin-top:5px;font-family:ui-monospace,monospace;font-size:11px;color:#7a8398}.att-todo{margin-top:10px;padding:12px 14px;border-radius:14px;background:#f5f6fa}.att-todo small{display:block;margin-bottom:6px;color:#8a94a8;font-size:11px;font-weight:800;letter-spacing:.4px}.att-todo p{margin:0;font-size:14px;font-weight:600;color:#2a3344}.att-todo ul{margin:0;padding-left:4px;list-style:none;display:grid;grid-gap:5px;gap:5px}.att-todo li{font-size:13px;font-weight:500;color:#3b4458}.att-todo li b{color:var(--primary);margin-right:4px}.history-list{display:flex;flex-direction:column;gap:14px}.todo-content{white-space:pre-line;line-height:1.55;overflow-wrap:anywhere}.att-todo .todo-content{margin:0;font-size:13.5px;font-weight:500;color:#2a3344}.att-todo .todo-content+.todo-content{margin-top:8px;padding-top:8px;border-top:1px dashed #e2e7f0}.modal-backdrop.map-layer{z-index:120}.map-modal{position:relative;display:flex;flex-direction:column;width:min(860px,95vw);max-height:90vh;border-radius:22px;background:#fff;overflow:hidden;box-shadow:0 30px 80px rgba(38,48,67,.34)}.map-modal header{display:flex;align-items:center;gap:14px;padding:18px 22px;border-bottom:1px solid #eef1f6}.map-modal-icon{display:grid;place-items:center;width:48px;height:48px;flex-shrink:0;border-radius:14px;background:#eef0ff;color:var(--primary)}.map-modal-head{flex:1 1;min-width:0}.map-modal-head h2{margin:0;font-size:20px;letter-spacing:-.01em}.map-modal-head p{margin:2px 0 0;font-family:ui-monospace,monospace;font-size:12px;color:#8a94a8;font-weight:600}.map-gmaps{display:inline-flex;align-items:center;gap:7px;flex-shrink:0;padding:9px 15px;border:1.5px solid #d7dcff;border-radius:11px;background:#f4f3ff;color:var(--primary);font-size:13px;font-weight:700;text-decoration:none;transition:all .15s ease}.map-gmaps:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px)}.map-modal header>button{display:grid;place-items:center;width:44px;height:44px;flex-shrink:0;border-radius:50%;background:#f1f3f8;color:#6f7c91;cursor:pointer;transition:background .15s ease,color .15s ease}.map-modal header>button:hover{background:#e7e9f0;color:#2a3344}.map-address{display:flex;align-items:flex-start;gap:9px;padding:13px 22px;border-bottom:1px solid #eef1f6;color:var(--red)}.map-address small{display:block;color:#8a94a8;font-size:11px;font-weight:800;letter-spacing:.4px}.map-address p{margin:3px 0 0;color:#3b4458;font-size:14px;font-weight:600}.map-frame{flex:1 1;min-height:360px;background:#eef1f5}.map-frame iframe{display:block;width:100%;height:100%;min-height:360px;border:0}@media (max-width:560px){.modal-backdrop{padding:14px}.map-modal{width:100%}.map-modal header{flex-wrap:wrap;padding:15px 16px;gap:12px}.map-modal-icon{width:42px;height:42px;border-radius:12px}.map-modal-head{order:0}.map-modal-head h2{font-size:17px}.map-modal-head p{font-size:11px;word-break:break-all}.map-modal header>button{order:2;width:40px;height:40px}.map-gmaps{order:3;flex-basis:100%;justify-content:center;padding:11px}.map-address{padding:12px 16px}.map-frame,.map-frame iframe{min-height:300px}.emp-att-modal header{padding:16px;gap:12px}.emp-att-avatar{width:46px;height:46px;font-size:20px;border-radius:14px}.emp-att-head h2{font-size:19px}.emp-att-modal header>button{width:40px;height:40px}.emp-att-body{padding:14px 14px 20px}.att-day{padding:13px 14px}.att-day-head{flex-direction:column;align-items:stretch;gap:8px}.att-dur{align-self:flex-start}.audit-modal header,.audit-modal-body,.ref-modal header,.ref-modal-body{padding:16px}.audit-modal header h2,.audit-modal-head h2{font-size:15px;word-break:break-all}.audit-meta-grid{grid-template-columns:1fr}.confirm-dialog{width:100%}}@media (max-width:768px){.login-card{width:min(380px,100%);border-radius:24px}.login-head{padding:24px 22px 20px}.login-brand .brand-logo{height:34px}.login-product strong{font-size:18px}.login-tagline{font-size:9px;letter-spacing:1.4px;margin-top:18px}.login-body{padding:26px 24px 28px;gap:16px}.login-field{gap:8px}.login-input input{min-height:50px;font-size:14px}.login-submit{min-height:52px;font-size:14.5px}}@media (max-width:480px){.login-shell{padding:16px}.login-card{width:100%;border-radius:22px;box-shadow:0 20px 50px rgba(30,25,80,.18)}.login-head{padding:22px 20px 18px}.login-brand{gap:10px}.login-brand .brand-logo{height:30px}.login-product strong{font-size:17px}.login-product span{font-size:7.5px}.login-tagline{font-size:8.5px;letter-spacing:1.2px;margin-top:16px}.login-body{padding:24px 20px 26px;gap:15px}.login-field span{font-size:10.5px}.login-input input{min-height:48px;padding:0 46px 0 42px;font-size:13.5px}.login-error{padding:10px 14px}.login-error:before{width:20px;height:20px;font-size:13px}.password-toggle{width:34px;height:34px;right:10px}.password-toggle svg{width:16px;height:16px}.login-submit{min-height:50px;font-size:14px}.login-error{font-size:12px}}@media (max-width:360px){.login-card{border-radius:20px}.login-brand .brand-logo{height:28px}.login-product strong{font-size:16px}.login-body{padding:22px 18px 24px}.login-input input{min-height:46px;padding:0 44px 0 40px}}.pwa-banner{position:fixed;bottom:0;left:0;right:0;z-index:100;background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 24px rgba(0,0,0,.12);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pwa-banner-content{display:flex;align-items:center;gap:12px;max-width:600px;margin:0 auto;padding:16px 20px}.pwa-banner-icon{flex-shrink:0}.pwa-banner-icon img{width:56px;height:56px;border-radius:14px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.pwa-banner-text{flex:1 1;min-width:0}.pwa-banner-text strong{display:block;font-size:15px;font-weight:700;color:var(--text);margin-bottom:2px}.pwa-banner-text span{display:block;font-size:12.5px;color:var(--muted);line-height:1.4}.pwa-install-btn{display:inline-flex;align-items:center;gap:6px;min-height:42px;padding:0 18px;border-radius:11px;background:var(--primary);color:#fff;font-size:14px;font-weight:700;white-space:nowrap;box-shadow:0 4px 12px rgba(81,70,229,.28);transition:all .2s ease}.pwa-install-btn:hover{background:var(--primary-2);transform:translateY(-1px);box-shadow:0 6px 16px rgba(81,70,229,.36)}.pwa-install-btn:active{transform:translateY(0)}.pwa-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;flex-shrink:0;border-radius:50%;background:transparent;color:var(--muted);transition:all .2s ease}.pwa-close-btn:hover{background:#f5f7fa;color:var(--text)}.pwa-banner.ios .pwa-banner-text span{font-size:11.5px}.pwa-banner.ios .pwa-banner-text span strong{display:inline;font-size:inherit;color:var(--primary);margin:0}@media (max-width:480px){.pwa-banner-content{padding:14px 16px;gap:10px}.pwa-banner-icon img{width:48px;height:48px;border-radius:12px}.pwa-banner-text strong{font-size:14px}.pwa-banner-text span{font-size:11.5px}.pwa-install-btn{min-height:38px;padding:0 14px;font-size:13px}.pwa-install-btn svg{width:16px;height:16px}.pwa-close-btn{width:32px;height:32px}.pwa-close-btn svg{width:16px;height:16px}}.offline-indicator{position:fixed;top:0;left:0;right:0;z-index:99;display:flex;align-items:center;justify-content:center;gap:8px;height:36px;background:#ffa726;color:#fff;font-size:13px;font-weight:600;text-align:center;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.metric.clickable{cursor:pointer;transition:all .2s ease}.metric.clickable:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(38,48,67,.14);border-color:var(--primary-2)}.metric.clickable:active{transform:translateY(0)}.metric.clickable span{color:var(--primary);font-size:11px;font-weight:600}.attendance-detail-modal{width:min(920px,94vw);max-height:85vh;display:flex;flex-direction:column;border-radius:28px;background:#fff;box-shadow:0 30px 80px rgba(0,0,0,.28);overflow:hidden}.attendance-detail-modal header{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:90px;padding:24px 32px;background:linear-gradient(135deg,#5a5a5a,#6d6d6d);color:#fff}.attendance-detail-modal h2{margin:0 0 6px;font-size:24px;font-weight:700;letter-spacing:-.02em}.attendance-detail-modal header p{margin:0;font-size:14px;color:rgba(255,255,255,.85)}.attendance-detail-modal header p strong{color:#fff;font-weight:700}.attendance-detail-modal header button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;flex-shrink:0;border-radius:12px;background:rgba(255,255,255,.15);color:#fff;transition:all .2s ease}.attendance-detail-modal header button:hover{background:rgba(255,255,255,.25)}.modal-table-container{flex:1 1;overflow:auto;padding:0;background:#fafbfe}.attendance-detail-table{width:100%;border-collapse:collapse}.attendance-detail-table thead{position:-webkit-sticky;position:sticky;top:0;z-index:1;background:#f0f3f8}.attendance-detail-table th{padding:16px 24px;text-align:left;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#7a8398;border-bottom:2px solid #e0e4ed}.attendance-detail-table th:first-child{width:80px;text-align:center}.attendance-detail-table th:last-child{width:160px;text-align:center}.attendance-detail-table tbody tr{border-bottom:1px solid #eef1f6;transition:background .15s ease}.attendance-detail-table tbody tr:hover{background:#f8f9fd}.attendance-detail-table tbody tr:last-child{border-bottom:0}.attendance-detail-table td{padding:18px 24px;font-size:14px;color:var(--text)}.attendance-detail-table td:first-child{text-align:center;font-weight:700;color:#9aa6ba;font-size:13px}.attendance-detail-table td:last-child{text-align:center}.attendance-detail-table td strong{font-weight:700;color:#2a3344}.attendance-detail-modal .badge{display:inline-block;padding:6px 14px;border-radius:8px;font-size:11.5px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap}.attendance-detail-modal .badge.status-present{background:#d9f6e7;color:var(--green)}.attendance-detail-modal .badge.status-absent{background:#ffe8ec;color:var(--red)}.attendance-detail-modal footer{display:flex;align-items:center;justify-content:center;min-height:88px;padding:22px 32px;border-top:1px solid #e7ebf3;background:#fff}.attendance-detail-modal .btn-close{min-width:180px;min-height:52px;border-radius:14px;background:var(--primary);color:#fff;font-size:16px;font-weight:700;box-shadow:0 4px 12px rgba(81,70,229,.28);transition:all .2s ease}.attendance-detail-modal .btn-close:hover{background:var(--primary-2);transform:translateY(-1px);box-shadow:0 6px 16px rgba(81,70,229,.36)}.attendance-detail-modal .btn-close:active{transform:translateY(0)}.modal-empty,.modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px}.modal-empty p,.modal-loading p{margin:0;color:#9aa6ba;font-size:15px;font-weight:600}.spinner{width:42px;height:42px;border:4px solid #e7ebf3;border-top:4px solid var(--primary);border-radius:50%;animation:spin .8s linear infinite}@media (max-width:768px){.attendance-detail-modal{width:100%;max-height:95vh;border-radius:20px 20px 0 0}.attendance-detail-modal header{padding:20px;min-height:80px}.attendance-detail-modal h2{font-size:20px}.attendance-detail-modal header p{font-size:13px}.attendance-detail-table td,.attendance-detail-table th{padding:14px 16px;font-size:13px}.attendance-detail-table th{font-size:10px}.attendance-detail-modal .badge{font-size:10px;padding:5px 10px}.attendance-detail-modal footer{padding:18px 20px;min-height:78px}.attendance-detail-modal .btn-close{width:100%;min-height:48px;font-size:15px}}