.tt-pp,.tt-filter-panel{z-index:600;background:var(--surface);box-shadow:var(--box-shadow);flex-direction:column;display:flex;position:fixed;overflow:hidden}.tt-pp input,.tt-filter-panel input{color:var(--text);font-size:var(--font-size-normal);border:var(--input-border);border-radius:var(--input-border-radius);outline:none;width:100%;margin:.5rem 0;padding:1rem .5rem;overflow:hidden}.tt-pp #tt-pp-list,.tt-filter-panel #tt-pp-list{overflow-y:auto}.tt-pp .tt-pp-group-header,.tt-filter-panel .tt-pp-group-header{font-size:var(--font-size-smaller);text-transform:uppercase;letter-spacing:.7px;color:#999;padding:10px 14px 4px}.tt-filter-panel{display:none;position:absolute}.tt-filter-panel.open{display:block}.tt-filter-panel.tt-filter-panel--project{width:280px}.tt-filter-panel.tt-filter-panel--project .tt-filter-options{max-height:320px;padding-bottom:6px;overflow-y:auto}.tt-filter-panel-search{border-bottom:1px solid var(--border-color);align-items:center;gap:8px;padding:8px 12px;display:flex}.BulkEditBar{background:var(--surface);border-bottom:1px solid var(--border-color);width:100%;top:-100px;left:var(--sidebar-width);box-shadow:var(--box-shadow);align-items:center;gap:12px;padding:1rem;transition:all .2s ease-in-out;display:flex;position:absolute}.BulkEditBar[data-selected=yes]{top:0}.BulkEditBar .bulkEditCount{font-size:var(--font-size-normal);color:var(--muted)}:root{--bg:#0f1117;--surface:#1a1d27;--border-color:#2e3341;--text:#e4e7ef;--muted:#8b90a0;--primary:#03a9f4;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--info:#0ea5e9;--radius:0;--font-size-smaller:.8125rem;--font-size-normal:.875rem;--font-size-bigger:1rem;--body-font:"Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--calc-font:"SF Mono", "Fira Code", monospace;--box-shadow:0 5px 10px #0000001a;--input-border-radius:2px;--input-border:1px solid #c6d2d9;--sidebar-width:220px;--dot-size:.4286rem}[data-theme=light]{--bg:#f4f5f7;--surface:#fff;--border-color:#dde1ea;--text:#1a1d27;--muted:#6b7280;--primary:#03a9f4;--success:#16a34a;--warning:#d97706;--danger:#dc2626;--info:#0284c7}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--body-font);background:var(--bg);color:var(--text);height:100vh;font-size:var(--font-size-normal);display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border-color);z-index:50;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-brand{border-bottom:1px solid var(--border-color);flex-shrink:0;padding:20px 20px 16px}.sidebar-brand .brand-title{font-size:17px;font-weight:700}.sidebar-brand .brand-title .r{color:var(--primary)}.sidebar-brand .brand-title .a{color:var(--muted);font-weight:400}.sidebar-brand .brand-sub{color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-top:2px;font-size:10px}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.sidebar-section{text-transform:uppercase;letter-spacing:.7px;color:var(--muted);padding:12px 16px 4px;font-size:10px;font-weight:600}.sidebar-footer{border-top:1px solid var(--border-color);flex-shrink:0;padding:12px 16px}.sidebar-user{align-items:center;gap:8px;margin-bottom:4px;padding:8px 4px 10px;display:flex}.sidebar-user .sidebar-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:28px;height:28px}.sidebar-user .sidebar-avatar-placeholder{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:600;display:flex}.sidebar-user .sidebar-user-name{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.8rem;overflow:hidden}.sidebar-user .sidebar-logout{color:var(--muted);border-radius:4px;flex-shrink:0;padding:3px 4px;font-size:15px;text-decoration:none;transition:color .12s,background .12s}.sidebar-user .sidebar-logout:hover{color:var(--danger);background:#ef44441a}.nav-link{color:var(--muted);text-align:left;text-transform:uppercase;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:1rem;text-decoration:none;transition:background .12s,color .12s;display:flex}.nav-link:hover{color:var(--text);background:#ffffff0d}.nav-link.active{color:var(--primary);background:#e4eaee;font-weight:400}.nav-link .nav-icon{text-align:center;flex-shrink:0;width:20px}.nav-group{position:relative}.nav-group:hover .nav-submenu,.nav-group.open .nav-submenu{max-height:400px;padding:.5rem 0}.nav-submenu{background-color:#e4eaee4d;max-height:0;transition:max-height .22s;overflow:hidden}.nav-sub-link{color:var(--muted);cursor:pointer;align-items:center;gap:10px;width:100%;padding:.5rem 1rem;text-decoration:none;transition:background .12s,color .12s;display:flex}.nav-sub-link:hover{color:var(--text)}.nav-sub-link.active{color:var(--primary);font-weight:500}.nav-sub-link .nav-icon{text-align:center;flex-shrink:0;width:18px}.nav-sub-section{font-size:var(--font-size-small);text-transform:uppercase;letter-spacing:.7px;color:#999;padding:1rem}.content-wrap{flex:1;height:100vh;margin-left:220px;padding:32px 36px;overflow-y:auto}.content-wrap.no-padding{padding:0}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;padding:12px 1rem}.btn-primary:hover{filter:brightness(1.15)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{color:var(--muted);border:1px solid var(--border-color);background:0 0}.btn-ghost:hover{color:var(--text);border-color:var(--muted)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{filter:brightness(1.1)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(1.1)}.btn-info{background:var(--info);color:#fff}.btn-info:hover{filter:brightness(1.1)}.btn-link{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-size:.875rem}.btn-link:hover{color:var(--text);background:#ffffff0d}.btn-sm{padding:5px 10px;font-size:.875rem}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sortable-th:hover{color:var(--primary)}.sort-arrow{color:var(--primary);font-size:11px}.table-wrap{background:var(--surface);border:1px solid var(--border-color);border-radius:10px;overflow:hidden}table{border-collapse:collapse;width:100%;font-size:.875rem}th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);padding:10px 16px;font-size:11px;font-weight:500}td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:13px 16px}tr:last-child td{border-bottom:none}.detail-row{display:none}.detail-row.open{display:table-row}.detail-row td{border-bottom:1px solid var(--border-color);padding:0!important}.detail-inner{background:#0000000f;padding:12px 16px 16px 44px}[data-theme=light] .detail-inner{background:#00000008}.detail-inner table{font-size:.875rem}.detail-inner th{border-bottom:1px solid #ffffff0f;padding:6px 12px;font-size:10px}.detail-inner td{color:var(--muted);border-bottom:1px solid #ffffff0a;padding:7px 12px}.detail-inner tr:last-child td{border-bottom:none}.detail-inner .fn-num{color:#818cf8;font-weight:600}.detail-inner .amt{color:var(--success)}.mono{font-family:var(--calc-font)}.amount{color:var(--success);font-size:16px;font-weight:600}.fn-desc{color:#818cf8;font-size:.875rem}.date-cell{color:var(--muted);white-space:nowrap;font-size:.875rem}.badge{border-radius:20px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.badge-ok{color:var(--success);background:#22c55e26}.copy-btn{border:1px solid var(--border-color);color:var(--muted);cursor:pointer;vertical-align:middle;background:0 0;border-radius:5px;margin-left:6px;padding:3px 7px;font-size:11px}.copy-btn:hover{color:var(--text);border-color:var(--muted)}.empty{text-align:center;color:var(--muted);font-size:var(--font-size-normal);padding:48px}.empty-icon{margin-bottom:10px;font-size:32px}.toggle-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:11px;transition:color .15s,transform .2s;display:inline-block}.toggle-btn:hover{color:var(--text)}.toggle-btn.open{color:var(--text);transform:rotate(90deg)}.row-actions{justify-content:end;align-items:center;gap:6px;display:flex}.status-dot{border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.status-dot.ok{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.err{background:var(--danger)}.status-dot.unknown{background:var(--muted)}.connect-bar{border:1px solid var(--border-color);background:#ffffff08;border-radius:8px;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;display:flex}.connect-bar .status-text{flex:1;font-size:.875rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-header h2{font-size:15px;font-weight:600}.callout{border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:.875rem;line-height:1.6}.callout-info{color:#7dd3fc;background:#0ea5e91a;border:1px solid #0ea5e940}.callout-warn{color:#fcd34d;background:#f59e0b1a;border:1px solid #f59e0b40}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:12px;height:12px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.toasts{z-index:999;position:fixed;top:20px;right:20px}.toast{background:var(--surface);border:1px solid var(--border-color);max-width:320px;box-shadow:var(--box-shadow);border-radius:7px;margin-bottom:8px;padding:10px 14px;font-size:.875rem;animation:.2s slideIn}.toast.ok{border-left:3px solid var(--success)}.toast.err{border-left:3px solid var(--danger)}.toast.info{border-left:3px solid var(--info)}@keyframes slideIn{0%{transform:translate(110%)}to{transform:translate(0)}}.modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:none;position:fixed;top:0;bottom:0;left:0;right:0}.modal-overlay.open{display:flex}.modal{background:var(--surface);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;width:780px;max-width:95vw;max-height:90vh;display:flex}.modal h3{margin-bottom:20px;font-size:15px;font-weight:600}.modal-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.modal-header h3{margin:0;font-size:15px;font-weight:600}.modal-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:18px}.modal-close:hover{color:var(--text);background:var(--border-color)}.modal-body{padding:20px 24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.form-row{gap:12px;margin-bottom:12px;display:flex}.form-group{flex-direction:column;flex:1;gap:4px;display:flex}.form-group label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px}.form-group input,.form-group select,.form-group textarea{background:var(--bg);border:1px solid var(--border-color);color:var(--text);padding:14px 10px;font-size:.875rem;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-group textarea{resize:vertical}.page-tabs{background:var(--bg);border:1px solid var(--border-color);border-radius:6px;gap:2px;margin-bottom:20px;padding:3px;display:inline-flex}.page-tab{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:4px;padding:6px 16px;font-size:.875rem;font-weight:500;transition:background .12s,color .12s,box-shadow .12s}.page-tab:hover{color:var(--text)}.page-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000026}.tab-panel.hidden{display:none}.theme-option-row{gap:8px;display:flex}.theme-option-row .btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.settings-grid{grid-template-columns:repeat(auto-fill,minmax(440px,1fr));gap:20px;display:grid}.form-card{background:var(--surface);border:1px solid var(--border-color);border-radius:10px;padding:28px}.form-card h3{margin-bottom:6px;font-size:15px;font-weight:600}.form-card .card-desc{color:var(--muted);margin-bottom:20px;font-size:.875rem}.field{margin-bottom:16px}.field label{color:var(--muted);margin-bottom:5px;font-size:.875rem;display:block}.field input,.field select{background:var(--bg);border:1px solid var(--border-color);width:100%;color:var(--text);border-radius:6px;padding:8px 12px;font-size:.875rem}.field input:focus,.field select:focus{border-color:var(--primary);outline:none}.field input{font-family:var(--calc-font)}.field select{cursor:pointer;font-family:inherit}.field .hint{color:var(--muted);margin-top:4px;font-size:11px;line-height:1.5}.field .hint a{color:var(--info);text-decoration:none}.field .hint a:hover{text-decoration:underline}.test-result{border-radius:6px;margin-top:10px;padding:9px 12px;font-size:.875rem;display:none}.ss-wrap{position:relative}.ss-control{background:var(--bg);border:1px solid var(--border-color);cursor:pointer;border-radius:6px;align-items:center;gap:6px;min-height:36px;padding:6px 10px;transition:border-color .15s;display:flex}.ss-control:focus-within,.ss-control.open{border-color:var(--primary)}.ss-control.open .ss-arrow{transform:rotate(180deg)}.ss-selected{flex-wrap:wrap;flex:1;align-items:center;gap:6px;display:flex}.ss-chip{background:var(--primary);color:#fff;border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:.875rem;font-weight:500;display:inline-flex}.ss-chip-remove{color:#fff;cursor:pointer;font-size:var(--font-size-normal);opacity:.8;background:0 0;border:none;padding:0;line-height:1}.ss-chip-remove:hover{opacity:1}.ss-placeholder{color:var(--muted);font-size:.875rem}.ss-arrow{color:var(--muted);margin-left:auto;font-size:11px;transition:transform .15s}.ss-dropdown{z-index:300;background:var(--surface);border:1px solid var(--border-color);box-shadow:var(--box-shadow);border-radius:8px;display:none;position:absolute;top:calc(100% + 3px);left:0;right:0;overflow:hidden}.ss-dropdown.open{display:block}.ss-dropdown-search{border-bottom:1px solid var(--border-color);padding:8px 10px}.ss-dropdown-search input{width:100%;color:var(--text);background:0 0;border:none;outline:none;font-size:.875rem}.ss-list{max-height:220px;overflow-y:auto}.ss-item{cursor:pointer;border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:9px 12px;font-size:.875rem;transition:background .1s;display:flex}.ss-item:last-child{border-bottom:none}.ss-item:hover,.ss-item.active{background:color-mix(in srgb, var(--primary) 12%, transparent)}.ss-item.selected{color:var(--primary);font-weight:500}.ss-item .ss-code{color:var(--muted);font-size:11px}.ss-empty{text-align:center;color:var(--muted);padding:12px;font-size:.875rem}.stats-bar{flex-wrap:wrap;gap:16px;margin-bottom:24px;display:flex}.stat-card{background:var(--surface);border:1px solid var(--border-color);border-radius:10px;flex:1;min-width:140px;padding:16px 20px}.stat-card .stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px}.stat-card .stat-value{font-size:22px;font-weight:700}.tt-main{flex-direction:column;height:100vh;display:flex;overflow:hidden}.tt-timer-bar{background:var(--surface);border-bottom:1px solid var(--border-color);z-index:10;flex-shrink:0;align-items:center;gap:10px;padding:12px 24px;display:flex;position:-webkit-sticky;position:sticky;top:0}.tt-desc-input{color:var(--text);font-size:var(--font-size-normal);background:0 0;border:none;outline:none;flex:1}.tt-desc-input::placeholder{color:var(--muted)}.tt-bar-sep{background:var(--border-color);width:1px;height:28px}.tt-project-btn{border:1px solid var(--border-color);color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;align-items:center;gap:6px;padding:6px 10px;font-size:.875rem;transition:all .12s;display:flex}.tt-project-btn:hover{border-color:var(--primary);color:var(--text)}.tt-project-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.tt-billable-btn{border:1px solid var(--border-color);color:var(--muted);cursor:pointer;background:0 0;padding:6px 10px;font-size:.875rem;transition:all .12s}.tt-billable-btn.active{color:var(--success);border-color:var(--success)}.tt-clock{font-size:18px;font-weight:600;font-family:var(--calc-font);color:var(--text);text-align:center;min-width:80px}.tt-start-btn{border-radius:var(--radius);background:var(--primary);color:#fff;font-size:var(--font-size-normal);cursor:pointer;white-space:nowrap;border:none;padding:8px 20px;font-weight:600;transition:filter .15s}.tt-start-btn:hover{filter:brightness(1.1)}.tt-start-btn.running{background:var(--danger)}.tt-starttime-btn{border:1px solid var(--border-color);color:var(--muted);font-size:.875rem;font-family:var(--calc-font);cursor:pointer;white-space:nowrap;background:0 0;align-items:center;gap:5px;padding:5px 9px;transition:all .12s;display:flex}.tt-starttime-btn:hover{border-color:var(--primary);color:var(--text)}.tt-starttime-btn.custom{color:var(--primary);border-color:var(--primary)}.tt-starttime-popup{z-index:500;background:var(--surface);border:1px solid var(--border-color);box-shadow:var(--box-shadow);border-radius:10px;width:220px;padding:14px 16px;position:fixed}.tt-starttime-popup label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px;font-size:11px;display:block}.tt-starttime-popup input[type=time]{background:var(--bg);border:1px solid var(--border-color);width:100%;color:var(--text);font-size:15px;font-family:var(--calc-font);border-radius:6px;outline:none;padding:7px 10px;transition:border-color .15s}.tt-starttime-popup input[type=time]:focus{border-color:var(--primary)}.tt-starttime-popup .popup-actions{gap:6px;margin-top:10px;display:flex}.tt-views{flex:1;position:relative;overflow-y:auto}.tt-view{display:none}.tt-view.active{display:block}.tt-content{padding:24px}.tt-week-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.tt-week-total{font-size:var(--font-size-normal);color:var(--text);font-weight:600}.tt-week-group{margin-bottom:24px}.tt-week-group-header{justify-content:space-between;align-items:center;margin-bottom:8px;padding:0 2px 8px;display:flex}.tt-week-group-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-size:.75rem;font-weight:600}.tt-week-group-total{color:var(--muted);font-size:.8rem;font-weight:600;font-family:var(--calc-font)}.tt-day-group{border:1px solid var(--border-color);border-radius:10px;margin-bottom:12px;overflow:hidden}.tt-day-header{background:var(--bg);justify-content:space-between;align-items:center;padding:10px 18px;font-size:.875rem;display:flex}.tt-day-label{color:var(--text);font-size:.875rem;font-weight:400}.tt-day-total{color:var(--muted);align-items:center;gap:8px;font-size:.875rem;display:flex}.tt-day-total strong{color:var(--text);font-weight:700;font-family:var(--calc-font);font-size:15px}.tt-entry{background:var(--surface);border-top:1px solid var(--border-color);align-items:center;gap:14px;padding:14px 18px;transition:background .1s;display:flex}.tt-entry:hover{background:color-mix(in srgb, var(--primary) 4%, var(--surface))}.tt-entry:hover .tt-entry-actions{opacity:1}.tt-entry-count{color:#03a9f4;cursor:pointer;background:#03a9f426;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;min-width:24px;height:24px;font-size:11px;font-weight:700;transition:background .12s;display:flex}.tt-entry-count:hover{background:#03a9f44d}.tt-entry-count.expanded{color:#fff;background:#03a9f4}.tt-entry-count.hidden{color:#0000;cursor:default;pointer-events:none;background:0 0}.tt-entry-grouped{display:none}.tt-entry-grouped.open{display:flex;background:#f6fcff!important}[data-theme=light] .tt-entry-grouped.open{background:#f6fcff!important}.tt-entry-grouped.open .tt-entry-count.hidden{display:none}.tt-entry-group-header{cursor:pointer}.tt-entry-group-header:hover{background:#ffffff0a}.tt-entry-group-header.expanded{background:#e8f4fd!important}[data-theme=light] .tt-entry-group-header.expanded{background:#def!important}.tt-entry-desc{flex-wrap:wrap;flex:1;align-items:center;gap:12px;min-width:0;display:flex}.tt-entry-desc .tt-desc-text{white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:.875rem;font-weight:400;overflow:hidden}.tt-entry-desc .tt-no-desc{color:var(--muted);flex-shrink:0;font-size:.875rem;font-style:italic}.tt-entry-project{align-items:center;gap:5px;font-size:12.5px;display:flex}.tt-dot{width:var(--dot-size);height:var(--dot-size);border-radius:50%;flex-shrink:0}.tt-proj-link,.tt-task-link{color:var(--primary);font-weight:400}.tt-client-sep{color:var(--muted)}.tt-entry-meta{flex-shrink:0;align-items:center;gap:14px;display:flex}.tt-meta-icon{color:var(--muted);opacity:.5;font-size:13px}.tt-entry-billable{font-size:var(--font-size-normal);font-weight:600}.tt-entry-billable.yes{color:var(--primary);opacity:.8}.tt-entry-billable.no{color:var(--muted);opacity:.4}.tt-entry-time{color:var(--muted);white-space:nowrap;text-align:center;min-width:100px;font-size:.875rem}.tt-entry-dur{font-size:var(--font-size-normal);font-weight:700;font-family:var(--calc-font);text-align:right;min-width:52px;color:var(--text)}.tt-entry-actions{opacity:0;flex-shrink:0;gap:2px;transition:opacity .15s;display:flex}.tt-icon-btn{cursor:pointer;color:var(--muted);font-size:var(--font-size-normal);background:0 0;border:none;border-radius:5px;padding:5px 7px;line-height:1;transition:color .1s,background .1s}.tt-icon-btn:hover{color:var(--text);background:var(--border-color)}.tt-kebab-menu{z-index:600;background:var(--surface);border:1px solid var(--border-color);box-shadow:var(--box-shadow);border-radius:8px;min-width:140px;position:fixed;overflow:hidden}.tt-kebab-item{cursor:pointer;align-items:center;gap:8px;padding:9px 14px;font-size:.875rem;transition:background .1s;display:flex}.tt-kebab-item:hover{background:#ffffff0f}.tt-kebab-item.danger{color:var(--danger)}.tt-entry-check{-webkit-appearance:none;appearance:none;border:2px solid var(--border-color);cursor:pointer;background:var(--bg);border-radius:3px;flex-shrink:0;width:15px;height:15px;transition:all .1s}.tt-entry-check:checked{background:var(--primary);border-color:var(--primary)}.tt-color-dot{vertical-align:middle;border-radius:50%;width:10px;height:10px;margin-right:8px;display:inline-block}.tt-table-wrap{background:var(--surface);border:1px solid var(--border-color);overflow:hidden}.tt-table{border-collapse:collapse;width:100%;font-size:.875rem}.tt-table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border-color);padding:12px 20px;font-size:11px;font-weight:600}.tt-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;padding:16px 20px}.tt-table tr:last-child td{border-bottom:none}.tt-table tbody tr:hover td{background:color-mix(in srgb, var(--primary) 3%, var(--surface))}.tt-invoice-bar{background:var(--surface);border-top:1px solid var(--border-color);align-items:center;gap:12px;padding:12px 24px;display:none;position:-webkit-sticky;position:sticky;bottom:0}.tt-invoice-bar.visible{display:flex}.color-swatches{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:22px;height:22px;transition:transform .1s}.color-swatch:hover{transform:scale(1.2)}.color-swatch.selected{border-color:var(--text)}.tt-proj-detail{display:none}.tt-proj-detail.open{display:table-row}.tt-proj-detail td{border-bottom:1px solid var(--border-color)}.tt-proj-detail-inner{background:#0000000a;padding:0 20px 20px 48px}[data-theme=light] .tt-proj-detail-inner{background:#00000005}.tt-proj-detail-inner table{width:100%;margin-top:0;font-size:.875rem}.tt-proj-detail-inner th{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);padding:8px 12px;font-size:10px;font-weight:600}.tt-proj-detail-inner td{color:var(--muted);border-bottom:1px solid var(--border-color);padding:12px;font-size:.875rem}.tt-proj-detail-inner tr:last-child td{border-bottom:none}.tt-proj-summary{color:var(--muted);border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:28px;margin-bottom:4px;padding:16px 0 12px;font-size:.875rem;display:flex}.tt-proj-summary strong{color:var(--text);font-size:.875rem}.tt-proj-invoiced-badge{border-radius:10px;padding:1px 7px;font-size:10px;font-weight:600;display:inline-block}.tt-proj-invoiced-badge.yes{color:var(--success);background:#22c55e26}.tt-proj-invoiced-badge.no{color:var(--warning);background:#f59e0b1f}.tt-proj-tracked{font-variant-numeric:tabular-nums;color:var(--text)}.tt-proj-amount{font-variant-numeric:tabular-nums;color:var(--success);font-weight:500}.tt-proj-amount.zero{color:var(--muted)}#tt-client-modal .modal-body{overflow:visible}#tt-client-modal .form-group{position:relative}#tt-client-modal #tt-cm-hf-list{border:1px solid var(--border-color);z-index:99;background-color:#fff;max-height:280px;font-size:.875rem;position:absolute;top:50px;overflow-x:hidden;overflow-y:auto}#tt-client-modal #tt-cm-hf-list .hf-client-list{cursor:pointer;border-bottom:1px solid var(--border-color);width:410px;padding:.678rem 1.4286rem;font-size:.875rem}.tt-filter-bar{background-color:#fff;border:1px solid #e1e9ef;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;padding:12px 8px;display:flex}.tt-filter-label{text-transform:uppercase;letter-spacing:.7px;color:#999;padding:0 4px;font-size:11px;font-weight:600}.tt-filter-dropdown{position:relative}.tt-filter-btn{background:var(--surface);color:#666;cursor:pointer;white-space:nowrap;border:none;border-left:1px dotted #cfd8dd;border-right:1px dotted #cfd8dd;align-items:center;gap:6px;padding:.5rem 1.4286rem;font-size:.875rem;transition:border-color .15s;display:inline-flex}.tt-filter-btn.has-filter{border-color:var(--primary);color:var(--primary)}.tt-filter-chevron{font-size:var(--font-size-bigger);color:var(--muted)}.tt-filter-badge{background:var(--primary);color:#fff;border-radius:20px;padding:1px 7px;font-size:11px;font-weight:600;line-height:1.6}.tt-filter-options{max-height:280px;overflow-y:auto}.tt-filter-option{cursor:pointer;border-bottom:1px solid var(--border-color);align-items:center;gap:10px;padding:9px 14px;font-size:.875rem;transition:background .1s;display:flex}.tt-filter-option:last-child{border-bottom:none}.tt-filter-option:hover{background:#ffffff0a}.tt-filter-option.select-all{font-weight:500}.tt-filter-option input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.tt-import-dropzone{border:2px dashed var(--border-color);text-align:center;cursor:pointer;color:var(--text);border-radius:10px;margin-bottom:16px;padding:32px;font-size:.875rem;transition:border-color .15s,background .15s}.tt-import-dropzone:hover,.tt-import-dropzone.drag{border-color:var(--primary);background:#6366f10f}.tt-pp-search-bar{border-bottom:1px solid var(--border-color);flex-shrink:0;align-items:center;gap:8px;padding:10px 12px;display:flex}.tt-pp-search-bar input{color:var(--text);font-size:var(--font-size-normal);background:0 0;border:none;outline:none;flex:1;font-family:inherit}.tt-pp-list{flex:1;overflow-y:auto}.tt-pp-footer{border-top:1px solid var(--border-color);flex-shrink:0}.tt-pp-project{align-items:center;gap:8px;padding:10px 12px;display:flex}.tt-pp-project.tt-pp-project--check{cursor:pointer;transition:background .1s}.tt-pp-project.tt-pp-project--check:hover{background:#ffffff0a}.tt-pp-project .tt-pp-dot{width:var(--dot-size);height:var(--dot-size);border-radius:50%;flex-shrink:0;display:inline-block}.tt-pp-project .tt-pp-pname{font-size:var(--font-size-normal);cursor:pointer;color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.tt-pp-project .tt-pp-pname:hover{color:var(--primary)}.tt-pp-tasks-btn{color:var(--primary);cursor:pointer;white-space:nowrap;background:#6366f11a;border:none;border-radius:5px;flex-shrink:0;align-items:center;gap:4px;padding:3px 8px;font-size:11px;transition:background .12s;display:flex}.tt-pp-tasks-btn:hover{background:#6366f133}.tt-pp-chevron{font-size:10px;transition:transform .15s;display:inline-block}.tt-pp-chevron.open{transform:rotate(-180deg)}.tt-pp-task{cursor:pointer;color:var(--muted);border-bottom:1px solid var(--border-color);align-items:center;gap:7px;padding:11px 14px 10px 30px;font-size:.875rem;transition:background .1s;display:flex}.tt-pp-task:hover{color:var(--text);background:#6366f114}.tt-pp-task.tt-pp-newtask{color:var(--primary)!important}.tt-pp-task.tt-pp-newtask:hover{background:#6366f114!important}.tt-pp-task.tt-pp-task-active{background:#5c6bc01f;font-weight:500;color:var(--primary)!important}.tt-pp-action{cursor:pointer;align-items:center;gap:8px;padding:10px 14px;font-size:.875rem;transition:background .1s;display:flex}.tt-pp-action:hover{background:#6366f114}.tt-em-proj-btn{background:var(--bg);border:1px solid var(--border-color);width:100%;color:var(--text);font-size:var(--font-size-normal);cursor:pointer;text-align:left;align-items:center;gap:8px;padding:8px 10px;transition:border-color .15s;display:flex}.tt-em-proj-btn:hover,.tt-em-proj-btn:focus{border-color:var(--primary);outline:none}.tt-em-proj-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.hf-search-input{background:var(--bg);border:1px solid var(--border-color);width:100%;color:var(--text);border-radius:6px;padding:8px 10px;font-family:inherit;font-size:.875rem;transition:border-color .15s}.hf-search-input:focus{border-color:var(--primary);outline:none}.hf-search-list{border:1px solid var(--border-color);border-radius:6px;max-height:200px;margin-top:3px;display:none;overflow-x:hidden;overflow-y:auto}.hf-search-list.open{display:block}.hf-search-item{cursor:pointer;border-bottom:1px solid var(--border-color);align-items:center;gap:8px;padding:8px 10px;font-size:.875rem;transition:background .1s;display:flex}.hf-search-item:last-child{border-bottom:none}.hf-search-item:hover{background:color-mix(in srgb, var(--primary) 10%, transparent)}.hf-search-item .hf-code{color:var(--muted);font-family:monospace;font-size:11px}.tt-settings-card{background:var(--surface);border:1px solid var(--border-color);border-radius:10px;max-width:480px;padding:24px}.tt-settings-card h3{font-size:var(--font-size-normal);margin-bottom:16px;font-weight:600}.tt-filter-clear{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:.8rem;transition:color .12s,background .12s}.tt-filter-clear:hover{color:var(--danger);background:#ef444414}.rep-chart-wrap{margin-bottom:20px}.rep-chart{background:var(--surface);border:1px solid var(--border-color);align-items:flex-start;padding:20px 24px 12px 0;display:flex;overflow-x:auto}.rep-chart-y{flex-shrink:0;width:40px;height:320px;position:relative}.rep-chart-y-tick{color:var(--muted);white-space:nowrap;opacity:.6;pointer-events:none;font-size:9px;position:absolute;right:6px;transform:translateY(50%)}.rep-bars{flex:1;align-items:flex-end;gap:3.4375rem;min-width:-webkit-min-content;min-width:min-content;height:320px;padding-bottom:36px;display:flex;position:relative}.rep-chart-gridlines{pointer-events:none;z-index:0;position:absolute;top:0;bottom:0;left:0;right:0}.rep-chart-gridline{background:var(--border-color);opacity:.5;height:1px;position:absolute;left:0;right:0}.rep-bar-col{z-index:1;flex-direction:column;flex:1;align-items:center;height:100%;display:flex;position:relative}.rep-bar-top-label{color:var(--muted);white-space:nowrap;height:14px;margin-bottom:4px;font-size:10px;line-height:14px}.rep-bar-track{background:#ffffff0a;flex-direction:column;flex:1;justify-content:end;align-items:center;width:100%;min-height:4px;display:flex;overflow:hidden}.rep-bar-fill{background:#ffffff14;border-radius:3px 3px 0 0;width:100%;transition:height .3s}.rep-bar-fill.has-data{background:var(--success);opacity:.8}.rep-bar-day-label{color:var(--muted);text-align:center;white-space:nowrap;padding:.5rem 0;font-size:11px;line-height:1.3}.rep-bar-day-label span{color:var(--muted);opacity:.7;font-size:10px}.rep-proj-table .rep-proj-row{cursor:pointer}.rep-proj-table .rep-proj-row:hover{background:#ffffff08}.rep-proj-table .rep-proj-row.rep-proj-open{background:#03a9f40d}.rep-proj-table .rep-task-row td{background:var(--bg);font-size:.8rem}.rep-proj-table .rep-total-row td{border-top:2px solid var(--border-color);background:var(--surface);padding-top:10px;padding-bottom:10px}.rep-col-num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--calc-font);white-space:nowrap;font-size:.875rem}.proj-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-right:6px;display:inline-block}.tt-date-picker{position:relative}.tt-date-picker-btn{background:var(--bg);border:1px solid var(--border-color);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:4px;align-items:center;gap:6px;padding:5px 12px;font-size:.875rem;transition:border-color .12s,color .12s;display:flex}.tt-date-picker-btn:hover{border-color:var(--muted)}.tt-date-picker-panel{z-index:200;background:var(--surface);border:1px solid var(--border-color);box-shadow:var(--box-shadow);display:none;position:absolute;top:calc(100% + 4px);left:0;overflow:hidden}.tt-date-picker-panel.open{display:flex}.tt-date-presets{border-right:1px solid var(--border-color);flex-direction:column;width:170px;padding:8px;display:flex}.tt-date-presets button{text-align:left;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:7px 10px;font-size:.875rem;transition:background .1s}.tt-date-presets button:hover{background:#ffffff0f}.tt-date-presets button.active{color:var(--primary);background:#03a9f41f;font-weight:500}.tt-date-custom-range{flex-direction:column;gap:8px;padding:10px 8px;display:flex}.tt-date-custom-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-size:10px;font-weight:600}.tt-date-custom-inputs{color:var(--muted);align-items:center;gap:6px;font-size:.8rem;display:flex}.tt-date-custom-inputs input[type=date]{background:var(--bg);border:1px solid var(--border-color);color:var(--text);border-radius:4px;flex:1;padding:4px 6px;font-size:.8rem}.tt-date-custom-inputs input[type=date]:focus{border-color:var(--primary);outline:none}.tt-rep-nav{align-items:center;gap:2px;margin-left:auto;display:flex}.tt-rep-nav .tt-date-picker-panel{left:auto;right:0}.tt-nav-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:4px;padding:4px 9px;font-size:1.1rem;line-height:1;transition:color .12s,border-color .12s}.tt-nav-btn:hover{color:var(--text);border-color:var(--muted)}