:root{--font-sans:"Segoe UI", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:ui-monospace, "Cascadia Code", "Segoe UI Mono", monospace;--bg-base:#09090b;--bg-elevated:#111113;--bg-surface:#18181b;--bg-hover:#1f1f23;--bg-active:#27272a;--border-subtle:#27272a;--border-default:#3f3f46;--text-primary:#fafafa;--text-secondary:#a1a1aa;--text-muted:#71717a;--accent:#10b981;--accent-hover:#059669;--accent-muted:#10b9811f;--accent-text:#34d399;--danger:#ef4444;--danger-muted:#ef44441f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 16px #00000059;--shadow-lg:0 8px 32px #00000073;--nav-height:64px;--safe-bottom:env(safe-area-inset-bottom,0px);--stage-new:#3b82f6;--stage-onsite:#8b5cf6;--stage-prep:#f59e0b;--stage-in-progress:#eab308;--stage-done:#22c55e;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}html,body,#root{background:var(--bg-base);min-height:100%;margin:0}a{color:var(--accent-text);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{letter-spacing:-.02em;color:var(--text-primary);margin:0;font-weight:600}h1{font-size:1.5rem;line-height:1.2}h2{font-size:1.125rem;line-height:1.3}h3{font-size:1rem;line-height:1.4}p{margin:0}.page{min-height:100dvh;padding:var(--space-4);padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + var(--space-4));gap:var(--space-4);flex-direction:column;max-width:640px;margin:0 auto;display:flex}.page--no-nav{padding-bottom:var(--space-4)}.auth-layout{min-height:100dvh;padding:var(--space-6) var(--space-4);justify-content:center;align-items:center;gap:var(--space-6);flex-direction:column;max-width:420px;margin:0 auto;display:flex}.auth-layout .panel{width:100%}.auth-brand{text-align:center}.auth-brand-mark{width:48px;height:48px;margin:0 auto var(--space-4);border-radius:var(--radius-md);background:var(--accent-muted);color:var(--accent);border:1px solid #10b98140;justify-content:center;align-items:center;display:flex}.auth-brand h1{font-size:1.375rem}.panel{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5)}.panel+.panel{margin-top:0}.form{gap:var(--space-4);flex-direction:column;display:flex}label{gap:var(--space-2);color:var(--text-secondary);flex-direction:column;font-size:.875rem;font-weight:500;display:flex}input{border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-base);width:100%;color:var(--text-primary);padding:12px 14px;font-family:inherit;font-size:1rem;transition:border-color .15s,box-shadow .15s}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted);outline:none}input::placeholder{color:var(--text-muted)}.button{justify-content:center;align-items:center;gap:var(--space-2);border-radius:var(--radius-md);cursor:pointer;color:var(--bg-base);background:var(--accent);border:none;padding:12px 18px;font-family:inherit;font-size:.9375rem;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.button:hover:not(:disabled){background:var(--accent-hover)}.button:active:not(:disabled){transform:scale(.98)}.button:disabled{opacity:.5;cursor:not-allowed}.button-secondary{color:var(--text-primary);background:var(--bg-active);border:1px solid var(--border-subtle)}.button-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-default)}.button-ghost{color:var(--text-secondary);background:0 0;border:1px solid #0000;padding:8px 12px}.button-ghost:hover:not(:disabled){color:var(--text-primary);background:var(--bg-hover)}.button-icon{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:10px;transition:color .15s,background .15s;display:inline-flex}.button-icon:hover{color:var(--text-primary);background:var(--bg-hover)}.danger{color:#fff;background:var(--danger)}.danger:hover:not(:disabled){background:#dc2626}.link-button{color:var(--accent-text);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.875rem;font-weight:500;text-decoration:none}.link-button:hover{text-decoration:underline}.page-header{justify-content:space-between;align-items:center;gap:var(--space-3);padding-top:var(--space-1);display:flex}.page-header-start{align-items:center;gap:var(--space-3);min-width:0;display:flex}.page-header-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.page-subtitle{color:var(--text-muted);margin-top:2px;font-size:.8125rem}.topbar{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.filter-bar{gap:var(--space-2);padding-bottom:var(--space-1);margin:0 calc(-1 * var(--space-1));padding-left:var(--space-1);padding-right:var(--space-1);scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.tab{border:1px solid var(--border-subtle);background:var(--bg-elevated);color:var(--text-secondary);border-radius:var(--radius-full);white-space:nowrap;cursor:pointer;flex-shrink:0;align-items:center;gap:6px;padding:8px 14px;font-family:inherit;font-size:.8125rem;font-weight:500;transition:all .15s;display:inline-flex}.tab:hover{border-color:var(--border-default);color:var(--text-primary)}.tab.active{background:var(--accent-muted);color:var(--accent-text);border-color:#10b98159}.tab-count{font-variant-numeric:tabular-nums;background:var(--bg-active);color:var(--text-muted);border-radius:var(--radius-full);text-align:center;min-width:18px;padding:1px 6px;font-size:.6875rem;font-weight:600}.tab.active .tab-count{color:var(--accent-text);background:#10b98133}.tabs{gap:var(--space-2);padding-bottom:2px;display:flex;overflow-x:auto}.task-list{gap:var(--space-3);flex-direction:column;display:flex}.task-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);color:inherit;gap:var(--space-3);flex-direction:column;text-decoration:none;transition:border-color .15s,background .15s,transform .1s;display:flex;position:relative;overflow:hidden}.task-card:before{content:"";background:var(--stage-color,var(--text-muted));border-radius:3px 0 0 3px;width:3px;position:absolute;top:0;bottom:0;left:0}.task-card:hover{border-color:var(--border-default);background:var(--bg-hover)}.task-card:active{transform:scale(.99)}.task-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-3);display:flex}.task-card h2{flex:1;min-width:0;font-size:1rem;font-weight:600;line-height:1.35}.task-card-meta{gap:var(--space-3);flex-wrap:wrap;display:flex}.task-meta-item{color:var(--text-muted);align-items:center;gap:5px;font-size:.8125rem;display:inline-flex}.task-meta-item svg{opacity:.7;flex-shrink:0}.task-meta-item--urgent{color:#fbbf24}.task-meta-item--urgent svg{opacity:1}.stage-badge{border-radius:var(--radius-full);letter-spacing:.02em;text-transform:uppercase;white-space:nowrap;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-size:.6875rem;font-weight:600;display:inline-flex}.stage-badge-dot{opacity:.85;background:currentColor;border-radius:50%;width:6px;height:6px}.pipeline-stepper{padding:var(--space-4) 0;align-items:flex-start;gap:0;display:flex}.pipeline-step{align-items:center;gap:var(--space-2);flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.pipeline-step:not(:last-child):after{content:"";background:var(--border-subtle);z-index:0;height:2px;position:absolute;top:11px;left:calc(50% + 14px);right:calc(14px - 50%)}.pipeline-step.done:not(:last-child):after{background:var(--accent);opacity:.5}.pipeline-step-dot{border:2px solid var(--border-default);background:var(--bg-base);z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:all .2s;display:flex}.pipeline-step.done .pipeline-step-dot{border-color:var(--accent);background:var(--accent);color:var(--bg-base)}.pipeline-step.current .pipeline-step-dot{border-color:var(--accent);background:var(--accent-muted);box-shadow:0 0 0 4px var(--accent-muted)}.pipeline-step-label{color:var(--text-muted);text-align:center;word-break:break-word;max-width:72px;font-size:.625rem;line-height:1.3}.pipeline-step.current .pipeline-step-label{color:var(--accent-text);font-weight:600}.pipeline-step.done .pipeline-step-label{color:var(--text-secondary)}.task-detail-body{color:var(--text-secondary);margin-top:var(--space-4);font-size:.9375rem;line-height:1.6}.task-detail-body>:first-child{margin-top:0}.task-detail-body p{margin:0 0 var(--space-3)}.task-detail-body p:last-child{margin-bottom:0}.task-detail-body ul,.task-detail-body ol{margin:0 0 var(--space-3);padding-left:1.25rem}.task-detail-body a{color:var(--accent-text);word-break:break-word;text-decoration:underline}.task-detail-image{width:100%;max-width:100%;height:auto;margin:var(--space-3) 0;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--surface-elevated);display:block}.task-actions{gap:var(--space-3);margin-top:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.task-actions .button{width:100%}.detail-stats{gap:var(--space-3);margin-top:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.stat-card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.stat-card-label{color:var(--text-muted);align-items:center;gap:4px;margin-bottom:2px;font-size:.75rem;display:flex}.stat-card-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:.9375rem;font-weight:600}.photo-uploader-actions{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.photo-uploader-actions label.button{cursor:pointer;text-align:center}.photo-grid{gap:var(--space-2);margin-top:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(88px,1fr));display:grid}.photo-preview{aspect-ratio:1;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--border-subtle);width:100%}.photo-drop-hint{margin-top:var(--space-3);padding:var(--space-4);border:1px dashed var(--border-default);border-radius:var(--radius-md);text-align:center;color:var(--text-muted);font-size:.8125rem}.setting-row{justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.setting-row h2{margin-bottom:2px;font-size:1rem}.toggle{cursor:pointer;flex-shrink:0;width:48px;height:28px;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{background:var(--bg-active);border:1px solid var(--border-default);border-radius:var(--radius-full);transition:background .2s,border-color .2s;position:absolute;inset:0}.toggle-thumb{background:var(--text-secondary);border-radius:50%;width:20px;height:20px;transition:transform .2s,background .2s;position:absolute;top:3px;left:3px}.toggle input:checked+.toggle-track{background:var(--accent-muted);border-color:#10b98166}.toggle input:checked+.toggle-track .toggle-thumb{background:var(--accent);transform:translate(20px)}.toggle input:disabled+.toggle-track{opacity:.5;cursor:not-allowed}.bottom-nav{height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border-subtle);z-index:50;background:#09090beb;justify-content:center;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav-inner{width:100%;max-width:640px;padding:0 var(--space-2);display:flex}.bottom-nav-item{padding:var(--space-2);color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;font-family:inherit;font-size:.6875rem;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.bottom-nav-item:hover{color:var(--text-secondary);text-decoration:none}.bottom-nav-item.active{color:var(--accent-text)}.bottom-nav-item svg{width:22px;height:22px}.muted{color:var(--text-muted);font-size:.875rem;line-height:1.5}.error{color:#fca5a5;padding:var(--space-3);background:var(--danger-muted);border-radius:var(--radius-md);border:1px solid #ef444433;font-size:.875rem}.empty-state{text-align:center;padding:var(--space-8) var(--space-4);justify-content:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.empty-state-icon{border-radius:var(--radius-lg);background:var(--bg-elevated);border:1px solid var(--border-subtle);width:56px;height:56px;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.empty-state h2{color:var(--text-secondary);font-size:1rem}.skeleton{background:linear-gradient(90deg, var(--bg-elevated) 0%, var(--bg-hover) 50%, var(--bg-elevated) 100%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (prefers-reduced-motion:reduce){.skeleton{background:var(--bg-elevated);animation:none}.button:active:not(:disabled),.task-card:active{transform:none}}.task-skeleton{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);gap:var(--space-3);flex-direction:column;display:flex}.skeleton-line{height:14px}.skeleton-line--title{width:70%;height:18px}.skeleton-line--short{width:45%}.skeleton-badge{border-radius:var(--radius-full);width:72px;height:22px}.pull-indicator{opacity:0;text-align:center;height:0;color:var(--text-muted);font-size:.8125rem;transition:height .2s,opacity .2s;overflow:hidden}.pull-indicator.visible{opacity:1;height:24px}.row{gap:var(--space-3);flex-wrap:wrap;display:flex}.section-gap{gap:var(--space-4);flex-direction:column;display:flex}.panel h2,.panel h3{margin-bottom:var(--space-2)}
