*{margin:0;padding:0;box-sizing:border-box}:root{--primary:#7c9cff;--primary-dark:#5f84f8;--primary-light:#9db6ff;--primary-hover:#8eabff;--slate-50:#17233a;--slate-100:#1b2942;--slate-200:#24324e;--slate-300:#324464;--slate-400:#4a6188;--slate-500:#6e86ad;--slate-600:#95abca;--slate-700:#b8cae3;--slate-800:#d4e0f2;--slate-900:#e9f0fd;--success:#2fd08c;--success-dark:#26b778;--success-light:#53dea2;--danger:#ff6b72;--danger-dark:#f4535d;--danger-light:#ff8e93;--warning:#f6b73c;--warning-dark:#e59e21;--info:#7c9cff;--bg:#0b1220;--bg-secondary:#111a2c;--bg-tertiary:#17233a;--text-primary:#e7eefc;--text-secondary:#a5b7d8;--text-tertiary:#8197bc;--text-inverse:#fff;--border:#2a3955;--border-light:#24324c;--border-dark:#385078;--shadow-sm:0 2px 6px rgba(0,0,0,.24);--shadow:0 6px 18px rgba(0,0,0,.32);--shadow-md:0 10px 24px rgba(0,0,0,.34);--shadow-lg:0 14px 30px rgba(0,0,0,.4);--shadow-xl:0 22px 44px rgba(0,0,0,.45);--shadow-2xl:0 30px 70px rgba(0,0,0,.5);--shadow-primary:0 6px 18px rgba(124,156,255,.32);--shadow-primary-lg:0 10px 30px rgba(124,156,255,.45);--radius:12px;--radius-sm:8px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--control-height:40px;--control-height-mobile:44px;--control-padding-x:14px;--chip-height:36px;--chip-padding-x:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg);background-image:radial-gradient(at 0 0,rgba(37,99,235,.03) 0,transparent 50%),radial-gradient(at 100% 100%,rgba(37,99,235,.03) 0,transparent 50%);background-attachment:fixed;min-height:100vh;color:var(--text-primary);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{max-width:1200px;margin:0 auto;padding:16px 20px}.app-header{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:16px 24px;margin-bottom:24px;box-shadow:var(--shadow-md);border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.app-header:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary) 0,var(--primary-light) 100%)}.app-header h1{font-size:24px;font-weight:700;color:var(--slate-900);margin:0;letter-spacing:-.5px;position:relative}.app-header .user-info{display:flex;align-items:center;gap:12px}.app-header .welcome-text{color:var(--text-secondary);font-size:13px;font-weight:500}.role-badge{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:0 10px;border-radius:var(--radius-full);font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;border:1px solid transparent}.role-badge.master{color:#78350f;background:#fef3c7;border-color:#fcd34d}.role-badge.household{color:#1e3a8a;background:#dbeafe;border-color:#93c5fd}.app-header .logout-label{color:var(--text-secondary);font-size:13px;font-weight:600}.card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:20px;box-shadow:var(--shadow);border:1px solid var(--border);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--primary);opacity:0;transition:opacity .3s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-dark)}.card:hover:before{opacity:1}.card h2{font-size:20px;font-weight:700;color:var(--slate-900);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-light);letter-spacing:-.3px;position:relative}.card h2:after{content:"";position:absolute;bottom:-1px;left:0;width:50px;height:2px;background:var(--primary);border-radius:2px}.btn{min-height:var(--control-height);padding:0 20px;border:none;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);touch-action:manipulation;-webkit-tap-highlight-color:transparent;gap:6px;position:relative;overflow:hidden;letter-spacing:.01em;text-transform:none;white-space:nowrap}.btn,.btn-icon{border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center}.btn-icon{padding:0;width:var(--control-height);height:var(--control-height);min-width:var(--control-height)}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:hsla(0,0%,100%,.2);transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn:hover:before{width:300px;height:300px}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:var(--text-inverse);box-shadow:var(--shadow-primary);border:1px solid var(--primary-dark)}.btn-primary:hover{background:var(--primary-hover);box-shadow:var(--shadow-primary-lg);transform:translateY(-1px)}.btn-primary:active{background:var(--primary-dark);transform:translateY(0) scale(.97)}.btn-success{background:var(--success);color:var(--text-inverse);box-shadow:0 4px 14px 0 rgba(16,185,129,.25);border:1px solid var(--success-dark)}.btn-success:hover{background:var(--success-dark);box-shadow:0 6px 20px 0 rgba(16,185,129,.35);transform:translateY(-1px)}.btn-success:active{background:#047857;transform:translateY(0) scale(.97)}.btn-danger{background:var(--danger);color:var(--text-inverse);box-shadow:0 4px 14px 0 rgba(239,68,68,.25);border:1px solid var(--danger-dark)}.btn-danger:hover{background:var(--danger-dark);box-shadow:0 6px 20px 0 rgba(239,68,68,.35);transform:translateY(-1px)}.btn-danger:active{background:#b91c1c;transform:translateY(0) scale(.97)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1.5px solid var(--border-dark);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--slate-50);border-color:var(--slate-300);box-shadow:var(--shadow);transform:translateY(-1px)}.btn-secondary:active{background:var(--slate-100);transform:translateY(0) scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn:focus-visible,.tab-btn:focus-visible{outline:3px solid rgba(37,99,235,.35);outline-offset:2px}input:not([type=checkbox]):not([type=radio]):not([type=color]),select,textarea{width:100%;min-height:var(--control-height);border:1.5px solid var(--border-dark);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);padding:0 var(--control-padding-x);font-size:14px;font-weight:500;line-height:1.2;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}textarea{min-height:96px;padding-top:10px;padding-bottom:10px}input:not([type=checkbox]):not([type=radio]):not([type=color]):focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,.1)}input::placeholder,textarea::placeholder{color:var(--text-tertiary);font-weight:500}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:8px;font-weight:600}.form-group input,.form-group label{color:var(--text-primary);font-size:14px}.form-group input{width:100%;padding:12px 16px;border:1.5px solid var(--border-dark);border-radius:var(--radius-md);transition:all .2s cubic-bezier(.4,0,.2,1);background:var(--bg-secondary);font-weight:500}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(37,99,235,.1);background:var(--bg-secondary)}.form-group input:hover:not(:focus){border-color:var(--slate-400)}.form-group small{display:block;margin-top:6px;color:var(--text-secondary);font-size:13px}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:16px;border-radius:var(--radius-md);border:1px solid var(--border)}table{width:100%;min-width:600px;background:var(--bg-secondary)}table td,table th{padding:12px 14px;text-align:left;border-bottom:1px solid var(--border)}.compact-datetime{display:flex;flex-direction:column;gap:2px;white-space:nowrap;line-height:1.2}.compact-datetime>div:last-child{color:var(--text-secondary);font-size:12px}table th{background:var(--slate-50);font-weight:700;color:var(--slate-900);font-size:11px;text-transform:uppercase;letter-spacing:.8px;position:-webkit-sticky;position:sticky;top:0;z-index:10;border-bottom:2px solid var(--border-dark);padding:14px}table tbody tr{transition:background-color .2s}table tbody tr:hover{background-color:var(--slate-50);transition:background-color .15s ease}table tbody tr:last-child td{border-bottom:none}.error{background:#fef2f2;color:var(--danger-dark);border-radius:var(--radius-md);border:1px solid #fee2e2}.error,.warning{padding:14px 18px;margin-top:12px;font-size:14px;font-weight:600;box-shadow:var(--shadow-sm)}.warning{background:#fffbeb;color:var(--warning-dark);border-radius:var(--radius-md);border:1px solid #fde68a}.info{background:#eff6ff;color:#1e3a8a;border-radius:var(--radius-md);border:1px solid #bfdbfe}.info,.success{padding:14px 18px;margin-top:12px;font-size:14px;font-weight:600;box-shadow:var(--shadow-sm)}.success{background:#f0fdf4;color:var(--success-dark);border-radius:var(--radius-md);border:1px solid #d1fae5}.tabs-container{display:flex;gap:6px;margin-bottom:24px;background:var(--bg-secondary);padding:6px;border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch}.dashboard-tabs{align-items:stretch}.dashboard-tabs .tab-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:44px}.dashboard-tabs .tab-badge{margin-left:0}.tab-btn{min-height:var(--control-height);padding:0 20px;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);background:transparent;color:var(--text-secondary);white-space:nowrap;flex-shrink:0;position:relative;letter-spacing:.01em}.tab-btn:after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:3px;background:var(--primary);border-radius:3px 3px 0 0;transition:width .3s ease}.tab-btn.active{background:var(--primary);color:var(--text-inverse);box-shadow:var(--shadow-primary)}.tab-btn.active:after{width:0}.tab-btn:not(.active):hover{background:var(--slate-50);color:var(--text-primary)}.tab-btn:not(.active):hover:after{width:60%}.tab-badge{margin-left:6px;min-width:20px;height:20px;border-radius:999px;padding:0 6px;font-size:11px;font-weight:700;line-height:20px;text-align:center;background:var(--slate-200);color:var(--slate-800)}.tab-btn.active .tab-badge{background:hsla(0,0%,100%,.24);color:#fff}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:10px;gap:10px;margin-bottom:10px}.kpi-card{background:linear-gradient(180deg,#101a2c,#0f192a);border:1px solid #2a3b59;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:10px 14px;min-height:84px}.kpi-action{text-align:left;cursor:pointer;transition:all .2s ease,border-color .2s ease}.kpi-action:hover{transform:translateY(-1px) scale(1.01);border-color:#3d5682;box-shadow:0 8px 20px rgba(8,15,30,.45)}.section-context{font-size:13px;color:var(--text-secondary);margin:4px 2px 14px}.kpi-card.calm .kpi-value{color:#dde6f8}.kpi-card.attention{border-color:rgba(246,183,60,.45);background:linear-gradient(180deg,rgba(246,183,60,.08),#111a2c)}.kpi-card.attention .kpi-value{color:#ffd694}.kpi-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-weight:700}.kpi-value{margin-top:6px;font-size:34px;line-height:1.1;font-weight:800;color:#dde6f8;letter-spacing:-.8px}.kpi-strip{display:flex;align-items:center;justify-content:space-between;background:rgba(16,26,44,.6);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 12px;margin-bottom:16px}.kpi-strip-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:700}.kpi-strip-value{border:none;background:transparent;color:#d2def8;font-weight:700;font-size:14px;cursor:pointer;padding:0}.kpi-strip-value:hover{color:var(--primary-light);text-decoration:underline}.status-badge{display:inline-block;padding:6px 14px;border-radius:var(--radius-full);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid transparent;box-shadow:var(--shadow-sm)}.status-badge.success{background:#d1fae5;color:#065f46;border-color:#a7f3d0}.status-badge.warning{background:#fef3c7;color:#92400e;border-color:#fde68a}.status-badge.info{background:#dbeafe;color:#1e40af;border-color:#93c5fd}.status-badge.danger{background:#fee2e2;color:#991b1b;border-color:#fca5a5}.loading-spinner{display:inline-block;width:20px;height:20px;border-radius:50%;border:3px solid hsla(0,0%,100%,.3);border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-text{display:flex;align-items:center;justify-content:center;gap:12px;padding:40px;font-size:15px}.empty-state,.loading-text{color:var(--text-secondary)}.empty-state{text-align:center;padding:40px 20px}.empty-state p{font-size:15px;margin-top:8px}.undo-banner{margin-top:14px;background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a;border-radius:var(--radius-md);padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px}.undo-banner-text{font-size:14px;line-height:1.4}.filter-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px}.filter-toolbar input{padding:10px 12px;border:1px solid var(--border-dark);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:13px}.table-controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.table-controls input,.table-controls select{min-height:var(--control-height);padding:0 12px;border:1.5px solid var(--border-dark);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;box-shadow:var(--shadow-sm)}.table-controls .control-grow{flex:1 1;min-width:240px}.table-controls .control-fixed{min-width:170px}.table-controls .btn{min-height:var(--control-height);width:auto}.payment-toolbar{margin-bottom:12px}.payment-toolbar-controls{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}.payment-toolbar-controls .control-grow{min-width:260px}.payment-toolbar-controls .control-fixed{min-width:150px}.payment-toolbar-meta{margin:6px 2px 0}.approval-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.legend-chip{display:inline-flex;align-items:center;border:1px solid var(--border);background:var(--slate-50);color:var(--text-secondary);border-radius:var(--radius-full);padding:6px 10px;font-size:12px;line-height:1.3}.approval-cell{display:flex;flex-direction:column;gap:4px}.approval-helper{font-size:11px;color:var(--text-tertiary);line-height:1.3}.skeleton-stack{display:grid;grid-gap:10px;gap:10px}.skeleton-box{border-radius:var(--radius-md);background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9 37%,#e2e8f0 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite}@keyframes shimmer{0%{background-position:100% 0}to{background-position:0 0}}.desktop-time-table{display:block}.mobile-time-cards{display:none}.time-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);padding:12px;margin-top:10px;box-shadow:var(--shadow-sm)}.time-card-row{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding:7px 0;border-bottom:1px dashed var(--border)}.time-card-row:last-child{border-bottom:none}.time-card-label{font-size:12px;color:var(--text-secondary);font-weight:700;min-width:92px}.time-card-value{font-size:13px;color:var(--text-primary);text-align:right;word-break:break-word}.rates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:14px;gap:14px;margin-bottom:16px}.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.sortable:hover{color:var(--primary-dark)}.bulk-action-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;font-size:13px;color:var(--text-secondary)}.bulk-action-buttons{display:flex;gap:8px;flex-wrap:wrap}.operations-toolbar{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:14px}.operations-title{font-size:16px;font-weight:700;color:var(--slate-900)}.operations-subtitle{font-size:13px;color:var(--text-secondary)}.operations-date-picker{display:flex;flex-direction:column;gap:6px}.operations-filters{display:flex;gap:10px;align-items:flex-end}.operations-date-picker label{font-size:12px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.4px}.operations-date-picker input{border:1px solid var(--border-dark);border-radius:var(--radius-md);background:var(--bg-secondary);padding:8px 10px;font-size:13px;color:var(--text-primary)}.operations-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));grid-gap:10px;gap:10px;margin-bottom:12px}.operations-summary-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.ops-chip{display:inline-flex;align-items:center;justify-content:center;min-height:var(--chip-height);gap:6px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);border-radius:var(--radius-full);padding:0 var(--chip-padding-x);font-size:12px;font-weight:700;line-height:1.1;text-transform:uppercase;letter-spacing:.35px;white-space:nowrap;box-shadow:var(--shadow-sm)}.ops-chip.success{border-color:#a7f3d0;background:#ecfdf5;color:#065f46}.ops-chip.info{border-color:#93c5fd;background:#eff6ff;color:#1e3a8a}.ops-chip.muted{border-color:var(--border-dark);background:var(--slate-50);color:var(--text-secondary)}.ops-chip.danger{border-color:#fecaca;background:#fef2f2;color:#991b1b}.fleet-subtabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.fleet-subtab-active{background:linear-gradient(135deg,#6d8cff,#8ba3ff)!important;border-color:#6d8cff!important;color:#fff!important}.fleet-vehicle-list{display:grid;grid-gap:8px;gap:8px;max-height:380px;overflow-y:auto;padding-right:4px}.fleet-vehicle-item{border:1px solid var(--border-dark);background:var(--bg-secondary);border-radius:var(--radius-md);padding:10px 12px;display:grid;grid-gap:4px;gap:4px;text-align:left;color:var(--text-primary);cursor:pointer}.fleet-vehicle-item.selected{border-color:#6d8cff;box-shadow:0 0 0 1px rgba(109,140,255,.35)}.field-grid{display:grid;grid-gap:12px;gap:12px}.field-grid.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.ui-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ui-actions.tight{gap:8px}.table-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.btn-sm{min-height:34px;padding:0 12px;font-size:13px;border-radius:var(--radius-sm)}.input-compact{min-height:34px!important;font-size:13px}.input-compact.sm{max-width:92px}.input-compact.md{max-width:118px}.input-compact.lg{max-width:170px}.text-muted-sm{color:var(--text-secondary);font-size:13px}.roster-list{display:grid;grid-gap:12px;gap:12px;margin-top:12px}.roster-card{padding:12px 14px}.roster-row{display:grid;grid-template-columns:minmax(190px,1.25fr) 96px 80px 74px minmax(260px,1.35fr) auto;align-items:center;grid-gap:10px;gap:10px}.roster-col{display:grid;grid-gap:4px;gap:4px;min-width:0}.roster-col.identity .text-muted-sm{line-height:1.2}.roster-primary-name{font-size:15px;line-height:1.2}.roster-col.wide{min-width:0}.roster-creds-stack{gap:8px}.roster-cred-row{display:grid;grid-template-columns:74px minmax(0,1fr);align-items:center;grid-gap:8px;gap:8px}.roster-inline-controls{display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-width:0}.roster-label{font-size:11px;letter-spacing:.3px;text-transform:uppercase;color:var(--text-secondary);font-weight:700}.roster-inline-controls strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.roster-actions-row{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.roster-inline-btn{min-width:66px;padding:0 10px}.roster-action-btn{min-width:96px}.operations-summary-card{border:1px solid var(--border);background:var(--bg-secondary);border-radius:var(--radius-md);padding:10px 12px}.operations-summary-card .label{font-size:11px;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px;font-weight:700}.operations-summary-card .value{margin-top:4px;font-size:24px;line-height:1;font-weight:700;color:var(--slate-900)}.operations-summary-card.success{border-color:#a7f3d0;background:#f0fdf4}.operations-summary-card.info{border-color:#93c5fd;background:#eff6ff}.operations-summary-card.danger{border-color:#fecaca;background:#fef2f2}.operations-summary-card.muted{border-color:var(--border-dark);background:var(--slate-50)}.history-row td{background:var(--slate-50)}.driver-history-panel{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-secondary);padding:12px}.driver-history-title{font-size:13px;font-weight:700;color:var(--slate-900)}.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-card{width:min(420px,100%);background:var(--bg-secondary);border-radius:var(--radius);box-shadow:var(--shadow-xl);border:1px solid var(--border);padding:20px}.modal-card h3{margin-bottom:10px;font-size:20px}.modal-card p{color:var(--text-secondary);margin-bottom:18px}.modal-actions{gap:10px}.history-filter-row,.modal-actions{display:flex;justify-content:flex-end}.history-filter-row{margin-bottom:10px}.history-table .history-date-cell{font-size:14px;font-weight:600;color:var(--text-secondary)}.history-table .history-time-cell{font-size:18px;font-weight:700;color:var(--slate-900);letter-spacing:-.2px}@media (max-width:768px){body{background:var(--bg);background-image:radial-gradient(at 0 0,rgba(37,99,235,.03) 0,transparent 50%),radial-gradient(at 100% 100%,rgba(37,99,235,.03) 0,transparent 50%)}.container{padding:12px}.app-header{flex-direction:row;align-items:center;gap:12px;padding:14px 18px}.app-header h1{font-size:20px;flex:1 1}.app-header .user-info{flex-shrink:0;gap:10px}.app-header .welcome-text{font-size:12px;display:none}.role-badge{min-height:24px;font-size:10px;padding:0 8px}.app-header .logout-label{font-size:12px;display:inline-flex}.card{padding:18px 20px;border-radius:var(--radius)}.card,.card h2{margin-bottom:16px}.card h2{font-size:18px;padding-bottom:10px}.btn{min-height:var(--control-height-mobile);padding:0 18px;font-size:15px;width:100%}.btn-icon{width:var(--control-height-mobile);height:var(--control-height-mobile);min-width:var(--control-height-mobile)}.tabs-container{padding:4px;gap:4px}.dashboard-tabs{position:-webkit-sticky;position:sticky;bottom:8px;z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.has-mobile-tabs{padding-bottom:72px}.tab-btn{min-height:var(--control-height-mobile);padding:0 16px;font-size:14px}.tab-badge{min-width:18px;height:18px;line-height:18px;font-size:10px;margin-left:4px}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.kpi-value{font-size:20px}table td,table th{padding:12px 8px;font-size:13px}table th{font-size:11px}input:not([type=checkbox]):not([type=radio]):not([type=color]),select,textarea{min-height:var(--control-height-mobile);font-size:16px}.button-group{flex-direction:column;gap:12px}.button-group .btn{width:100%;min-height:48px}table .btn{padding:8px;font-size:13px;min-height:36px;min-width:36px;width:auto}table .btn svg{width:18px;height:18px}table td>div{flex-direction:column;gap:8px}table td>div>input{width:100%!important}table td{white-space:normal!important;word-break:break-word}.undo-banner{flex-direction:column;align-items:flex-start}.filter-toolbar{flex-direction:column;align-items:stretch}.filter-toolbar input{width:100%}.field-grid.two-col{grid-template-columns:1fr}.bulk-action-row{flex-direction:column;align-items:stretch}.bulk-action-buttons{width:100%}.operations-filters,.operations-toolbar{flex-direction:column;align-items:stretch}.operations-date-picker input{width:100%}.roster-row{grid-template-columns:1fr;align-items:stretch;gap:8px}.roster-inline-controls{flex-wrap:wrap}.roster-actions-row{justify-content:flex-start;flex-wrap:wrap}.history-filter-row{justify-content:stretch}.history-table .history-time-cell{font-size:16px}.approval-helper{font-size:10px}.desktop-time-table{display:none}.mobile-time-cards{display:block;margin-top:10px}.status-badge{font-size:10px;letter-spacing:.3px;padding:5px 10px;white-space:normal;text-align:center}.approval-cell{align-items:flex-start}.approval-legend{flex-direction:column}.legend-chip{border-radius:var(--radius-md)}.section-context{font-size:12px;margin-bottom:10px}}@media (max-width:480px){.container{padding:8px}.app-header{padding:12px 16px}.app-header h1{font-size:18px}.card{padding:16px}.card h2{font-size:16px;margin-bottom:14px}.kpi-grid{grid-template-columns:1fr}.btn-icon{width:40px;height:40px;min-width:40px}table td,table th{padding:10px 6px;font-size:12px}table{min-width:500px}}.ant-form-item-label>label,.ant-input,.ant-input-password input,.ant-select-item,.ant-select-selection-item,.ant-typography{color:var(--text-primary)!important}.error{background:rgba(255,107,114,.14);color:#ffc0c4;border:1px solid rgba(255,107,114,.4)}.warning{background:rgba(246,183,60,.14);color:#ffd98c;border:1px solid rgba(246,183,60,.4)}.info{background:rgba(124,156,255,.14);color:#c8d8ff;border:1px solid rgba(124,156,255,.42)}.success{background:rgba(47,208,140,.14);color:#9ef1c8;border:1px solid rgba(47,208,140,.42)}body,html{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,:after,:before{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[data-original-title],abbr[title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=number],input[type=password],input[type=text],textarea{-webkit-appearance:none}dl,ol,ul{margin-top:0;margin-bottom:1em}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}code,kbd,pre,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}[role=button],a,area,button,input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}button,input,optgroup,select,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{padding:0;border-style:none}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=date],input[type=datetime-local],input[type=month],input[type=time]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}