.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 20px 60px #0000004d;text-align:center;max-width:400px;width:90%}.login-card h1{color:#333;margin-bottom:.5rem;font-size:2rem}.login-card p{color:#666;margin-bottom:2rem}.login-button-wrapper{display:flex;justify-content:center;margin-top:2rem}.mock-login-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s}.mock-login-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media (prefers-color-scheme: dark){.login-card{background:#1a1a1a}.login-card h1{color:#fff}.login-card p{color:#aaa}}.time-entry-form-container{margin-bottom:2rem}.time-entry-form-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.time-entry-form-card h2{margin:0 0 1.5rem;color:#333;font-size:1.5rem}.time-entry-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#555;font-size:.9rem}.form-group input,.form-group select{padding:.75rem;font-size:1rem;border:1px solid #ddd;border-radius:6px}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 6px 6px;max-height:300px;overflow-y:auto;z-index:1000;box-shadow:0 4px 12px #00000026;margin-top:-6px}.dropdown-item{padding:.75rem;cursor:pointer;transition:background-color .15s;border-left:3px solid #667eea}.dropdown-item.selected{background-color:#e8eaf6}.dropdown-item.highlighted{background-color:#f0f0f0}.dropdown-item.selected.highlighted{background-color:#d0d4f7}.dropdown-item.empty{color:#999;cursor:default;border-left:none}.dropdown-item.empty:hover{background-color:transparent}.dropdown-item-client{font-size:.75rem;color:#999;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.dropdown-item-project{font-size:.95rem;color:#333;font-weight:500}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.submit-button{padding:1rem 2rem;font-size:1rem;font-weight:600;background-color:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s;margin-top:.5rem}.submit-button:hover{background-color:#5568d3}.submit-button:disabled{opacity:.5;cursor:not-allowed}@media (prefers-color-scheme: dark){.time-entry-form-card{background:#242424}.time-entry-form-card h2{color:#fff}.form-group label{color:#aaa}.form-group input,.form-group select{background-color:#1a1a1a;border-color:#444;color:#fff}.autocomplete-dropdown{background:#1a1a1a;border-color:#444}.dropdown-item:hover{background-color:#2a2a2a}.dropdown-item.selected{background-color:#3a3a5a}.dropdown-item-client{color:#666}.dropdown-item-project{color:#fff}}@media (max-width: 768px){.form-row{grid-template-columns:1fr}.time-entry-form-card{padding:1.5rem}}.time-entry-list{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e5e5}.list-header h2{font-size:1.5rem;color:#333;margin:0}.total-time{font-size:1.25rem;font-weight:600;color:#667eea}.empty-state{text-align:center;padding:3rem;color:#999}.entries-list{display:flex;flex-direction:column;gap:1rem}.entry-card{padding:1rem;border:1px solid #e5e5e5;border-radius:8px;transition:all .2s}.entry-card:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.entry-project{font-weight:600;color:#333;font-size:1rem}.entry-duration{font-weight:700;color:#667eea;font-size:1rem}.entry-description{color:#666;margin-bottom:.5rem;font-size:.9rem}.entry-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem}.entry-time{font-size:.85rem;color:#999}.invalid-badge{display:inline-block;margin-left:.5rem;padding:.2rem .5rem;background-color:#ef4444;color:#fff;font-size:.7rem;border-radius:4px;text-transform:uppercase;font-weight:600}.entry-card.invalid{opacity:.5;background-color:#f9f9f9}.entry-card.invalid .entry-project,.entry-card.invalid .entry-description,.entry-card.invalid .entry-time{text-decoration:line-through;color:#999}.entry-card.invalid .entry-duration{color:#999;text-decoration:line-through}.invalidate-button{padding:.4rem .8rem;font-size:.8rem;background-color:#ef4444;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.invalidate-button:hover{background-color:#dc2626}@media (prefers-color-scheme: dark){.time-entry-list{background:#242424}.list-header{border-bottom-color:#333}.list-header h2{color:#fff}.entry-card{border-color:#333}.entry-card:hover{border-color:#667eea}.entry-project{color:#fff}.entry-description{color:#aaa}.entry-time{color:#666}}@media (max-width: 768px){.list-header{flex-direction:column;align-items:flex-start;gap:.5rem}.entry-header{flex-direction:column;align-items:flex-start;gap:.25rem}}.project-manager{display:grid;gap:2rem}.manager-section{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e5e5}.section-header h2{font-size:1.5rem;color:#333;margin:0}.add-button{background-color:#667eea;color:#fff;border:none;padding:.6rem 1.2rem}.add-button:hover{background-color:#5568d3}.create-form{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;background-color:#f9f9f9;border-radius:8px;margin-bottom:1.5rem}.color-input{display:flex;align-items:center;gap:1rem}.color-input input[type=color]{width:60px;height:40px;border:none;cursor:pointer}.form-buttons{display:flex;gap:1rem}.form-buttons button[type=submit]{background-color:#10b981;color:#fff;border:none}.form-buttons button[type=submit]:hover{background-color:#059669}.form-buttons button[type=button]{background-color:#6b7280;color:#fff;border:none}.form-buttons button[type=button]:hover{background-color:#4b5563}.clients-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.client-card{padding:1.2rem;border:1px solid #e5e5e5;border-radius:8px;transition:all .2s}.client-card:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.client-card.selected{border-color:#667eea;background-color:#f0f4ff;box-shadow:0 2px 8px #667eea33}.client-card h3{color:#333;margin:0 0 .4rem;font-size:1.1rem}.client-card p{color:#666;margin:0;font-size:.9rem}.projects-list{display:flex;flex-direction:column;gap:2rem}.filter-indicator{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#f0f4ff;border:1px solid #667eea;border-radius:8px;margin-bottom:1rem}.filter-indicator span{color:#667eea;font-weight:500}.clear-filter-button{background-color:#667eea;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem}.clear-filter-button:hover{background-color:#5568d3}.client-projects .client-name{color:#666;font-size:1rem;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.05em}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.project-card{padding:.84rem;border:1px solid #e5e5e5;border-left:4px solid #667eea;border-radius:8px;transition:all .2s}.project-card:hover{box-shadow:0 2px 8px #0000001a}.project-card h4{color:#333;margin:0 0 .25rem;font-size:.95rem;line-height:1.3}.project-card p{color:#666;margin:0;font-size:.8rem;line-height:1.3}.empty-message{text-align:center;padding:2rem;color:#999}@media (prefers-color-scheme: dark){.manager-section{background:#242424}.section-header{border-bottom-color:#333}.section-header h2{color:#fff}.create-form{background-color:#1a1a1a}.client-card,.project-card{border-color:#333}.client-card:hover,.project-card:hover{border-color:#667eea}.client-card.selected,.filter-indicator{background-color:#1a1a2e;border-color:#667eea}.filter-indicator span{color:#a5b4fc}.client-card h3,.project-card h4{color:#fff}.client-card p,.project-card p,.client-projects .client-name{color:#aaa}}@media (max-width: 768px){.clients-list,.projects-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}}.statistics-container{width:100%}.statistics-header{margin-bottom:2rem}.statistics-header h2{font-size:2rem;color:#333;margin:0}.filter-group select,.filter-group input[type=text]{padding:.6rem;font-size:1rem;border:1px solid #ddd;border-radius:6px;background-color:#fff}.stats-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center}.stat-label{font-size:.9rem;color:#666;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:2rem;font-weight:700;color:#667eea}.stat-value.invalid{color:#ef4444}.stats-by-client{display:flex;flex-direction:column;gap:1rem}.client-stats-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.client-stats-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:2px solid #e5e5e5;margin-bottom:1rem}.client-stats-header h3{margin:0 0 .25rem;color:#333;font-size:1.25rem}.client-meta{font-size:.85rem;color:#999}.client-total{font-size:1.75rem;font-weight:700;color:#667eea}.project-breakdown{display:flex;flex-direction:column;gap:.75rem}.project-stat-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:1rem;padding:.75rem;background-color:#f9f9f9;border-radius:6px;align-items:center}.project-stat-name{font-weight:500;color:#333}.project-stat-meta{font-size:.85rem;color:#666}.project-stat-time{font-weight:600;color:#667eea;text-align:right}.stats-by-project,.stats-by-user,.stats-by-project-user,.stats-graphical{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.chart-container{height:500px;width:100%;position:relative}.stats-table{width:100%;border-collapse:collapse}.stats-table thead{background-color:#f5f5f5}.stats-table th{padding:1rem;text-align:left;font-weight:600;color:#333;text-transform:uppercase;font-size:.85rem;letter-spacing:.05em}.stats-table td{padding:1rem;border-top:1px solid #e5e5e5}.stats-table tbody tr:hover{background-color:#f9f9f9}@media (prefers-color-scheme: dark){.statistics-header h2{color:#fff}.filters-section,.date-range-selector,.stat-card,.client-stats-card,.stats-by-project,.stats-by-user,.stats-by-project-user,.stats-graphical,.empty-message,.loading-footer{background:#242424}.loading-footer{color:#667eea}.filters-section h3,.date-range-selector h3{color:#fff}.filter-group label{color:#aaa}.filter-group select,.filter-group input[type=text]{background-color:#1a1a1a;border-color:#444;color:#fff}.filter-group .dropdown-item.highlighted{background-color:#2a2a2a}.filter-group .dropdown-item.selected{background-color:#3a3a5a}.preset-buttons button{background-color:#1a1a1a;color:#fff}.preset-buttons button:hover{background-color:#2a2a5a}.preset-buttons button.active{background-color:#667eea}.view-mode-selector button{background-color:#1a1a1a;color:#fff}.view-mode-selector button:hover{background-color:#2a2a5a}.view-mode-selector button.active{background-color:#667eea}.custom-range input{background-color:#1a1a1a;border-color:#444;color:#fff}.custom-range span,.stat-label{color:#aaa}.client-stats-header h3,.project-stat-name{color:#fff}.client-stats-header{border-bottom-color:#333}.project-stat-row,.stats-table thead{background-color:#1a1a1a}.stats-table th{color:#fff}.stats-table td{border-top-color:#333;color:#fff}.stats-table tbody tr:hover{background-color:#2a2a2a}}@media (max-width: 768px){.filter-row{grid-template-columns:1fr}.clear-filters-button{width:100%}.preset-buttons{flex-direction:column}.preset-buttons button{width:100%}.custom-range{flex-direction:column;align-items:stretch}.custom-range input{width:100%}.stats-summary{grid-template-columns:1fr 1fr}.project-stat-row{grid-template-columns:1fr;gap:.5rem}.project-stat-time{text-align:left}.stats-table{font-size:.85rem}.stats-table th,.stats-table td{padding:.5rem}}.graphical-container{width:100%}.graphical-header{margin-bottom:2rem}.graphical-header h2{font-size:2rem;color:#333;margin:0}.filters-section{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:1rem}.filters-section h3{margin:0 0 1rem;font-size:1.1rem;color:#333}.filter-row{display:grid;grid-template-columns:1fr 1fr auto;gap:1rem;align-items:end}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-weight:500;color:#555;font-size:.9rem}.filter-group input[type=text]{padding:.6rem;font-size:1rem;border:1px solid #ddd;border-radius:6px;background-color:#fff}.filter-group input[type=text]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.filter-dropdown{max-height:250px}.filter-group .dropdown-item.highlighted{background-color:#f0f0f0}.filter-group .dropdown-item.selected{background-color:#e8eaf6}.clear-filters-button{padding:.6rem 1.2rem;background-color:#6b7280;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s;white-space:nowrap}.clear-filters-button:hover{background-color:#4b5563}.date-range-selector{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.date-range-selector h3{margin:0 0 1rem;font-size:1.1rem;color:#333}.preset-buttons{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.preset-buttons button{padding:.6rem 1rem;font-size:.9rem;background-color:#f5f5f5;color:#333;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s}.preset-buttons button:hover{background-color:#e8eaf6;border-color:#667eea}.preset-buttons button.active{background-color:#667eea;color:#fff;border-color:#667eea}.custom-range{display:flex;align-items:center;gap:1rem}.custom-range input[type=date]{padding:.6rem;font-size:1rem;border:1px solid #ddd;border-radius:6px}.custom-range span{color:#666;font-weight:500}.view-mode-selector{display:flex;gap:.5rem;margin-bottom:1.5rem}.view-mode-selector button{padding:.75rem 1.5rem;background-color:#f5f5f5;color:#333;border:2px solid transparent;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.view-mode-selector button:hover{background-color:#e8eaf6;border-color:#667eea}.view-mode-selector button.active{background-color:#667eea;color:#fff;border-color:#667eea}.chart-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;height:500px;width:100%;position:relative}.empty-message{text-align:center;padding:3rem;color:#999;background:#fff;border-radius:12px}.loading-footer{display:flex;align-items:center;justify-content:center;gap:1rem;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-top:2rem;color:#667eea;font-weight:500}.loading-spinner{width:24px;height:24px;border:3px solid #e8eaf6;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.autocomplete-wrapper{position:relative}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 6px #0000001a;z-index:1000;overflow-y:auto;margin-top:.25rem}.dropdown-item{padding:.75rem 1rem;cursor:pointer;transition:background-color .15s}.dropdown-item:hover{background-color:#f5f5f5}.dropdown-item-project{font-weight:500;color:#333}@media (prefers-color-scheme: dark){.graphical-header h2{color:#fff}.filters-section,.date-range-selector,.chart-container,.empty-message,.loading-footer{background:#242424}.filters-section h3,.date-range-selector h3{color:#fff}.filter-group label{color:#aaa}.filter-group input[type=text]{background-color:#1a1a1a;border-color:#444;color:#fff}.filter-group .dropdown-item.highlighted{background-color:#2a2a2a}.filter-group .dropdown-item.selected{background-color:#3a3a5a}.preset-buttons button{background-color:#1a1a1a;color:#fff}.preset-buttons button:hover{background-color:#2a2a5a}.preset-buttons button.active{background-color:#667eea}.view-mode-selector button{background-color:#1a1a1a;color:#fff}.view-mode-selector button:hover{background-color:#2a2a5a}.view-mode-selector button.active{background-color:#667eea}.custom-range input{background-color:#1a1a1a;border-color:#444;color:#fff}.custom-range span{color:#aaa}.autocomplete-dropdown{background:#242424;border-color:#444}.dropdown-item-project{color:#fff}}@media (max-width: 768px){.filter-row{grid-template-columns:1fr}.clear-filters-button{width:100%}.preset-buttons{flex-direction:column}.preset-buttons button{width:100%}.custom-range{flex-direction:column;align-items:stretch}.custom-range input{width:100%}}.logs-container{padding:20px;max-width:1200px;margin:0 auto}.logs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.logs-header h2{margin:0;font-size:24px;font-weight:600}.logs-count{color:var(--text-secondary);font-size:14px}.loading-state,.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary)}.logs-list{display:flex;flex-direction:column;gap:8px}.log-entry{display:flex;gap:16px;padding:12px 16px;background:var(--card-background);border:1px solid var(--border-color);border-radius:8px;transition:background-color .2s}.log-entry:hover{background:var(--card-hover)}.log-entry.invalid{opacity:.6}.log-timestamp{font-family:Monaco,Menlo,Courier New,monospace;font-size:13px;color:var(--text-secondary);white-space:nowrap;min-width:160px}.log-content{flex:1;display:flex;flex-direction:column;gap:4px}.log-main{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.log-user{color:var(--text-primary)}.log-separator{color:var(--text-secondary);margin:0 4px}.log-project{font-weight:600;color:var(--text-primary)}.log-description{color:var(--text-secondary);font-size:14px}.log-meta{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-secondary)}.log-date-range,.log-duration{font-weight:500}.log-time-range{font-family:Monaco,Menlo,Courier New,monospace}.invalid-badge{display:inline-block;padding:2px 8px;background:var(--error-background);color:var(--error-text);border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding:16px 0}.pagination-button{padding:8px 16px;background:var(--card-background);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.pagination-button:hover:not(:disabled){background:var(--card-hover);border-color:var(--text-secondary)}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{color:var(--text-secondary);font-size:14px;min-width:100px;text-align:center}@media (prefers-color-scheme: dark){.logs-container{--card-background: #1e1e1e;--card-hover: #252525;--border-color: #333;--text-primary: #e0e0e0;--text-secondary: #a0a0a0;--error-background: #4a1f1f;--error-text: #ff6b6b}}@media (prefers-color-scheme: light){.logs-container{--card-background: #ffffff;--card-hover: #f5f5f5;--border-color: #e0e0e0;--text-primary: #1a1a1a;--text-secondary: #666;--error-background: #ffe0e0;--error-text: #cc0000}}.settings-container{padding:20px;max-width:800px;margin:0 auto}.settings-header{margin-bottom:24px}.settings-header h2{margin:0;font-size:24px;font-weight:600}.settings-content{background:var(--card-background);border:1px solid var(--border-color);border-radius:8px;padding:24px}.settings-section{margin-bottom:32px}.settings-section:last-child{margin-bottom:0}.settings-section h3{margin:0 0 8px;font-size:18px;font-weight:600}.settings-description{margin:0 0 16px;color:var(--text-secondary);font-size:14px}.timezone-selector,.timezone-search{margin-bottom:16px}.timezone-search-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;background:var(--input-background);color:var(--text-primary)}.timezone-search-input:focus{outline:none;border-color:var(--primary-color)}.timezone-list{max-height:400px;overflow-y:auto;border:1px solid var(--border-color);border-radius:6px;background:var(--input-background)}.timezone-group{border-bottom:1px solid var(--border-color)}.timezone-group:last-child{border-bottom:none}.timezone-group-header{padding:8px 12px;font-weight:600;font-size:12px;text-transform:uppercase;color:var(--text-secondary);background:var(--group-header-background);position:sticky;top:0;z-index:1}.timezone-option{display:flex;align-items:center;padding:10px 12px;cursor:pointer;transition:background-color .2s;border-bottom:1px solid var(--border-color)}.timezone-option:last-child{border-bottom:none}.timezone-option:hover{background:var(--card-hover)}.timezone-option.selected{background:var(--selected-background)}.timezone-option input[type=radio]{margin-right:12px;cursor:pointer}.timezone-option-label{display:flex;flex-direction:column;flex:1}.timezone-name{font-weight:500;color:var(--text-primary);margin-bottom:2px}.timezone-id{font-size:12px;color:var(--text-secondary);font-family:Monaco,Menlo,Courier New,monospace}.settings-actions{display:flex;gap:12px;align-items:center}.save-button,.reset-button{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.save-button{background:var(--primary-color);color:#fff}.save-button:hover{background:var(--primary-hover)}.reset-button{background:var(--secondary-background);color:var(--text-primary);border:1px solid var(--border-color)}.reset-button:hover{background:var(--card-hover)}.saved-indicator{color:var(--success-color);font-size:14px;font-weight:500}@media (prefers-color-scheme: dark){.settings-container{--card-background: #1e1e1e;--card-hover: #252525;--border-color: #333;--text-primary: #e0e0e0;--text-secondary: #a0a0a0;--input-background: #252525;--primary-color: #667eea;--primary-hover: #5568d3;--secondary-background: #2a2a2a;--group-header-background: #252525;--selected-background: #2a3a5a;--success-color: #4ade80}}@media (prefers-color-scheme: light){.settings-container{--card-background: #ffffff;--card-hover: #f5f5f5;--border-color: #e0e0e0;--text-primary: #1a1a1a;--text-secondary: #666;--input-background: #ffffff;--primary-color: #667eea;--primary-hover: #5568d3;--secondary-background: #f5f5f5;--group-header-background: #f9f9f9;--selected-background: #e8edff;--success-color: #22c55e}}.calendar-container{padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;height:calc(100vh - 150px);display:flex;flex-direction:column;position:relative}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:1rem;border-bottom:2px solid #e5e5e5}.calendar-controls{display:flex;align-items:center;gap:.5rem}.calendar-controls button{background:#fff;border:1px solid #e5e5e5;color:#666;border-radius:6px;padding:.5rem 1rem;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.calendar-controls button:hover{border-color:#667eea;color:#667eea;background:#f9f9f9}.current-date-display{font-size:.9rem;font-weight:500;color:#666;margin-left:1rem;min-width:200px}.user-filter-wrapper{position:relative;margin-left:1rem}.user-filter-button{background:#fff;border:1px solid #e5e5e5;color:#666;border-radius:6px;padding:.5rem 1rem;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.user-filter-button:hover{border-color:#667eea;color:#667eea;background:#f9f9f9}.user-filter-dropdown{position:absolute;top:100%;left:0;margin-top:.25rem;background:#fff;border:1px solid #e5e5e5;border-radius:6px;box-shadow:0 2px 8px #0000001a;z-index:100;min-width:150px;max-height:300px;overflow-y:auto}.user-filter-option{padding:.5rem 1rem;cursor:pointer;color:#333;font-size:.9rem;transition:background-color .2s}.user-filter-option:hover{background-color:#f9f9f9}.user-filter-option.selected{background-color:#667eea;color:#fff}.view-switcher{display:flex;gap:.5rem}.view-switcher button{padding:.5rem 1rem;border:1px solid #e5e5e5;background:#fff;color:#666;font-weight:500;font-size:.9rem;cursor:pointer;transition:all .2s;border-radius:6px}.view-switcher button.active{background:#667eea;color:#fff;border-color:#667eea;z-index:1}.calendar-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:auto 1fr;flex:1;border-left:1px solid #e5e5e5;border-top:1px solid #e5e5e5;overflow:auto}.week-day-header{padding:10px;text-align:center;font-weight:600;color:#666;background:#f9f9f9;border-bottom:1px solid #e5e5e5;border-right:1px solid #e5e5e5;position:sticky;top:0;z-index:10}.month-day-cell{border-right:1px solid #e5e5e5;border-bottom:1px solid #e5e5e5;min-height:100px;padding:2px;display:flex;flex-direction:column;gap:0px;background:#fff}.month-day-cell.other-month{background:#fcfcfc;color:#999}.month-day-cell.today{background:#f0f4ff}.day-number{font-weight:600;margin-bottom:5px;font-size:.9rem;color:#333}.month-day-cell.other-month .day-number{color:#ccc}.calendar-entry{font-size:.75rem;padding:0 3px;background:#e3f2fd;border-left:3px solid #2196f3;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;color:#333;font-weight:500;margin-bottom:0;transition:transform .1s;display:flex;align-items:flex-start;text-align:left}.calendar-entry:hover{transform:scale(1.02);z-index:5}.week-view-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.week-header{display:grid;grid-template-columns:60px repeat(7,1fr);border-bottom:1px solid #e5e5e5;flex-shrink:0}.week-header-cell{padding:10px;text-align:center;border-right:1px solid #e5e5e5;background:#f9f9f9;color:#333}.time-gutter-header{border-right:1px solid #e5e5e5;background:#f9f9f9}.week-body{flex:1;overflow-y:auto;display:grid;grid-template-columns:60px repeat(7,1fr);position:relative}.time-gutter{border-right:1px solid #e5e5e5;background:#fff}.time-slot-label{height:30px;display:flex;align-items:flex-start;justify-content:flex-end;padding-right:8px;font-size:.75rem;color:#999;transform:translateY(-50%);font-weight:500}.day-column{border-right:1px solid #e5e5e5;position:relative;height:720px;background:#fff}.hour-cell{height:30px;border-bottom:1px solid #f5f5f5}.week-entry{position:absolute;left:2px;right:2px;background:#e3f2fd;border:1px solid #90caf9;border-radius:4px;padding:0 2px;font-size:.75rem;overflow:hidden;z-index:1;color:#333;box-shadow:0 1px 3px #0000001a;transition:all .2s;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;text-align:left}.week-entry:hover{z-index:10;box-shadow:0 4px 8px #00000026;transform:scale(1.02)}.entry-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.entry-modal{background:#fff;padding:20px;border-radius:12px;box-shadow:0 4px 20px #0003;width:100%;max-width:400px;animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.entry-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e5e5e5}.entry-modal-header h3{margin:0;font-size:1.25rem;color:#333}.close-button{background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;padding:0;line-height:1}.close-button:hover{color:#333}.detail-row{display:flex;margin-bottom:.75rem;align-items:baseline}.detail-row.description{flex-direction:column;gap:.25rem}.detail-label{font-weight:600;color:#666;min-width:80px;font-size:.9rem}.detail-value{color:#333;font-size:.95rem}.detail-row.description .detail-value{background:#f9f9f9;padding:10px;border-radius:6px;width:100%;margin:0;box-sizing:border-box;line-height:1.4}@media (prefers-color-scheme: dark){.calendar-container{background:#242424;box-shadow:none;border:1px solid #333}.calendar-header{border-bottom-color:#333}.calendar-controls button,.view-switcher button{background:#2a2a2a;border-color:#333;color:#aaa}.calendar-controls button:hover,.view-switcher button:hover{background:#333;color:#fff;border-color:#667eea}.view-switcher button.active{background:#667eea;color:#fff}.current-date-display{color:#aaa}.user-filter-button{background:#2a2a2a;border-color:#333;color:#aaa}.user-filter-button:hover{background:#333;color:#fff;border-color:#667eea}.user-filter-dropdown{background:#242424;border-color:#333}.user-filter-option{color:#fff}.user-filter-option:hover{background-color:#333}.user-filter-option.selected{background-color:#667eea;color:#fff}.month-grid,.month-day-cell,.week-day-header,.week-header,.week-header-cell,.time-gutter-header,.time-gutter,.day-column,.hour-cell{border-color:#333;background:#242424}.week-day-header,.week-header-cell,.time-gutter-header{background:#2a2a2a;color:#aaa}.month-day-cell.other-month{background:#1a1a1a;color:#444}.month-day-cell.today{background:#2c3e50}.day-number{color:#ddd}.month-day-cell.other-month .day-number{color:#555}.calendar-entry,.week-entry{color:#ddd}.entry-modal{background:#242424;border:1px solid #333}.entry-modal-header{border-bottom-color:#333}.entry-modal-header h3{color:#fff}.detail-label{color:#aaa}.detail-value{color:#fff}.detail-row.description .detail-value{background:#2a2a2a}}.dashboard{min-height:100vh;background-color:#f5f5f5}.dashboard-header{background:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.header-left h1{font-size:1.5rem;color:#333;margin:0}.header-right{display:flex;align-items:center;gap:1rem}.timezone-info{color:#666;font-size:.875rem;font-weight:400;padding:.25rem .5rem;background-color:#f5f5f5;border-radius:4px;white-space:nowrap}.user-name{color:#666;font-weight:500}.user-avatar{width:40px;height:40px;border-radius:50%}.logout-button{background-color:#dc2626;color:#fff;border:none}.logout-button:hover{background-color:#b91c1c}.dashboard-nav{background:#fff;padding:0 2rem;display:flex;gap:1rem;border-bottom:1px solid #e5e5e5}.dashboard-nav button{background:none;border:none;border-bottom:3px solid transparent;padding:1rem 1.5rem;color:#666;font-weight:500;border-radius:0;transition:all .2s}.dashboard-nav button:hover{color:#333;background-color:#f9f9f9}.dashboard-nav button.active{color:#667eea;border-bottom-color:#667eea}.dashboard-content{padding:2rem;max-width:1400px;margin:0 auto}@media (prefers-color-scheme: dark){.dashboard{background-color:#1a1a1a}.dashboard-header{background:#242424}.header-left h1{color:#fff}.timezone-info{color:#aaa;background-color:#2a2a2a}.user-name{color:#aaa}.dashboard-nav{background:#242424;border-bottom-color:#333}.dashboard-nav button{color:#aaa}.dashboard-nav button:hover{color:#fff;background-color:#2a2a2a}}@media (max-width: 768px){.dashboard-header{flex-direction:column;gap:1rem;padding:1rem}.dashboard-content{padding:1rem}}.app{min-height:100vh;width:100%}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-width:320px;min-height:100vh}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}input,select,textarea{font-family:inherit;font-size:1em;padding:.6em;border:1px solid #444;border-radius:4px;background-color:#1a1a1a;color:inherit}input:focus,select:focus,textarea:focus{outline:none;border-color:#646cff}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}button{background-color:#f9f9f9}input,select,textarea{background-color:#fff;border-color:#ddd}}
