@import "https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600&family=Mulish:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--brand:#1a1a1a;--accent:#8b6f47;--accent-lt:#d4b896;--accent-xlt:#f5ede3;--blue:#2c4a6e;--blue-lt:#e8eef5;--green:#2d6a4f;--green-lt:#d8f3dc;--amber:#b45309;--amber-lt:#fef3c7;--red:#991b1b;--red-lt:#fee2e2;--sidebar-bg:#1a1a1a;--sidebar-w:240px;--bg:#f9f7f4;--surface:#fff;--border:#e5ddd4;--text:#2d2d2d;--muted:#8a7a6e;--radius:8px;--shadow:0 1px 3px #00000014, 0 4px 16px #0000000a}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Mulish,sans-serif;font-size:14px}#app{min-height:100vh}#main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.page{padding:32px;animation:.2s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:50;align-items:center;gap:16px;height:60px;padding:0 32px;display:flex;position:sticky;top:0}.topbar-title{color:var(--brand);flex:1;font-family:Playfair Display,serif;font-size:20px;font-weight:500}.topbar-actions{align-items:center;gap:12px;display:flex}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 16px;font-family:Mulish,sans-serif;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#7a5f38}.btn-ghost{color:var(--muted);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg);color:var(--text)}.btn-sm{padding:5px 12px;font-size:12px}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#7f1515}.stat-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 22px}.stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px;font-size:11px;font-weight:700}.stat-value{color:var(--brand);font-family:Playfair Display,serif;font-size:28px;font-weight:500;line-height:1}.stat-sub{color:var(--muted);margin-top:4px;font-size:11px}.stat-card.accent{border-left:3px solid var(--accent)}.stat-card.green{border-left:3px solid var(--green)}.stat-card.amber{border-left:3px solid var(--amber)}.stat-card.blue{border-left:3px solid var(--blue)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px 14px;display:flex}.card-title{color:var(--brand);font-family:Playfair Display,serif;font-size:16px;font-weight:500}.card-body{padding:20px 22px}.data-table{border-collapse:collapse;width:100%}.data-table th{color:var(--accent);text-transform:uppercase;letter-spacing:.08em;text-align:left;background:#f5ede3;padding:10px 14px;font-size:11px;font-weight:700}.data-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:11px 14px;font-size:13px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg)}.data-table tbody tr{cursor:pointer;transition:background .1s}.badge{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:20px;align-items:center;padding:3px 9px;font-size:11px;font-weight:700;display:inline-flex}.badge-green{background:var(--green-lt);color:var(--green)}.badge-amber{background:var(--amber-lt);color:var(--amber)}.badge-red{background:var(--red-lt);color:var(--red)}.badge-blue{background:var(--blue-lt);color:var(--blue)}.badge-gray{color:#6b7280;background:#f3f4f6}.badge-accent{background:var(--accent-xlt);color:var(--accent)}.avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:700;display:flex}.progress-wrap{background:var(--border);border-radius:4px;height:6px}.progress-bar{border-radius:4px;height:6px}.prog-green{background:var(--green)}.prog-amber{background:var(--amber)}.prog-red{background:var(--red)}.tabs{border-bottom:2px solid var(--border);margin-bottom:24px;display:flex}.tab{cursor:pointer;color:var(--muted);border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:13px;font-weight:600;transition:all .15s}.tab:hover{color:var(--accent)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.form-group{margin-bottom:16px}.form-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.form-input{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:var(--surface);outline:none;padding:9px 12px;font-family:Mulish,sans-serif;font-size:13px;transition:border-color .15s}.form-input:focus{border-color:var(--accent)}.form-select{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);background:var(--surface);outline:none;padding:9px 10px;font-family:Mulish,sans-serif;font-size:13px}.form-select:focus{border-color:var(--accent)}.two-col{grid-template-columns:1fr 1fr;gap:24px;display:grid}.three-col{grid-template-columns:1fr 1fr 1fr;gap:24px;display:grid}.four-col{grid-template-columns:1fr 1fr 1fr 1fr;gap:24px;display:grid}.five-col{grid-template-columns:1fr 1fr 1fr 1fr 1fr;gap:20px;display:grid}.timeline{padding-left:24px;position:relative}.timeline:before{content:"";background:var(--border);width:2px;position:absolute;top:6px;bottom:6px;left:7px}.timeline-item{margin-bottom:24px;position:relative}.timeline-dot{border:2px solid var(--accent);background:var(--surface);border-radius:50%;width:12px;height:12px;position:absolute;top:4px;left:-20px}.timeline-meta{color:var(--muted);margin-bottom:4px;font-size:11px}.timeline-text{font-size:13px;line-height:1.6}.todo-check{border:2px solid var(--border);cursor:pointer;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:flex}.todo-check.done{background:var(--green);border-color:var(--green);color:#fff;font-size:10px}.todo-text{flex:1;font-size:13px}.todo-text.done-text{color:var(--muted);text-decoration:line-through}.todo-due{color:var(--muted);white-space:nowrap;font-size:11px}.todo-due.overdue{color:var(--amber);font-weight:700}.modal-overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:10px;width:500px;max-width:95vw;padding:28px;box-shadow:0 8px 40px #00000026}.modal-title{margin-bottom:20px;font-family:Playfair Display,serif;font-size:20px;font-weight:500}.modal-footer{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.week-nav{align-items:center;gap:12px;display:flex}.week-nav button{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--muted);background:0 0;padding:6px 12px;font-family:Mulish,sans-serif;font-size:13px}.week-nav button:hover{background:var(--accent-xlt);color:var(--accent);border-color:var(--accent-lt)}.week-label{text-align:center;min-width:220px;font-family:Playfair Display,serif;font-size:15px;font-weight:500}.ts-page{flex-direction:column;gap:0;height:calc(100vh - 72px);display:flex}.ts-topbar{flex-shrink:0;justify-content:space-between;align-items:center;padding-bottom:16px;display:flex}.ts-stats{color:var(--muted);align-items:center;gap:12px;font-size:13px;display:flex}.ts-stats strong{color:var(--text)}.ts-cal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.ts-cal-header{border-bottom:2px solid var(--border);background:#f5ede3;flex-shrink:0;grid-template-columns:52px repeat(7,1fr);display:grid}.ts-gutter-head{background:#f5ede3}.ts-day-head{text-align:center;border-left:1px solid var(--border);flex-direction:column;align-items:center;gap:3px;padding:10px 8px 8px;display:flex}.ts-day-head.weekend{background:#f5f3f0}.ts-day-head.today{background:#ede0d0}.ts-wd{color:var(--accent);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:700}.ts-day-head.weekend .ts-wd{color:var(--muted)}.ts-dn{color:var(--text);font-size:14px;font-weight:600}.ts-dtotal{color:var(--accent);background:var(--accent-xlt);border-radius:10px;padding:1px 7px;font-family:JetBrains Mono,monospace;font-size:10px}.ts-cal-body{flex:1;grid-template-columns:52px repeat(7,1fr);display:grid;overflow-y:auto}.ts-gutter{background:var(--surface);border-right:1px solid var(--border);z-index:2;position:sticky;left:0}.ts-hour-label{height:64px;color:var(--muted);text-align:right;box-sizing:border-box;padding:4px 8px 0 0;font-family:JetBrains Mono,monospace;font-size:10px}.ts-day-col{border-left:1px solid var(--border);cursor:crosshair;-webkit-user-select:none;user-select:none;height:768px;position:relative}.ts-day-col.weekend{background:#faf9f7}.ts-day-col.today{background:#fdf9f5}.ts-line{pointer-events:none;position:absolute;left:0;right:0}.ts-line-hour{border-top:1px solid var(--border)}.ts-line-half{border-top:1px dashed #e8e4dd}.ts-line-qh{border-top:1px dotted #f0ece8}.ts-now-line{z-index:3;pointer-events:none;border-top:2px solid #ef4444;position:absolute;left:0;right:0}.ts-now-line:before{content:"";background:#ef4444;border-radius:50%;width:8px;height:8px;position:absolute;top:-4px;left:-4px}.ts-entry{color:#fff;z-index:1;border-radius:6px;flex-direction:column;min-height:16px;display:flex;position:absolute;left:3px;right:3px;overflow:hidden;box-shadow:0 1px 4px #00000026}.ts-entry-inner{flex-direction:column;flex:1;gap:1px;padding:4px 24px 4px 8px;display:flex;overflow:hidden}.ts-entry-proj{white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:700;overflow:hidden}.ts-entry-time{opacity:.85;font-family:JetBrains Mono,monospace;font-size:10px}.ts-entry-del{color:#fff;cursor:pointer;opacity:0;background:0 0;border:none;padding:0;font-size:15px;line-height:1;position:absolute;top:2px;right:4px}.ts-entry:hover .ts-entry-del{opacity:.7}.ts-entry-del:hover{opacity:1!important}.ts-entry-handle{cursor:ns-resize;opacity:0;background:#0000002e;border-radius:0 0 6px 6px;height:7px;transition:opacity .15s;position:absolute;bottom:0;left:0;right:0}.ts-entry:hover .ts-entry-handle{opacity:1}.ts-drag-preview{background:var(--accent);opacity:.35;pointer-events:none;color:#fff;border:2px dashed var(--accent);border-radius:6px;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex;position:absolute;left:3px;right:3px}.gantt-wrap{overflow-x:auto}.gantt-table{border-collapse:collapse;min-width:100%}.gantt-table th{color:var(--accent);text-align:left;white-space:nowrap;border-bottom:1px solid var(--border);background:#f5ede3;padding:8px 12px;font-size:11px;font-weight:700}.gantt-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:8px 12px;font-size:13px}.gantt-bar-bg{background:#f5ede3;border-radius:4px;height:20px;position:relative}.gantt-bar{color:#fff;white-space:nowrap;border-radius:4px;align-items:center;height:20px;padding:0 8px;font-size:10px;font-weight:700;display:flex;position:absolute;top:0;overflow:hidden}.customer-panel{background:var(--accent-xlt);border:1px solid var(--accent-lt);border-radius:var(--radius);grid-template-columns:repeat(3,1fr);gap:12px 24px;margin-bottom:24px;padding:18px 22px;display:grid}.cust-field label{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:2px;font-size:10px;font-weight:700;display:block}.cust-field span{color:var(--brand);font-size:13px;font-weight:500}.summary-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;display:grid}.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.summary-label{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px;font-size:10px;font-weight:700}.summary-val{color:var(--brand);font-family:Playfair Display,serif;font-size:22px}.summary-sub{color:var(--muted);margin-top:2px;font-size:11px}.filter-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:18px;display:flex}.filter-search{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);outline:none;width:230px;padding:8px 14px;font-family:Mulish,sans-serif;font-size:13px}.filter-search:focus{border-color:var(--accent)}.filter-select{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);outline:none;padding:8px 10px;font-family:Mulish,sans-serif;font-size:13px}code{color:var(--blue);background:#f3f4f6;border-radius:3px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:12px}.loading{color:var(--muted);justify-content:center;align-items:center;gap:10px;padding:48px;font-size:14px;display:flex}.empty-state{text-align:center;color:var(--muted);padding:48px}.empty-state .icon{margin-bottom:10px;font-size:32px}.dash-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}.todo-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:10px 0;display:flex}.todo-item:last-child{border-bottom:none}.todo-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px}.todo-title{color:var(--text);font-size:13px;font-weight:600}.todo-meta{color:var(--muted);margin-top:2px;font-size:11px}.todo-deadline{white-space:nowrap;border-radius:10px;margin-left:auto;padding:2px 8px;font-size:11px;font-weight:600}.time-chart-wrap{padding:0 0 8px}.time-chart{align-items:flex-end;gap:6px;height:120px;display:flex}.time-bar-day{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:2px;display:flex}.time-bar-stack{border-radius:4px 4px 0 0;flex-direction:column;justify-content:flex-end;gap:1px;width:100%;min-height:2px;display:flex;overflow:hidden}.time-bar-seg{width:100%;transition:height .3s}.time-bar-label{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:10px}.time-chart-legend{flex-wrap:wrap;gap:12px;margin-top:8px;display:flex}.legend-item{color:var(--muted);align-items:center;gap:5px;font-size:11px;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px}.mini-gantt-wrap{overflow-x:auto}.mini-gantt-row{border-bottom:1px solid var(--border);align-items:center;padding:8px 0;display:grid}.mini-gantt-label{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.mini-gantt-track{background:var(--accent-xlt);border-radius:4px;height:18px;position:relative}.mini-gantt-bar{color:#fff;white-space:nowrap;border-radius:4px;align-items:center;height:18px;padding:0 6px;font-size:10px;font-weight:700;display:flex;position:absolute;overflow:hidden}body.dark{--bg:#111113;--surface:#1c1c1f;--surface-alt:#222226;--border:#ffffff1a;--text:#e8e8ea;--text-secondary:#fff9;--muted:#ffffff59;--accent:#a08050;--accent-lt:#a0805033;--accent-xlt:#a0805014;--green:#4caf72;--red:#e05555;--blue:#4a90d9;--amber:#d4922a}body.dark #sidebar{background:#0d0d0f}body.dark .topbar{background:#1c1c1f;border-bottom-color:#ffffff12}body.dark .card{background:#1c1c1f;border-color:#ffffff14}body.dark .data-table th{color:#ffffff80;background:#222226}body.dark .data-table tr:hover td{background:#ffffff08}body.dark .form-input,body.dark .form-select,body.dark .filter-select{color:#e8e8ea;background:#222226;border-color:#ffffff1f}body.dark .modal{background:#1c1c1f}body.dark .modal-overlay{background:#000000b3}body.dark .btn-ghost{color:#ffffffb3}body.dark .btn-ghost:hover{background:#ffffff12}body.dark .stat-card{background:#1c1c1f;border-color:#ffffff14}.settings-layout{gap:0;min-height:calc(100vh - 56px);display:flex}.settings-nav{border-right:1px solid var(--border);width:210px;min-width:210px;padding:24px 0}.settings-nav-section{margin-bottom:4px}.settings-nav-label{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);padding:12px 20px 4px;font-size:10px;font-weight:700}.settings-nav-item{color:var(--text-secondary);border-right:2px solid #0000;align-items:center;gap:8px;padding:8px 20px;font-size:13px;text-decoration:none;transition:all .15s;display:flex}.settings-nav-item:hover{color:var(--text);background:var(--accent-xlt)}.settings-nav-item.active{color:var(--accent);border-right-color:var(--accent);background:var(--accent-xlt);font-weight:600}.settings-content{flex:1;max-width:720px;padding:28px 32px}.settings-section{margin-bottom:28px}.settings-section-title{color:var(--text);border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:10px;font-size:15px;font-weight:700}.toggle-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:16px;padding:12px 0;display:flex}.toggle-row:last-child{border-bottom:none}.toggle-label{color:var(--text);font-size:13px;font-weight:500}.toggle-sub{color:var(--muted);margin-top:2px;font-size:12px}.toggle{flex-shrink:0;width:40px;height:22px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{background:var(--border);cursor:pointer;border-radius:22px;transition:all .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:all .2s;position:absolute;top:3px;left:3px}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(18px)}
