@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--font-primary:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--text-xs:.6875rem;--text-sm:.75rem;--text-base:.8125rem;--text-md:.875rem;--text-lg:1rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--weight-light:300;--weight-regular:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--color-bg:#f8f9fb;--color-bg-elevated:#fff;--color-bg-subtle:#f1f3f5;--color-bg-hover:#e9ecef;--color-bg-active:#dee2e6;--color-text-primary:#1a1d23;--color-text-secondary:#5f6c7b;--color-text-tertiary:#8b95a1;--color-text-inverse:#fff;--color-border:#e2e5e9;--color-border-strong:#ced2d8;--color-border-subtle:#eef0f2;--color-primary:#4f6ef7;--color-primary-hover:#3d5ce5;--color-primary-light:#eef1fe;--color-primary-subtle:#dde3fc;--color-success:#22c55e;--color-success-light:#dcfce7;--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-danger:#ef4444;--color-danger-light:#fee2e2;--color-info:#3b82f6;--color-info-light:#dbeafe;--color-util-low:#94a3b8;--color-util-normal:#22c55e;--color-util-high:#f59e0b;--color-util-over:#ef4444;--project-blue:#4f6ef7;--project-purple:#8b5cf6;--project-pink:#ec4899;--project-red:#ef4444;--project-orange:#f97316;--project-amber:#f59e0b;--project-green:#22c55e;--project-teal:#14b8a6;--project-cyan:#06b6d4;--project-indigo:#6366f1;--project-slate:#64748b;--project-rose:#f43f5e;--space-0:0;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--radius-2xl:16px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000000d;--shadow-glow:0 0 20px #4f6ef726;--transition-fast:.12s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--transition-spring:.35s cubic-bezier(.34,1.56,.64,1);--sidebar-width:220px;--sidebar-collapsed-width:64px;--topbar-height:52px;--timeline-row-height:80px;--timeline-header-height:48px;--z-sidebar:100;--z-topbar:90;--z-dropdown:200;--z-modal-backdrop:300;--z-modal:310;--z-toast:400}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-size:16px}body{font-family:var(--font-primary);font-size:var(--text-md);font-weight:var(--weight-regular);color:var(--color-text-primary);background-color:var(--color-bg);min-height:100vh;line-height:1.5}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}button{font-family:var(--font-primary);cursor:pointer;font-size:inherit;background:0 0;border:none}input,select,textarea{font-family:var(--font-primary);font-size:var(--text-md);color:var(--color-text-primary);border:1px solid var(--color-border);background:var(--color-bg-elevated);border-radius:var(--radius-md);padding:var(--space-2)var(--space-3);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.app-layout{min-height:100vh;display:flex}.app-main{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left var(--transition-base);flex-direction:column;flex:1;display:flex;overflow-x:hidden}.app-content{padding:var(--space-6);flex:1;overflow-x:auto}.visually-hidden{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--color-bg-subtle)25%,var(--color-bg-hover)50%,var(--color-bg-subtle)75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes slideFromLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.9)translateY(6px)}to{opacity:1;transform:scale(1)translateY(0)}}.fade-in{animation:fadeIn var(--transition-slow)ease forwards}
@media (max-width:1024px){.sidebar{width:var(--sidebar-collapsed-width)}.sidebar-brand-text,.sidebar-link span,.sidebar-section-label,.sidebar-user-info{display:none}.sidebar-brand{padding:var(--space-4)var(--space-2);justify-content:center}.sidebar-nav{align-items:center}.sidebar-link{padding:var(--space-2);justify-content:center;width:40px;height:40px}.sidebar-link.active:before{display:none}.sidebar-user{padding:var(--space-2);justify-content:center}.sidebar-footer{align-items:center}.sidebar-user-row{justify-content:center}.sidebar-signout-btn{display:none}.app-main{margin-left:var(--sidebar-collapsed-width)}.people-stats{grid-template-columns:1fr 1fr;display:grid}.people-table th:nth-child(4),.people-table td:nth-child(4),.people-table th:nth-child(6),.people-table td:nth-child(6){display:none}.projects-grid{grid-template-columns:repeat(2,1fr)}.projects-stats,.reports-kpis{grid-template-columns:1fr 1fr;display:grid}.reports-charts{grid-template-columns:1fr}.people-panel{min-width:150px;max-width:150px}.person-role,.person-office{display:none}.timelog-controls{flex-direction:column;align-items:stretch}.timelog-week-nav{justify-content:center}}@media (max-width:640px){.sidebar{border-right:none;border-top:1px solid var(--color-border);width:100%;height:56px;z-index:var(--z-sidebar);flex-direction:row;padding:0;position:fixed;inset:auto 0 0}.sidebar-brand,.sidebar-section-label,.sidebar-footer,.sidebar-link span,.sidebar-user-info,.sidebar-signout-btn{display:none}.sidebar-nav{flex-direction:row;justify-content:space-around;align-items:center;gap:0;width:100%;height:100%;padding:0;overflow:visible}.sidebar-link{padding:var(--space-1);width:auto;height:auto;font-size:var(--text-xs);border-radius:0;flex-direction:column;gap:2px;min-width:48px}.sidebar-link-icon{width:22px;height:22px}.sidebar-link.active:before{display:none}.sidebar-link.active{background:0 0}.app-main{margin-left:0;padding-bottom:56px}.topbar{padding:0 var(--space-3);gap:var(--space-2)}.topbar-title{font-size:var(--text-lg)}.topbar-right{gap:var(--space-1)}.topbar-action-btn span,.topbar-action-btn:not(.primary){font-size:0}.topbar-action-btn svg{font-size:initial}.topbar-date-range{font-size:var(--text-sm);min-width:auto}.topbar-util-badge{font-size:var(--text-xs)}.modal{min-width:unset;border-radius:0;width:100%;max-width:100%;height:100vh;max-height:100vh;animation:.25s modalSlideUp}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-body,.modal-header{padding:var(--space-4)}.modal-footer{padding:var(--space-3)var(--space-4)}.form-row{gap:var(--space-3);flex-direction:column}.people-page{padding:var(--space-3)}.people-stats{gap:var(--space-2);margin-bottom:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.people-stat-card{padding:var(--space-3)}.people-stat-value{font-size:var(--text-xl)}.people-toolbar{gap:var(--space-2);flex-direction:column}.people-search{width:100%}.people-view-toggle{align-self:flex-end}.people-grid{grid-template-columns:1fr}.people-table th:nth-child(4),.people-table td:nth-child(4),.people-table th:nth-child(5),.people-table td:nth-child(5),.people-table th:nth-child(6),.people-table td:nth-child(6),.people-table th:nth-child(7),.people-table td:nth-child(7),.people-table th:nth-child(8),.people-table td:nth-child(8){display:none}.projects-page{padding:var(--space-3)}.projects-stats{gap:var(--space-2);margin-bottom:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.projects-grid{grid-template-columns:1fr}.projects-toolbar{gap:var(--space-2);flex-direction:column}.schedule-page{padding:0}.timeline-container{flex-direction:column}.people-panel{border-right:none;border-bottom:1px solid var(--color-border);flex-direction:row;min-width:100%;max-width:100%;overflow-x:auto}.people-panel-header{display:none}.person-row-info{min-width:100px;padding:var(--space-2);text-align:center;flex-direction:column}.person-utilization{font-size:var(--text-xs)}.timeline-grid{overflow-x:auto}.timeline-grid .timeline-header,.timeline-grid .timeline-row{min-width:500px}.reports-page{padding:var(--space-3)}.reports-kpis{gap:var(--space-2);grid-template-columns:1fr 1fr;display:grid}.reports-charts{grid-template-columns:1fr}.reports-table-card{overflow-x:auto}.reports-budget-grid{grid-template-columns:1fr}.reports-tabs{overflow-x:auto}.timelog-page{padding:var(--space-3)}.timelog-controls{align-items:stretch;gap:var(--space-2);flex-direction:column}.timelog-person-select{width:100%}.timelog-week-nav{justify-content:center}.timelog-grid-card{overflow-x:auto}.settings-page{padding:var(--space-3)}.settings-tabs{flex-wrap:nowrap;gap:0;overflow-x:auto}.settings-tab{white-space:nowrap;flex-shrink:0}.toast{left:var(--space-3);right:var(--space-3);bottom:64px}.login-card{margin:var(--space-4);max-width:100%}}
.sidebar{width:var(--sidebar-width);background:var(--color-bg-elevated);border-right:1px solid var(--color-border);z-index:var(--z-sidebar);transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar-brand{align-items:center;gap:var(--space-3);padding:var(--space-4)var(--space-4);border-bottom:1px solid var(--color-border-subtle);height:var(--topbar-height);box-sizing:border-box;display:flex}.sidebar-brand-icon{background:linear-gradient(135deg,var(--color-primary),#7c3aed);border-radius:var(--radius-lg);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex;box-shadow:0 2px 8px #4f6ef74d}.sidebar-brand-text{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--color-text-primary);letter-spacing:-.02em;white-space:nowrap}.sidebar-nav{padding:var(--space-3)var(--space-2);gap:var(--space-1);flex-direction:column;flex:1;display:flex;overflow-y:auto}.sidebar-section-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;padding:var(--space-3)var(--space-3)var(--space-1)}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2)var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-md);font-weight:var(--weight-medium);transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.sidebar-link.active{background:var(--color-primary-light);color:var(--color-primary)}.sidebar-link.active:before{content:"";background:var(--color-primary);border-radius:0 var(--radius-full)var(--radius-full)0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-link-icon{opacity:.7;flex-shrink:0;width:20px;height:20px}.sidebar-link.active .sidebar-link-icon{opacity:1}.sidebar-footer{border-top:1px solid var(--color-border-subtle);padding:var(--space-3)var(--space-2)}.sidebar-user-row{align-items:center;gap:var(--space-3);padding:var(--space-2)var(--space-3);border-radius:var(--radius-md);display:flex}.sidebar-user-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),#7c3aed);color:#fff;width:28px;height:28px;font-size:var(--text-xs);font-weight:var(--weight-semibold);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-user-info{flex-direction:column;flex:1;min-width:0;display:flex}.sidebar-user-name{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar-user-role{font-size:var(--text-xs);color:var(--color-text-tertiary)}.sidebar-signout-btn{border-radius:var(--radius-md);width:28px;height:28px;color:var(--color-text-tertiary);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-signout-btn:hover{background:var(--color-danger-light);color:var(--color-danger)}.sidebar-user-avatar:hover{box-shadow:0 0 0 3px var(--color-primary-light),0 0 0 1px var(--color-primary);transition:box-shadow .2s}.profile-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.profile-modal{background:var(--color-bg-elevated);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);width:420px;max-width:90vw;max-height:90vh;animation:.3s cubic-bezier(.34,1.56,.64,1) modalSlideIn;overflow-y:auto}.profile-modal-header{padding:var(--space-5)var(--space-6);border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;display:flex}.profile-modal-header h2{font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--color-text-primary)}.profile-close-btn{border-radius:var(--radius-md);width:32px;height:32px;color:var(--color-text-tertiary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.profile-close-btn:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.profile-modal-body{padding:var(--space-6);gap:var(--space-4);flex-direction:column;display:flex}.profile-avatar-section{align-items:center;gap:var(--space-2);padding-bottom:var(--space-4);flex-direction:column;display:flex}.profile-avatar-large{border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),#7c3aed);color:#fff;width:72px;height:72px;font-size:var(--text-xl);font-weight:var(--weight-bold);justify-content:center;align-items:center;display:flex;box-shadow:0 4px 16px #4f6ef740}.profile-avatar-hint{font-size:var(--text-sm);color:var(--color-text-tertiary)}.profile-field{gap:var(--space-1);flex-direction:column;display:flex}.profile-field-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);align-items:center;gap:var(--space-2);display:flex}.profile-field-input{height:40px;padding:0 var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-md);background:var(--color-bg);transition:all var(--transition-fast)}.profile-field-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.profile-divider{align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--color-text-tertiary);padding-top:var(--space-3);border-top:1px solid var(--color-border-subtle);text-transform:uppercase;letter-spacing:.04em;display:flex}.profile-error{background:var(--color-danger-light);color:var(--color-danger);font-size:var(--text-sm);font-weight:var(--weight-medium);padding:var(--space-3)var(--space-4);border-radius:var(--radius-lg)}.profile-success{background:var(--color-success-light);color:var(--color-success);font-size:var(--text-sm);font-weight:var(--weight-medium);padding:var(--space-3)var(--space-4);border-radius:var(--radius-lg);align-items:center;gap:var(--space-2);display:flex}.profile-modal-footer{justify-content:flex-end;gap:var(--space-3);padding:var(--space-4)var(--space-6);border-top:1px solid var(--color-border-subtle);display:flex}
