@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap");:root{--primary-50:#f0f4f8;--primary-100:#d9e2ec;--primary-200:#bcccdc;--primary-300:#9fb3c8;--primary-400:#829ab1;--primary-500:#627d98;--primary-600:#486581;--primary-700:#334e68;--primary-800:#243b53;--primary-900:#102a43;--accent-50:#f0fdfa;--accent-100:#ccfbf1;--accent-200:#99f6e4;--accent-300:#5eead4;--accent-400:#2dd4bf;--accent-500:#14b8a6;--accent-600:#0d9488;--warning-50:#fffbeb;--warning-100:#fef3c7;--warning-400:#fbbf24;--warning-500:#f59e0b;--warning-600:#d97706;--danger-50:#fff1f2;--danger-100:#ffe4e6;--danger-400:#fb7185;--danger-500:#f43f5e;--danger-600:#e11d48;--gray-25:#fdfdfe;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--gray-950:#020617;--sidebar-bg:var(--primary-900);--sidebar-hover:var(--primary-800);--sidebar-active:var(--primary-700);--sidebar-text:var(--primary-300);--sidebar-text-active:#fff;--sidebar-width:260px;--sidebar-collapsed-width:72px;--content-bg:var(--gray-50);--card-bg:#fff;--card-border:rgba(226,232,240,.8);--card-shadow:0 4px 20px -2px rgba(15,23,42,.05),0 0 3px rgba(15,23,42,.02);--card-shadow-hover:0 12px 32px -4px rgba(15,23,42,.08),0 4px 12px -2px rgba(15,23,42,.04);--card-shadow-lg:0 20px 40px -8px rgba(15,23,42,.12),0 8px 16px -4px rgba(15,23,42,.06);--font-family:"Inter",system-ui,-apple-system,sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.8125rem;--font-size-base:0.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--header-height:72px;--transition-fast:200ms cubic-bezier(0.4,0,0.2,1);--transition-base:300ms cubic-bezier(0.4,0,0.2,1);--transition-slow:500ms cubic-bezier(0.4,0,0.2,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--gray-800);background:var(--content-bg)}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit;font-size:inherit}.app-content-wrapper,.app-layout{display:flex;min-height:100vh}.app-content-wrapper{flex:1 1;margin-left:var(--sidebar-width);flex-direction:column;transition:margin-left var(--transition-slow)}.app-content-wrapper.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.app-main{flex:1 1;padding:var(--space-8);overflow-x:auto}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;z-index:50;transition:width var(--transition-slow);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{padding:var(--space-6);gap:var(--space-3);border-bottom:1px solid hsla(0,0%,100%,.06)}.sidebar-header,.sidebar-logo{display:flex;align-items:center}.sidebar-logo{width:36px;height:36px;background:linear-gradient(135deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-md);justify-content:center;color:#fff;font-weight:800;font-size:var(--font-size-lg);flex-shrink:0}.sidebar-brand{font-size:var(--font-size-xl);font-weight:700;color:#fff;letter-spacing:-.02em;white-space:nowrap;transition:opacity var(--transition-base)}.sidebar.collapsed .sidebar-brand{opacity:0;width:0}.sidebar-nav{flex:1 1;padding:var(--space-4) var(--space-3);display:flex;flex-direction:column;gap:var(--space-1);overflow-y:auto}.sidebar-section-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--gray-500);padding:var(--space-4) var(--space-3) var(--space-2);white-space:nowrap}.sidebar.collapsed .sidebar-section-label{opacity:0}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--sidebar-text);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast);white-space:nowrap}.sidebar-link:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}.sidebar-link.active{background:var(--sidebar-active);color:var(--sidebar-text-active)}.sidebar-link svg{width:20px;height:20px;flex-shrink:0}.sidebar.collapsed .sidebar-link span{opacity:0;width:0}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid hsla(0,0%,100%,.06)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast)}.sidebar-user:hover{background:var(--sidebar-hover)}.sidebar-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-400),var(--accent-400));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:var(--font-size-sm);flex-shrink:0}.sidebar-user-info{white-space:nowrap;overflow:hidden}.sidebar.collapsed .sidebar-user-info{opacity:0;width:0}.sidebar-user-name{font-size:var(--font-size-sm);font-weight:600;color:var(--sidebar-text-active)}.sidebar-user-role{font-size:var(--font-size-xs);color:var(--gray-500)}.sidebar-toggle{position:absolute;right:-12px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:var(--radius-full);background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--card-shadow);display:flex;align-items:center;justify-content:center;z-index:51;transition:all var(--transition-fast)}.sidebar-toggle:hover{background:var(--primary-50);border-color:var(--primary-300)}.header{height:var(--header-height);background:hsla(0,0%,100%,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--card-border);justify-content:space-between;padding:0 var(--space-8);position:-webkit-sticky;position:sticky;top:0;z-index:40}.header,.header-left{display:flex;align-items:center}.header-left{gap:var(--space-4)}.header-title{font-size:var(--font-size-lg);font-weight:700;color:var(--gray-900)}.header-subtitle{font-size:var(--font-size-sm);color:var(--gray-500)}.header-right{gap:var(--space-3)}.header-right,.header-search{display:flex;align-items:center}.header-search{gap:var(--space-2);background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);width:260px;transition:all var(--transition-fast)}.header-search:focus-within{border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100);background:#fff}.header-search input{border:none;background:none;outline:none;width:100%;font-size:var(--font-size-sm);color:var(--gray-700)}.header-search svg{width:16px;height:16px;color:var(--gray-400);flex-shrink:0}.header-icon-btn{position:relative;width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--gray-500);transition:all var(--transition-fast)}.header-icon-btn:hover{background:var(--gray-100);color:var(--gray-700)}.header-icon-btn .badge{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:var(--radius-full);background:var(--danger-500);border:2px solid var(--card-bg)}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--card-shadow);transition:all var(--transition-base)}.card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-2px)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.card-title{font-size:var(--font-size-md);font-weight:700;color:var(--gray-900)}.card-description{color:var(--gray-500);margin-top:var(--space-1)}.btn,.card-description{font-size:var(--font-size-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-weight:600;transition:all var(--transition-fast);line-height:1.5;white-space:nowrap}.btn svg{width:16px;height:16px}.btn-primary{background:linear-gradient(180deg,var(--primary-600) 0,var(--primary-700) 100%);color:#fff;box-shadow:0 1px 2px rgba(15,23,42,.1),inset 0 1px 0 hsla(0,0%,100%,.1);border:1px solid var(--primary-800)}.btn-primary:hover{background:linear-gradient(180deg,var(--primary-500) 0,var(--primary-600) 100%);box-shadow:0 4px 12px rgba(15,23,42,.15),inset 0 1px 0 hsla(0,0%,100%,.1);transform:translateY(-1px)}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:hover{background:var(--gray-200);color:var(--gray-900)}.btn-accent{background:var(--accent-600);color:#fff}.btn-accent:hover{background:var(--accent-500);transform:translateY(-1px)}.btn-danger{background:var(--danger-600);color:#fff}.btn-danger:hover{background:var(--danger-500)}.btn-ghost{color:var(--gray-600)}.btn-ghost:hover{background:var(--gray-100);color:var(--gray-900)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--font-size-md)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-weight:600;color:var(--gray-700)}.form-input,.form-label{font-size:var(--font-size-sm)}.form-input{padding:var(--space-2) var(--space-3);border:1px solid var(--gray-300);border-radius:var(--radius-md);color:var(--gray-800);background:#fff;transition:all var(--transition-fast);outline:none}.form-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.form-input::placeholder{color:var(--gray-400)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:var(--space-2) var(--space-3);padding-right:var(--space-8);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--gray-800);background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='m4.5 6.5 3.5 3.5 3.5-3.5'/%3E%3C/svg%3E") no-repeat right 12px center;transition:all var(--transition-fast);outline:none;cursor:pointer}.form-select:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.toggle-switch-wrapper{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.toggle-switch-label{font-size:var(--font-size-xs);font-weight:600;color:var(--gray-500)}.toggle-switch{position:relative;display:inline-block;width:40px;height:22px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--gray-300);transition:.2s;border-radius:22px}.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background-color:#fff;transition:.2s;border-radius:50%;box-shadow:0 1px 2px rgba(0,0,0,.1)}input:checked+.toggle-slider{background-color:var(--primary-500)}input:focus+.toggle-slider{box-shadow:0 0 0 2px var(--primary-100)}input:checked+.toggle-slider:before{transform:translateX(18px)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;line-height:1.5}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-accent{background:var(--accent-100);color:var(--accent-600)}.badge-warning{background:var(--warning-100);color:var(--warning-600)}.badge-danger{background:var(--danger-100);color:var(--danger-600)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.grid-responsive-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));grid-gap:var(--space-6);gap:var(--space-6)}.grid-responsive-2col{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-6);gap:var(--space-6)}@media (max-width:640px){.grid-responsive-2col{grid-template-columns:1fr;gap:var(--space-4)}}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));grid-gap:var(--space-6);gap:var(--space-6)}.kpi-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--card-shadow);position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.kpi-card.kpi-primary:before{background:linear-gradient(90deg,var(--primary-500),var(--primary-400))}.kpi-card.kpi-accent:before{background:linear-gradient(90deg,var(--accent-500),var(--accent-400))}.kpi-card.kpi-warning:before{background:linear-gradient(90deg,var(--warning-500),var(--warning-400))}.kpi-card.kpi-danger:before{background:linear-gradient(90deg,var(--danger-500),var(--danger-400))}.kpi-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4)}.kpi-primary .kpi-icon{background:var(--primary-100);color:var(--primary-600)}.kpi-accent .kpi-icon{background:var(--accent-100);color:var(--accent-600)}.kpi-warning .kpi-icon{background:var(--warning-100);color:var(--warning-600)}.kpi-danger .kpi-icon{background:var(--danger-100);color:var(--danger-600)}.kpi-value{font-size:var(--font-size-3xl);font-weight:800;color:var(--gray-900);line-height:1.2}.kpi-label{font-size:var(--font-size-sm);color:var(--gray-500);margin-top:var(--space-1)}.kpi-trend{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);font-weight:600;margin-top:var(--space-3)}.kpi-trend.up{color:var(--accent-600)}.kpi-trend.down{color:var(--danger-600)}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);border-bottom:1px solid var(--card-border);background:var(--gray-50)}.table td,.table th{padding:var(--space-3) var(--space-4)}.table td{border-bottom:1px solid var(--gray-100);font-size:var(--font-size-sm)}.table tr:hover td{background:var(--gray-25)}.board-container{overflow-x:auto;border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--card-bg);isolation:isolate}.board-toolbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--card-border);gap:var(--space-4);flex-wrap:wrap}.board-toolbar-left,.board-toolbar-right{display:flex;align-items:center;gap:var(--space-3)}.view-toggle{display:flex;background:var(--gray-100);border-radius:var(--radius-md);padding:2px}.view-toggle-btn{padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;color:var(--gray-500);transition:all var(--transition-fast)}.view-toggle-btn.active{background:var(--card-bg);color:var(--gray-900);box-shadow:var(--card-shadow)}.board-container-scroll{width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}.board-container-scroll::-webkit-scrollbar{display:none}.board-grid{display:grid;min-width:max-content}.board-header-cell{padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--gray-500);border-bottom:1px solid var(--card-border);border-right:1px solid var(--gray-100);text-align:center;top:0;z-index:3}.board-header-cell,.board-header-cell:first-child{background:var(--gray-50);position:-webkit-sticky;position:sticky}.board-header-cell:first-child{text-align:left;left:0;z-index:4;min-width:220px}.board-header-week{font-size:var(--font-size-xs);color:var(--gray-600)}.board-header-dates{font-size:10px;color:var(--gray-400);margin-top:2px}.board-row{display:contents}.board-row:hover .board-cell{background:var(--gray-25)}.board-cell{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--gray-100);border-right:1px solid var(--gray-100);min-width:120px;min-height:56px;display:flex;flex-direction:column;gap:2px;transition:background var(--transition-fast)}.board-cell:first-child{position:-webkit-sticky;position:sticky;left:0;z-index:2;background:var(--card-bg);min-width:220px;flex-direction:row;align-items:center;gap:var(--space-3)}.board-row:hover .board-cell:first-child{background:var(--gray-25)}.board-member-avatar{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:600;color:#fff;flex-shrink:0}.board-member-info{overflow:hidden}.board-member-name{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-900);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.board-member-dept{font-size:11px;color:var(--gray-400)}.board-assignment{padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:all var(--transition-fast)}.zoom-large .board-cell{min-height:80px;padding:var(--space-3) var(--space-4);gap:4px}.zoom-large .board-cell:first-child{min-width:280px;gap:var(--space-4)}.zoom-large .board-header-cell:first-child{min-width:280px}.zoom-large .board-member-avatar{width:44px;height:44px;font-size:var(--font-size-sm)}.zoom-large .board-member-name{font-size:var(--font-size-md)}.zoom-large .board-member-dept{font-size:var(--font-size-xs)}.zoom-large .board-assignment{font-size:var(--font-size-sm);padding:4px var(--space-3)}.zoom-large .board-availability{font-size:var(--font-size-sm)}.board-assignment:hover{filter:brightness(.95);transform:scale(1.02)}.board-availability-wrapper{margin-top:4px;display:flex;align-items:center;gap:var(--space-2)}.board-availability-bar{flex:1 1;height:6px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.board-availability-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-base)}.board-availability-text{font-size:10px;font-weight:600;color:var(--gray-500);min-width:32px;text-align:right}.avail-bg-free{background:var(--accent-500)}.avail-bg-partial{background:var(--warning-500)}.avail-bg-full,.avail-bg-over{background:var(--danger-500)}.avail-bg-over{animation:pulse-over 2s infinite}@keyframes pulse-over{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.board-cell-empty{display:flex;align-items:center;justify-content:center;color:var(--gray-300);font-size:var(--font-size-xs);cursor:pointer;border-radius:var(--radius-sm);border:1px dashed transparent;transition:all var(--transition-fast);min-height:40px}.board-cell-empty.editable:hover{border-color:var(--primary-300);background:var(--primary-50);color:var(--primary-500)}.heatmap-container{overflow-x:auto}.heatmap-grid{display:grid;grid-gap:2px;gap:2px;min-width:max-content}.heatmap-cell{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff;cursor:pointer;transition:all var(--transition-fast)}.heatmap-cell:hover{transform:scale(1.15);z-index:5}.heatmap-label{font-size:var(--font-size-xs);color:var(--gray-600);font-weight:500;white-space:nowrap;padding-right:var(--space-3);min-width:140px}.heatmap-label,.modal-overlay{display:flex;align-items:center}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);justify-content:center;z-index:100;animation:fadeIn .2s ease}.modal{background:var(--card-bg);border-radius:var(--radius-xl);box-shadow:var(--card-shadow-lg);width:90%;max-width:560px;max-height:85vh;overflow-y:auto;animation:slideUp .3s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--card-border)}.modal-title{font-size:var(--font-size-lg);font-weight:700;color:var(--gray-900)}.modal-close{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--gray-400);transition:all var(--transition-fast)}.modal-close:hover{background:var(--gray-100);color:var(--gray-700)}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--card-border)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--gray-950) 0,#1a1a3e 50%,var(--primary-900) 100%);position:relative;overflow:hidden}.login-bg-gradient{position:absolute;inset:0;opacity:.4;background:radial-gradient(600px circle at 20% 30%,rgba(99,102,241,.3),transparent 60%),radial-gradient(400px circle at 80% 70%,rgba(16,185,129,.2),transparent 60%)}.login-bg-dots{position:absolute;inset:0;background-image:radial-gradient(hsla(0,0%,100%,.08) 1px,transparent 0);background-size:30px 30px}.login-card{position:relative;z-index:2;width:100%;max-width:440px;background:hsla(0,0%,100%,.06);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid hsla(0,0%,100%,.1);border-radius:var(--radius-2xl);padding:var(--space-10);box-shadow:0 20px 60px rgba(0,0,0,.4);animation:fadeSlideUp .6s ease}.login-logo{gap:var(--space-3);margin-bottom:var(--space-8)}.login-logo,.login-logo-icon{display:flex;align-items:center;justify-content:center}.login-logo-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--primary-500),var(--accent-500));border-radius:var(--radius-lg);color:#fff;font-size:var(--font-size-xl);font-weight:800}.login-logo-text{font-size:var(--font-size-3xl);font-weight:800;color:#fff;letter-spacing:-.03em}.login-title{text-align:center;font-size:var(--font-size-xl);font-weight:600;color:hsla(0,0%,100%,.9);margin-bottom:var(--space-2)}.login-subtitle{text-align:center;font-size:var(--font-size-sm);color:hsla(0,0%,100%,.5);margin-bottom:var(--space-8)}.login-form{gap:var(--space-5)}.login-form,.login-input-group{display:flex;flex-direction:column}.login-input-group{gap:var(--space-2)}.login-input-label{font-size:var(--font-size-sm);font-weight:500;color:hsla(0,0%,100%,.7)}.login-input{padding:var(--space-3) var(--space-4);background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.15);border-radius:var(--radius-md);color:#fff;font-size:var(--font-size-base);outline:none;transition:all var(--transition-fast)}.login-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px rgba(99,102,241,.2);background:hsla(0,0%,100%,.12)}.login-input::placeholder{color:hsla(0,0%,100%,.3)}.login-btn{padding:var(--space-3) var(--space-6);background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-md);font-weight:700;cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-2)}.login-btn:hover{background:linear-gradient(135deg,var(--primary-500),var(--primary-400));transform:translateY(-2px);box-shadow:0 4px 12px rgba(99,102,241,.4)}.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-error{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);color:var(--danger-400)}.login-error,.login-footer{font-size:var(--font-size-sm);text-align:center}.login-footer{margin-top:var(--space-6);color:hsla(0,0%,100%,.4)}.forecast-week{border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--card-bg);overflow:hidden;transition:all var(--transition-fast)}.forecast-week:hover{box-shadow:var(--card-shadow-hover)}.forecast-week-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--gray-50);border-bottom:1px solid var(--card-border)}.forecast-week-title{font-weight:700;color:var(--gray-900)}.forecast-week-hours{font-size:var(--font-size-sm);font-weight:600}.forecast-week-body{padding:var(--space-4) var(--space-6);display:flex;flex-direction:column;gap:var(--space-3)}.forecast-assignment{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3);border-radius:var(--radius-md);background:var(--gray-50)}.forecast-assignment-color{width:4px;height:36px;border-radius:2px;flex-shrink:0}.forecast-assignment-info{flex:1 1}.forecast-assignment-project{font-weight:600;font-size:var(--font-size-sm);color:var(--gray-800)}.forecast-assignment-client{font-size:var(--font-size-xs);color:var(--gray-500)}.forecast-assignment-hours{font-weight:700;font-size:var(--font-size-md);color:var(--gray-700)}.export-format-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:var(--space-4);gap:var(--space-4)}.export-format-card{border:2px solid var(--gray-200);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;cursor:pointer;transition:all var(--transition-fast)}.export-format-card:hover{border-color:var(--primary-300);background:var(--primary-50)}.export-format-card.selected{border-color:var(--primary-500);background:var(--primary-50);box-shadow:0 0 0 3px var(--primary-100)}.export-format-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-3)}.export-format-name{font-weight:700;color:var(--gray-900)}.export-format-desc{font-size:var(--font-size-xs);color:var(--gray-500);margin-top:var(--space-1)}.tabs{display:flex;border-bottom:1px solid var(--card-border);gap:0}.tab-btn{padding:var(--space-3) var(--space-5);font-size:var(--font-size-sm);font-weight:600;color:var(--gray-500);border-bottom:2px solid transparent;transition:all var(--transition-fast);margin-bottom:-1px}.tab-btn:hover{color:var(--gray-700)}.tab-btn.active{color:var(--primary-600);border-bottom-color:var(--primary-600)}.onboarding-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--content-bg);padding:var(--space-8)}.onboarding-card{width:100%;max-width:560px;background:var(--card-bg);border-radius:var(--radius-xl);box-shadow:var(--card-shadow-lg);overflow:hidden}.onboarding-progress{height:4px;background:var(--gray-100)}.onboarding-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--accent-500));transition:width var(--transition-slow)}.onboarding-content{padding:var(--space-10)}.onboarding-step-title{font-size:var(--font-size-2xl);font-weight:800;color:var(--gray-900);margin-bottom:var(--space-2)}.onboarding-step-desc{color:var(--gray-500);margin-bottom:var(--space-8)}.onboarding-actions{display:flex;justify-content:space-between;margin-top:var(--space-8)}.page-header{margin-bottom:var(--space-8)}.page-header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.page-title{font-size:var(--font-size-2xl);font-weight:800;color:var(--gray-900);letter-spacing:-.02em}.page-subtitle{font-size:var(--font-size-sm);color:var(--gray-500);margin-top:var(--space-1)}.availability-list{display:flex;flex-direction:column;gap:var(--space-3)}.availability-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);border:1px solid var(--card-border);border-radius:var(--radius-lg);background:var(--card-bg);transition:all var(--transition-fast);cursor:pointer}.availability-item:hover{box-shadow:var(--card-shadow-hover);border-color:var(--primary-200)}.availability-item-info{flex:1 1}.availability-item-name{font-weight:600;color:var(--gray-900)}.availability-item-dept{font-size:var(--font-size-xs);color:var(--gray-500)}.availability-bar{flex:1 1;max-width:200px;height:8px;background:var(--gray-100);border-radius:var(--radius-full);overflow:hidden}.availability-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}.availability-hours{font-weight:700;min-width:60px;text-align:right}.alert,.availability-hours{font-size:var(--font-size-sm)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md)}.alert-warning{background:var(--warning-50);border:1px solid var(--warning-100);color:var(--warning-600)}.alert-danger{background:var(--danger-50);border:1px solid var(--danger-100);color:var(--danger-600)}.alert-info{background:var(--primary-50);border:1px solid var(--primary-100);color:var(--primary-600)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.animate-fadeIn{animation:fadeIn .3s ease}.animate-slideUp{animation:slideUp .3s ease}.spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:currentcolor;border-radius:50%;animation:spin .6s linear infinite}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-50) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}@media (max-width:768px){.sidebar{transform:translateX(-100%);z-index:60}.sidebar.mobile-open{transform:translateX(0)}.app-content-wrapper{margin-left:0}.app-main{padding:var(--space-4)}.header{padding:0 var(--space-4)}.header-search{display:none}.kpi-grid{grid-template-columns:repeat(2,1fr)}.board-toolbar{flex-direction:column;align-items:stretch}.export-format-grid{grid-template-columns:1fr}.login-card{margin:var(--space-4);padding:var(--space-6);width:100%;max-width:none}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.text-center{text-align:center}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.text-gray-500{color:var(--gray-500)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.w-full{width:100%}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-6);gap:var(--space-6)}.heatmap-controls{display:flex;gap:var(--space-4);align-items:center}.board-date-nav{display:flex;align-items:center;gap:4px}.forecast-add-controls{flex:1 1;display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:flex-start}.admin-form-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:12px;gap:12px}.admin-actions{display:flex;justify-content:flex-end;margin-bottom:16px}.admin-table-actions{display:flex;align-items:center;gap:10px}.menu-btn,.mobile-tab-bar,.sidebar-mobile-overlay{display:none}@media (max-width:768px){.desktop-only,.menu-btn{display:none!important}.app-content-wrapper,.app-content-wrapper.sidebar-collapsed{margin-left:0!important}.sidebar{display:none!important}.mobile-tab-bar{display:flex;position:fixed;bottom:0;left:0;width:100%;transform:translateZ(0);background:hsla(0,0%,100%,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(0,0,0,.05);box-shadow:0 -4px 12px rgba(0,0,0,.03);padding-bottom:env(safe-area-inset-bottom);z-index:50;justify-content:space-around;align-items:center;height:65px}.dark .mobile-tab-bar{background:rgba(15,23,42,.85);border-top:1px solid hsla(0,0%,100%,.05)}.tab-item{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--gray-500);text-decoration:none;font-size:10px;font-weight:600;gap:4px;width:100%;height:100%;transition:color var(--transition-base)}.tab-item.active{color:var(--primary-600)}.tab-item:active{background:rgba(0,0,0,.05)}.app-content-wrapper{padding-bottom:calc(80px + env(safe-area-inset-bottom))}.header{padding:0 var(--space-4)}.header-search input{width:120px;transition:width var(--transition-base)}.header-search input:focus{width:160px}.app-main{padding:var(--space-4)}.dashboard-charts-grid{grid-template-columns:1fr}.heatmap-controls{flex-wrap:wrap;gap:var(--space-2)}.heatmap-controls select{width:100%}.modal{width:95%!important;max-height:90vh;overflow-y:auto}.board-date-nav{justify-content:space-between;width:100%;margin:var(--space-2) 0}.forecast-assignment{flex-direction:column;align-items:flex-start}.forecast-add-controls{flex-direction:column;align-items:stretch;width:100%}.admin-form-grid{grid-template-columns:1fr}table,tbody,thead{display:block;width:100%}.card{overflow-x:auto}}