@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-primary: #0a0e14;--bg-secondary: #0d1117;--bg-tertiary: #151b23;--bg-hover: #1c242e;--bg-selected: #1a2332;--border-subtle: rgba(255, 255, 255, .06);--border-default: rgba(255, 255, 255, .1);--border-active: rgba(255, 255, 255, .2);--text-primary: #e6edf3;--text-secondary: #8b949e;--text-tertiary: #6e7681;--accent-cyan: #58a6ff;--accent-cyan-dim: rgba(88, 166, 255, .15);--accent-amber: #f0b429;--accent-amber-dim: rgba(240, 180, 41, .15);--accent-green: #3fb950;--accent-red: #f85149;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-glow: 0 0 40px rgba(88, 166, 255, .1)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Outfit,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;height:100%;min-height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-left{display:flex;align-items:center;gap:20px}.header-left svg{height:32px;width:auto}.header-title{display:flex;flex-direction:column;gap:2px}.header-title h1{font-size:18px;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.header-subtitle{font-size:12px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;font-weight:500}.header-right{display:flex;align-items:center;gap:16px}.date-picker{display:flex;align-items:center;gap:12px;padding:8px 16px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:8px}.date-field{display:flex;flex-direction:column;gap:4px}.date-field label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);font-weight:500}.date-field input[type=date]{background:transparent;border:none;color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:13px;padding:4px 0;cursor:pointer;color-scheme:dark}.date-field input[type=date]:focus{outline:none}.date-field input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.7}.date-field input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.date-separator{color:var(--text-tertiary);font-size:14px;margin-top:14px}.error-banner{display:flex;align-items:center;gap:12px;padding:12px 32px;background:#f851491a;border-bottom:1px solid rgba(248,81,73,.2);color:var(--accent-red);font-size:14px}.error-icon{font-size:16px}.error-dismiss{margin-left:auto;background:none;border:none;color:var(--accent-red);font-size:20px;cursor:pointer;padding:0 4px;opacity:.7;transition:opacity .2s}.error-dismiss:hover{opacity:1}.success-banner{display:flex;align-items:center;gap:12px;padding:12px 32px;background:#34c7591a;border-bottom:1px solid rgba(52,199,89,.2);color:#34c759;font-size:14px}.success-icon{font-size:16px;font-weight:700}.success-dismiss{margin-left:auto;background:none;border:none;color:#34c759;font-size:20px;cursor:pointer;padding:0 4px;opacity:.7;transition:opacity .2s}.success-dismiss:hover{opacity:1}.main{flex:1;overflow:auto;padding:24px 32px 100px}.table-container{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-md)}.table-toolbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-subtle);background:var(--bg-tertiary)}.search-box{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:8px;min-width:280px;transition:border-color .15s,box-shadow .15s}.search-box:focus-within{border-color:var(--accent-cyan);box-shadow:0 0 0 3px var(--accent-cyan-dim)}.search-icon{color:var(--text-tertiary);font-size:16px}.search-box input{flex:1;background:transparent;border:none;color:var(--text-primary);font-family:Outfit,sans-serif;font-size:14px;outline:none}.search-box input::placeholder{color:var(--text-tertiary)}.search-clear{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--border-default);border:none;border-radius:50%;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .15s}.search-clear:hover{background:var(--border-active);color:var(--text-primary)}.toolbar-right{display:flex;align-items:center;gap:16px}.loading-indicator{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--accent-cyan);padding:6px 12px;background:var(--accent-cyan-dim);border-radius:6px}.loading-spinner-small{width:14px;height:14px;border:2px solid var(--border-default);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin .8s linear infinite}.table-stats{font-size:13px;color:var(--text-tertiary)}.btn-group{display:flex;gap:1px;background:var(--border-default);border-radius:6px;overflow:hidden}.btn-toolbar{padding:6px 12px;background:var(--bg-secondary);border:none;color:var(--text-secondary);font-family:Outfit,sans-serif;font-size:13px;cursor:pointer;transition:all .15s}.btn-toolbar:hover{background:var(--bg-hover);color:var(--accent-cyan)}.toggle-filter{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-filter input{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;width:36px;height:20px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:10px;transition:all .2s}.toggle-slider:after{content:"";position:absolute;left:2px;top:2px;width:14px;height:14px;background:var(--text-tertiary);border-radius:50%;transition:all .2s}.toggle-filter input:checked+.toggle-slider{background:var(--accent-cyan-dim);border-color:var(--accent-cyan)}.toggle-filter input:checked+.toggle-slider:after{left:18px;background:var(--accent-cyan)}.toggle-label{font-size:13px;color:var(--text-secondary)}.toggle-filter:hover .toggle-label{color:var(--text-primary)}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table thead{background:var(--bg-tertiary);position:sticky;top:0}.data-table th{padding:12px 16px;text-align:left;font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);border-bottom:1px solid var(--border-default)}.data-table td{padding:12px 16px;border-bottom:1px solid var(--border-subtle);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.col-checkbox{width:48px;text-align:center}.col-expand{width:40px}.col-name{min-width:300px}th.col-hours,td.col-hours{width:120px;text-align:right}th.col-amount,td.col-amount{width:160px;text-align:right}.col-hours.mono,.col-amount.mono{font-family:JetBrains Mono,monospace;font-size:13px}.customer-row{background:var(--bg-secondary);transition:background .15s;border-left:3px solid transparent}.customer-row:hover{background:var(--bg-hover)}.customer-row.expanded{background:var(--bg-tertiary)}.customer-row.has-selection{border-left-color:var(--accent-cyan);background:var(--bg-tertiary)}.customer-row.has-selection .customer-name:after{content:"";display:inline-block;width:8px;height:8px;background:var(--accent-cyan);border-radius:50%;margin-left:10px;vertical-align:middle;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.customer-name{font-weight:600;font-size:15px;color:var(--text-primary)}.inline-loader{margin-left:8px;color:var(--accent-cyan)}.spinner{animation:spin .8s linear infinite}.refresh-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;margin-left:10px;background:transparent;border:1px solid var(--border-default);border-radius:4px;color:var(--text-tertiary);font-size:14px;cursor:pointer;transition:all .15s;vertical-align:middle}.refresh-btn:hover{background:var(--bg-hover);border-color:var(--accent-cyan);color:var(--accent-cyan)}.project-row{background:var(--bg-primary);transition:background .15s;border-left:3px solid var(--border-subtle)}.project-row:hover{background:var(--bg-hover)}.project-row.selected{background:var(--accent-cyan-dim);border-left-color:var(--accent-cyan)}.project-row .col-checkbox{padding-left:16px}.project-row .col-name{padding-left:20px;position:relative}.project-row .col-name:before{content:"";position:absolute;left:8px;top:50%;width:6px;height:1px;background:var(--border-default)}.project-row .project-name{font-size:13px;font-weight:400}.project-name{color:var(--text-secondary)}.project-row.selected .project-name{color:var(--text-primary);font-weight:500}.entry-count{display:inline-block;margin-left:12px;padding:2px 8px;background:var(--accent-cyan-dim);color:var(--accent-cyan);font-size:11px;font-weight:500;border-radius:4px}.error-badge{display:inline-block;margin-left:12px;padding:2px 8px;background:#f8514926;color:var(--accent-red);font-size:11px;font-weight:500;border-radius:4px}.error-text{color:var(--accent-red)}.project-row.error{opacity:.6}.project-row.error .project-name{color:var(--text-tertiary)}.project-loading{padding:8px 20px 8px 88px;color:var(--text-tertiary);font-size:12px;font-style:italic}.no-projects-badge{display:inline-block;margin-left:12px;padding:2px 8px;background:var(--bg-tertiary);color:var(--text-tertiary);font-size:11px;border-radius:4px;font-style:italic}.has-value{color:var(--accent-amber)}.expand-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:1px solid var(--border-default);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.expand-btn:hover{background:var(--bg-hover);border-color:var(--border-active);color:var(--text-primary)}.expand-icon{font-size:16px;font-weight:600;transition:transform .2s ease}.expand-icon.rotated{transform:rotate(90deg)}.checkbox-wrapper{display:flex;align-items:center;justify-content:center;cursor:pointer}.checkbox-wrapper input{position:absolute;opacity:0;width:0;height:0}.checkbox-custom{width:18px;height:18px;border:2px solid var(--border-active);border-radius:4px;background:transparent;transition:all .15s;position:relative}.checkbox-wrapper:hover .checkbox-custom{border-color:var(--accent-cyan)}.checkbox-wrapper input:checked+.checkbox-custom{background:var(--accent-cyan);border-color:var(--accent-cyan)}.checkbox-wrapper input:checked+.checkbox-custom:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid var(--bg-primary);border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-wrapper input:indeterminate+.checkbox-custom{background:var(--accent-cyan);border-color:var(--accent-cyan)}.checkbox-wrapper input:indeterminate+.checkbox-custom:after{content:"";position:absolute;left:3px;top:6px;width:8px;height:2px;background:var(--bg-primary)}.loading-row td,.empty-row td{text-align:center;padding:48px 16px;color:var(--text-tertiary)}.loading-row td{display:flex;align-items:center;justify-content:center;gap:12px}.loading-spinner{width:20px;height:20px;border:2px solid var(--border-default);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.action-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:24px;padding:16px 24px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:12px;box-shadow:var(--shadow-lg),var(--shadow-glow);z-index:200;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.action-bar-info{display:flex;align-items:center;gap:12px;font-size:14px;white-space:nowrap}.selection-count{font-weight:600;color:var(--text-primary)}.selection-divider{color:var(--text-tertiary)}.selection-hours{font-family:JetBrains Mono,monospace;color:var(--text-secondary)}.selection-amount{font-family:JetBrains Mono,monospace;font-weight:600;color:var(--accent-amber)}.action-bar-actions{display:flex;align-items:center;gap:12px}.btn-secondary,.btn-action,.btn-primary{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:6px;font-family:Outfit,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-secondary{background:transparent;border:1px solid var(--border-default);color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-active);color:var(--text-primary)}.btn-action{background:var(--accent-amber-dim);border:1px solid var(--accent-amber);color:var(--accent-amber);font-weight:600}.btn-action:hover{background:#f0b42940;box-shadow:0 4px 12px #f0b42933}.btn-primary{background:var(--accent-cyan);border:none;color:var(--bg-primary);font-weight:600}.btn-primary:hover{background:#79b8ff;box-shadow:0 4px 12px #58a6ff4d}.btn-icon{font-size:14px}@media (max-width: 768px){.header{flex-direction:column;gap:16px;padding:16px}.header-left,.header-right{width:100%}.date-picker{width:100%;justify-content:center}.main{padding:16px}.col-name{min-width:auto}.action-bar{left:16px;right:16px;transform:none;flex-direction:column;gap:16px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}}.minimap{position:fixed;left:8px;top:100px;bottom:100px;width:8px;background:var(--bg-tertiary);border-radius:4px;border:1px solid var(--border-subtle);z-index:150;overflow:hidden}.minimap-viewport{position:absolute;left:0;right:0;background:#ffffff1a;border-radius:2px;border:1px solid rgba(255,255,255,.2);transition:top .1s ease-out}.minimap-marker{position:absolute;left:1px;right:1px;height:4px;background:var(--accent-cyan);border-radius:2px;box-shadow:0 0 6px var(--accent-cyan)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-active);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-active);border-radius:12px;box-shadow:var(--shadow-xl),0 0 40px #00000080;width:90%;max-width:500px;animation:modalSlideUp .3s ease}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-default)}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-tertiary);font-size:24px;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:24px}.modal-description{margin:0 0 20px;color:var(--text-secondary);font-size:14px;line-height:1.5}.modal-summary{background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:8px;padding:16px;margin-bottom:20px}.modal-stat{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.modal-stat:not(:last-child){border-bottom:1px solid var(--border-default)}.modal-stat-label{font-size:14px;color:var(--text-secondary)}.modal-stat-value{font-size:14px;font-weight:600;color:var(--text-primary);font-family:JetBrains Mono,monospace}.modal-warning{margin:0;padding:12px 16px;background:#f851491a;border:1px solid rgba(248,81,73,.2);border-radius:8px;color:var(--accent-red);font-size:13px;line-height:1.5}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--border-default);background:var(--bg-tertiary);border-radius:0 0 12px 12px}.modal-footer .btn-secondary,.modal-footer .btn-primary{min-width:100px;justify-content:center}.modal-results{max-width:600px}.results-summary{display:flex;gap:16px;margin-bottom:24px}.results-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:8px;opacity:.5;transition:all .2s}.results-stat.success,.results-stat.failed{opacity:1}.results-stat.success{background:#34c7591a;border-color:#34c7594d}.results-stat.failed{background:#f851491a;border-color:#f851494d}.results-icon{font-size:24px;font-weight:700}.results-stat.success .results-icon{color:#34c759}.results-stat.failed .results-icon{color:var(--accent-red)}.results-count{font-size:28px;font-weight:600;color:var(--text-primary)}.results-label{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.results-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.result-item{display:flex;gap:12px;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:8px;transition:all .2s}.result-success{border-left:3px solid #34c759}.result-failed{border-left:3px solid var(--accent-red)}.result-status{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;flex-shrink:0}.result-success .result-status{background:#34c75926}.result-failed .result-status{background:#f8514926}.result-icon{font-size:16px;font-weight:700}.result-success .result-icon{color:#34c759}.result-failed .result-icon{color:var(--accent-red)}.result-details{flex:1;min-width:0}.result-customer{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.result-info{font-size:12px;color:var(--text-secondary);font-family:JetBrains Mono,monospace}.result-date{color:var(--text-tertiary)}.result-error{font-size:12px;color:var(--accent-red);line-height:1.4}
