:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: rgba(15, 23, 42, .8);--bg-elevated: rgba(255, 255, 255, .03);--border-color: rgba(255, 255, 255, .1);--border-accent: rgba(6, 182, 212, .3);--text-primary: #f8fafc;--text-secondary: rgba(255, 255, 255, .6);--text-muted: rgba(255, 255, 255, .4);--accent: #06b6d4;--accent-dim: rgba(6, 182, 212, .15);--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--info: #3b82f6;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .3);--header-height: auto;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--touch-min: 44px;--bg-gradient: radial-gradient(circle at 50% 0%, #083344, #0f172a 70%);--header-bg: radial-gradient(circle at top, #083344, transparent)}.light-theme{--bg-primary: #f8fafc;--bg-secondary: #e2e8f0;--bg-card: rgba(255, 255, 255, .95);--bg-elevated: rgba(0, 0, 0, .03);--border-color: rgba(15, 23, 42, .08);--border-accent: rgba(8, 145, 178, .2);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--accent: #0891b2;--accent-dim: rgba(8, 145, 178, .08);--bg-gradient: radial-gradient(circle at 50% 0%, #cffafe, #f8fafc 70%);--header-bg: radial-gradient(circle at top, #cffafe, transparent);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .05)}.light-theme input,.light-theme select,.light-theme textarea{background:#00000008}.light-theme select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%230891b2' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E")}.light-theme .nav-btn{background:#00000008;border:1px solid rgba(0,0,0,.08);color:#0f172a}.light-theme .nav-btn.active{background:#0f172a;color:#fff}.light-theme .status-ot{background:#dbeafe;color:#1e40af}.light-theme .status-off{background:#fee2e2;color:#b91c1c}.light-theme .status-pending{background:#fef3c7;color:#b45309}.light-theme .status-incomplete{background:#f1f5f9;color:#475569}.light-theme .status-missing{background:#e2e8f0;color:#475569}.light-theme .status-comp{background:#fef3c7;color:#b45309}.light-theme .status-normal{background:#d1fae5;color:#047857}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-text-size-adjust:100%}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;min-height:-webkit-fill-available;overflow-x:hidden;-webkit-overflow-scrolling:touch;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;min-height:-webkit-fill-available;display:flex;flex-direction:column}@media(min-width:900px){html{scroll-behavior:smooth}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#0891b2}::-webkit-scrollbar-track{background:transparent}*{scrollbar-width:thin;scrollbar-color:var(--accent) transparent}h1,h2,h3{font-weight:800}h4,h5,h6{font-weight:700}small{font-size:.75rem}button{cursor:pointer;font-family:inherit;border:none;outline:none;transition:all .2s ease;-webkit-touch-callout:none}button:active{transform:scale(.97)}button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}@media(max-width:480px){button,.nav-btn,[role=button],select,input[type=date],input[type=month],input[type=time]{min-height:var(--touch-min)}.btn-sm{padding:10px 16px!important;font-size:.7rem!important}}.btn-primary{padding:16px 24px;border-radius:var(--radius-md);font-weight:800;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:#fff;width:100%}.btn-primary.green{background:var(--success)}.btn-primary.red{background:var(--danger)}.btn-primary.cyan{background:var(--accent)}.btn-primary.slate{background:var(--bg-secondary)}.btn-sm{padding:8px 14px;border-radius:var(--radius-sm);font-weight:700;font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:#fff;white-space:nowrap}input,select,textarea{width:100%;padding:14px 16px;background:#0000004d;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;font-family:inherit;outline:none;transition:border-color .2s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}@media(max-width:480px){input,select,textarea{font-size:16px!important}}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2306b6d4' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}label{display:block;font-size:.65rem;color:var(--accent);font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.card{background:var(--bg-card);border-radius:var(--radius-xl);padding:24px;border:1px solid var(--border-color);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@media(max-width:480px){.card{padding:16px;border-radius:var(--radius-lg)}}@media(min-width:1200px){.card{padding:28px 32px}}.card-accent{background:var(--accent-dim);border:1px solid var(--border-accent);border-radius:var(--radius-lg);padding:20px}@media(max-width:480px){.card-accent{padding:14px;border-radius:var(--radius-md)}}.status-pill{padding:4px 10px;border-radius:6px;font-size:.6rem;font-weight:800;text-transform:uppercase;display:inline-block;letter-spacing:.5px;white-space:nowrap}.status-ot{background:#1e3a8a;color:#fff}.status-off{background:#ef444433;color:var(--danger)}.status-pending{background:#f59e0b33;color:var(--warning)}.status-incomplete{background:#ffffff1a;color:var(--text-secondary)}.status-missing{background:#6b728033;color:#9ca3af}.status-comp{background:#f59e0b26;color:#f59e0b}.status-normal{background:#10b98126;color:var(--success)}.loader{width:18px;height:18px;border:2px solid var(--text-primary);border-bottom-color:transparent;border-radius:50%;display:inline-block;animation:rotation 1s linear infinite}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.toast{visibility:hidden;position:fixed;top:20px;left:50%;transform:translate(-50%);background:var(--success);color:#fff;padding:12px 24px;border-radius:var(--radius-md);font-weight:800;font-size:.85rem;z-index:9999;opacity:0;transition:opacity .3s,transform .3s;text-align:center;max-width:calc(100vw - 40px);width:auto;box-shadow:var(--shadow);pointer-events:none}.toast.show{visibility:visible;opacity:1;transform:translate(-50%) translateY(0)}.toast.error{background:var(--danger)}@media(max-width:480px){.toast{top:12px;padding:10px 18px;font-size:.8rem;max-width:calc(100vw - 24px);width:auto;border-radius:var(--radius-sm)}}.loading-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#020617d9;z-index:9998;justify-content:center;align-items:center;flex-direction:column;gap:16px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.loading-overlay.show{display:flex}.loading-overlay span{font-size:.8rem;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:2px}.stat-card{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:18px;text-align:center;border:1px solid rgba(255,255,255,.06);transition:transform .2s}.stat-card:hover{transform:translateY(-2px)}.stat-card .num{font-size:2rem;font-weight:800}.stat-card .lbl{font-size:.6rem;text-transform:uppercase;letter-spacing:2px;color:var(--accent);font-weight:700;margin-top:4px}@media(max-width:480px){.stat-card{padding:14px 10px}.stat-card .num{font-size:1.6rem}}.stat-card.compact{padding:12px 8px;border-radius:var(--radius-md)}.stat-card.compact .num{font-size:1.4rem}.stat-card.compact .lbl{font-size:.5rem;margin-top:2px;letter-spacing:1.5px}@media(max-width:480px){.stat-card.compact{padding:10px 6px}.stat-card.compact .num{font-size:1.2rem}}.dashboard-stats{gap:8px}@media(max-width:480px){.dashboard-stats{gap:6px}}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:1000;justify-content:center;align-items:flex-start;padding:40px 16px;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-overlay.show{display:flex}.modal-body{background:var(--bg-primary);width:100%;max-width:420px;padding:28px 24px;border-radius:var(--radius-xl);border:1px solid var(--accent);margin:auto;animation:modalIn .25s ease}@media(max-width:480px){.modal-body{padding:24px 18px;border-radius:var(--radius-lg);max-width:100%}.modal-overlay{align-items:center;padding:16px}}@keyframes modalIn{0%{transform:translateY(24px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.container{width:94%;max-width:680px;margin:0 auto;padding-bottom:48px}@media(min-width:900px){.container{max-width:780px;padding-bottom:60px}}@media(min-width:1200px){.container{max-width:900px;padding-bottom:80px}}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}@media(max-width:480px){.grid-2{grid-template-columns:1fr}.grid-3{grid-template-columns:1fr 1fr}}@media(min-width:481px)and (max-width:900px){.grid-3{grid-template-columns:1fr 1fr}}.responsive-table{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity}.responsive-table table{width:100%;border-collapse:separate;border-spacing:0 6px;font-size:.8rem;min-width:max-content}@media(min-width:900px){.responsive-table{scrollbar-width:thin}.responsive-table::-webkit-scrollbar{height:4px}}.dashboard-table-card{overflow:visible;padding:clamp(8px,1.5vw,20px)}.dashboard-table{width:100%}.dashboard-table table{font-size:.75rem}@media(max-width:480px){.dashboard-table-card{padding:6px!important;border-radius:var(--radius-md)!important}.dashboard-table table{font-size:.65rem}.th-hrs,.th-ot{font-size:.48rem;padding:0 4px 4px}.td-hrs,.td-ot{font-size:.6rem;padding:6px 4px}}@media(min-width:481px)and (max-width:900px){.dashboard-table table{font-size:.7rem}}.th-date,.th-shift,.th-hrs,.th-ot,.th-status{color:#06b6d4;font-size:.55rem;text-align:left;padding:0 6px 6px;text-transform:uppercase;font-weight:800;white-space:nowrap}.th-hrs,.th-ot{text-align:center}.th-status{text-align:right}.td-date{padding:8px 6px;background:#ffffff05;border-radius:8px 0 0 8px;font-weight:600;font-size:.7rem;white-space:nowrap}.td-shift{padding:8px 6px;background:#ffffff05;font-size:.65rem}.td-hrs{padding:8px 6px;background:#ffffff05;text-align:center;font-weight:700;font-size:.7rem;white-space:nowrap;font-variant-numeric:tabular-nums}.td-ot{padding:8px 6px;background:#ffffff05;text-align:center;font-weight:700;font-size:.7rem;white-space:nowrap}.td-status{padding:8px 6px;background:#ffffff05;border-radius:0 8px 8px 0;text-align:right;white-space:nowrap}.split-badge{margin-left:3px;font-size:.5rem;color:#a78bfa}.shift-text{opacity:.7;white-space:nowrap;font-size:inherit}.mgr-actions{display:inline-flex;gap:4px;margin-left:6px;flex-wrap:nowrap;align-items:center}.mgr-btn{border:none;border-radius:6px;font-size:.55rem;padding:5px 8px;color:#fff;cursor:pointer;font-weight:800;text-transform:uppercase;white-space:nowrap;min-height:28px;min-width:32px;font-family:inherit;transition:opacity .2s;display:inline-flex;align-items:center;justify-content:center}.mgr-btn.approve{background:#10b981}.mgr-btn.reject{background:#6b7280}.mgr-btn.fix{background:#06b6d4}.mgr-btn.delete{background:#ef4444;opacity:.7}.mgr-btn:active{transform:scale(.93)}@media(max-width:480px){.mgr-btn{font-size:.5rem;padding:4px 7px;min-height:26px;min-width:28px}.mgr-actions{gap:3px;margin-left:4px}}.admin-staff-row{border-bottom:1px solid rgba(255,255,255,.05)}.admin-staff-info{padding:10px 0}.admin-staff-name{font-weight:700;font-size:clamp(.7rem,1.5vw,.8rem)}.admin-staff-detail{opacity:.5;font-size:clamp(.55rem,1.2vw,.65rem)}.admin-staff-actions{text-align:right;white-space:nowrap;padding:10px 0}.admin-staff-actions .btn-sm{min-height:var(--touch-min)}@media(max-width:480px){.admin-staff-row td{padding:6px 0!important}.admin-staff-info{padding:6px 0}.admin-staff-name{font-size:clamp(.6rem,1.2vw,.7rem)}.admin-staff-detail{font-size:clamp(.5rem,1vw,.55rem)}.admin-staff-actions{padding:6px 0}.admin-staff-actions .btn-sm{padding:4px 8px!important;font-size:.55rem!important;min-height:32px!important}}.admin-on-duty-card{background:#ffffff08;padding:clamp(10px,2vw,14px);border-radius:12px;font-size:clamp(.6rem,1.4vw,.7rem);min-height:var(--touch-min)}.admin-on-duty-name{font-weight:800;font-size:clamp(.65rem,1.5vw,.75rem)}.admin-on-duty-since{opacity:.6;margin-top:2px}.admin-section-inner{padding:clamp(14px,2.5vw,20px)}@media(max-width:480px){.admin-section-inner{padding:12px}.admin-on-duty-card{padding:8px 10px;font-size:clamp(.5rem,1.2vw,.6rem);min-height:36px}.admin-on-duty-name{font-size:clamp(.55rem,1.2vw,.65rem)}.admin-on-duty-since{font-size:clamp(.45rem,1vw,.55rem)}}.admin-audit-box{max-height:260px;overflow-y:auto;background:#0003;border-radius:10px;padding:8px;font-size:clamp(.55rem,1.3vw,.65rem);-webkit-overflow-scrolling:touch}.admin-audit-entry{padding:6px 8px;border-bottom:1px solid rgba(255,255,255,.04);display:grid;grid-template-columns:minmax(50px,60px) 1fr;gap:6px}.admin-audit-entry:last-child{border-bottom:none}.admin-audit-time{color:#06b6d4;font-weight:600;opacity:.7;font-size:clamp(.5rem,1.2vw,.6rem)}.admin-audit-action{font-weight:600;font-size:clamp(.55rem,1.3vw,.65rem)}.admin-audit-detail{color:#ffffff80;grid-column:2;font-size:clamp(.5rem,1.2vw,.6rem);word-break:break-word}@media(max-width:480px){.admin-audit-entry{padding:4px 6px;gap:4px}.admin-audit-time{font-size:clamp(.45rem,1vw,.5rem)}.admin-audit-action{font-size:clamp(.5rem,1.1vw,.55rem)}.admin-audit-detail{font-size:clamp(.45rem,1vw,.5rem)}.admin-audit-box{padding:6px;max-height:200px}}.admin-pin-layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(8px,2vw,12px);align-items:end}.admin-pin-layout button{grid-column:1 / -1}.admin-pin-title{font-size:clamp(.6rem,1.5vw,.7rem);color:#06b6d4;font-weight:700;margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}@media(max-width:480px){.admin-pin-title{font-size:clamp(.5rem,1.2vw,.6rem);margin-bottom:8px}.admin-pin-layout{gap:6px}.admin-pin-layout input{padding:12px 14px}}.terminal-card{animation:fadeIn .3s ease}.terminal-staff-card{margin-top:12px;padding:clamp(12px,2vw,16px);background:var(--accent-dim);border:1px solid var(--border-accent);border-radius:var(--radius-lg);animation:slideUp .25s ease}.terminal-staff-name{font-size:clamp(.85rem,2vw,1rem);font-weight:800;color:var(--accent)}.terminal-staff-meta{display:flex;gap:clamp(8px,2vw,16px);margin-top:8px;flex-wrap:wrap;font-size:clamp(.6rem,1.3vw,.7rem)}.terminal-staff-meta-item{display:flex;align-items:center;gap:4px;opacity:.7}.terminal-staff-meta-item span{font-weight:700;color:#f8fafc}.terminal-status-badge{margin-top:10px;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:30px;font-size:clamp(.55rem,1.3vw,.65rem);font-weight:800;text-transform:uppercase;letter-spacing:.5px}.terminal-status-badge.on-duty{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.terminal-status-badge.off-duty{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.25)}.terminal-status-badge.checked-out{background:#3b82f61f;color:#3b82f6;border:1px solid rgba(59,130,246,.25)}.terminal-quick-dates{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.terminal-quick-date-btn{padding:6px 12px;border-radius:20px;font-size:clamp(.55rem,1.2vw,.65rem);font-weight:700;background:#06b6d41a;border:1px solid rgba(6,182,212,.2);color:var(--accent);cursor:pointer;font-family:inherit;transition:all .2s;min-height:32px}.terminal-quick-date-btn:hover{background:#06b6d433}.terminal-quick-date-btn.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:800}.terminal-punch-btn{padding:clamp(14px,3vw,18px);font-size:clamp(.8rem,2vw,.85rem);min-height:var(--touch-min);border-radius:var(--radius-md);position:relative;overflow:hidden}.terminal-punch-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff1a;opacity:0;transition:opacity .2s}.terminal-punch-btn:active:after{opacity:1}@media(max-width:480px){.terminal-staff-card{padding:10px 12px}.terminal-staff-name{font-size:clamp(.7rem,1.5vw,.8rem)}.terminal-staff-meta{font-size:clamp(.5rem,1.1vw,.6rem);gap:6px}.terminal-status-badge{padding:4px 8px;font-size:clamp(.5rem,1.1vw,.55rem)}.terminal-quick-date-btn{padding:5px 10px;font-size:clamp(.5rem,1vw,.55rem);min-height:28px}.terminal-punch-btn{padding:12px;font-size:clamp(.7rem,1.5vw,.8rem)}}.section-title{color:var(--accent);font-size:.65rem;letter-spacing:2px;text-transform:uppercase;margin:0 0 12px;display:flex;align-items:center;gap:8px}.section-title:after{content:"";flex:1;height:1px;background:#ffffff14}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease}.tab-content{animation:fadeIn .25s ease}.tab-content.swipe-left{animation:swipeLeft .25s ease}.tab-content.swipe-right{animation:swipeRight .25s ease}@keyframes swipeLeft{0%{opacity:.6;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes swipeRight{0%{opacity:.6;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.roster-list{display:flex;flex-direction:column;gap:4px}.roster-empty{opacity:.5;text-align:center;padding:20px;font-size:.75rem}.roster-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;background:#ffffff05;border:1px solid transparent;cursor:pointer;transition:all .2s;min-height:var(--touch-min);flex-wrap:wrap}.roster-row.off{background:#ef444414}.roster-row.set{background:#06b6d40f}.roster-row.today,.roster-row:hover{border-color:var(--accent)}.roster-date{font-weight:600;font-size:clamp(.6rem,1.4vw,.7rem);min-width:0;flex:0 1 auto}.roster-info{font-size:clamp(.55rem,1.3vw,.65rem);opacity:.8;flex:1 1 auto;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.roster-off-label{color:#ef4444;font-weight:700}.roster-time{color:inherit}.roster-split{color:#a78bfa;margin-left:4px;font-size:clamp(.45rem,1.1vw,.55rem)}.roster-unset{opacity:.4}.roster-today{font-size:clamp(.4rem,.9vw,.45rem);color:#06b6d4;font-weight:800;flex-shrink:0}.roster-info-card{margin-bottom:16px;padding:clamp(10px,2vw,16px);background:var(--accent-dim);border:1px solid var(--border-accent);border-radius:var(--radius-lg)}@media(max-width:480px){.roster-info-card{padding:10px 12px;border-radius:var(--radius-md)}}.roster-info-title{font-size:clamp(.55rem,1.3vw,.65rem);color:#06b6d4;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.roster-info-text{font-size:clamp(.55rem,1.3vw,.65rem);opacity:.8;line-height:1.5}.roster-info-text ul{margin-top:4px;padding-left:14px;opacity:.7}.roster-info-text li{margin-bottom:1px}@media(max-width:480px){.roster-row{padding:6px 8px;gap:6px;min-height:36px;border-radius:8px}.roster-date{font-size:.55rem}.roster-info{font-size:.5rem}.roster-split{display:block;margin-left:0;font-size:.45rem}.roster-today{font-size:.4rem}.roster-list{gap:3px}}.tab-bar{display:flex;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:4px 0 8px;scroll-snap-type:x mandatory;justify-content:center;margin-bottom:16px}.tab-bar::-webkit-scrollbar{display:none}.tab-bar>*{scroll-snap-align:start;flex-shrink:0}.nav-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 14px;border-radius:30px;cursor:pointer;font-weight:700;font-size:.75rem;min-height:var(--touch-min);white-space:nowrap;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#f8fafc;transition:all .2s ease;font-family:inherit}.nav-btn.active{background:#fff;color:#000;border-color:transparent}.nav-btn .tab-icon{font-size:.9rem;line-height:1}.nav-btn .tab-label{font-size:.7rem}.nav-btn.auth-btn{padding:8px 12px;font-size:.85rem}.nav-btn.auth-btn.logout{border-color:#ef44444d;background:#ef44441a;color:#ef4444}.nav-btn.auth-btn.login{border-color:#06b6d44d;background:#06b6d41a;color:#06b6d4}@media(max-width:480px){.nav-btn{padding:6px 10px;font-size:.65rem;gap:3px}.nav-btn .tab-icon{font-size:.75rem}.nav-btn .tab-label{font-size:.6rem}.nav-btn.auth-btn{padding:6px 8px;font-size:.7rem}.tab-bar{gap:3px;margin-bottom:12px;padding-bottom:4px}}@media(min-width:900px){.hover-lift{transition:transform .2s,box-shadow .2s}.hover-lift:hover{transform:translateY(-2px);box-shadow:0 6px 12px -2px #0006}}.ptr-indicator{display:flex;align-items:center;justify-content:center;width:100%;overflow:hidden;pointer-events:none}.ptr-content{display:flex;align-items:center;gap:8px;color:var(--accent);font-size:clamp(.6rem,1.3vw,.7rem);font-weight:700;text-transform:uppercase;letter-spacing:1px}.ptr-arrow{font-size:clamp(1rem,2vw,1.2rem);transition:transform .2s;display:inline-block}.ptr-arrow.down{transform:translateY(4px)}.ptr-text{white-space:nowrap}.ptr-spinner{width:18px;height:18px;border:2px solid var(--accent);border-bottom-color:transparent;border-radius:50%;display:inline-block;animation:ptrSpin .8s linear infinite}@keyframes ptrSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.today-summary-card{padding:clamp(14px,2.5vw,18px)}.today-summary-loading{text-align:center;padding:12px;font-size:clamp(.6rem,1.3vw,.7rem);opacity:.5}.today-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(8px,1.5vw,12px)}.today-stat{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-md);padding:clamp(10px,2vw,14px);text-align:center;transition:transform .2s}.today-stat:active{transform:scale(.97)}.today-stat-num{font-size:clamp(1.5rem,4vw,1.8rem);font-weight:800;line-height:1.1}.today-stat-lbl{font-size:clamp(.5rem,1.2vw,.55rem);text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-top:4px}.today-stat-on-duty .today-stat-num,.today-stat-on-duty .today-stat-lbl{color:#10b981}.today-stat-out .today-stat-num,.today-stat-out .today-stat-lbl{color:#3b82f6}.today-stat-absent .today-stat-num,.today-stat-absent .today-stat-lbl{color:#6b7280}@media(max-width:480px){.today-summary-grid{gap:6px}.today-stat{padding:8px 6px}.today-stat-num{font-size:clamp(1.2rem,3vw,1.5rem)}.today-stat-lbl{font-size:clamp(.45rem,1vw,.5rem)}}@supports (padding: env(safe-area-inset-bottom)){.container{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:calc(48px + env(safe-area-inset-bottom))}}@media print{body{background:#fff;color:#000}.card,.card-accent,.stat-card{background:#fff;border:1px solid #ddd;color:#000;-webkit-backdrop-filter:none;backdrop-filter:none}.status-pill{border:1px solid currentColor}}
