@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);position:relative;overflow:hidden}.auth-background{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.gradient-orb{position:absolute;border-radius:50%;filter:blur(100px);animation:float 20s ease-in-out infinite}.orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(59,130,246,.25) 0%,transparent 70%);top:-200px;left:-200px}.orb-2{width:500px;height:500px;background:radial-gradient(circle,rgba(14,165,233,.2) 0%,transparent 70%);bottom:-150px;right:-150px;animation-delay:-5s}.orb-3{width:400px;height:400px;background:radial-gradient(circle,rgba(34,211,238,.2) 0%,transparent 70%);top:40%;left:50%;animation-delay:-10s}.auth-container{display:flex;justify-content:center;gap:var(--space-3xl);max-width:1000px;width:100%;z-index:1}.auth-card{width:100%;max-width:440px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--space-2xl);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);animation:scaleIn var(--transition-spring)}.auth-header{text-align:center;margin-bottom:var(--space-2xl)}.auth-logo{width:72px;height:72px;background:var(--gradient-primary);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-lg);box-shadow:var(--shadow-glow);animation:float 3s ease-in-out infinite}.auth-logo-icon{width:36px;height:36px;color:#fff}.auth-header h1{font-size:1.75rem;margin-bottom:var(--space-sm)}.auth-header p{color:var(--text-tertiary)}.auth-form{display:flex;flex-direction:column;gap:var(--space-lg)}.input-with-icon{position:relative}.input-icon{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-tertiary);pointer-events:none}.input-with-icon .input{padding-left:calc(var(--space-md) * 2 + 20px)}.error-message{padding:var(--space-md);background:#fb71851a;border:1px solid rgba(251,113,133,.3);border-radius:var(--radius-lg);color:var(--accent-rose);font-size:.875rem;text-align:center}.auth-footer{margin-top:var(--space-xl);text-align:center}.auth-footer p{color:var(--text-tertiary);font-size:.875rem}.auth-footer a{color:var(--primary-400);font-weight:600;text-decoration:none;transition:color var(--transition-fast)}.auth-footer a:hover{color:var(--primary-300)}.pending-card{text-align:center;max-width:480px}.pending-icon{width:80px;height:80px;background:linear-gradient(135deg,#fbbf2433,#fbbf241a);border:2px solid rgba(251,191,36,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-xl);animation:pulse 2s ease-in-out infinite}.pending-clock-icon{width:40px;height:40px;color:var(--accent-amber)}.pending-card h1{margin-bottom:var(--space-lg);color:var(--accent-amber)}.pending-message{font-size:1.125rem;color:var(--text-secondary);margin-bottom:var(--space-md);line-height:1.7}.pending-info{font-size:.875rem;color:var(--text-tertiary);margin-bottom:var(--space-2xl)}.auth-info{flex:1;max-width:400px;display:flex;flex-direction:column;justify-content:center;animation:slideUp var(--transition-base) ease-out;animation-delay:.15s;animation-fill-mode:both}.auth-info h2{font-size:2rem;margin-bottom:var(--space-md);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-info>p{color:var(--text-secondary);font-size:1.125rem;line-height:1.7;margin-bottom:var(--space-2xl)}.features-list{display:flex;flex-direction:column;gap:var(--space-md)}.feature-item{display:flex;align-items:center;gap:var(--space-md);color:var(--text-secondary)}.feature-dot{width:8px;height:8px;background:var(--gradient-primary);border-radius:50%;flex-shrink:0}@media (max-width: 900px){.auth-container{flex-direction:column-reverse;align-items:center;gap:var(--space-2xl)}.auth-info{max-width:440px;text-align:center}.features-list{align-items:center}}@media (max-width: 480px){.auth-card{padding:var(--space-xl)}.auth-logo{width:60px;height:60px}.auth-logo-icon{width:28px;height:28px}.auth-header h1{font-size:1.5rem}.auth-info{display:none}}.dashboard{max-width:1400px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-lg);margin-bottom:var(--space-2xl)}.welcome-section h1{font-size:2rem;margin-bottom:var(--space-xs)}.welcome-section p{color:var(--text-tertiary);font-size:1rem}.running-timer-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);padding:var(--space-lg) var(--space-xl);background:linear-gradient(135deg,#3b82f61f,#2563eb14);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-xl);margin-bottom:var(--space-2xl)}.timer-info{display:flex;align-items:center;gap:var(--space-md)}.timer-pulse{width:12px;height:12px;background:var(--accent-emerald);border-radius:50%;animation:pulse 2s ease-in-out infinite;box-shadow:0 0 #34d39980}@keyframes pulse{0%,to{box-shadow:0 0 #34d39980}50%{box-shadow:0 0 0 8px #34d39900}}.timer-info>.icon{color:var(--primary-400)}.timer-details{display:flex;flex-direction:column}.timer-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.timer-project{font-weight:600;color:var(--text-primary)}.timer-actions{display:flex;align-items:center;gap:var(--space-lg)}.timer-duration{font-size:1.5rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg);margin-bottom:var(--space-2xl)}.stat-card{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-xl);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);transition:all var(--transition-base)}.stat-card:hover{border-color:var(--border-glow);transform:translateY(-2px)}.stat-icon{width:52px;height:52px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon svg{width:24px;height:24px}.stat-icon-primary{background:linear-gradient(135deg,#3b82f626,#2563eb14);color:var(--primary-400)}.stat-icon-cyan{background:linear-gradient(135deg,#06b6d426,#3b82f614);color:var(--accent-cyan)}.stat-icon-emerald{background:linear-gradient(135deg,#34d39933,#22d3ee1a);color:var(--accent-emerald)}.stat-icon-amber{background:linear-gradient(135deg,#fbbf2433,#fb71851a);color:var(--accent-amber)}.stat-icon-rose{background:linear-gradient(135deg,#ef444433,#ef44441a);color:var(--accent-rose)}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{transform:translateY(-2px)}.text-danger{color:var(--accent-rose)!important}.text-warning{color:var(--accent-amber)!important}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-label{font-size:.875rem;color:var(--text-tertiary)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);margin-bottom:var(--space-2xl)}.dashboard-grid-single{grid-template-columns:1fr}.dashboard-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-xl)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg)}.section-header h2{font-size:1.125rem;font-weight:600}.section-link{display:flex;align-items:center;gap:var(--space-xs);font-size:.875rem;color:var(--primary-400);text-decoration:none;font-weight:500}.section-link .icon{width:16px;height:16px}.section-link:hover{color:var(--primary-300)}.project-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-lg);transition:background var(--transition-fast)}.project-card:hover{background:var(--bg-tertiary)}.project-info{flex:1;min-width:0}.project-info h3{font-size:.9375rem;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-info p{font-size:.8125rem;color:var(--text-tertiary)}.activity-list{display:flex;flex-direction:column;gap:var(--space-sm)}.activity-item{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-lg)}.activity-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px}.activity-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.activity-project{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.activity-description{font-size:.8125rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.activity-duration{font-size:.875rem;font-weight:600;color:var(--text-primary)}.activity-date{font-size:.75rem;color:var(--text-tertiary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);text-align:center}.empty-icon{width:48px;height:48px;color:var(--text-muted);margin-bottom:var(--space-md)}.empty-state p{color:var(--text-tertiary);margin-bottom:var(--space-md)}.quick-actions{margin-top:var(--space-xl)}.quick-actions h2{font-size:1.125rem;margin-bottom:var(--space-lg)}.actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.action-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);text-decoration:none;color:var(--text-primary);transition:all var(--transition-base)}.action-card:hover{border-color:var(--primary-500);background:#3b82f614;transform:translateY(-2px)}.action-icon{width:32px;height:32px;color:var(--primary-400)}.action-card span{font-weight:500}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.dashboard-grid{grid-template-columns:1fr}.actions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.dashboard-header{flex-direction:column;align-items:stretch}.welcome-section h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.stat-card{padding:var(--space-lg)}.running-timer-banner{flex-direction:column;align-items:flex-start}.timer-actions{width:100%;justify-content:space-between}.actions-grid{grid-template-columns:1fr}}.time-tracking-page{max-width:600px;margin:0 auto}.time-entry-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-xl)}.time-entry-form{display:flex;flex-direction:column;gap:var(--space-lg)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.form-grid .span-full{grid-column:1 / -1}.hours-input-wrapper{display:flex;align-items:stretch;gap:0;border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-secondary);transition:border-color var(--transition-fast)}.hours-input-wrapper:focus-within{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.hours-input-wrapper .hours-input{border:none;border-radius:0;text-align:center;font-size:1.125rem;font-weight:600;padding:.625rem var(--space-sm);flex:1;min-width:0}.hours-input-wrapper .hours-input:focus{box-shadow:none}.hours-btn{width:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:none;color:var(--text-primary);font-size:1.25rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.hours-btn:hover:not(:disabled){background:var(--primary-600);color:#fff}.hours-btn:disabled{opacity:.3;cursor:not-allowed}.quick-hours{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.quick-hours-label{font-size:.75rem;color:var(--text-tertiary);font-weight:500;margin-right:var(--space-xs)}.quick-hour-btn{padding:4px 10px;border:1px solid var(--border-color);border-radius:var(--radius-full);background:transparent;color:var(--text-secondary);font-size:.75rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.quick-hour-btn:hover{border-color:var(--primary-500);color:var(--primary-400)}.quick-hour-btn.active{background:var(--primary-500);border-color:var(--primary-500);color:#fff}.form-error{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:#fb71851a;border:1px solid rgba(251,113,133,.2);border-radius:var(--radius-lg);color:var(--accent-rose);font-size:.875rem;font-weight:500}.form-error .icon{width:18px;height:18px;flex-shrink:0}.form-success{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:#34d3991a;border:1px solid rgba(52,211,153,.2);border-radius:var(--radius-lg);color:var(--accent-emerald);font-size:.875rem;font-weight:500}.form-success .icon{width:18px;height:18px;flex-shrink:0}.submit-btn{margin-top:var(--space-sm)}.project-picker-trigger{display:flex;align-items:center;text-align:left;cursor:pointer;min-height:44px}.project-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:1000;display:flex;align-items:flex-end;justify-content:center}.project-picker{background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .25s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.project-picker-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border-color);flex-shrink:0}.project-picker-header h2{font-size:1.125rem;font-weight:600}.project-picker-search{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);border-bottom:1px solid var(--border-color);flex-shrink:0}.project-picker-search .icon{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.project-picker-search-input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:1rem;outline:none;padding:var(--space-xs) 0}.project-picker-search-input::placeholder{color:var(--text-muted)}.project-picker-list{flex:1;overflow-y:auto;padding:var(--space-sm) 0;-webkit-overflow-scrolling:touch}.project-picker-item{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:var(--space-md) var(--space-xl);border:none;background:transparent;cursor:pointer;text-align:left;color:var(--text-primary);font-size:.9375rem;transition:background var(--transition-fast)}.project-picker-item:hover{background:var(--bg-secondary)}.project-picker-item.selected{background:#3b82f614}.project-picker-color{width:4px;height:32px;border-radius:var(--radius-full);flex-shrink:0}.project-picker-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.project-picker-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-picker-customer{font-size:.8125rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-picker-empty{padding:var(--space-2xl);text-align:center;color:var(--text-tertiary);font-size:.875rem}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}.quick-hours{justify-content:flex-start}}.projects-page{max-width:900px;margin:0 auto}.list-toolbar{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);align-items:center;flex-wrap:wrap}.search-box{flex:1;min-width:200px;position:relative}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted)}.search-input{width:100%;padding:.5rem .5rem .5rem 36px;font-family:inherit;font-size:.875rem;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f626}.filter-tabs{display:flex;gap:2px;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:2px;border:1px solid var(--border-color)}.filter-tab{padding:6px 12px;border:none;background:transparent;color:var(--text-tertiary);font-size:.75rem;font-weight:500;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap}.filter-tab:hover{color:var(--text-primary)}.filter-tab.active{background:var(--primary-500);color:#fff}.compact-list{display:flex;flex-direction:column;gap:2px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:visible}.compact-list-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-card);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--border-color)}.compact-list-item:first-child{border-radius:var(--radius-xl) var(--radius-xl) 0 0}.compact-list-item:last-child{border-bottom:none;border-radius:0 0 var(--radius-xl) var(--radius-xl)}.compact-list-item:only-child{border-radius:var(--radius-xl)}.compact-list-item:hover{background:var(--bg-glass)}.item-color-bar{width:4px;height:36px;border-radius:var(--radius-full);flex-shrink:0}.item-content{flex:1;min-width:0}.item-title-row{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:2px}.item-title{font-weight:600;font-size:.9375rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-meta{display:flex;gap:var(--space-md);flex-wrap:wrap}.item-meta-tag{display:flex;align-items:center;gap:4px;font-size:.8125rem;color:var(--text-tertiary)}.item-meta-tag .icon{width:14px;height:14px}.item-actions{display:flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.item-chevron{width:16px;height:16px;color:var(--text-muted)}.item-menu-wrapper{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:4px;min-width:140px;z-index:10;box-shadow:var(--shadow-lg)}.dropdown-menu button{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:8px 12px;background:transparent;border:none;color:var(--text-primary);font-size:.8125rem;cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-fast)}.dropdown-menu button:hover{background:var(--bg-tertiary)}.dropdown-menu button.danger{color:var(--accent-rose)}.dropdown-menu button .icon{width:14px;height:14px}@media (max-width: 768px){.list-toolbar{flex-direction:column;align-items:stretch}.filter-tabs{overflow-x:auto}.compact-list-item{padding:var(--space-sm) var(--space-md)}}.project-detail-page{max-width:1000px;margin:0 auto}.project-header{border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-lg);color:#fff;display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md)}.project-edit-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap;flex-shrink:0}.project-edit-btn:hover{background:#ffffff59}.project-header-info h1{color:#fff;font-size:1.5rem;margin-bottom:var(--space-xs)}.project-desc{color:#ffffffd9;font-size:.875rem;margin-bottom:var(--space-sm)}.project-customer-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#fff3;border-radius:var(--radius-full);font-size:.75rem;font-weight:500;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.project-customer-tag .icon{width:14px;height:14px}.detail-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.detail-stat{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.detail-stat-icon{width:20px;height:20px;color:var(--primary-400);flex-shrink:0}.detail-stat-value{font-size:1.125rem;font-weight:700;color:var(--text-primary);display:block;line-height:1.2}.detail-stat-label{font-size:.6875rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.budget-bar-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-lg)}.budget-bar-header{display:flex;justify-content:space-between;margin-bottom:var(--space-sm);font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.budget-bar-track{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.budget-bar-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width .5s ease}.budget-bar-fill.warning{background:linear-gradient(135deg,var(--accent-amber) 0%,#f59e0b 100%)}.budget-bar-fill.danger{background:linear-gradient(135deg,var(--accent-rose) 0%,#ef4444 100%)}.budget-bar-footer{display:flex;justify-content:space-between;margin-top:var(--space-xs);font-size:.6875rem;color:var(--text-tertiary)}.detail-filters{display:flex;gap:var(--space-sm);align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap}.filter-input{flex:1;min-width:120px;max-width:180px;padding:6px 10px;font-size:.8125rem}.detail-grid{display:grid;grid-template-columns:1fr 2fr;gap:var(--space-lg)}.detail-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg)}.detail-card h2{font-size:1rem;margin-bottom:var(--space-md);display:flex;align-items:center}.detail-card h2 .icon{width:18px;height:18px;color:var(--primary-400)}.team-list{display:flex;flex-direction:column;gap:var(--space-sm)}.team-member-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md);transition:background var(--transition-fast)}.team-member-row:hover{background:var(--bg-glass)}.team-member-avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.team-member-avatar .icon{width:14px;height:14px;color:var(--text-tertiary)}.team-member-info{flex:1;min-width:0}.team-member-name{font-size:.8125rem;font-weight:500;color:var(--text-primary);display:block;margin-bottom:4px}.team-member-bar{height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.team-member-bar-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width .5s ease;min-width:4px}.team-member-hours{font-size:.8125rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.entries-table{overflow-x:auto}.entries-table-header{display:grid;grid-template-columns:80px 1fr 100px 80px;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:.6875rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color)}.entries-table-row{display:grid;grid-template-columns:80px 1fr 100px 80px;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:.8125rem;border-bottom:1px solid var(--border-color);transition:background var(--transition-fast)}.entries-table-row:last-child{border-bottom:none}.entries-table-row:hover{background:var(--bg-glass)}.entry-date{color:var(--text-secondary);font-variant-numeric:tabular-nums}.entry-desc{color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-user{color:var(--text-tertiary);font-size:.75rem}.entry-hours{font-weight:600;color:var(--text-primary)}.text-right{text-align:right}@media (max-width: 768px){.detail-grid{grid-template-columns:1fr}.detail-stats-row{grid-template-columns:repeat(2,1fr)}.detail-filters{flex-direction:column;align-items:stretch}.filter-input{max-width:none}.entries-table-header,.entries-table-row{grid-template-columns:60px 1fr 60px}.entry-user{display:none}}.customers-page{max-width:900px;margin:0 auto}.customer-avatar-small{width:36px;height:36px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.customer-avatar-small .icon{width:18px;height:18px}.item-subtitle{font-size:.75rem;color:var(--text-tertiary);font-weight:400}@media (max-width: 768px){.customers-page{padding:0}}.customer-detail-page{max-width:1000px;margin:0 auto}.back-btn{margin-bottom:var(--space-md);font-size:.875rem}.customer-header{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg);background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:var(--radius-xl);margin-bottom:var(--space-lg)}.customer-header-icon{width:56px;height:56px;background:#fff3;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.customer-header-icon svg{width:28px;height:28px}.customer-header-content h1{color:#fff;font-size:1.5rem;margin-bottom:2px}.customer-company{color:#ffffffd9;font-size:.9375rem}.customer-details-grid{display:grid;grid-template-columns:1fr 2fr;gap:var(--space-lg)}.customer-info-card,.customer-projects-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg)}.customer-info-card h2,.customer-projects-card h2{font-size:1rem;margin-bottom:var(--space-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.info-list{display:flex;flex-direction:column;gap:var(--space-md)}.info-item{display:flex;gap:var(--space-sm)}.info-item-icon{width:16px;height:16px;color:var(--primary-400);flex-shrink:0;margin-top:2px}.info-label{display:block;font-size:.6875rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.info-value{display:block;color:var(--text-primary);font-size:.875rem}.info-value.link{color:var(--primary-400);text-decoration:none;transition:color var(--transition-fast)}.info-value.link:hover{color:var(--primary-300)}.info-value.notes{white-space:pre-wrap;line-height:1.5;color:var(--text-secondary)}.projects-list{display:flex;flex-direction:column;gap:var(--space-sm)}.project-item{display:flex;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast);align-items:center}.project-item.clickable{cursor:pointer}.project-item.clickable:hover{background:var(--bg-glass);border-color:var(--border-glow);transform:translate(4px)}.project-color{width:4px;height:36px;border-radius:var(--radius-full);flex-shrink:0}.project-content{flex:1;min-width:0}.project-header-row{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:2px}.project-header-row h3{font-size:.9375rem;color:var(--text-primary);margin:0}.project-description{color:var(--text-secondary);font-size:.8125rem;margin-bottom:var(--space-xs);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical}.project-meta{display:flex;gap:var(--space-md)}.meta-item{display:flex;align-items:center;gap:4px;color:var(--text-tertiary);font-size:.75rem}.meta-item .icon{width:12px;height:12px}.project-chevron{width:16px;height:16px;color:var(--text-muted);flex-shrink:0}@media (max-width: 900px){.customer-details-grid{grid-template-columns:1fr}}@media (max-width: 640px){.customer-header{padding:var(--space-md)}.customer-header-icon{width:44px;height:44px}.customer-header-icon svg{width:22px;height:22px}.customer-header-content h1{font-size:1.25rem}}.team-page{max-width:1000px;margin:0 auto}.team-page .page-header{margin-bottom:var(--space-2xl)}.team-page .page-header h1{font-size:1.75rem;margin-bottom:var(--space-xs)}.team-page .page-header p{color:var(--text-tertiary)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);gap:var(--space-lg)}.loading-state p{color:var(--text-tertiary)}.team-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);margin-bottom:var(--space-2xl)}.team-stat{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-xl);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl)}.team-stat.pending{border-color:#fbbf2466;animation:pulse-border 2s ease-in-out infinite}@keyframes pulse-border{0%,to{border-color:#fbbf2466}50%{border-color:#fbbf24cc}}.team-stat-icon{width:52px;height:52px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f626,#2563eb14);color:var(--primary-400)}.team-stat-icon.admin{background:linear-gradient(135deg,#fbbf2433,#fb71851a);color:var(--accent-amber)}.team-stat-icon.employee{background:linear-gradient(135deg,#06b6d426,#3b82f614);color:var(--accent-cyan)}.team-stat-icon.pending{background:linear-gradient(135deg,#fbbf244d,#fbbf241a);color:var(--accent-amber)}.team-stat-icon svg{width:24px;height:24px}.team-stat-content{display:flex;flex-direction:column}.team-stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1.2}.team-stat-label{font-size:.875rem;color:var(--text-tertiary)}.pending-container{margin-bottom:var(--space-xl);border-color:#fbbf244d;background:linear-gradient(135deg,rgba(251,191,36,.05) 0%,var(--bg-card) 50%)}.pending-container .team-list-header h2{display:flex;align-items:center;gap:var(--space-sm)}.header-icon{width:20px;height:20px}.header-icon.warning{color:var(--accent-amber)}.pending-badge{font-size:.75rem;font-weight:600;padding:4px 10px;background:#fbbf2433;color:var(--accent-amber);border-radius:var(--radius-full)}.pending-member{background:#fbbf2408}.member-avatar.pending{background:linear-gradient(135deg,#fbbf2499,#fbbf2466)}.team-list-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.team-list-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xl);border-bottom:1px solid var(--border-color)}.team-list-header h2{font-size:1.125rem}.team-list{display:flex;flex-direction:column}.team-member{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border-color);transition:background var(--transition-fast)}.team-member:last-child{border-bottom:none}.team-member:hover{background:var(--bg-secondary)}.member-avatar{width:48px;height:48px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1rem;flex-shrink:0}.member-info{flex:1;min-width:0}.member-name{font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm)}.you-badge{font-size:.625rem;font-weight:600;padding:2px 6px;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:var(--radius-full);text-transform:uppercase}.member-email{display:flex;align-items:center;gap:var(--space-xs);font-size:.875rem;color:var(--text-tertiary);margin-top:2px}.member-email .icon{width:14px;height:14px}.member-role{min-width:120px}.member-date{display:flex;flex-direction:column;align-items:flex-end;min-width:100px}.date-label{font-size:.75rem;color:var(--text-tertiary)}.date-value{font-size:.875rem;color:var(--text-secondary)}.member-actions{min-width:40px;display:flex;justify-content:flex-end}.member-actions.approval-actions{gap:var(--space-sm);min-width:auto}.modal-small{max-width:420px}.modal-small .modal-body{gap:var(--space-xl)}.edit-user-info{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.edit-user-info .member-name{font-size:1rem}.edit-user-info .member-email{margin-top:0}.role-options{display:flex;flex-direction:column;gap:var(--space-sm)}.role-option{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.role-option:hover{border-color:var(--text-tertiary)}.role-option.selected{border-color:var(--primary-500);background:#3b82f614}.role-icon{width:24px;height:24px;color:var(--primary-400);flex-shrink:0;margin-top:2px}.role-content{flex:1;display:flex;flex-direction:column;gap:2px}.role-title{font-weight:600;color:var(--text-primary)}.role-desc{font-size:.8125rem;color:var(--text-tertiary)}.check-icon{width:20px;height:20px;color:var(--primary-400);flex-shrink:0}@media (max-width: 768px){.team-stats{grid-template-columns:1fr}.team-member{flex-wrap:wrap;gap:var(--space-md)}.member-info{flex:1 1 calc(100% - 64px)}.member-role{order:3}.member-date{order:4;align-items:flex-start}.member-actions{order:5;margin-left:auto}}.reports-page{max-width:1000px;margin:0 auto}.reports-filters{display:flex;gap:var(--space-sm);align-items:center;margin-bottom:var(--space-lg);flex-wrap:wrap}.reports-month-picker{display:flex;align-items:center;gap:var(--space-sm)}.reports-filters .filter-input{flex:none;width:auto;min-width:160px;max-width:none;padding:6px 10px;font-size:.8125rem}.reports-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-lg)}.report-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg)}.report-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.report-card-header h2{font-size:1rem;display:flex;align-items:center;gap:8px}.report-card-header h2 .icon{width:18px;height:18px;color:var(--primary-400)}.report-table{width:100%}.report-table-header{display:grid;grid-template-columns:1fr 100px;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:.6875rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color)}.report-table-row{display:grid;grid-template-columns:1fr 100px;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:.8125rem;border-bottom:1px solid var(--border-color);transition:background var(--transition-fast)}.report-table-row:last-child{border-bottom:none}.report-table-row:hover{background:var(--bg-glass)}.report-table-row.total-row{font-weight:700;border-top:2px solid var(--border-color);border-bottom:none;color:var(--text-primary)}.report-name{color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.report-hours{text-align:right;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.csv-export-btn{margin-left:auto}.reports-total-bar{display:flex;gap:var(--space-lg);margin-bottom:var(--space-lg)}.reports-total-card{flex:1;display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.reports-total-card .icon{width:20px;height:20px;color:var(--primary-400);flex-shrink:0}.reports-total-value{font-size:1.125rem;font-weight:700;color:var(--text-primary);display:block;line-height:1.2}.reports-total-label{font-size:.6875rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}@media (max-width: 768px){.reports-grid{grid-template-columns:1fr}.reports-filters{flex-direction:column;align-items:stretch}.reports-month-picker{justify-content:center}.reports-filters .filter-input{min-width:auto}.reports-total-bar{flex-direction:column;gap:var(--space-sm)}}.settings-page{max-width:700px;margin:0 auto}.settings-grid{display:flex;flex-direction:column;gap:var(--space-md)}.settings-section{display:flex;gap:var(--space-lg);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);transition:all var(--transition-base)}.settings-section:hover{border-color:var(--border-glow)}.danger-section:hover{border-color:#fb71854d}.section-icon{width:40px;height:40px;border-radius:var(--radius-lg);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary-400)}.section-icon svg{width:20px;height:20px}.section-icon.danger{color:var(--accent-rose)}.section-content{flex:1;min-width:0}.section-content h2{font-size:1rem;margin-bottom:2px}.section-content>p{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:var(--space-md)}.settings-form{display:flex;flex-direction:column;gap:var(--space-md)}.input-hint{font-size:.6875rem;color:var(--text-muted)}.spinner-icon{animation:spin .8s linear infinite}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) 0}.settings-row .info-label{font-size:.8125rem;color:var(--text-secondary)}@media (max-width: 640px){.settings-section{flex-direction:column;gap:var(--space-md)}.section-icon{width:36px;height:36px}}.pending-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);position:relative;overflow:hidden}.pending-background{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a)}.pending-background .gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4}.pending-background .orb-1{width:400px;height:400px;background:linear-gradient(135deg,#2563eb,#3b82f6);top:-100px;left:-100px;animation:float 8s ease-in-out infinite}.pending-background .orb-2{width:300px;height:300px;background:linear-gradient(135deg,#0ea5e9,#2563eb);bottom:-50px;right:-50px;animation:float 10s ease-in-out infinite reverse}.pending-background .orb-3{width:200px;height:200px;background:linear-gradient(135deg,#4b5563,#6b7280);top:50%;left:50%;transform:translate(-50%,-50%);animation:float 12s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(5deg)}}.pending-container{position:relative;z-index:1;width:100%;max-width:500px}.pending-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--space-3xl);text-align:center;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.pending-icon-wrapper{width:100px;height:100px;background:linear-gradient(135deg,#fbbf24,#f97316);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-xl);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #fbbf2466}50%{transform:scale(1.05);box-shadow:0 0 0 20px #fbbf2400}}.pending-icon{width:48px;height:48px;color:#fff}.pending-card h1{font-size:1.75rem;margin-bottom:var(--space-md);color:var(--text-primary)}.pending-greeting{font-size:1.125rem;color:var(--primary-400);margin-bottom:var(--space-md);font-weight:500}.pending-message{color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-xl)}.pending-info-box{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);text-align:left}.pending-info-box h3{font-size:.875rem;color:var(--text-primary);margin-bottom:var(--space-md);font-weight:600}.pending-info-box ul{list-style:none;padding:0;margin:0}.pending-info-box li{color:var(--text-secondary);font-size:.875rem;padding:var(--space-sm) 0;padding-left:var(--space-lg);position:relative}.pending-info-box li:before{content:"✓";position:absolute;left:0;color:var(--accent-emerald);font-weight:700}.pending-status{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md);background:#fbbf241a;border-radius:var(--radius-lg);margin-bottom:var(--space-xl);color:#fbbf24;font-weight:500}.status-dot{width:10px;height:10px;background:#fbbf24;border-radius:50%;animation:blink 1.5s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}@media (max-width: 640px){.pending-card{padding:var(--space-xl)}.pending-icon-wrapper{width:80px;height:80px}.pending-icon{width:36px;height:36px}.pending-card h1{font-size:1.5rem}}.network-status{position:fixed;top:0;left:0;right:0;z-index:1000;padding:6px var(--space-lg);animation:slideDown .3s ease-out;pointer-events:auto}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.network-status.offline{background:#ef4444e6;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.network-status.online{background:#22c55ee6;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.network-status.syncing{background:#f59e0be6;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.network-status-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:var(--space-sm)}.network-status-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.network-status-icon .icon{width:14px;height:14px}.network-status-icon .icon.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.network-status-text{flex:1;display:flex;align-items:center;gap:var(--space-sm);font-size:.75rem}.network-status-text strong{font-size:.75rem;font-weight:600}.network-status-text span{font-size:.75rem;opacity:.9}.btn-sync{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:2px var(--space-sm);gap:var(--space-xs);font-size:.6875rem;white-space:nowrap;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;align-items:center}.btn-sync:hover{background:#ffffff4d}.btn-sync .icon{width:12px;height:12px}.network-status-close{background:none;border:none;color:#fff;opacity:.7;cursor:pointer;padding:2px;display:flex;align-items:center;font-size:.75rem}.network-status-close:hover{opacity:1}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:280px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100}.sidebar-header{padding:var(--space-xl);border-bottom:1px solid var(--border-color)}.logo{display:flex;align-items:center;gap:var(--space-md)}.logo-icon{width:44px;height:44px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-glow-sm)}.logo-icon .icon{width:24px;height:24px;color:#fff}.logo-text{display:flex;flex-direction:column}.logo-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);line-height:1.2}.logo-subtitle{font-size:.75rem;font-weight:600;color:var(--primary-400);text-transform:uppercase;letter-spacing:.1em}.sidebar-nav{flex:1;padding:var(--space-lg) var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs);overflow-y:auto}.nav-link{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-lg);transition:all var(--transition-fast);font-weight:500}.nav-link:hover{background:var(--bg-glass);color:var(--text-primary)}.nav-link.active{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow-sm)}.nav-icon{width:20px;height:20px;flex-shrink:0}.sidebar-footer{padding:var(--space-lg);border-top:1px solid var(--border-color);display:flex;align-items:center;gap:var(--space-md)}.user-info{flex:1;display:flex;align-items:center;gap:var(--space-md);min-width:0}.user-details{flex:1;display:flex;flex-direction:column;min-width:0}.user-name{font-weight:600;color:var(--text-primary);font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.75rem;color:var(--text-tertiary)}.logout-btn{flex-shrink:0}.logout-btn:hover{color:var(--accent-rose)}.main-content{flex:1;margin-left:280px;padding:var(--space-2xl);height:100vh;overflow-y:auto;background:var(--bg-primary)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0 var(--space-sm);align-items:center;z-index:200}.mobile-header .btn-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-header .logo{flex:1;justify-content:center;gap:var(--space-xs)}.mobile-header .logo .icon{width:20px;height:20px;color:var(--primary-400)}.mobile-header .logo span{font-weight:700;font-size:1rem}.mobile-header .avatar-wrapper{width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-menu-overlay{display:none;position:fixed;top:56px;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:150;animation:fadeIn var(--transition-fast) ease-out}.mobile-menu{width:280px;height:100%;background:var(--bg-secondary);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs);animation:slideIn var(--transition-base) ease-out}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.logout-mobile{margin-top:auto;color:var(--accent-rose);border:none;background:transparent;cursor:pointer;width:100%;text-align:left}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:72px;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:0 var(--space-md);padding-bottom:env(safe-area-inset-bottom,0);align-items:center;z-index:200}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);color:var(--text-tertiary);text-decoration:none;font-size:.75rem;font-weight:500;transition:color var(--transition-fast)}.bottom-nav-item .icon{width:24px;height:24px}.bottom-nav-item.active{color:var(--primary-400)}@media (hover: hover){.bottom-nav-item:hover{color:var(--text-primary)}}@media (max-width: 1024px){.sidebar{width:240px}.main-content{margin-left:240px;padding:var(--space-xl)}}@media (max-width: 768px){.sidebar{display:none}.mobile-header{display:flex}.mobile-menu-overlay{display:block}.mobile-bottom-nav{display:flex}.main-content{margin-left:0;margin-top:56px;margin-bottom:72px;height:calc(100vh - 128px);padding:var(--space-lg)}}@media (max-width: 480px){.main-content{padding:var(--space-md)}}.icon{width:20px;height:20px;flex-shrink:0}:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a5f;--accent-cyan: #06b6d4;--accent-emerald: #10b981;--accent-amber: #f59e0b;--accent-rose: #ef4444;--bg-primary: #0f1419;--bg-secondary: #1a2027;--bg-tertiary: #2a3038;--bg-card: rgba(26, 32, 39, .85);--bg-glass: rgba(26, 32, 39, .6);--text-primary: #e8eaed;--text-secondary: #9aa0a6;--text-tertiary: #6b7280;--text-muted: #4b5563;--border-color: rgba(148, 163, 184, .12);--border-glow: rgba(59, 130, 246, .25);--gradient-primary: linear-gradient(135deg, #2563eb 0%, #3b82f6 100%);--gradient-accent: linear-gradient(135deg, #0ea5e9 0%, #2563eb 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #06b6d4 100%);--gradient-warm: linear-gradient(135deg, #f59e0b 0%, #ef4444 100%);--gradient-dark: linear-gradient(180deg, #0f1419 0%, #1a2027 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .12);--shadow-md: 0 4px 12px rgba(0, 0, 0, .16);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .2);--shadow-xl: 0 12px 48px rgba(0, 0, 0, .28);--shadow-glow: 0 0 30px rgba(59, 130, 246, .15);--shadow-glow-sm: 0 0 15px rgba(59, 130, 246, .1);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);color-scheme:dark}[data-theme=light]{--bg-primary: #f9fafb;--bg-secondary: #ffffff;--bg-tertiary: #e5e7eb;--bg-card: rgba(255, 255, 255, .92);--bg-glass: rgba(255, 255, 255, .7);--text-primary: #111827;--text-secondary: #4b5563;--text-tertiary: #6b7280;--text-muted: #9ca3af;--border-color: rgba(17, 24, 39, .08);--border-glow: rgba(59, 130, 246, .2);--gradient-dark: linear-gradient(180deg, #f9fafb 0%, #e5e7eb 100%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .08);--shadow-xl: 0 12px 48px rgba(0, 0, 0, .1);--shadow-glow: 0 0 30px rgba(59, 130, 246, .1);--shadow-glow-sm: 0 0 15px rgba(59, 130, 246, .06);color-scheme:light}[data-theme=light] .nav-link{color:var(--text-primary)}[data-theme=light] .nav-link:hover{background:var(--bg-glass)}[data-theme=light] .nav-link.active{color:#fff}[data-theme=light] .bottom-nav-item{color:var(--text-primary)}[data-theme=light] .bottom-nav-item.active{color:var(--primary-500)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}input,textarea,[contenteditable]{-webkit-user-select:text;user-select:text}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--gradient-dark);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--primary-600)}::selection{background:var(--primary-500);color:#fff}:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--text-primary)}h1{font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.02em}h2{font-size:clamp(1.125rem,2vw,1.5rem);letter-spacing:-.01em}h3{font-size:clamp(1rem,1.5vw,1.25rem)}h4{font-size:1rem}p{color:var(--text-secondary)}a{color:var(--primary-400);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-300)}[data-theme=light] a{color:var(--primary-600)}[data-theme=light] a:hover{color:var(--primary-700)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-family:inherit;font-size:.875rem;font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md),0 0 20px #3b82f64d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-lg),0 0 30px #3b82f666}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--primary-500)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-glass);color:var(--text-primary)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-lg),0 0 30px #ef444466}.btn-icon{padding:var(--space-sm);border-radius:var(--radius-md)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:.9375rem;border-radius:var(--radius-xl)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:.8125rem}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-base)}.card:hover{border-color:var(--border-glow);box-shadow:var(--shadow-glow-sm)}.card-glass{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.input-group{display:flex;flex-direction:column;gap:var(--space-xs)}.input-label{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.input{width:100%;padding:.625rem var(--space-md);font-family:inherit;font-size:.875rem;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.input::placeholder{color:var(--text-muted)}.input:hover{border-color:var(--text-tertiary)}.input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f633}.input-error{border-color:var(--accent-rose)}.input-error:focus{box-shadow:0 0 0 3px #fb718533}.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='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;padding-right:2.5rem}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=date],input[type=time],input[type=datetime-local]{color-scheme:dark;background:var(--bg-secondary);color:var(--text-primary)}[data-theme=light] input[type=date],[data-theme=light] input[type=time],[data-theme=light] input[type=datetime-local]{color-scheme:light}input[type=date]::-webkit-calendar-picker-indicator,input[type=time]::-webkit-calendar-picker-indicator,input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}[data-theme=light] input[type=date]::-webkit-calendar-picker-indicator,[data-theme=light] input[type=time]::-webkit-calendar-picker-indicator,[data-theme=light] input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:none}.badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:2px 8px;font-size:.6875rem;font-weight:600;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.badge-primary{background:#3b82f626;color:var(--primary-400)}.badge-success{background:#34d39926;color:var(--accent-emerald)}.badge-warning{background:#fbbf2426;color:var(--accent-amber)}.badge-danger{background:#fb718526;color:var(--accent-rose)}.badge-info{background:#22d3ee26;color:var(--accent-cyan)}[data-theme=light] .badge-primary{background:#3b82f61a;color:var(--primary-600)}[data-theme=light] .badge-success{background:#10b9811a;color:#059669}[data-theme=light] .badge-warning{background:#f59e0b1a;color:#d97706}[data-theme=light] .badge-danger{background:#ef44441a;color:#dc2626}[data-theme=light] .badge-info{background:#06b6d41a;color:#0891b2}.avatar{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;font-weight:600;overflow:hidden}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-md{width:36px;height:36px;font-size:.8125rem}.avatar-lg{width:44px;height:44px;font-size:1rem}.avatar-xl{width:56px;height:56px;font-size:1.125rem}.avatar img{width:100%;height:100%;object-fit:cover}.spinner{width:24px;height:24px;border:3px solid var(--bg-tertiary);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fadeIn{animation:fadeIn var(--transition-base) ease-out}.animate-slideUp{animation:slideUp var(--transition-base) ease-out}.animate-slideDown{animation:slideDown var(--transition-base) ease-out}.animate-scaleIn{animation:scaleIn var(--transition-spring)}.animate-pulse{animation:pulse 2s ease-in-out infinite}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);gap:var(--space-md);color:var(--text-tertiary)}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);z-index:9999}.loading-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--text-tertiary)}.empty-state .empty-icon,.empty-icon{width:48px;height:48px;margin:0 auto var(--space-md);opacity:.4}.empty-state h3{font-size:1rem;margin-bottom:var(--space-xs)}.empty-state-large{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-3xl);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);min-height:300px}.empty-icon-wrapper{width:64px;height:64px;background:var(--bg-secondary);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-lg)}.empty-icon-wrapper .empty-icon{width:32px;height:32px;color:var(--text-muted);margin:0}.empty-state-large h2{font-size:1.25rem;margin-bottom:var(--space-sm)}.empty-state-large p{color:var(--text-tertiary);max-width:400px;margin-bottom:var(--space-lg)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-lg);z-index:1000;animation:fadeIn var(--transition-fast) ease-out}.modal{width:100%;max-width:500px;max-height:90vh;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:1.125rem}.modal-body{padding:var(--space-lg);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-md)}.textarea{resize:vertical;min-height:60px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.modal-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--border-color)}.page-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.page-header h1{font-size:1.5rem;margin-bottom:2px}.page-header>div>p{color:var(--text-tertiary);font-size:.875rem}.w-full{width:100%}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.mono{font-family:SF Mono,Monaco,Consolas,monospace}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.modal{max-height:100dvh;height:100dvh;border-radius:0}.modal-overlay{padding:0}.input-label{font-size:.875rem}.input{font-size:1rem;padding:.75rem var(--space-md)}.select{font-size:1rem}.btn{font-size:.9375rem;padding:var(--space-md) var(--space-lg)}.btn-sm{font-size:.875rem;padding:var(--space-sm) var(--space-md)}.badge{font-size:.75rem}.page-header h1{font-size:1.375rem}.page-header>div>p{font-size:.9375rem}p,.text-sm{font-size:.9375rem}.text-xs{font-size:.8125rem}}@media (max-width: 480px){html{font-size:16px}}@supports (padding-top: env(safe-area-inset-top)){body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}.color-picker{display:flex;gap:var(--space-sm)}.color-option{width:32px;height:32px;border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:#fff;box-shadow:0 0 0 2px var(--primary-500)}.color-option .icon{color:#fff;width:16px;height:16px}.theme-toggle{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-lg);cursor:pointer;border:1px solid var(--border-color);transition:all var(--transition-fast)}.theme-toggle:hover{border-color:var(--primary-500)}.theme-toggle-track{width:44px;height:24px;background:var(--bg-tertiary);border-radius:var(--radius-full);position:relative;transition:background var(--transition-base)}.theme-toggle-track.active{background:var(--primary-500)}.theme-toggle-thumb{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform var(--transition-base);box-shadow:0 1px 3px #0003}.theme-toggle-track.active .theme-toggle-thumb{transform:translate(20px)}.theme-toggle-label{display:flex;flex-direction:column;flex:1}.theme-toggle-label span:first-child{font-weight:500;font-size:.875rem;color:var(--text-primary)}.theme-toggle-label span:last-child{font-size:.75rem;color:var(--text-tertiary)}
