*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:.875rem}:focus-visible{outline:2px solid #6366f1;outline-offset:2px}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.skip-link{position:absolute;top:-100px;left:0;background:var(--blue);color:#fff;padding:.5rem 1rem;z-index:1000;font-size:.85rem;border-radius:0 0 6px}.skip-link:focus{top:0}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}:root{--sidebar-w: 240px;--header-h: 56px;--bg: #f1f2f6;--card: #ffffff;--border: #e2e4ea;--text-primary: #1a1a2e;--text-secondary: #6b7280;--text-muted: #9ca3af;--blue: #3b82f6;--blue-hover: #2563eb;--blue-light: #eef2ff;--green: #22c55e;--green-bg: #dcfce7;--red: #dc2626;--red-bg: #fee2e2;--amber: #f59e0b;--amber-bg: #fef3c7;--sidebar-bg: #1e293b;--sidebar-text: #94a3b8;--sidebar-active: #3b82f6;--accent-gradient: linear-gradient(135deg, #3b82f6, #6366f1);--accent-gradient-hover: linear-gradient(135deg, #2563eb, #4f46e5);--glow-color: rgba(99, 102, 241, .15);--radius: 8px}html{background:var(--card)}body{background:var(--bg);color:var(--text-primary)}#main-content:focus{outline:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);color:var(--sidebar-text);position:fixed;top:0;left:0;height:100vh;display:flex;flex-direction:column;z-index:100}.main{margin-left:var(--sidebar-w);flex:1;min-height:100vh;min-width:0}.header{height:var(--header-h);background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:50}.content{padding:1.5rem;overflow:hidden}.sidebar-logo{padding:1rem 1.25rem;font-size:1.1rem;font-weight:700;color:#fff;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:.5rem;height:var(--header-h)}.sidebar-logo span{color:#818cf8}.sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto}.sidebar-section{padding:0 .75rem;margin-bottom:.5rem}.sidebar-section-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:#ffffff8c;padding:.5rem .75rem .25rem;font-weight:600}.sidebar-link{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;color:var(--sidebar-text);cursor:pointer;transition:background-color .3s,color .3s;text-decoration:none}.sidebar-link:hover{background:#ffffff0f;color:#fff}.sidebar-link:focus-visible{outline:2px solid #818cf8;outline-offset:-2px}.sidebar-link.active{background:var(--accent-gradient);color:#fff}.sidebar-link svg{width:18px;height:18px;flex-shrink:0}.sidebar-user{padding:.75rem 1rem;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:.625rem;font-size:.8rem}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.75rem;flex-shrink:0}.sidebar-user-name{color:#fff;font-weight:500}.sidebar-user-role{color:var(--sidebar-text);font-size:.7rem}.btn{display:inline-flex;align-items:center;gap:.375rem;padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;border:none;transition:background-color .3s,color .3s,opacity .3s,border-color .3s}.btn-primary{background:linear-gradient(135deg,#3b82f6,#6366f1,#2563eb,#4f46e5);background-size:200% 200%;background-position:0% 0%;color:#fff;border:1px solid transparent;transition:background-position .3s,opacity .3s}.btn-primary:hover{background-position:100% 100%}.btn-secondary{background-color:var(--card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background-color:#f0f1f5}.btn-danger{background-color:var(--red);color:#fff}.btn-danger:hover{background-color:#b91c1c}.btn-sm{padding:.375rem .75rem;font-size:.8rem}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}.badge{display:inline-block;padding:.125rem .5rem;border-radius:9999px;font-size:.7rem;font-weight:600}.badge-green{background:var(--green-bg);color:#166534}.badge-red{background:var(--red-bg);color:#991b1b}.badge-amber{background:var(--amber-bg);color:#92400e}.badge-blue{background:#eef2ff;color:#4338ca}.badge-gray{background:#f3f4f6;color:#4b5563}table{width:100%;border-collapse:collapse;font-size:.85rem;table-layout:fixed}thead th{text-align:left;padding:.625rem 1rem;font-weight:600;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);background:#f8f9fc}tbody td{padding:.75rem 1rem;border-bottom:1px solid var(--border)}tbody tr.clickable-row{transition:background-color .3s}tbody tr.clickable-row:hover{background-color:#f3f4f6!important}tbody tr:last-child td{border-bottom:none}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.8rem;font-weight:600;margin-bottom:.25rem;color:var(--text-secondary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.875rem;outline:none;transition:border-color .3s,box-shadow .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px var(--glow-color)}.progress-bar{height:8px;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress-fill{height:100%;border-radius:999px;transition:width .3s ease}.progress-fill.green{background:linear-gradient(90deg,#22c55e,#10b981)}.progress-fill.red{background:linear-gradient(90deg,#dc2626,#ef4444)}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-secondary)}.fw-600{font-weight:600}.pointer{cursor:pointer}.sign-out-btn{background:none;border:none;color:var(--text-secondary);font-size:.8rem;font-weight:600;cursor:pointer;padding:.375rem .5rem;transition:color .3s}.sign-out-btn:hover{color:var(--text-primary)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-top:1px solid var(--border);font-size:.8rem}.pagination-controls{display:flex;align-items:center;gap:.5rem}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;display:flex;align-items:center;justify-content:center}.dialog-content-wrapper{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;pointer-events:none}.dialog-content-wrapper>.dialog-content{pointer-events:auto}.dialog-content{background:var(--card);border-radius:12px;padding:1.5rem;width:480px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.dialog-title{font-size:1rem;font-weight:600;margin-bottom:.25rem}.dialog-description{font-size:.85rem;color:var(--text-secondary);margin-bottom:1.25rem}.dialog-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1.25rem}.toast-viewport{position:fixed;bottom:1rem;right:1rem;display:flex;flex-direction:column;gap:.5rem;width:360px;max-width:90vw;z-index:300;list-style:none}.toast{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem;box-shadow:0 4px 12px #0000001f;font-size:.85rem;animation:toast-slide-in .2s ease-out}.toast-success{border-left:3px solid var(--green)}.toast-error{border-left:3px solid var(--red)}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ts-grid{width:100%;border-collapse:collapse}.ts-grid th{padding:.625rem .5rem;text-align:center;font-size:.75rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#f8f9fc}.ts-grid th.col-project{text-align:left;padding-left:1.25rem}.ts-grid th.col-total{width:80px;padding-right:1.5rem;text-align:right}.ts-grid th.col-day{width:90px}.ts-grid td{padding:.5rem .375rem;text-align:center;border-bottom:1px solid var(--border);vertical-align:top}.ts-grid tfoot tr:last-child td,.ts-grid tbody tr:last-child td{border-bottom:none}.ts-grid td.project-cell{text-align:left;padding:.625rem .5rem .625rem 1.25rem;vertical-align:middle}.ts-project-name{font-weight:600;font-size:.85rem}.ts-task-name{font-size:.75rem;color:var(--text-secondary)}.ts-cell{position:relative}.ts-cell input[type=number]{width:100%;padding:.5rem .25rem;border:1px solid var(--border);border-radius:4px;text-align:center;font-size:.85rem;background:#fff;outline:none}.ts-cell input[type=number]:focus{border-color:#6366f1;box-shadow:0 0 0 3px var(--glow-color)}.ts-cell input[type=number]:disabled{background:#f3f4f6;color:var(--text-muted)}.ts-desc{font-size:.7rem;color:var(--text-muted);margin-top:2px;max-width:85px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;cursor:pointer;margin-inline:auto}.ts-desc:hover{color:var(--blue);text-decoration:underline}.ts-total{font-weight:700;font-size:.9rem;padding:.625rem 1.5rem .625rem .5rem!important;text-align:right!important;vertical-align:middle!important}.ts-day-total{font-weight:600;font-size:.8rem;color:var(--text-secondary)}.ts-add-row{display:flex;align-items:center;gap:.25rem;color:#2563eb;font-size:.8rem;background:none;border:none;cursor:pointer;padding:.5rem;font-weight:500}.ts-add-row:hover{text-decoration:underline}.ts-footer{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-top:1px solid var(--border)}.ts-week-nav{display:flex;align-items:center;gap:.75rem}.ts-week-nav button{background:none;border:1px solid var(--border);border-radius:6px;padding:.375rem .625rem;font-size:.8rem;cursor:pointer;transition:background-color .3s}.ts-week-nav button:hover{background-color:#f0f1f5}.ts-week-label{font-weight:600;font-size:.85rem}.ts-locked-banner{background:var(--amber-bg);border:1px solid #fde68a;border-radius:6px;padding:.625rem 1rem;font-size:.8rem;color:#92400e;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.ts-remove-row{color:var(--red);cursor:pointer;font-size:.75rem;opacity:0;transition:opacity .15s;background:none;border:none;padding:.25rem 0;min-height:24px}tr:hover .ts-remove-row,.ts-remove-row:focus{opacity:1}.res-level{padding:.625rem 1rem;border-bottom:1px solid var(--border);cursor:pointer}.res-level:hover{background:#f9fafb}.res-row{display:flex;align-items:center;gap:.75rem}.res-chevron{width:16px;color:var(--text-muted);flex-shrink:0;font-size:.7rem}.res-name{flex:1}.res-actions{display:flex;gap:.25rem;flex-shrink:0}.res-progress{width:200px;flex-shrink:0}.res-level-0{font-weight:700;font-size:.95rem}.res-level-1{padding-left:2rem;font-weight:600;font-size:.9rem}.res-level-2{padding-left:3rem;font-size:.85rem}.res-level-3{padding-left:4rem;font-size:.85rem}.res-level-4{padding-left:5rem;font-size:.85rem;cursor:default}.res-timeline{font-size:.7rem;color:var(--text-muted);margin-left:.5rem}
