:root,[data-bs-theme="dark"]{--bs-body-color:#1E293B !important;--bs-body-bg:#F8FAFC !important;--bs-emphasis-color:#1E293B !important;--bs-secondary-color:#64748B !important;--bs-tertiary-bg:#F1F5F9 !important;--bs-border-color:#E2E8F0 !important;--bs-heading-color:#1E293B !important;--bs-link-color:#4F46E5 !important;color-scheme:light !important;}[data-bs-theme="dark"] .form-control,[data-bs-theme="dark"] .form-select{background-color:#FFFFFF !important;color:#1E293B !important;border-color:#E2E8F0 !important;}[data-bs-theme="dark"] .form-control::placeholder{color:#94A3B8 !important;}[data-bs-theme="dark"] .modal-content{background-color:#FFFFFF !important;color:#1E293B !important;}[data-bs-theme="dark"] .btn-close{filter:none !important;}:root{--primary:#4F46E5;--primary-hover:#4338CA;--primary-light:#EEF2FF;--secondary:#7C3AED;--secondary-hover:#6D28D9;--background:#F8FAFC;--surface:#FFFFFF;--text-primary:#1E293B;--text-secondary:#64748B;--text-muted:#94A3B8;--success:#10B981;--success-light:#D1FAE5;--warning:#F59E0B;--warning-light:#FEF3C7;--error:#EF4444;--error-light:#FEE2E2;--border:#E2E8F0;--border-light:#F1F5F9;--sidebar-width:260px;--sidebar-bg:#1E293B;--sidebar-text:#CBD5E1;--sidebar-active:#4F46E5;--topbar-height:60px;--radius:12px;--radius-sm:8px;--radius-lg:16px;--shadow:0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.06);--shadow-md:0 4px 6px rgba(0,0,0,0.07),0 2px 4px rgba(0,0,0,0.06);--shadow-lg:0 10px 15px rgba(0,0,0,0.1),0 4px 6px rgba(0,0,0,0.05);--transition:all 0.2s ease;}*{margin:0;padding:0;box-sizing:border-box;}body{font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text','Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;color:var(--text-primary);background-color:var(--background);line-height:1.6;-webkit-font-smoothing:antialiased;}body.container{max-width:100% !important;padding:0 !important;margin:0 !important;}.auth-body{min-height:100vh;background:var(--background);}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;}.auth-card{background:var(--surface);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);}.auth-logo{display:block;width:60px;height:60px;margin:0 auto 24px;}.auth-title{text-align:center;color:var(--text-primary);margin-bottom:24px !important;font-weight:700;}.auth-form .form-label{font-weight:600;color:var(--text-primary);font-size:14px;margin-bottom:6px;}.auth-form .form-control{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:15px;transition:var(--transition);}.auth-form .form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(79,70,229,0.15);}.auth-link{color:var(--primary);text-decoration:none;transition:var(--transition);}.auth-link:hover{color:var(--primary-hover);text-decoration:underline;}.main-body{min-height:100vh;background:var(--background);}.app-wrapper{display:flex;min-height:100vh;}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);color:var(--sidebar-text);position:fixed;top:0;left:0;bottom:0;z-index:1000;display:flex;flex-direction:column;transition:transform 0.3s ease;}.sidebar-header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,0.08);}.sidebar-logo{font-size:24px;color:#fff;letter-spacing:-0.5px;margin:0 !important;}.sidebar-logo strong{color:var(--primary);font-weight:800;}.sidebar-nav{list-style:none;padding:12px;margin:0;flex:1;}.sidebar-item{margin-bottom:4px;}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 14px;color:var(--sidebar-text);text-decoration:none;border-radius:var(--radius-sm);transition:var(--transition);font-size:15px;font-weight:500;}.sidebar-link:hover{background:rgba(255,255,255,0.08);color:#fff;}.sidebar-link.active,.sidebar-item.active .sidebar-link{background:var(--sidebar-active);color:#fff;}.sidebar-link i,.sidebar-link img{width:20px;font-size:18px;opacity:0.8;}.admin-only-item{display:none;}.admin-only-item.visible{display:block;}.content-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;}.topbar{height:var(--topbar-height);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100;}.sidebar-toggle{display:none;background:none;border:none;width:36px;height:36px;cursor:pointer;position:relative;}.sidebar-toggle::before{content:'\2630';font-size:20px;color:var(--text-primary);}.topbar-right{margin-left:auto;}.topbar-user{display:flex;align-items:center;gap:10px;}.topbar-username{font-weight:600;font-size:14px;color:var(--text-primary);}.main-content{flex:1;padding:24px;max-width:1200px;width:100%;}.page-header{margin-bottom:24px;}.page-title{font-weight:700;color:var(--text-primary);margin:0 !important;}.section-title{font-weight:700;color:var(--text-primary);margin-bottom:16px !important;}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary);color:#fff;font-weight:700;text-transform:uppercase;}.avatar-sm{width:32px;height:32px;font-size:14px;}.avatar-md{width:40px;height:40px;font-size:16px;}.avatar-lg{width:80px;height:80px;font-size:32px;}.week-navigator{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px;}.week-range-text{font-size:16px;font-weight:600;color:var(--text-primary);min-width:180px;text-align:center;}.btn-icon{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:50%;}#prevWeek::before{content:'\2039';font-size:24px;line-height:1;}#nextWeek::before{content:'\203A';font-size:24px;line-height:1;}.day-picker{display:flex;gap:8px;justify-content:center;margin-bottom:20px;overflow-x:auto;padding:4px 0;}.day-chip{display:flex;flex-direction:column;align-items:center;padding:8px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;transition:var(--transition);min-width:60px;user-select:none;}.day-chip:hover{border-color:var(--primary);background:var(--primary-light);}.day-chip.active{background:var(--primary);border-color:var(--primary);color:#fff;}.day-chip.today{border-color:var(--primary);}.day-chip-weekday{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;opacity:0.7;}.day-chip.active .day-chip-weekday{opacity:1;}.day-chip-number{font-size:18px;font-weight:700;line-height:1.2;}.day-summary{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:16px;}.selected-date-text{font-weight:600;color:var(--text-primary);}.day-total-hours{font-weight:700;color:var(--primary);font-size:18px;}.entries-container{margin-bottom:80px;}.entries-list{display:flex;flex-direction:column;gap:8px;}.entry-card{background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border);padding:14px 16px;display:flex;align-items:center;gap:12px;transition:var(--transition);}.entry-card:hover{box-shadow:var(--shadow);}.entry-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;}.entry-info{flex:1;min-width:0;}.entry-project-name{font-weight:600;font-size:15px;color:var(--text-primary);}.entry-notes{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}.entry-hours{font-weight:700;font-size:16px;color:var(--primary);white-space:nowrap;}.entry-actions{display:flex;gap:4px;}.entry-actions button{background:none;border:none;padding:6px 8px;cursor:pointer;border-radius:var(--radius-sm);color:var(--text-secondary);transition:var(--transition);font-size:14px;}.entry-actions .btn-edit:hover{background:var(--primary-light);color:var(--primary);}.entry-actions .btn-delete:hover{background:var(--error-light);color:var(--error);}.fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;border:none;font-size:28px;font-weight:300;cursor:pointer;box-shadow:var(--shadow-lg);transition:var(--transition);display:flex;align-items:center;justify-content:center;z-index:50;line-height:1;}.fab:hover{background:var(--primary-hover);transform:scale(1.05);}.modal{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,0.5);align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px);overflow:visible;pointer-events:auto;}.modal.show{display:flex;}.modal .modal-dialog{pointer-events:auto !important;margin:0 !important;}.modal .modal-content{pointer-events:auto !important;background-color:var(--surface) !important;color:var(--text-primary) !important;}.modal .modal-content *{pointer-events:auto !important;}.modal .modal-content input,.modal .modal-content select,.modal .modal-content textarea,.modal .modal-content button{pointer-events:auto !important;position:relative;z-index:1;}.modal-dialog{width:100%;max-width:480px;}.modal-content{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden;}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);}.modal-header h3,.modal-header p{margin:0 !important;font-weight:700;}.modal-body{padding:20px;}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--border);}.hours-stepper{display:flex;align-items:center;gap:8px;}.btn-stepper{width:44px;height:44px;padding:0;font-size:20px;font-weight:600;border-radius:var(--radius-sm);flex-shrink:0;display:flex;align-items:center;justify-content:center;}.hours-input{font-size:20px !important;font-weight:700 !important;text-align:center;max-width:100px;}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}.project-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:20px;transition:var(--transition);position:relative;overflow:hidden;}.project-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;}.project-card:hover{box-shadow:var(--shadow-md);}.project-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}.project-card-name{font-weight:700;font-size:16px;color:var(--text-primary);}.project-card-badge{font-size:12px;padding:2px 10px;border-radius:20px;font-weight:600;}.project-card-badge.active{background:var(--success-light);color:var(--success);}.project-card-badge.inactive{background:var(--border-light);color:var(--text-secondary);}.project-card-actions{display:flex;gap:8px;margin-top:12px;}.project-card-actions button{flex:1;padding:8px;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:var(--transition);}.project-card-actions button:hover{background:var(--background);}.project-card-actions .btn-toggle-active.active-true:hover{background:var(--warning-light);color:var(--warning);border-color:var(--warning);}.project-card-actions .btn-toggle-active.active-false:hover{background:var(--success-light);color:var(--success);border-color:var(--success);}.project-card-actions .btn-delete-project:hover{background:var(--error-light);color:var(--error);border-color:var(--error);}.color-picker-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;}.color-swatch{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;border:3px solid transparent;transition:var(--transition);position:relative;}.color-swatch:hover{transform:scale(1.1);}.color-swatch.selected{border-color:var(--text-primary);}.color-swatch.selected::after{content:'\2713';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;}.date-filter{display:flex;align-items:flex-end;gap:12px;margin-bottom:24px;flex-wrap:wrap;}.date-filter-field{flex:1;min-width:150px;}.date-filter-field .form-label{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:4px;}.date-filter-field .form-control{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;}.btn-filter{height:42px;padding:0 24px;}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px;}.stat-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:20px;display:flex;flex-direction:column;align-items:center;text-align:center;}.stat-value{font-size:32px;font-weight:800;color:var(--primary);line-height:1.2;}.stat-label{font-size:14px;color:var(--text-secondary);font-weight:500;margin-top:4px;}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;}.dashboard-column{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:20px;}.data-list{display:flex;flex-direction:column;}.data-list-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-light);cursor:default;}.data-list-item:last-child{border-bottom:none;}.data-list-item.clickable{cursor:pointer;padding:12px 8px;margin:0 -8px;border-radius:var(--radius-sm);}.data-list-item.clickable:hover{background:var(--background);}.data-list-label{display:flex;align-items:center;gap:10px;flex:1;min-width:0;}.data-list-color{width:10px;height:10px;border-radius:50%;flex-shrink:0;}.data-list-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}.data-list-value{font-weight:700;color:var(--primary);white-space:nowrap;margin-left:12px;}.empty-state-sm{padding:24px;text-align:center;}.empty-text-sm{color:var(--text-muted);font-size:14px;}.employee-detail-panel{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:20px;margin-top:24px;}.detail-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;}.detail-title{margin:0 !important;font-weight:700;}.date-group{margin-bottom:16px;}.date-group-header{font-weight:600;font-size:14px;color:var(--text-secondary);padding:8px 0;border-bottom:1px solid var(--border);margin-bottom:8px;}.profile-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:32px;max-width:480px;margin:0 auto;}.profile-header{text-align:center;margin-bottom:24px;}.profile-avatar-container{margin-bottom:16px;}.profile-name{font-weight:700;margin-bottom:4px !important;}.profile-role{display:inline-block;padding:4px 14px;border-radius:20px;font-size:13px;font-weight:600;background:var(--primary-light);color:var(--primary);text-transform:capitalize;}.profile-details{border-top:1px solid var(--border);padding-top:20px;}.profile-field{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-light);}.profile-field:last-child{border-bottom:none;}.profile-field-label{color:var(--text-secondary);font-size:14px;font-weight:500;}.profile-field-value{font-weight:600;color:var(--text-primary);font-size:14px;}.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted);}.empty-icon{font-size:48px;margin-bottom:16px;opacity:0.4;}.empty-text{font-size:16px;font-weight:600;color:var(--text-secondary);margin-bottom:4px !important;}.empty-subtext{font-size:14px;color:var(--text-muted);}.loading-overlay{position:fixed;inset:0;background:var(--background);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity 0.3s ease;}.loading-overlay.hidden{opacity:0;pointer-events:none;}.loading-content{text-align:center;}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 0.8s linear infinite;margin:0 auto 12px;}@keyframes spin{to{transform:rotate(360deg);}}.loading-text{color:var(--text-secondary);font-size:14px;}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:8px;pointer-events:none;}.toast{background:var(--surface);border-radius:var(--radius-sm);padding:14px 20px;box-shadow:var(--shadow-lg);border-left:4px solid var(--primary);font-size:14px;font-weight:500;color:var(--text-primary);pointer-events:auto;animation:slideIn 0.3s ease;max-width:360px;}.toast.toast-success{border-left-color:var(--success);}.toast.toast-error{border-left-color:var(--error);}.toast.toast-warning{border-left-color:var(--warning);}.toast.toast-removing{animation:slideOut 0.3s ease forwards;}@keyframes slideIn{from{opacity:0;transform:translateX(100px);}to{opacity:1;transform:translateX(0);}}@keyframes slideOut{from{opacity:1;transform:translateX(0);}to{opacity:0;transform:translateX(100px);}}.btn{font-weight:600;border-radius:var(--radius-sm);padding:8px 20px;font-size:14px;transition:var(--transition);border:none;cursor:pointer;}.btn-primary{background:var(--primary) !important;color:#fff !important;border:none !important;}.btn-primary:hover{background:var(--primary-hover) !important;}.btn-secondary{background:var(--background) !important;color:var(--text-primary) !important;border:1px solid var(--border) !important;}.btn-secondary:hover{background:var(--border-light) !important;}.btn-danger{background:var(--error) !important;color:#fff !important;}.btn-danger:hover{background:#DC2626 !important;}.btn-outline-secondary{background:transparent;border:1.5px solid var(--border);color:var(--text-secondary);}.btn-outline-secondary:hover{background:var(--background);border-color:var(--text-secondary);color:var(--text-primary);}.btn-lg{padding:12px 24px;font-size:16px;}.btn-sm{padding:4px 12px;font-size:13px;}.form-control,.form-select{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:14px;transition:var(--transition);color:var(--text-primary);}.form-control:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(79,70,229,0.15);}.form-label{font-weight:600;font-size:14px;color:var(--text-primary);margin-bottom:6px;}.form-check-input:checked{background-color:var(--primary);border-color:var(--primary);}.alert{border-radius:var(--radius-sm);padding:12px 16px;font-size:14px;font-weight:500;border:none;}.alert-danger{background:var(--error-light);color:var(--error);}.alert-success{background:var(--success-light);color:var(--success);}.d-none{display:none !important;}.d-flex{display:flex !important;}.w-100{width:100% !important;}.text-center{text-align:center !important;}.fw-bold{font-weight:700 !important;}.mb-3{margin-bottom:16px !important;}.mt-3{margin-top:16px !important;}.mt-4{margin-top:24px !important;}.my-4{margin-top:24px !important;margin-bottom:24px !important;}.justify-content-between{justify-content:space-between !important;}.align-items-center{align-items:center !important;}.gap-2{gap:8px !important;}@media (max-width:768px){.sidebar{transform:translateX(-100%);}.sidebar.open{transform:translateX(0);}.sidebar-toggle{display:flex;}.content-wrapper{margin-left:0;}.main-content{padding:16px;}.dashboard-grid{grid-template-columns:1fr;}.date-filter{flex-direction:column;}.date-filter-field{width:100%;}.day-picker{gap:4px;}.day-chip{padding:6px 10px;min-width:48px;}.projects-grid{grid-template-columns:1fr;}.modal-dialog{max-width:100%;margin:0;}.auth-card{padding:24px;}.profile-card{padding:20px;}.stats-grid{grid-template-columns:1fr;}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:999;}.sidebar-overlay.show{display:block;}}@media (max-width:480px){.week-navigator{gap:8px;}.week-range-text{font-size:14px;min-width:140px;}}