:root{--accent: #ffcc00;--accent-hover: #e6b800;--accent-light: rgba(255, 204, 0, .12);--accent-text: #1a1a1a;--bg: #f5f5f5;--bg-card: #ffffff;--bg-input: #f0f0f0;--bg-hover: #e8e8e8;--text: #1a1a1a;--text-secondary: #444444;--text-muted: #666666;--border: #e0e0e0;--success: #22c55e;--error: #ef4444;--warning: #f59e0b;--radius: 10px;--radius-sm: 6px;--shadow: 0 2px 8px rgba(0, 0, 0, .06);--font: "Helvetica Neue", Helvetica, Arial, sans-serif;--header-height: 52px}[data-theme=dark]{--bg: #1a1a1a;--bg-card: #2a2a2a;--bg-input: #333333;--bg-hover: #3a3a3a;--text: #e0e0e0;--text-secondary: #aaaaaa;--text-muted: #777777;--border: #404040;--shadow: 0 2px 8px rgba(0, 0, 0, .3)}[data-theme=dark] html,[data-theme=dark]{background:var(--bg);color:var(--text)}[data-theme=dark] a{color:var(--text)}[data-theme=dark] .bottom-nav{background:#222;border-color:var(--border);box-shadow:0 -4px 12px #0000004d}[data-theme=dark] .avatar-menu{background:#333;border-color:var(--border)}[data-theme=dark] .btn{color:var(--text)}[data-theme=dark] .btn-primary{color:#1a1a1a}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background:var(--bg-input);color:var(--text);border-color:var(--border)}[data-theme=dark] .card-title{color:var(--text-secondary)}[data-theme=dark] .bottom-nav-item{color:var(--text-muted)}[data-theme=dark] .bottom-nav-item.active{color:#fff}[data-theme=dark] .admin-emp-title-pill{background:#9333ea33;color:#c084fc}[data-theme=dark] .emp-type-badge.hourly{background:#3b82f626;color:#93c5fd}[data-theme=dark] .emp-type-badge.salary{background:#22c55e26;color:#86efac}[data-theme=dark] .emp-type-badge.contract{background:#f59e0b26;color:#fcd34d}[data-theme=dark] .emp-type-badge.intern{background:#8b5cf626;color:#c4b5fd}[data-theme=dark] .te-period-status,[data-theme=dark] .te-entry-badge{opacity:.9}[data-theme=dark] .sched-emp-pill{color:var(--text-muted)}[data-theme=dark] .sched-today-col{background:#ffffff0f!important}[data-theme=dark] .sched-name-col,[data-theme=dark] .sched-grid th{background:var(--bg-card)}[data-theme=dark] .cal-cell.cal-scheduled{background:#1e293b}[data-theme=dark] .swatch-scheduled{background:#1e293b;border-color:#334155}[data-theme=dark] .swatch-logged{background:#14532d;border-color:#166534}[data-theme=dark] .schedule-editor{background:var(--bg-card)}[data-theme=dark] .schedule-day-chip{background:var(--bg-input);color:var(--text);border-color:var(--border)}[data-theme=dark] .schedule-day-chip.active{background:var(--accent);color:#1a1a1a}[data-theme=dark] .sched-toggle-btn{background:var(--bg-card);color:var(--text-secondary)}[data-theme=dark] .sched-toggle-btn.active{background:var(--accent);color:#1a1a1a}[data-theme=dark] .sched-grid td{border-color:var(--border)}[data-theme=dark] .sched-grid th{border-color:var(--border);color:var(--text-muted)}[data-theme=dark] .cal-cell{background:var(--bg-card);border-color:var(--border)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font);font-size:1rem;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text);background:var(--bg)}body{min-height:100dvh}a{color:var(--accent-text);text-decoration:none}.app-shell{display:flex;flex-direction:column;min-height:100dvh;max-width:960px;margin:0 auto;background:var(--bg)}.app-header{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 1.5rem;background:#000;position:sticky;top:0;z-index:100}.header-col{flex:1}.header-left{display:flex;align-items:center}.header-center{text-align:center}.header-right{display:flex;align-items:center;justify-content:flex-end;gap:.75rem}.header-logo{height:32px;width:auto;filter:brightness(0) invert(1)}.header-app-name{font-size:1.125rem;font-weight:400;color:#fff;margin:0;letter-spacing:0}.theme-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer}.theme-toggle-icon{font-size:.875rem;color:#fff;line-height:1}.theme-toggle-track{width:32px;height:18px;border-radius:100px;background:#ffffff26;position:relative}.theme-toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fc0;transition:left .2s ease}.theme-toggle-thumb.dark{left:16px}.avatar-group{display:flex;align-items:center;gap:.5rem;padding-left:.75rem;border-left:1px solid rgba(255,255,255,.1);position:relative}.avatar-btn{width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:transparent;cursor:pointer;padding:0;overflow:hidden;display:flex;align-items:center;justify-content:center}.avatar-btn:hover{border-color:#fff6}.avatar-img{width:100%;height:100%;object-fit:cover}.avatar-initials-btn{background:#ffffff26;font-size:.875rem;font-weight:500;color:#ffffffb3;font-family:inherit}.avatar-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px #00000026;min-width:120px;overflow:hidden;animation:fadeIn .15s ease}.avatar-menu-item{display:block;width:100%;padding:.6rem 1rem;background:none;border:none;font-size:.85rem;color:var(--text);cursor:pointer;text-align:left;font-family:inherit}.avatar-menu-item:hover{background:var(--bg-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app-main{flex:1;padding:32px 16px 80px}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:960px;display:flex;background:var(--bg-card);border-top:2px solid var(--border);box-shadow:0 -4px 12px #0000000f;padding:6px 0;padding-bottom:env(safe-area-inset-bottom,6px);z-index:100}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 0;font-size:.875rem;color:var(--text-muted);text-decoration:none;transition:color .15s}.bottom-nav-item.active{color:var(--accent-text);font-weight:600}.bottom-nav-item.active .bottom-nav-icon{fill:var(--accent)}.bottom-nav-icon{width:22px;height:22px;fill:var(--text-muted);transition:fill .15s}.sidebar-brand{display:none}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.card+.card{margin-top:12px}.card-title{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-text)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-input);color:var(--text)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-danger{background:var(--error);color:#fff}.btn-ghost{background:none;color:var(--text-secondary);padding:6px 10px}.btn-ghost:hover:not(:disabled){background:var(--bg-input)}.btn-full{width:100%}.btn-sm{padding:6px 10px;font-size:.75rem}.input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:1rem;background:var(--bg-input);color:var(--text);outline:none;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:4px}.input-row{display:flex;gap:10px}.input-row>*{flex:1}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.login-card{width:100%;max-width:360px;text-align:center}.login-logo{font-size:1.25rem;font-weight:700;letter-spacing:3px;color:var(--accent);margin-bottom:4px}.login-title{font-size:1.375rem;font-weight:300;margin-bottom:32px;color:var(--text)}.login-form{text-align:left}.login-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.login-form .input{margin-bottom:16px}.login-error{font-size:.875rem;color:var(--error);margin-bottom:12px}.login-sent{padding:24px 0}.login-sent-icon{font-size:2.5rem;margin-bottom:12px}.loading-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center}.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.quick-entry .input-row{margin-bottom:12px}.hours-preview{text-align:center;padding:8px;background:var(--accent-light);border-radius:var(--radius-sm);margin-bottom:12px;font-size:.875rem}.hours-preview strong{font-size:1.125rem;color:var(--accent-text)}.hours-preview .lunch-note{color:var(--text-secondary);font-size:.75rem}.timesheet-grid{list-style:none}.day-row{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);gap:8px}.day-row:last-child{border-bottom:none}.day-row.is-today{background:var(--accent-light);margin:0 -16px;padding:10px 16px;border-radius:var(--radius-sm)}.day-row.is-weekend{opacity:.5}.day-label{width:70px;font-size:.875rem;font-weight:500;flex-shrink:0}.day-times{flex:1;font-size:.875rem;color:var(--text-secondary)}.day-hours{font-size:.875rem;font-weight:600;width:45px;text-align:right;flex-shrink:0}.day-action{width:50px;flex-shrink:0;text-align:right}.period-summary{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-top:2px solid var(--text);margin-top:8px}.period-total-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.period-total-hours{font-size:1.25rem;font-weight:700}.period-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.period-range{font-size:1rem;font-weight:600}.period-status{font-size:.75rem;font-weight:600;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.period-status.open{background:var(--accent-light);color:var(--accent-text)}.period-status.closed{background:var(--bg-input);color:var(--text-muted)}.pagination{display:flex;justify-content:space-between;align-items:center;padding:12px 0 4px;border-top:1px solid var(--border);margin-top:8px}.btn-page{background:none;border:none;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;padding:6px 12px;border-radius:6px}.btn-page:hover:not(:disabled){background:var(--bg-hover)}.btn-page:disabled{color:var(--text-muted);cursor:default}.page-info{font-size:.875rem;color:var(--text-muted)}.btn-back{background:none;border:none;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;padding:4px 0}.btn-back:hover{color:var(--text)}.history-list{list-style:none}.history-item{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--border);cursor:pointer}.history-item:last-child{border-bottom:none}.history-range{font-size:.875rem;font-weight:500}.history-meta{display:flex;align-items:center;gap:8px}.history-hours{font-size:.875rem;font-weight:600}.profile-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}.profile-row:last-child{border-bottom:none}.profile-label{font-size:.875rem;color:var(--text-secondary)}.profile-value{font-size:.875rem;font-weight:500}.admin-tabs{display:flex;gap:0;margin-bottom:16px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.admin-tab{flex:1;padding:10px 0;border:none;background:var(--bg-card);font-family:var(--font);font-size:.875rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.admin-tab+.admin-tab{border-left:1px solid var(--border)}.admin-tab.active{background:var(--accent);color:var(--accent-text)}.admin-kpis{display:flex;gap:8px}.admin-kpi{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;text-align:center}.admin-kpi-value{font-size:1.375rem;font-weight:700}.admin-kpi-label{font-size:.875rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.admin-kpi.kpi-alert{background:#fef3c7;border-color:#f59e0b}.admin-kpi.kpi-alert .admin-kpi-value,.admin-kpi.kpi-alert .admin-kpi-label{color:#92400e}.admin-emp-row{border-bottom:1px solid var(--border)}.admin-emp-row:last-child{border-bottom:none}.admin-emp-row-main{display:flex;justify-content:space-between;align-items:center;padding:12px 0;cursor:pointer}.admin-emp-name{font-size:.875rem;font-weight:600}.admin-emp-title-pill{display:inline-block;font-size:.875rem;font-weight:600;color:#6b21a8;background:#f3e8ff;padding:2px 10px;border-radius:20px;margin-left:6px;vertical-align:middle}.admin-emp-meta{font-size:.75rem;color:var(--text);margin-top:2px}.admin-emp-status{font-size:.875rem;font-weight:600;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.admin-emp-status.active{background:#dcfce7;color:#166534}.admin-emp-status.inactive{background:#fee2e2;color:#991b1b}.admin-emp-detail{padding:0 0 12px}.admin-period-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:.875rem}.admin-period-row:last-child{border-bottom:none}.admin-period-row.is-closed{opacity:.45}.admin-period-row.is-closed:hover{opacity:.7}.admin-period-row.is-closed span[style]{color:var(--text-muted)!important}.admin-employee-card{margin-bottom:12px}.admin-employee-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.admin-employee-name{font-size:1rem;font-weight:600}.admin-employee-hours{font-size:.875rem;color:var(--text-secondary)}.admin-actions{display:flex;gap:8px;margin-top:12px}.year-filter{display:flex;gap:6px;margin:12px 0;flex-wrap:wrap}.year-btn{padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:var(--bg-card);font-family:var(--font);font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s}.year-btn:hover{background:var(--bg-hover)}.year-btn.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.timesheet-table{width:100%;border-collapse:collapse;font-size:.75rem;white-space:nowrap}.timesheet-table th,.timesheet-table td{padding:8px 6px;text-align:center;border-bottom:1px solid var(--border)}.timesheet-table th{font-size:.875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;position:sticky;top:0;background:var(--bg-card);z-index:1}.timesheet-table tbody tr:last-child td{border-bottom:none}.sticky-col{position:sticky;left:0;background:var(--bg-card);z-index:2;text-align:left!important;min-width:110px;border-right:1px solid var(--border)}.table-emp-name{font-size:.875rem;font-weight:600;line-height:1.2}.table-emp-rate{font-size:.875rem;color:var(--text-muted)}.has-hours{background:var(--accent-light)}.cell-hours{display:flex;flex-direction:column;align-items:center;gap:1px}.cell-net{font-weight:600;font-size:.875rem}.cell-break,.cell-times{font-size:.75rem;color:var(--text-muted)}.cell-empty{color:var(--text-muted);font-size:.875rem}.cell-add-hint{opacity:0;transition:opacity .15s;font-size:.875rem;font-weight:500}.cell-clickable:hover .cell-add-hint{opacity:.5}.cell-total{font-weight:700;font-size:.875rem;background:var(--bg-input)}.cell-clickable{cursor:pointer}.cell-clickable:hover{background:#ffcc0040}.te-th-sel{background:#ffcc0026}.te-td-sel{background:#ffcc001a;outline:2px solid var(--accent);outline-offset:-2px}.cell-holiday{position:relative;opacity:.5}.cell-holiday-dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:#e53e3e;margin-left:3px;vertical-align:middle}.period-stats{display:flex;gap:10px;margin-top:4px}.period-stat{font-size:.75rem;color:var(--text-muted)}.period-stat strong{color:var(--text-secondary);font-weight:600}.admin-status-banner{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.status-item{font-size:.875rem;color:var(--text-secondary);padding:8px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.status-item strong{font-weight:700;color:var(--text)}.status-item.status-alert{background:#fef3c7;border-color:#f59e0b;color:#92400e}.status-item.status-alert strong{color:#92400e}.toast-container{position:fixed;top:60px;left:50%;transform:translate(-50%);max-width:440px;width:calc(100% - 32px);z-index:200}.toast{padding:12px 16px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;animation:slideDown .2s ease;margin-bottom:8px}.toast.success{background:#dcfce7;color:#166534}.toast.error{background:#fee2e2;color:#991b1b}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.edit-form{background:var(--accent-light);padding:12px;border-radius:var(--radius-sm);margin:8px 0}.edit-form .input-row{margin-bottom:8px}.edit-actions{display:flex;gap:8px;justify-content:flex-end}.emp-summary{display:flex;gap:8px;margin-bottom:16px}.emp-summary-item{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 8px;text-align:center}.emp-summary-value{display:block;font-size:1.25rem;font-weight:700}.emp-summary-label{display:block;font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-top:2px}.cal-grid{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow)}.cal-dow-row{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}.cal-dow{text-align:center;font-size:.875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;padding:4px 0}.cal-cells{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-cell{aspect-ratio:1;border-radius:var(--radius-sm);padding:4px;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:background .15s,box-shadow .15s;border:2px solid transparent;position:relative;min-height:52px}.cal-cell:hover{background:var(--bg-hover)}.cal-cell.cal-empty{cursor:default;background:none}.cal-cell.cal-empty:hover{background:none}.cal-date{font-size:.875rem;font-weight:600;line-height:1}.cal-cell.cal-weekend{opacity:.4}.cal-cell.cal-weekend .cal-date{font-weight:400}.cal-cell.cal-today{border-color:var(--accent);background:var(--accent-light)}.cal-cell.cal-scheduled{background:#f0f7ff}.cal-cell.cal-logged{background:#dcfce7}.cal-cell.cal-selected{border-color:var(--text);box-shadow:0 0 0 1px var(--text)}.cal-entry-info{display:flex;flex-direction:column;align-items:center;margin-top:2px}.cal-hours{font-size:.75rem;font-weight:700;color:#166534;line-height:1.2}.cal-times{font-size:.75rem;color:var(--text-muted);line-height:1.2}.cal-scheduled-dot{width:6px;height:6px;border-radius:50%;background:#93c5fd;margin-top:4px}.cal-legend{display:flex;gap:16px;justify-content:center;margin-top:10px;margin-bottom:16px}.cal-legend-item{display:flex;align-items:center;gap:5px;font-size:.875rem;color:var(--text-muted)}.cal-legend-swatch{width:12px;height:12px;border-radius:3px}.swatch-logged{background:#dcfce7;border:1px solid #bbf7d0}.swatch-scheduled{background:#f0f7ff;border:1px solid #dbeafe}.swatch-today{background:var(--accent-light);border:2px solid var(--accent)}.entry-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);margin-top:12px}.entry-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.entry-panel-date{font-size:1rem;font-weight:600}.entry-panel-actions{display:flex;gap:8px;align-items:center}.schedule-editor{background:var(--bg-card);border-radius:var(--radius-sm)}.schedule-display{text-align:center}.schedule-days-row{display:flex;gap:4px;justify-content:center}.schedule-day-chip{width:36px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);cursor:pointer;transition:all .15s}.schedule-day-chip:hover{background:var(--bg-hover)}.schedule-day-chip.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.schedule-time-display{margin-top:8px;font-size:.875rem;font-weight:500;color:var(--text-secondary)}.emp-type-badge{display:inline-block;font-size:.75rem;font-weight:600;padding:1px 6px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;margin-left:6px;vertical-align:middle}.emp-type-badge.hourly{background:#dbeafe;color:#1e40af}.emp-type-badge.salary{background:#dcfce7;color:#166534}.emp-type-badge.contract{background:#fef3c7;color:#92400e}.emp-type-badge.intern{background:#f3e8ff;color:#7c3aed}.password-box{background:#fefce8;border:2px solid var(--accent);border-radius:var(--radius);padding:12px 16px;text-align:center}.password-box-label{font-size:.75rem;color:var(--text-secondary);margin-bottom:4px}.password-box-value{font-size:1.25rem;font-weight:700;font-family:Courier New,monospace;letter-spacing:1px;margin-bottom:8px;-webkit-user-select:all;user-select:all}.sched-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}.sched-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.sched-toggle-btn{padding:6px 16px;border:none;background:var(--bg-card);font-family:var(--font);font-size:.875rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s}.sched-toggle-btn+.sched-toggle-btn{border-left:1px solid var(--border)}.sched-toggle-btn.active{background:var(--accent);color:var(--accent-text)}.sched-nav{display:flex;align-items:center;gap:4px}.sched-week-label{font-size:.9375rem;font-weight:600;margin-bottom:10px}.sched-grid{width:100%;border-collapse:collapse;font-size:.75rem}.sched-grid th,.sched-grid td{padding:6px 4px;text-align:center;border-bottom:1px solid var(--border)}.sched-grid th{font-size:.875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;background:var(--bg-card);position:sticky;top:0;z-index:1}.sched-th-date{font-size:.875rem;font-weight:700;color:var(--text)}.sched-today-col{background:#0000000f!important}.sched-name-col{text-align:left!important;width:1%;white-space:nowrap;padding-left:12px!important;position:sticky;left:0;background:var(--bg-card);z-index:2;border-right:1px solid var(--border)}.sched-emp-name{font-size:.875rem;font-weight:600;line-height:1;white-space:nowrap}.sched-title-col{text-align:left!important;width:1%;white-space:nowrap;padding-left:8px!important;padding-right:12px!important;border-right:1px solid var(--border)}.sched-emp-pill{font-size:.875rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.sched-emp-inline{display:flex;align-items:center}.sched-dept-col{width:28px;min-width:28px;max-width:28px;padding:0!important}.sched-dept-label{position:relative;width:28px;min-width:28px;max-width:28px;padding:0!important;border-right:2px solid rgba(0,0,0,.08);border-bottom:2px solid var(--bg-card)!important;vertical-align:middle}.sched-dept-label span{display:block;writing-mode:vertical-rl;transform:rotate(180deg);text-align:center;font-size:.75rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-secondary);white-space:nowrap;padding:8px 0;margin:0 auto}.sched-grid tbody td{padding:6px 8px}.sched-cell{min-width:64px}.sched-cell.filled{background:#0000001a}.dept-production{background:#f3e8ff}.dept-marketing{background:#dbeafe}.dept-leadership{background:#fef9c3}.dept-default{background:#f1f5f9}[data-theme=dark] .dept-production{background:#a855f726}[data-theme=dark] .dept-marketing{background:#3b82f626}[data-theme=dark] .dept-leadership{background:#eab30826}[data-theme=dark] .dept-default{background:#94a3b81a}.sched-shift{font-size:.875rem;color:var(--text-secondary);font-weight:500;white-space:nowrap}.sched-daily-summary{font-size:.875rem;color:var(--text-secondary);margin-bottom:8px}.sched-daily-emp{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}.sched-daily-emp:last-child{border-bottom:none}.sched-daily-time{font-size:.875rem;color:var(--text-secondary);white-space:nowrap}.text-muted{color:var(--text-muted)}.text-center{text-align:center}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}:root{--section-bg: #2a2a2a}.te-reminder{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;margin-bottom:12px;background:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius);font-size:.875rem;color:#92400e}.te-reminder-x{background:none;border:none;font-size:1.125rem;line-height:1;color:#92400e;cursor:pointer;padding:0 2px;opacity:.6}.te-reminder-x:hover{opacity:1}.te-today{display:flex;flex-direction:column;gap:0;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:12px;color:var(--text);box-shadow:var(--shadow)}.te-today-info{flex:1}.te-today-eyebrow{font-size:.75rem;font-weight:700;letter-spacing:3px;color:var(--text-muted);text-transform:uppercase;margin-bottom:3px}.te-today-day{font-size:1.375rem;font-weight:700;line-height:1.15;color:var(--text)}.te-today-date{font-size:.875rem;color:var(--text-secondary);margin-top:1px}.te-today-divider{width:28px;height:2px;background:var(--accent);margin:10px 0;border-radius:1px}.te-today-status{display:flex;align-items:center;gap:8px;font-size:.875rem}.te-status-logged{color:#16a34a}.te-today-check{width:16px;height:16px;flex-shrink:0}.te-today-hrs{font-size:1.0625rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.te-today-times{font-size:.875rem;color:var(--text-secondary)}.te-status-pending{color:var(--text-muted)}.te-today-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:te-pulse 2s ease-in-out infinite}@keyframes te-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.75)}}.te-status-off{color:var(--text-muted);font-style:italic}.te-today-stats{display:flex;align-items:center;gap:14px;padding-top:14px;margin-top:14px;border-top:1px solid var(--border)}.te-ring-wrap{position:relative;width:50px;height:50px;flex-shrink:0}.te-ring{width:50px;height:50px;transform:rotate(-90deg)}.te-ring-bg{fill:none;stroke:var(--bg-input);stroke-width:4.5}.te-ring-fill{fill:none;stroke:var(--accent);stroke-width:4.5;stroke-linecap:round;transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1)}.te-ring-pct{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.75rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.te-stats-col{flex:1;min-width:0}.te-stats-hours{font-size:1.25rem;font-weight:700;line-height:1.1;color:var(--text);font-variant-numeric:tabular-nums}.te-stats-sub{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.te-stats-rest{text-align:center;flex-shrink:0;padding-left:14px;border-left:1px solid var(--border)}.te-stats-rest-num{font-size:1.5rem;font-weight:700;line-height:1;color:var(--text);font-variant-numeric:tabular-nums}.te-stats-rest-label{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600;margin-top:2px}.te-period-status{font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.te-period-status.open{background:#ffffff26;color:#fffc}.te-period-status.closed{background:#ffffff1a;color:#ffffff80}.te-cal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}.te-cal-head{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--section-bg);color:#fff}.te-cal-head-range{font-size:.875rem;font-weight:600}.te-cal-head-sep{color:#ffffff4d}.te-cal-head-pay{font-size:.75rem;color:#ffffff80}.te-cal-head .te-period-status{margin-left:auto}.te-cal-body{padding:14px}.te-cal-dow{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:6px}.te-cal-dow-cell{text-align:center;font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;padding:4px 0}.te-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.te-cal-cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s;position:relative;border:2px solid transparent;min-height:44px}.te-cal-cell:hover:not(.te-cal-empty){background:var(--bg-hover)}.te-cal-empty{cursor:default}.te-cal-num{font-size:.875rem;font-weight:600;line-height:1;font-variant-numeric:tabular-nums}.te-cal-hrs{font-size:.75rem;font-weight:700;line-height:1;margin-top:2px;font-variant-numeric:tabular-nums}.te-cal-wknd{opacity:.3}.te-cal-wknd .te-cal-num{font-weight:400}.te-cal-today{border-color:var(--accent);background:var(--accent-light)}.te-cal-logged{background:#22c55e;color:#fff}.te-cal-logged:hover{background:#16a34a!important}.te-cal-logged .te-cal-num{color:#fff}.te-cal-logged .te-cal-hrs{color:#fffc}.te-cal-sched{background:#f0f7ff}.te-cal-dot{width:5px;height:5px;border-radius:50%;background:#93c5fd;margin-top:3px}.te-cal-sel{border-color:var(--text-secondary)!important}.te-content{display:flex;flex-direction:column;gap:12px}.te-entry{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);animation:te-slide-up .2s ease}@keyframes te-slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.te-entry-head{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--section-bg);color:#fff}.te-entry-date{font-size:.875rem;font-weight:600}.te-entry-badge{font-size:.75rem;font-weight:700;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;background:#22c55e;color:#fff}.te-time-row{display:flex;align-items:flex-end;gap:0;padding:20px 20px 0}.te-time-block{flex:1;text-align:center}.te-time-label{display:block;font-size:.75rem;font-weight:700;letter-spacing:2px;color:var(--text-muted);text-transform:uppercase;margin-bottom:6px}.te-time-input{width:100%;padding:12px 8px;border:1px solid var(--border);border-radius:10px;font-family:var(--font);font-size:1.125rem;font-weight:600;text-align:center;background:var(--bg-input);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s;font-variant-numeric:tabular-nums;-webkit-appearance:none}.te-time-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #ffcc0026}.te-time-arrow{width:36px;text-align:center;font-size:1.25rem;color:var(--text-muted);padding-bottom:14px;flex-shrink:0}.te-hours-bar{margin:16px 20px;padding:10px 16px;background:#ffcc001a;border-radius:10px;text-align:center;font-size:.875rem}.te-hours-bar strong{font-size:1.25rem;font-variant-numeric:tabular-nums}.te-hours-detail{display:block;font-size:.75rem;color:var(--text-secondary);margin-top:2px}.te-error{font-size:.875rem;color:var(--error);padding:0 20px;margin-bottom:12px}.te-actions{display:flex;gap:8px;padding:0 20px 20px;align-items:center}.te-btn{padding:11px 20px;border:none;border-radius:10px;font-family:var(--font);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.te-btn:disabled{opacity:.5;cursor:not-allowed}.te-btn-save{background:var(--accent);color:var(--accent-text);flex:1}.te-btn-save:hover:not(:disabled){background:var(--accent-hover)}.te-btn-del{background:none;color:var(--error);padding:11px 14px}.te-btn-del:hover:not(:disabled){background:#ef444414}@media(min-width:640px){.app-shell{border-left:1px solid var(--border);border-right:1px solid var(--border);box-shadow:0 0 40px #0000000d}.app-header{padding:0 24px}.app-main{padding:24px 24px 80px}.time-entry-layout{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.admin-employee-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.admin-employee-grid .card{margin-bottom:0}.admin-kpis{gap:12px}.admin-kpi{padding:16px}.admin-kpi-value{font-size:1.625rem}.card{padding:20px}.bottom-nav{position:sticky;top:var(--header-height);left:0;transform:none;border-top:none;border-bottom:1px solid var(--border);padding:0;gap:0;width:100%;max-width:none}.bottom-nav-item{flex-direction:row;gap:6px;padding:12px 20px;font-size:.875rem;border-bottom:2px solid transparent}.bottom-nav-item.active{border-bottom-color:var(--accent)}.bottom-nav-icon{width:18px;height:18px}.app-main{padding-bottom:24px}.login-card{max-width:400px}.day-label{width:100px;font-size:.875rem}.day-times{font-size:.875rem}.day-hours{width:55px}.cal-cell{min-height:72px;padding:6px}.cal-date,.cal-hours{font-size:.875rem}.cal-times{font-size:.75rem}.schedule-day-chip{width:42px;height:36px;font-size:.75rem}.toast-container{max-width:600px}.te-today{flex-direction:row;align-items:center;gap:24px}.te-today-stats{border-top:none;margin-top:0;padding-top:0;padding-left:24px;border-left:1px solid var(--border)}.te-today-divider{margin:10px 0}.te-content{flex-direction:row;align-items:start}.te-content>*{flex:1;min-width:0}.te-cal-cell{min-height:56px}.te-cal-num{font-size:.875rem}.te-cal-hrs{font-size:.75rem}.te-time-input{font-size:1.25rem;padding:14px 10px}}@media(min-width:750px){.app-shell{max-width:none;margin-left:200px;padding-top:var(--header-height);border-left:none;border-right:none;box-shadow:none}.app-header{position:fixed;top:0;left:0;right:0;z-index:300;margin-left:0}.app-main{padding:32px 40px}.bottom-nav{position:fixed;top:var(--header-height);left:0;bottom:0;width:200px;max-width:200px;flex-direction:column;border-bottom:none;border-right:1px solid var(--border);border-top:none;padding:0;gap:0;z-index:200;box-shadow:2px 0 12px #0000000a;overflow-y:auto}.sidebar-brand{display:none}.bottom-nav-item{flex:none;flex-direction:row;gap:10px;padding:12px 16px;font-size:.875rem;border-bottom:none;border-left:3px solid transparent;border-radius:0;justify-content:flex-start}.bottom-nav-item.active{border-left-color:var(--accent);background:#00000008;border-bottom:none}.bottom-nav-icon{width:20px;height:20px}.admin-employee-grid{grid-template-columns:1fr 1fr 1fr}.admin-kpis{max-width:800px}}@media(min-width:1400px){.app-main{padding:40px 60px}.admin-employee-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:640px){.app-header{padding:.4rem .75rem}.header-logo{height:22px}.header-app-name{font-size:.8125rem}.theme-toggle{gap:.25rem}.theme-toggle-icon{font-size:.6875rem}.theme-toggle-track{width:26px;height:14px}.theme-toggle-thumb{width:10px;height:10px}.theme-toggle-thumb.dark{left:14px}.avatar-group{padding-left:.4rem}.avatar-btn{width:22px;height:22px}.bottom-nav{padding:4px 8px 6px}.bottom-nav .sidebar-brand{display:none}.bottom-nav-item{font-size:.625rem;gap:2px}.bottom-nav-icon{width:18px;height:18px}.app-main{padding:12px}.te-today{flex-direction:column;gap:12px}.te-today-stats{justify-content:center}.te-today-day{font-size:1rem}.te-time-row{gap:8px}.te-time-input{font-size:1.125rem;padding:8px 10px}.te-btn{padding:10px 16px;font-size:.875rem}.admin-kpis{gap:8px}.admin-kpi{padding:12px}.admin-kpi-value{font-size:1.375rem}.sched-header{flex-direction:column;gap:8px;align-items:stretch}.sched-nav{justify-content:center}.sched-daily-summary{font-size:.8125rem}}
