:root{--primary:#006838;--primary-dk:#004d2a;--primary-lt:#e8f5e9;--primary-rgb:0, 104, 56;--accent:#d4a843;--accent-lt:#fdf6e3;--accent-rgb:212, 168, 67;--danger:#c62828;--danger-lt:#fce4ec;--surface:#fff;--bg:#f3f4f6;--text:#1a1a1a;--text-muted:#6b7280;--text-light:#9ca3af;--border:#e5e7eb;--border-dk:#d1d5db;--radius:10px;--radius-sm:6px;--shadow-sm:0 1px 2px #0000000f;--shadow:0 2px 8px #00000014;--shadow-lg:0 8px 24px #0000001f;--transition:.2s ease;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-serif:"Playfair Display", Georgia, serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}.app-bar{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dk) 100%);color:#fff;z-index:100;padding:0 1.5rem;position:sticky;top:0;box-shadow:0 2px 12px #00000026}.app-bar-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:1100px;height:64px;margin:0 auto;display:flex}.app-bar-brand{align-items:center;gap:.75rem;display:flex}.seal-icon{opacity:.95;transition:transform var(--transition);flex-shrink:0}.seal-icon:hover{transform:scale(1.05)}.app-bar-title{letter-spacing:-.01em;font-size:1.2rem;font-weight:700;line-height:1.2}.app-bar-subtitle{opacity:.8;letter-spacing:.02em;font-size:.75rem;font-weight:400}.app-bar-actions{align-items:center;gap:.5rem;display:flex}.btn{border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;line-height:1.3;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dk);box-shadow:0 2px 8px rgba(var(--primary-rgb), .3)}.btn-accent{background:var(--accent);color:#1a1a1a}.btn-accent:hover{box-shadow:0 2px 8px rgba(var(--accent-rgb), .35);background:#c49a38}.btn-ghost{color:var(--primary);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--primary-lt);border-color:var(--primary)}.btn-outline{color:var(--text);border:1px solid var(--border-dk);background:0 0}.btn-outline:hover{background:var(--bg);border-color:var(--text-muted)}.btn-outline-danger{color:#fff;background:0 0;border:1px solid #ffffff4d}.btn-outline-danger:hover{background:#ffffff1a;border-color:#ffffff80}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b71c1c}.btn-sm{padding:.3rem .65rem;font-size:.78rem}.btn-xs{border-radius:4px;padding:.2rem .45rem;font-size:.72rem;font-weight:500}.main-content{flex-direction:column;gap:1rem;max-width:1100px;margin:1.5rem auto;padding:0 1rem;display:flex}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition);overflow:hidden}.card:hover{box-shadow:var(--shadow)}.card-header{border-bottom:1px solid var(--border);background:linear-gradient(#fafbfc,#f6f7f9);padding:.85rem 1.25rem}.card-title{color:var(--primary);align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;display:flex}.card-body{padding:1.25rem}.form-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.form-group{flex-direction:column;gap:.3rem;display:flex}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:600}.form-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-sans);color:var(--text);background:var(--surface);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:.55rem .75rem;font-size:.9rem}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb), .1)}.form-input[readonly]{background:var(--bg);color:var(--text-muted);cursor:default}.toolbar-card .card-body{flex-direction:column;gap:.65rem;padding:.75rem 1rem;display:flex}.toolbar-row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.toolbar-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;align-items:center;gap:.3rem;min-width:120px;font-size:.78rem;font-weight:600;display:flex}.toolbar-btns{flex-wrap:wrap;gap:.35rem;display:flex}.toolbar-warning{color:var(--danger);background:var(--danger-lt);border-radius:4px;align-items:center;gap:.35rem;padding:.25rem .6rem;font-size:.78rem;font-weight:500;animation:.4s shake;display:flex}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.table-wrapper{border-radius:0 0 var(--radius) var(--radius);overflow:auto}.timesheet-table{border-collapse:collapse;table-layout:fixed;width:100%;font-size:.88rem}.timesheet-table th{background:var(--primary);color:#fff;text-transform:uppercase;letter-spacing:.04em;text-align:center;white-space:nowrap;z-index:10;padding:.65rem .5rem;font-size:.78rem;font-weight:600;position:sticky;top:0;box-shadow:0 1px #ffffff26}.timesheet-table td{text-align:center;border-bottom:1px solid var(--border);vertical-align:middle;padding:.35rem}.col-check{width:36px}.col-date{width:130px;text-align:left!important}.col-time{width:110px}.col-reason{width:150px}.col-hours{width:80px}.col-presets{width:110px}.date-cell{text-align:left;padding-left:.5rem!important}.day-name{font-size:.82rem;font-weight:700;line-height:1.2;display:block}.day-date{color:var(--text-muted);font-size:.82rem;line-height:1.3;display:block}.row-weekend{background:#f0f4f0}.row-holiday{background:var(--accent-lt)}.row-holiday .day-name:after{content:"🎉";margin-left:.3rem;font-size:.7rem}.row-selected{box-shadow:inset 3px 0 0 var(--primary);background:rgba(var(--primary-rgb), .08)!important}.row-weekend.row-selected{background:rgba(var(--primary-rgb), .12)!important}.row-holiday.row-selected{background:rgba(var(--accent-rgb), .18)!important}.time-input{border:1.5px solid var(--border);width:100%;font-family:var(--font-sans);text-align:center;transition:border-color var(--transition), box-shadow var(--transition);background:var(--surface);border-radius:4px;outline:none;padding:.35rem .4rem;font-size:.82rem}.time-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb), .12)}.time-input.is-locked{background:var(--accent-lt);border-color:var(--accent);color:var(--text-muted)}.reason-input{border:1.5px solid var(--border);width:100%;font-family:var(--font-sans);text-align:center;transition:border-color var(--transition);background:var(--surface);border-radius:4px;outline:none;padding:.35rem .4rem;font-size:.82rem}.reason-input:focus{border-color:var(--primary)}.reason-input.is-holiday{background:var(--accent-lt);color:#8b6914;border-color:var(--accent);font-weight:600}.lunch-select{border:1.5px solid var(--border);width:100%;font-family:var(--font-sans);text-align:center;background:var(--surface);cursor:pointer;transition:border-color var(--transition);appearance:auto;border-radius:4px;outline:none;padding:.35rem .25rem;font-size:.82rem}.lunch-select:focus{border-color:var(--primary)}.hours-display{color:var(--primary);font-variant-numeric:tabular-nums;font-size:.9rem;font-weight:700}.hours-display.has-value{color:var(--primary-dk)}.row-check{cursor:pointer;width:16px;height:16px;accent-color:var(--primary)}.preset-btns{justify-content:center;gap:.25rem;display:flex}.btn-preset{border:1px solid var(--border);background:var(--surface);color:var(--primary);cursor:pointer;transition:all var(--transition);white-space:nowrap;font-size:.7rem;font-weight:600;font-family:var(--font-sans);border-radius:3px;padding:.15rem .4rem}.btn-preset:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.holiday-badge{color:#8b6914;background:rgba(var(--accent-rgb), .2);white-space:nowrap;border-radius:3px;margin-top:.1rem;padding:.1rem .35rem;font-size:.65rem;font-weight:600;display:inline-block}.totals-card{max-width:400px;margin:0 auto}.totals-grid{flex-direction:column;gap:.6rem;padding:1.25rem 1.5rem;display:flex}.totals-row{justify-content:space-between;align-items:center;padding:.3rem 0;display:flex}.totals-label{color:var(--text-muted);font-size:.88rem;font-weight:500}.totals-value{color:var(--text);text-align:right;font-variant-numeric:tabular-nums;border-bottom:1.5px solid var(--border-dk);min-width:60px;padding-bottom:2px;font-size:1rem;font-weight:700}.totals-row-total{border-top:2px solid var(--primary);margin-top:.3rem;padding-top:.6rem}.totals-row-total .totals-label{color:var(--text);font-size:.92rem;font-weight:700}.totals-row-total .totals-value{color:var(--primary);border-bottom-color:var(--primary);border-bottom-width:2px;font-size:1.1rem}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:90%;max-width:420px;animation:.25s modalSlide}@keyframes modalSlide{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--border);padding:1rem 1.25rem}.modal-title{color:var(--text);font-size:1rem;font-weight:700}.modal-body{color:var(--text-muted);padding:1.25rem;font-size:.9rem;line-height:1.6}.modal-footer{border-top:1px solid var(--border);background:var(--bg);border-radius:0 0 var(--radius) var(--radius);justify-content:flex-end;gap:.5rem;padding:.75rem 1.25rem;display:flex}@media screen{.print-only{display:none!important}}@media (width<=768px){.app-bar-inner{flex-direction:column;align-items:flex-start;gap:.5rem;height:auto;padding:.75rem 0}.form-grid{grid-template-columns:1fr}.toolbar-row{flex-direction:column;align-items:flex-start}.toolbar-label{min-width:auto}.totals-card{max-width:100%}.timesheet-table{font-size:.8rem}.col-presets{display:none}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-dk);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.selection-count{color:var(--primary);background:var(--primary-lt);border-radius:10px;margin-left:.5rem;padding:.15rem .5rem;font-size:.75rem;font-weight:600}.timesheet-table tbody tr{transition:background var(--transition);cursor:pointer}.timesheet-table tbody tr:hover{background:rgba(var(--primary-rgb), .04)}.timesheet-table tbody tr.row-weekend:hover{background:#e8ede8}.timesheet-table tbody tr.row-holiday:hover{background:#faf0d4}.timesheet-table tbody tr.row-selected:hover{background:rgba(var(--primary-rgb), .12)!important}.btn-unlock{cursor:pointer;opacity:.6;transition:opacity var(--transition);vertical-align:middle;background:0 0;border:none;padding:.1rem;font-size:.75rem}.btn-unlock:hover{opacity:1}.save-indicator{color:#fff9;transition:opacity var(--transition);align-items:center;gap:.3rem;font-size:.7rem;display:flex}.save-indicator.saving{color:var(--accent)}
