*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{color:#0f1f3d;background:#f4f6f9}table{width:100%}*{-webkit-tap-highlight-color:transparent}.dl-app{background:var(--t-scene-bg,#fdf0e8);flex-direction:column;height:100vh;font-family:Inter,Segoe UI,sans-serif;display:flex;overflow:hidden}@media (width>=768px){.dl-app{flex-direction:row}}.dl-mobile-header{border-bottom:1px solid var(--t-card-border,#f0d5c5);z-index:10;background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;min-width:0;padding:10px 12px;display:flex}@media (width>=768px){.dl-mobile-header{display:none}}.dl-mobile-logo{color:var(--t-heading,#2d1a10);flex-shrink:0;align-items:center;gap:7px;font-size:15px;font-weight:700;text-decoration:none;display:flex}.dl-mobile-logo-icon{color:#fff;background:#2563eb;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.dl-mobile-controls{flex-shrink:0;align-items:center;gap:6px;display:flex}.dl-mobile-logout{border:1.5px solid var(--t-card-border,#f0d5c5);cursor:pointer;color:#e07060;touch-action:manipulation;background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:background .15s;display:flex}.dl-mobile-logout:hover{background:#fdecea}@media (width>=768px){.dl-mobile-logout{display:none}}.dl-sidebar{background:#0f1f3d;border-right:1px solid #1e3a6e;flex-direction:column;flex-shrink:0;width:220px;transition:width .25s;display:none;overflow:hidden auto}@media (width>=768px){.dl-sidebar{display:flex}.dl-collapsed .dl-sidebar{width:60px}}.dl-logo{border-bottom:1px solid #ffffff14;flex-shrink:0;align-items:center;gap:9px;min-height:58px;padding:16px 14px 13px;display:flex}.dl-logo-icon{color:#2563eb;background:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:700;transition:background .4s;display:flex}.dl-logo-text{color:#fff;white-space:nowrap;flex:1;font-size:15px;font-weight:700;overflow:hidden}.dl-logo-text span{color:#60a5fa}.dl-collapse-btn{cursor:pointer;color:#fff6;background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;padding:4px;transition:color .15s;display:flex}.dl-collapse-btn:hover{color:#60a5fa}.dl-nav{flex-direction:column;flex:1;gap:1px;padding:8px;display:flex;overflow-y:auto}.dl-nav-section{color:#ffffff4d;letter-spacing:.6px;text-transform:uppercase;white-space:nowrap;padding:10px 8px 4px;font-size:10px;font-weight:700;overflow:hidden}.dl-nav-item{cursor:pointer;color:#fff9;text-align:left;white-space:nowrap;touch-action:manipulation;background:0 0;border:none;border-radius:9px;align-items:center;gap:10px;width:100%;margin-top:5px;padding:9px 10px;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:flex;overflow:hidden}.dl-nav-item:hover{color:#fff;background:#ffffff14}.dl-nav-item.active{color:#fff;background:#2563eb;font-weight:600}.dl-nav-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.dl-collapsed .dl-nav-item{justify-content:center;padding:9px}.dl-collapsed .dl-nav-section{visibility:hidden;height:20px}.dl-footer{border-top:1px solid #ffffff14;flex-shrink:0;padding:10px 10px 14px}.dl-guest-banner{background:var(--t-scene-bg,#fdf0e8);border:1px solid var(--t-card-border,#f0d5c5);color:var(--t-label,#6b4535);border-radius:8px;flex-direction:column;gap:5px;margin-bottom:10px;padding:8px 10px;font-size:11.5px;display:flex}.dl-guest-banner button{background:var(--t-accent,#e8856a);color:#fff;cursor:pointer;touch-action:manipulation;border:none;border-radius:6px;padding:5px 8px;font-size:11.5px;font-weight:600}.dl-user-row{align-items:center;gap:8px;display:flex}.dl-avatar{color:#60a5fa;background:#1e3a6e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:700;display:flex}.dl-user-info{flex:1;min-width:0}.dl-user-name{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:600;overflow:hidden}.dl-user-role{color:#fff6;text-transform:capitalize;font-size:11px}.dl-logout-btn{cursor:pointer;color:var(--t-sub,#a0836f);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:5px;transition:color .15s,background .15s;display:flex}.dl-logout-btn:hover{color:#e07060;background:#fdecea}.dl-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.dl-topbar{display:none}@media (width>=768px){.dl-topbar{flex-shrink:0;justify-content:flex-end;align-items:center;gap:10px;padding:12px 22px 0;display:flex}}.dl-content{-webkit-overflow-scrolling:touch;flex:1;padding:12px 14px 100px;overflow-y:auto}@media (width>=768px){.dl-content{padding:8px 22px 24px}}.dl-mobile-nav{border-top:1px solid var(--t-card-border,#f0d5c5);z-index:100;padding-bottom:env(safe-area-inset-bottom);background:#fff;display:flex;position:fixed;bottom:0;left:0;right:0}@media (width>=768px){.dl-mobile-nav{display:none}}.dl-tab-item{cursor:pointer;color:var(--t-sub,#a0836f);touch-action:manipulation;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-width:0;min-height:52px;padding:6px 2px;font-size:9px;font-weight:500;transition:color .15s;display:flex}.dl-tab-item.active{color:#2563eb}.dl-tab-item svg{flex-shrink:0}.dl-tab-item span{white-space:nowrap;text-overflow:ellipsis;max-width:100%;overflow:hidden}.usp-wrap{position:relative}.usp-trigger{cursor:pointer;white-space:nowrap;touch-action:manipulation;border:1.5px solid;border-radius:20px;align-items:center;gap:6px;padding:5px 10px;font-size:11.5px;font-weight:600;transition:opacity .15s;display:flex}@media (width>=480px){.usp-trigger{padding:6px 12px;font-size:12.5px}}.usp-trigger:hover{opacity:.85}.usp-icon{font-size:13px;line-height:1}.usp-trigger-label{display:none}@media (width>=480px){.usp-trigger-label{display:inline}}.usp-timer{font-variant-numeric:tabular-nums;opacity:.75;font-size:10.5px;font-weight:700}.usp-overdue{animation:1.5s infinite usp-pulse}.usp-overdue-dot{background:#e07060;border-radius:50%;width:7px;height:7px;animation:1s infinite usp-pulse}@keyframes usp-pulse{0%,to{opacity:1}50%{opacity:.5}}.usp-dropdown{border:1px solid var(--t-card-border);z-index:300;background:#fff;border-radius:14px;padding:6px;position:fixed;bottom:70px;left:8px;right:8px;box-shadow:0 8px 24px #2d1a101f}@media (width>=768px){.usp-dropdown{width:240px;position:absolute;inset:calc(100% + 8px) 0 auto auto}}.usp-dropdown-header{color:var(--t-sub);text-transform:uppercase;letter-spacing:.5px;padding:6px 10px 8px;font-size:11px;font-weight:700}.usp-option{cursor:pointer;text-align:left;touch-action:manipulation;background:0 0;border:none;border-radius:9px;align-items:center;gap:10px;width:100%;padding:10px;transition:background .12s;display:flex}.usp-option:hover{background:var(--t-scene-bg)}.usp-opt-icon{flex-shrink:0;font-size:16px}.usp-opt-info{flex:1;min-width:0}.usp-opt-label{color:var(--t-heading);font-size:13px;font-weight:600;display:block}.usp-opt-desc{color:var(--t-sub);font-size:11px;display:block}.usp-opt-dur{border-radius:10px;flex-shrink:0;padding:2px 7px;font-size:10.5px;font-weight:700}.usp-opt-check{flex-shrink:0;font-size:13px}.usp-dropdown-footer{color:var(--t-sub);text-align:center;border-top:1px solid var(--t-card-border);margin-top:4px;padding:8px 10px 4px;font-size:11px}.nb-wrap{position:relative}.nb-bell{border:1.5px solid var(--t-card-border,#f0d5c5);cursor:pointer;width:36px;height:36px;color:var(--t-sub,#a0836f);touch-action:manipulation;background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex;position:relative}.nb-bell:hover{background:var(--t-scene-bg);color:var(--t-accent)}.nb-badge{color:#fff;background:#e07060;border:2px solid #fff;border-radius:20px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:9px;font-weight:700;animation:.3s cubic-bezier(.34,1.56,.64,1) nb-pop;display:flex;position:absolute;top:-4px;right:-4px}@keyframes nb-pop{0%{transform:scale(0)}to{transform:scale(1)}}.nb-dropdown{border:1px solid var(--t-card-border,#f0d5c5);z-index:400;background:#fff;border-radius:14px;flex-direction:column;max-height:80vh;display:flex;position:fixed;top:60px;left:8px;right:8px;overflow:hidden;box-shadow:0 8px 32px #2d1a101f}@media (width>=480px){.nb-dropdown{width:360px;max-height:480px;position:absolute;top:calc(100% + 8px);left:auto;right:0}}.nb-header{border-bottom:1px solid var(--t-card-border,#f0d5c5);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.nb-header-title{color:var(--t-heading,#2d1a10);font-size:14px;font-weight:700}.nb-mark-all{cursor:pointer;color:var(--t-accent,#e8856a);touch-action:manipulation;background:0 0;border:none;font-size:12px;font-weight:600}.nb-mark-all:hover{text-decoration:underline}.nb-list{flex:1;overflow-y:auto}.nb-empty{text-align:center;color:var(--t-sub,#a0836f);padding:40px 20px;font-size:13.5px}.nb-item{border-bottom:1px solid var(--t-scene-bg,#fdf0e8);cursor:pointer;align-items:flex-start;gap:12px;padding:12px 16px;transition:background .12s;display:flex;position:relative}.nb-item:last-child{border-bottom:none}.nb-item:hover,.nb-item-unread{background:var(--t-scene-bg,#fdf6f0)}.nb-item-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.nb-item-body{flex:1;min-width:0}.nb-item-title{color:var(--t-heading,#2d1a10);margin-bottom:2px;font-size:13px;font-weight:600}.nb-item-msg{color:var(--t-sub,#a0836f);margin-bottom:4px;font-size:12px;line-height:1.4}.nb-item-meta{color:var(--t-divider-text,#c9a899);font-size:11px}.nb-unread-dot{background:var(--t-accent,#e8856a);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:4px}.db-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.db-title{color:var(--t-heading,#2d1a10);letter-spacing:-.3px;font-size:18px;font-weight:700}.db-sub{color:var(--t-sub,#a0836f);margin-top:2px;font-size:12px}.db-header-right{align-items:center;gap:8px;display:flex}.db-badge{border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600}.db-badge-live{color:#2e7d32;background:#e8f5e9}.db-badge-muted{background:var(--t-scene-bg,#fdf6f0);color:var(--t-sub,#a0836f);border:1px solid var(--t-card-border,#f0d5c5)}.db-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:14px;display:grid}@media (width>=900px){.db-metrics{grid-template-columns:repeat(4,minmax(0,1fr))}}.db-mc{border:1px solid var(--t-card-border,#f0d5c5);background:#fff;border-radius:12px;padding:12px 14px}.db-mc-label{color:var(--t-sub);letter-spacing:.3px;text-transform:uppercase;margin-bottom:5px;font-size:10px;font-weight:600}.db-mc-val{color:var(--t-heading);letter-spacing:-.5px;font-size:24px;font-weight:700;line-height:1}.db-mc-sub{margin-top:4px;font-size:11px}.db-mc-track{background:var(--t-scene-bg);border-radius:2px;height:3px;margin-top:8px}.db-mc-fill{border-radius:2px;height:100%;transition:width 1s}.db-card{border:1px solid var(--t-card-border,#f0d5c5);background:#fff;border-radius:12px;padding:14px 16px}.db-card-title{color:var(--t-heading);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:4px;margin-bottom:10px;font-size:13px;font-weight:700;display:flex}.db-card-title span{color:var(--t-sub);font-size:11px;font-weight:400}.db-chart-legend{color:var(--t-sub);flex-wrap:wrap;gap:12px;margin-bottom:10px;font-size:11.5px;display:flex}.db-chart-legend span{align-items:center;gap:5px;display:flex}.db-chart-legend i{border-radius:2px;width:10px;height:10px;font-style:normal;display:inline-block}.db-charts-row{grid-template-columns:1fr;gap:12px;margin-bottom:12px;display:grid}@media (width>=768px){.db-charts-row{grid-template-columns:1.6fr 1fr}}.db-productivity{flex-direction:column;gap:10px;margin-top:4px;display:flex}.db-prog-label{color:var(--t-label);justify-content:space-between;margin-bottom:4px;font-size:12px;display:flex}.db-prog-track{background:var(--t-scene-bg);border-radius:3px;height:6px}.db-prog-fill{border-radius:3px;height:100%;transition:width 1s}.db-bottom-row{grid-template-columns:1fr;gap:12px;display:grid}@media (width>=768px){.db-bottom-row{grid-template-columns:1fr 1fr}}.db-leaderboard{flex-direction:column;display:flex}.db-lb-row{border-bottom:1px solid var(--t-scene-bg);align-items:center;gap:10px;padding:8px 0;display:flex}.db-lb-row:last-child{border-bottom:none}.db-lb-rank{color:var(--t-sub);text-align:center;width:16px;font-size:11px;font-weight:700}.db-lb-rank.gold{color:#b8860b}.db-lb-rank.silver{color:#888}.db-lb-rank.bronze{color:#cd7f32}.db-lb-av{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:10px;font-weight:700;display:flex}.db-lb-info{flex:1;min-width:0}.db-lb-name{color:var(--t-heading);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:600;overflow:hidden}.db-lb-dept{color:var(--t-sub);font-size:11px}.db-lb-score{color:var(--t-accent);white-space:nowrap;font-size:12.5px;font-weight:700}.db-spinner{border:3px solid var(--t-card-border,#f0d5c5);border-top-color:var(--t-accent,#e8856a);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.crud-card{overflow-x:auto}.crud-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:16px;display:flex}.crud-toolbar{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.crud-search{width:100%;min-width:unset;border:1.5px solid var(--t-input-border,#f0d5c5);background:var(--t-input-bg);color:var(--t-heading);-webkit-appearance:none;border-radius:9px;outline:none;padding:10px 12px;font-size:16px}.crud-filter{border:1.5px solid var(--t-input-border,#f0d5c5);background:var(--t-input-bg);min-width:100px;color:var(--t-heading);-webkit-appearance:none;border-radius:9px;outline:none;flex:1;padding:10px 8px;font-size:13px}.btn-add{background:var(--t-accent);color:#fff;cursor:pointer;text-align:center;touch-action:manipulation;white-space:nowrap;border:none;border-radius:9px;flex:1;min-width:100px;padding:10px 12px;font-size:13px;font-weight:600}.crud-table{border-collapse:collapse;width:100%;min-width:500px;font-size:13px}.badge{white-space:nowrap;border-radius:20px;align-items:center;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.action-btns{flex-wrap:wrap;gap:5px;display:flex}.btn-edit,.btn-del,.btn-approve{cursor:pointer;touch-action:manipulation;white-space:nowrap;border:none;border-radius:7px;padding:5px 10px;font-size:11.5px;font-weight:600}@media (width>=600px){.modal-overlay{align-items:center;padding:20px}}.modal{border:1px solid var(--t-card-border);width:100%;max-width:100%;max-height:92vh;padding:24px 20px 32px;padding-bottom:calc(24px + env(safe-area-inset-bottom));background:#fff;border-radius:18px 18px 0 0;overflow-y:auto}@media (width>=600px){.modal{border-radius:16px;max-width:460px;padding:28px 28px 24px}}.modal-field input,.modal-field select,.modal-field textarea{border:1.5px solid var(--t-input-border);width:100%;color:var(--t-heading);background:var(--t-input-bg);-webkit-appearance:none;border-radius:8px;outline:none;padding:11px 13px;font-family:inherit;font-size:16px}.modal-row{flex-wrap:wrap;gap:10px;display:flex}.modal-row .modal-field{flex:1;min-width:120px}.modal-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.btn-cancel{background:var(--t-scene-bg);color:var(--t-label);border:1.5px solid var(--t-card-border);cursor:pointer;touch-action:manipulation;border-radius:9px;padding:10px 16px;font-size:13.5px;font-weight:600}.btn-save{background:var(--t-accent);color:#fff;cursor:pointer;touch-action:manipulation;border:none;border-radius:9px;flex:1;padding:10px 20px;font-size:13.5px;font-weight:600}@media (width>=480px){.btn-save{flex:none}}.crud-pagination{border-top:1px solid var(--t-card-border);color:var(--t-sub);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:12px 14px;font-size:12px;display:flex}.page-btns{flex-wrap:wrap;gap:4px;display:flex}.page-btn{border:1.5px solid var(--t-card-border);cursor:pointer;color:var(--t-label);touch-action:manipulation;background:#fff;border-radius:6px;padding:5px 10px;font-size:12px}.att-quick-panel{border:1px solid var(--t-card-border);background:#fff;border-radius:12px;margin-bottom:4px;padding:14px 16px;overflow-x:auto}.att-quick-list{flex-direction:column;gap:6px;min-width:320px;display:flex}.att-quick-btn{cursor:pointer;touch-action:manipulation;border:none;border-radius:7px;width:28px;height:28px;font-size:11px;font-weight:700}.crud-page{padding:0}.crud-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.crud-title{color:var(--t-heading,#2d1a10);letter-spacing:-.3px;font-size:20px;font-weight:700}.crud-sub{color:var(--t-sub,#a0836f);margin-top:2px;font-size:12.5px}.crud-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.crud-search{border:1.5px solid var(--t-input-border,#f0d5c5);background:var(--t-input-bg,#fdf9f7);min-width:200px;color:var(--t-heading,#2d1a10);border-radius:9px;outline:none;flex:1;padding:9px 13px;font-size:13.5px;transition:border-color .2s,box-shadow .2s}.crud-search:focus{border-color:var(--t-accent,#e8856a);box-shadow:0 0 0 3px var(--t-focus-shadow,#e8856a1f)}.crud-filter{border:1.5px solid var(--t-input-border,#f0d5c5);background:var(--t-input-bg,#fdf9f7);color:var(--t-heading,#2d1a10);cursor:pointer;border-radius:9px;outline:none;padding:9px 13px;font-size:13px}.btn-add{background:var(--t-accent,#e8856a);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:9px;align-items:center;gap:6px;padding:9px 18px;font-size:13.5px;font-weight:600;transition:background .2s;display:flex}.btn-add:hover{background:var(--t-accent-hover,#d9714f)}.crud-card{border:1px solid var(--t-card-border,#f0d5c5);background:#fff;border-radius:14px;overflow:hidden}.crud-table{border-collapse:collapse;width:100%;font-size:13.5px}.crud-table thead tr{background:var(--t-scene-bg,#fdf6f0);border-bottom:1px solid var(--t-card-border,#f0d5c5)}.crud-table th{text-align:left;color:var(--t-sub,#a0836f);letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;padding:11px 16px;font-size:11px;font-weight:700}.crud-table td{color:var(--t-heading,#2d1a10);border-bottom:1px solid var(--t-scene-bg,#fdf0e8);vertical-align:middle;padding:12px 16px}.crud-table tbody tr:last-child td{border-bottom:none}.crud-table tbody tr:hover{background:#fffaf8}.emp-av{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:700;display:flex}.badge{border-radius:20px;align-items:center;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-present{color:#2e7d32;background:#e8f5e9}.badge-absent{color:#c62828;background:#fdecea}.badge-leave{color:#e65100;background:#fff3e0}.badge-pending{color:#f57f17;background:#fff8e1}.badge-approved{color:#2e7d32;background:#e8f5e9}.badge-rejected{color:#c62828;background:#fdecea}.action-btns{gap:6px;display:flex}.btn-edit,.btn-del,.btn-approve{cursor:pointer;border:none;border-radius:7px;padding:5px 11px;font-size:12px;font-weight:600;transition:opacity .15s}.btn-edit{background:var(--t-scene-bg,#fdf0e8);color:var(--t-label,#6b4535)}.btn-del{color:#c62828;background:#fdecea}.btn-approve{color:#2e7d32;background:#e8f5e9}.btn-edit:hover,.btn-del:hover,.btn-approve:hover{opacity:.75}.crud-state{text-align:center;color:var(--t-sub,#a0836f);padding:48px 20px;font-size:14px}.crud-spinner{border:3px solid var(--t-card-border,#f0d5c5);border-top-color:var(--t-accent,#e8856a);border-radius:50%;width:28px;height:28px;margin:0 auto 12px;animation:.7s linear infinite spin}.modal-overlay{z-index:200;background:#2d1a1059;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--t-card-border,#f0d5c5);background:#fff;border-radius:16px;width:100%;max-width:460px;max-height:90vh;padding:28px 28px 24px;overflow-y:auto}.modal-title{color:var(--t-heading,#2d1a10);justify-content:space-between;align-items:center;margin-bottom:20px;font-size:17px;font-weight:700;display:flex}.modal-close{cursor:pointer;color:var(--t-sub,#a0836f);background:0 0;border:none;padding:0;font-size:20px;line-height:1}.modal-close:hover{color:var(--t-heading,#2d1a10)}.modal-field{margin-bottom:15px}.modal-field label{color:var(--t-label,#6b4535);margin-bottom:5px;font-size:12px;font-weight:600;display:block}.modal-field input,.modal-field select,.modal-field textarea{border:1.5px solid var(--t-input-border,#f0d5c5);width:100%;color:var(--t-heading,#2d1a10);background:var(--t-input-bg,#fdf9f7);border-radius:8px;outline:none;padding:9px 13px;font-family:inherit;font-size:13.5px;transition:border-color .2s,box-shadow .2s}.modal-field input:focus,.modal-field select:focus,.modal-field textarea:focus{border-color:var(--t-accent,#e8856a);box-shadow:0 0 0 3px var(--t-focus-shadow,#e8856a1f)}.modal-field textarea{resize:vertical;min-height:80px}.modal-row{gap:12px;display:flex}.modal-row .modal-field{flex:1}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.btn-cancel{background:var(--t-scene-bg,#fdf0e8);color:var(--t-label,#6b4535);border:1.5px solid var(--t-card-border,#f0d5c5);cursor:pointer;border-radius:9px;padding:9px 18px;font-size:13.5px;font-weight:600}.btn-cancel:hover{background:var(--t-guest-hover,#fdeee3)}.btn-save{background:var(--t-accent,#e8856a);color:#fff;cursor:pointer;border:none;border-radius:9px;padding:9px 20px;font-size:13.5px;font-weight:600;transition:background .2s}.btn-save:hover{background:var(--t-accent-hover,#d9714f)}.btn-save:disabled{opacity:.6;cursor:not-allowed}.modal-error{color:#c62828;background:#fdecea;border:1px solid #f5c2c2;border-radius:8px;margin-bottom:14px;padding:10px 13px;font-size:13px}.crud-pagination{border-top:1px solid var(--t-card-border,#f0d5c5);color:var(--t-sub,#a0836f);justify-content:space-between;align-items:center;padding:12px 16px;font-size:12.5px;display:flex}.page-btns{gap:4px;display:flex}.page-btn{border:1.5px solid var(--t-card-border,#f0d5c5);cursor:pointer;color:var(--t-label,#6b4535);background:#fff;border-radius:6px;padding:4px 10px;font-size:12.5px}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-btn.active{background:var(--t-accent,#e8856a);color:#fff;border-color:var(--t-accent,#e8856a)}.att-quick-panel{border:1px solid var(--t-card-border,#f0d5c5);background:#fff;border-radius:12px;margin-bottom:4px;padding:14px 18px}.att-quick-title{color:var(--t-sub);text-transform:uppercase;letter-spacing:.4px;margin-bottom:12px;font-size:12px;font-weight:700}.att-quick-list{flex-direction:column;gap:8px;display:flex}.att-quick-item{border-bottom:1px solid var(--t-scene-bg,#fdf0e8);justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;display:flex}.att-quick-item:last-child{border-bottom:none}.att-quick-name{color:var(--t-heading);font-weight:500}.att-quick-btn{cursor:pointer;border:none;border-radius:6px;width:26px;height:26px;font-size:11px;font-weight:700;transition:opacity .15s}.att-quick-btn:disabled{opacity:.4;cursor:not-allowed}.att-quick-present{color:#2e7d32;background:#e8f5e9}.att-quick-absent{color:#c62828;background:#fdecea}.att-quick-leave{color:#e65100;background:#fff3e0}.att-quick-active{outline:2px solid}@media (width<=767px){.crud-card{background:0 0;border:none;border-radius:0;overflow:visible}.crud-table{display:none}.mobile-card-list{flex-direction:column;gap:10px;display:flex}.mobile-card{border:1px solid var(--t-card-border,#f0d5c5);cursor:pointer;background:#fff;border-radius:12px;padding:14px}.mobile-card:active{opacity:.85}.mobile-card-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.mobile-card-row:last-child{margin-bottom:0}.mobile-card-label{color:var(--t-sub,#a0836f);text-transform:uppercase;letter-spacing:.4px;flex-shrink:0;font-size:10px;font-weight:700}.mobile-card-value{color:var(--t-heading,#2d1a10);text-align:right;word-break:break-word;max-width:60%;font-size:13px}.mobile-card-actions{border-top:1px solid var(--t-scene-bg,#fdf0e8);gap:8px;margin-top:10px;padding-top:10px;display:flex}.mobile-card-actions button{cursor:pointer;touch-action:manipulation;border:none;border-radius:8px;flex:1;padding:8px;font-size:12px;font-weight:600}}@media (width>=768px){.mobile-card-list{display:none}.crud-table{display:table}.crud-search{width:auto}}.mobile-card-list{flex-direction:column;gap:10px;display:none}.mobile-card{border:1px solid var(--t-card-border,#f0d5c5);cursor:default;background:#fff;border-radius:12px;padding:14px}.mobile-card-row{border-bottom:1px solid var(--t-scene-bg,#fdf0e8);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:5px 0;display:flex}.mobile-card-row:last-of-type{border-bottom:none}.mobile-card-label{color:var(--t-sub,#a0836f);text-transform:uppercase;letter-spacing:.4px;flex-shrink:0;font-size:10px;font-weight:700}.mobile-card-value{color:var(--t-heading,#2d1a10);text-align:right;word-break:break-word;font-size:13px}.mobile-card-actions{border-top:1px solid var(--t-scene-bg,#fdf0e8);gap:8px;margin-top:12px;padding-top:10px;display:flex}.mobile-card-actions button{cursor:pointer;touch-action:manipulation;border:none;border-radius:8px;flex:1;padding:9px 8px;font-size:13px;font-weight:600}@media (width<=767px){.mobile-card-list{display:flex}.crud-card{display:none}}@media (width>=768px){.mobile-card-list{display:none}.crud-card{display:block}}.ed-page{padding:0}.ed-back{cursor:pointer;color:var(--t-sub);touch-action:manipulation;background:0 0;border:none;align-items:center;gap:4px;margin-bottom:14px;padding:0;font-size:13px;font-weight:600;display:flex}.ed-back:hover{color:var(--t-accent)}.ed-profile-card{border:1px solid var(--t-card-border);background:#fff;border-radius:14px;flex-wrap:wrap;align-items:flex-start;gap:14px;margin-bottom:14px;padding:18px 16px;display:flex}@media (width>=600px){.ed-profile-card{flex-wrap:nowrap;align-items:center;padding:24px}}.ed-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:54px;height:54px;font-size:18px;font-weight:700;display:flex}@media (width>=600px){.ed-avatar{width:64px;height:64px;font-size:22px}}.ed-profile-info{flex:1;min-width:0}.ed-name{color:var(--t-heading);letter-spacing:-.3px;margin-bottom:5px;font-size:18px;font-weight:700}@media (width>=600px){.ed-name{font-size:20px}}.ed-meta{color:var(--t-sub);flex-wrap:wrap;align-items:center;gap:6px;font-size:12.5px;display:flex}.ed-dot{opacity:.4}.ed-dept-badge{background:var(--t-scene-bg);color:var(--t-label);border-radius:20px;padding:2px 10px;font-size:11.5px;font-weight:600}.ed-perf-ring{text-align:center;flex-shrink:0;margin-left:auto}.ed-perf-label{color:var(--t-sub);margin-top:3px;font-size:11px}.ed-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:14px;display:grid}@media (width>=900px){.ed-stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.ed-stat-card{border:1px solid var(--t-card-border);background:#fff;border-radius:12px;padding:14px}.ed-stat-val{letter-spacing:-.5px;font-size:26px;font-weight:700;line-height:1}.ed-stat-label{color:var(--t-sub);margin-top:4px;font-size:12px;font-weight:500}.ed-bottom-grid{grid-template-columns:1fr;gap:12px;display:grid}@media (width>=900px){.ed-bottom-grid{grid-template-columns:1.2fr 1fr}}.ed-card{border:1px solid var(--t-card-border);background:#fff;border-radius:12px;padding:16px}.ed-card-title{color:var(--t-heading);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:4px;margin-bottom:12px;font-size:13px;font-weight:700;display:flex}.ed-card-title span{color:var(--t-sub);font-size:11px;font-weight:400}.ed-cal-legend{flex-wrap:wrap;gap:10px;margin-bottom:10px;display:flex}.ed-cal-legend-item{color:var(--t-sub);align-items:center;gap:4px;font-size:11px;display:flex}.ed-cal-legend-item i{border-radius:3px;width:11px;height:11px;font-style:normal;display:inline-block}.ed-cal-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.ed-cal-weekday{text-align:center;color:var(--t-sub);padding-bottom:3px;font-size:9.5px;font-weight:700}.ed-cal-day{aspect-ratio:1;cursor:default;border-radius:4px;justify-content:center;align-items:center;font-size:9.5px;font-weight:600;display:flex}@media (width>=400px){.ed-cal-day{font-size:10.5px}}.ed-cal-day:hover{z-index:1;position:relative;transform:scale(1.15)}.ed-leave-row{border-bottom:1px solid var(--t-scene-bg);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;padding:8px 0;display:flex}.ed-leave-row:last-child{border-bottom:none}
