@import "https://fonts.googleapis.com/css2?family=Fraunces:wght@600;700&family=DM+Sans:wght@400;500;600&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f7f5f2;--surface:#fff;--surface2:#f0ede9;--border:#e8e3dc;--text:#1c1917;--text2:#78716c;--text3:#a8a29e;--accent:#e07b39;--accent-hover:#c96a2a;--shadow:0 1px 3px #0000000f, 0 4px 12px #0000000a;--shadow-hover:0 4px 12px #0000001a, 0 8px 24px #0000000f;--radius:14px;--radius-sm:8px;--header-h:calc(61px + env(safe-area-inset-top))}.dark{--bg:#0f0e0d;--surface:#1a1917;--surface2:#242220;--border:#2e2c29;--text:#f5f0eb;--text2:#a8a29e;--text3:#6b6560;--accent:#f0924a;--shadow:0 1px 3px #0000004d, 0 4px 12px #0003;--shadow-hover:0 4px 16px #0006, 0 8px 28px #0000004d}body{background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;transition:background .2s,color .2s}.app{min-height:100vh}.header{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 24px;padding-top:calc(14px + env(safe-area-inset-top));z-index:100;justify-content:space-between;align-items:center;transition:background .2s;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:14px;display:flex}.logo{color:var(--text);letter-spacing:-.5px;font-family:Fraunces,serif;font-size:21px}.logo span{color:var(--accent)}.stage-pills{gap:6px;display:flex}.stage-pill{border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;display:flex}.stage-dot{border-radius:50%;width:6px;height:6px}.header-right{align-items:center;gap:8px;display:flex}.total-hours{color:var(--text2);background:var(--surface2);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:500}.theme-toggle{background:var(--surface2);border:1.5px solid var(--border);cursor:pointer;border-radius:20px;padding:5px 10px;font-size:14px;line-height:1;transition:all .15s}.theme-toggle:hover{border-color:var(--accent)}.palette-btn{background:var(--surface2);border:1.5px solid var(--border);cursor:pointer;border-radius:20px;padding:5px 10px;font-size:14px;line-height:1;transition:all .15s}.palette-btn:hover{border-color:var(--accent)}.palette-popover{z-index:9999;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-hover);min-width:180px;padding:12px 14px;font-family:DM Sans,sans-serif;position:fixed}.palette-popover-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:10px;font-size:10px;font-weight:700}.palette-swatches{flex-wrap:wrap;gap:8px;display:flex}.palette-swatch{cursor:pointer;border:3px solid #0000;border-radius:50%;flex-shrink:0;width:32px;height:32px;transition:border-color .15s,transform .1s}.palette-swatch:hover{transform:scale(1.1)}.palette-swatch.selected{border-color:var(--text)}.add-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:8px 16px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;transition:background .15s,transform .1s}.add-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}@keyframes micPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@keyframes burst-out{0%{opacity:1;transform:translate(-50%,-50%)translate(0)scale(1)}to{transform:translate(-50%, -50%) translate(var(--tx), var(--ty)) scale(0);opacity:0}}.burst-particle{pointer-events:none;z-index:9999;border-radius:50%;animation:.6s ease-out forwards burst-out;position:fixed}.voice-fab{z-index:500;color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;background:#1c1917;border:none;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;font-size:26px;transition:background .15s,transform .1s,box-shadow .15s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 20px #00000040,0 2px 8px #00000026}.voice-fab:hover{transform:scale(1.06);box-shadow:0 6px 24px #0000004d}.voice-fab.listening{background:#dc2626;animation:1s ease-in-out infinite micPulse}.voice-fab.processing{opacity:.65;cursor:not-allowed}.dark .voice-fab{color:#1c1917;background:#f5f0eb}.dark .voice-fab.listening{color:#fff;background:#dc2626}.voice-transcript-overlay{z-index:499;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-hover);color:var(--text);align-items:center;min-height:56px;padding:14px 18px;font-family:DM Sans,sans-serif;font-size:15px;line-height:1.4;display:flex;position:fixed;bottom:100px;left:16px;right:16px}.voice-transcript-placeholder{color:var(--text3);font-style:italic}.progress-wrap{background:var(--border);height:3px;top:var(--header-h);z-index:99;position:sticky}.progress-fill{background:linear-gradient(90deg, var(--accent), #f59e5a);border-radius:0 2px 2px 0;height:100%;transition:width .5s}.controls{background:var(--surface);border-bottom:1px solid var(--border);top:calc(var(--header-h) + 3px);z-index:98;flex-wrap:wrap;align-items:center;gap:6px;padding:10px 24px;transition:background .2s;display:flex;position:sticky}.filter-btn{border:1.5px solid var(--border);cursor:pointer;color:var(--text2);background:0 0;border-radius:20px;padding:5px 12px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;transition:all .15s}.filter-btn:hover{border-color:var(--text);color:var(--text)}.filter-btn.active{background:var(--text);color:var(--bg);border-color:var(--text)}.filter-btn.need-active{color:#fff;background:#dc2626;border-color:#dc2626}.filter-btn.want-active{color:#fff;background:#3b82c4;border-color:#3b82c4}.filter-btn.manage-cat{color:var(--text3);border-style:dashed;font-size:11px}.filter-btn.manage-cat:hover{border-color:var(--accent);color:var(--accent)}.divider{background:var(--border);width:1px;height:16px;margin:0 2px}.view-toggle{background:var(--surface2);border-radius:8px;gap:2px;margin-left:auto;padding:2px;display:flex}.view-btn{cursor:pointer;color:var(--text2);background:0 0;border:none;border-radius:6px;padding:4px 10px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600;transition:all .15s}.view-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}.main{padding:18px 24px}.cat-breakdown{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.cat-card{background:var(--surface);border-radius:var(--radius-sm);min-width:100px;box-shadow:var(--shadow);border:1px solid var(--border);cursor:pointer;flex:1;padding:10px 14px;transition:box-shadow .15s}.cat-card:hover{box-shadow:var(--shadow-hover)}.cat-card-label{text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:10px;font-weight:600}.cat-card-row{align-items:baseline;gap:6px;display:flex}.cat-card-count{font-family:Fraunces,serif;font-size:20px;line-height:1}.cat-card-hrs{color:var(--text3);font-size:11px;font-weight:500}.queue-view{flex-direction:column;gap:20px;display:flex}.queue-section-header{border-bottom:2px solid var(--border);align-items:center;gap:10px;margin-bottom:10px;padding-bottom:8px;display:flex}.queue-section-title{color:var(--text);font-family:Fraunces,serif;font-size:15px}.queue-section-badge{border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.queue-section-hours{color:var(--text3);margin-left:auto;font-size:11px;font-weight:500}.queue-list{flex-direction:column;gap:6px;display:flex}.queue-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);cursor:grab;border:1.5px solid #0000;padding:12px 14px;transition:box-shadow .15s,transform .1s,background .2s}.queue-card:hover{box-shadow:var(--shadow-hover);border-color:var(--border);transform:translateY(-1px)}.queue-card.pinned{border-color:var(--accent)}.queue-card.done-card{background:var(--surface2);opacity:.65}.queue-card-top{justify-content:space-between;align-items:center;gap:10px;margin-bottom:5px;display:flex}.queue-card-top-left{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.queue-card-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:16px;font-weight:600;line-height:1.3;overflow:hidden}.queue-card-title.done-title{color:var(--text3);font-weight:400;text-decoration:line-through}.queue-card-hours{color:var(--text2);white-space:nowrap;background:var(--surface2);border-radius:20px;flex-shrink:0;padding:2px 8px;font-size:12px;font-weight:600}.queue-card-notes{color:var(--text2);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:8px;font-size:11.5px;line-height:1.45;display:-webkit-box;overflow:hidden}.queue-card-bottom{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.queue-card-bottom-left,.queue-card-bottom-right{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.due-date-badge{border-radius:20px;align-items:center;gap:3px;margin:3px 0 2px;padding:1px 7px;font-size:10px;font-weight:600;display:inline-flex}.today-rank{color:var(--accent);text-align:center;opacity:.85;flex-shrink:0;min-width:20px;font-family:Fraunces,serif;font-size:14px;font-weight:700}.pin-btn{cursor:pointer;color:var(--text3);background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:18px;line-height:1;transition:color .15s}.pin-btn:hover,.pin-btn.pinned{color:var(--accent)}.filter-dropdown-wrap{display:inline-block;position:relative}.portal-dropdown{z-index:9999;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-hover);min-width:130px;font-family:DM Sans,sans-serif;position:fixed;overflow:hidden}.tag-dropdown-item{cursor:pointer;color:var(--text);align-items:center;gap:7px;padding:7px 12px;font-size:12px;font-weight:500;transition:background .1s;display:flex}.tag-dropdown-item:hover{background:var(--surface2)}.tag-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.tag-wrap{display:inline-block;position:relative}.tag{letter-spacing:.3px;text-transform:uppercase;cursor:pointer;white-space:nowrap;border-radius:20px;padding:1px 6px;font-size:8px;font-weight:700;transition:opacity .15s;display:inline-block}.tag:hover{opacity:.75}.tag.static{cursor:default}.tag.static:hover{opacity:1}.status-btn-group{flex-wrap:wrap;gap:4px;display:flex}.status-action-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:20px;padding:4px 9px;font-family:DM Sans,sans-serif;font-size:10px;font-weight:600;transition:all .15s}.mobile-col-tabs{display:none}.kanban-view{grid-template-columns:5fr 5fr 3fr;align-items:start;gap:16px;display:grid}.column{background:var(--surface2);border-radius:var(--radius);border:1px solid var(--border);flex-direction:column;transition:background .2s;display:flex;overflow:hidden}.column-header{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;padding:11px 16px;transition:background .2s;display:flex}.column-title-wrap{align-items:center;gap:8px;display:flex}.column-status-dot{border-radius:50%;width:8px;height:8px}.column-title{color:var(--text);font-size:12px;font-weight:600}.column-count{color:var(--text3);background:var(--surface2);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.column-hours{color:var(--text3);font-size:10px;font-weight:500}.task-list{flex-direction:column;flex:1;gap:6px;min-height:200px;padding:10px;display:flex}.type-divider{align-items:center;gap:8px;padding:4px 2px;display:flex}.type-divider-label{letter-spacing:.8px;text-transform:uppercase;color:var(--text3);white-space:nowrap;font-size:9px;font-weight:700}.type-divider-line{background:var(--border);flex:1;height:1px}.task-card{background:var(--surface);border-radius:var(--radius-sm);cursor:grab;box-shadow:var(--shadow);border:1.5px solid #0000;padding:10px 12px;transition:box-shadow .15s,transform .1s,background .2s}.task-card:hover{box-shadow:var(--shadow-hover);border-color:var(--border);transform:translateY(-1px)}.task-card.pinned{border-color:var(--accent)}.task-card.is-want{border-left:3px solid #3b82c4}.task-card-top{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.task-card-top-left{flex:1;align-items:center;gap:6px;min-width:0;display:flex}.task-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:15px;font-weight:600;line-height:1.35;overflow:hidden}.task-title.done-title{color:var(--text3);font-weight:400;text-decoration:line-through}.task-hrs{color:var(--text2);background:var(--surface2);border-radius:20px;flex-shrink:0;padding:2px 7px;font-size:11px;font-weight:600}.task-notes-small{color:var(--text2);-webkit-line-clamp:2;text-align:left;-webkit-box-orient:vertical;margin-bottom:6px;font-size:11px;line-height:1.4;display:-webkit-box;overflow:hidden}.card-meta-rows{flex-direction:column;gap:2px;margin-bottom:6px;display:flex}.card-meta-row{color:var(--text2);align-items:center;gap:5px;min-width:0;padding:2px 0;font-size:11px;text-decoration:none;display:flex}.card-meta-row:hover{color:var(--accent)}.card-meta-row span{white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}.task-card-bottom{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;margin-top:7px;display:flex}.task-card-bottom-left,.task-card-bottom-right{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.board-status-btns{flex-wrap:wrap;gap:4px;display:flex}.board-status-btn{border:1.5px solid var(--border);cursor:pointer;background:var(--surface2);color:var(--text2);white-space:nowrap;border-radius:20px;padding:3px 9px;font-family:DM Sans,sans-serif;font-size:10px;font-weight:600;transition:all .15s}.board-status-btn:hover{border-color:var(--text);color:var(--text);background:var(--surface)}.mobile-status-btns{display:none}.mobile-status-btn{border:1.5px solid var(--border);cursor:pointer;background:var(--surface2);color:var(--text2);white-space:nowrap;border-radius:20px;padding:5px 12px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600;transition:all .15s}.mobile-status-btn:hover{border-color:var(--text);color:var(--text);background:var(--surface)}.mobile-status-btn.forward{border-color:var(--accent);color:var(--accent)}.mobile-status-btn.forward:hover{background:var(--accent);color:#fff}.empty-col{color:var(--text3);text-align:center;padding:20px 10px;font-size:11px;font-weight:500}.today-section{margin-bottom:18px}.today-header{letter-spacing:.8px;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-size:11px;font-weight:700}.today-tasks{flex-direction:column;gap:5px;display:flex}.today-task{background:var(--surface);border:1.5px solid var(--accent);border-radius:var(--radius-sm);box-shadow:var(--shadow);cursor:grab;text-align:left;align-items:center;gap:10px;padding:8px 14px;font-size:12px;display:flex}.today-task-title{min-width:0;color:var(--text);text-align:left;flex:1;font-weight:500}.today-unpin{cursor:pointer;color:var(--text3);background:0 0;border:none;padding:0 2px;font-size:14px;transition:color .15s}.today-unpin:hover{color:var(--accent)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.toast{z-index:9999;white-space:nowrap;pointer-events:none;border-radius:20px;padding:10px 18px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;animation:.2s toastIn;position:fixed;bottom:28px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0000002e}.toast.success{color:#fff;background:#3b9e6e}.toast.error{color:#fff;background:#dc2626}.overlay{z-index:400;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{padding:16px 20px 14px;padding-top:calc(16px + env(safe-area-inset-top));border-bottom:1px solid var(--border);background:var(--surface);z-index:50;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.modal-title{color:var(--text);font-family:Fraunces,serif;font-size:17px}.modal-close{background:var(--surface2);cursor:pointer;width:28px;height:28px;color:var(--text2);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:background .15s;display:flex}.modal-close:hover{background:var(--border)}.modal-body{flex-direction:column;gap:13px;padding:18px 20px;display:flex}.field label{text-transform:uppercase;letter-spacing:.5px;color:var(--text2);margin-bottom:5px;font-size:11px;font-weight:600;display:block}.field input,.field textarea,.field select{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);width:100%;color:var(--text);outline:none;padding:8px 12px;font-family:DM Sans,sans-serif;font-size:13px;transition:border-color .15s}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);background:var(--surface)}.field textarea{resize:vertical;min-height:70px}.field-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.places-dropdown{z-index:40;background:var(--surface);border:1.5px solid var(--border);border-radius:8px;max-height:200px;margin-top:4px;font-family:DM Sans,sans-serif;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 20px #00000026}.places-suggestion{color:var(--text);cursor:pointer;border-bottom:1px solid var(--border);padding:8px 12px;font-size:13px;line-height:1.4}.places-suggestion:hover{background:var(--surface2)}.places-suggestion:last-child{border-bottom:none}.places-suggestion-main{font-weight:500}.places-suggestion-secondary{color:var(--text3);margin-top:1px;font-size:11px}.type-toggle{gap:6px;display:flex}.type-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;color:var(--text2);text-align:center;flex:1;padding:8px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.type-btn.need-active{color:#dc2626;background:#fef2f2;border-color:#dc2626}.type-btn.want-active{color:#3b82c4;background:#ebf3fe;border-color:#3b82c4}.dark .type-btn.need-active{background:#2d1515}.dark .type-btn.want-active{background:#0f2236}.assignee-toggle{flex-wrap:wrap;gap:5px;display:flex}.assignee-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;min-width:80px;color:var(--text2);text-align:center;flex:1;padding:8px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.effort-hint{color:var(--text3);margin-top:3px;font-size:10px}.checkbox-label{color:var(--text2);cursor:pointer;align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:12px 20px;display:flex}.btn-secondary{border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text2);background:0 0;padding:8px 16px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.btn-secondary:hover{border-color:var(--text);color:var(--text)}.btn-danger{border-radius:var(--radius-sm);cursor:pointer;color:#dc2626;background:0 0;border:1.5px solid #fca5a5;margin-right:auto;padding:8px 16px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.btn-danger:hover{background:#fef2f2}.btn-danger.btn-danger-confirm{color:#fff;background:#dc2626;border-color:#dc2626}.btn-danger.btn-danger-confirm:hover{background:#b91c1c;border-color:#b91c1c}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:8px 18px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:background .15s}.btn-primary:hover{background:var(--accent-hover)}.cat-manage-modal{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);width:100%;max-width:420px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.cat-list{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.cat-list-item{background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border);align-items:center;gap:10px;padding:9px 12px;display:flex}.cat-list-swatch{border-radius:50%;flex-shrink:0;width:14px;height:14px}.cat-list-name{color:var(--text);flex:1;font-size:13px;font-weight:500}.cat-list-count{color:var(--text3);font-size:11px;font-weight:500}.cat-list-delete{cursor:pointer;color:var(--text3);background:0 0;border:none;flex-shrink:0;padding:0 4px;font-size:16px;line-height:1;transition:color .15s}.cat-list-delete:hover{color:#dc2626}.cat-list-delete:disabled{opacity:.3;cursor:not-allowed}.cat-divider{background:var(--border);height:1px;margin:4px 0 16px}.cat-section-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:10px;font-size:11px;font-weight:700}.color-swatches{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.color-swatch{cursor:pointer;border:3px solid #0000;border-radius:50%;flex-shrink:0;width:28px;height:28px;transition:border-color .15s}.color-swatch.selected{border-color:var(--text)}.ai-view{flex-direction:column;gap:16px;display:flex}.ai-prompt-section{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:20px 22px}.ai-prompt-title{color:var(--text);margin-bottom:4px;font-family:Fraunces,serif;font-size:19px}.ai-prompt-sub{color:var(--text2);margin-bottom:16px;font-size:13px;line-height:1.5}.ai-hours-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.ai-hours-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);outline:none;width:90px;padding:9px 14px;font-family:DM Sans,sans-serif;font-size:14px;transition:border-color .15s}.ai-hours-input:focus{border-color:var(--accent)}.ai-generate-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:9px 20px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;transition:background .15s}.ai-generate-btn:hover:not(:disabled){background:var(--accent-hover)}.ai-generate-btn:disabled{opacity:.5;cursor:not-allowed}.ai-error{color:#dc2626;border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fca5a5;padding:12px 16px;font-size:13px}.dark .ai-error{background:#2d1515}.ai-results{flex-direction:column;gap:10px;display:flex}.ai-intro{color:var(--text2);padding:2px 0 4px;font-size:13px;font-style:italic}.ai-result-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:14px 16px}.ai-result-header{align-items:center;gap:10px;margin-bottom:6px;display:flex}.ai-result-num{color:var(--accent);flex-shrink:0;width:22px;font-family:Fraunces,serif;font-size:17px;font-weight:700}.ai-result-title{color:var(--text);flex:1;font-size:15px;font-weight:600;line-height:1.3}.ai-result-time{color:var(--text2);background:var(--surface2);white-space:nowrap;border-radius:20px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:600}.ai-result-reason{color:var(--text2);padding-left:32px;font-size:12px;line-height:1.55}.ai-pin-all-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;align-self:flex-start;padding:8px 16px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:background .15s}.ai-pin-all-btn:hover{background:var(--accent-hover)}.ai-summary-display{color:var(--text2);background:var(--surface2);border:1.5px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius-sm);white-space:pre-wrap;padding:10px 12px;font-size:13px;line-height:1.55}.chat-section{border-top:1px solid var(--border);padding-top:14px}.chat-toggle-btn{border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text2);background:0 0;padding:7px 14px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.chat-toggle-btn:hover{border-color:var(--accent);color:var(--accent)}.chat-body{flex-direction:column;gap:10px;margin-top:12px;display:flex}.chat-summary-box{background:var(--surface2);border-radius:var(--radius-sm);border-left:3px solid var(--accent);padding:10px 12px}.chat-summary-label{text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin-bottom:4px;font-size:10px;font-weight:700}.chat-summary-text{color:var(--text2);font-size:12px;line-height:1.55}.chat-messages{flex-direction:column;gap:8px;max-height:220px;padding:2px 0;display:flex;overflow-y:auto}.chat-bubble{border-radius:var(--radius-sm);white-space:pre-wrap;text-align:left;max-width:88%;padding:8px 12px;font-size:12px;line-height:1.55}.chat-bubble.user{background:var(--accent);color:#fff;border-radius:var(--radius-sm) var(--radius-sm) 2px var(--radius-sm);align-self:flex-end}.chat-bubble.assistant{background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm) var(--radius-sm) var(--radius-sm) 2px;align-self:flex-start}.chat-thinking{color:var(--text3);align-self:flex-start;padding:2px 0;font-size:12px;font-style:italic}.chat-input-row{align-items:flex-end;gap:8px;display:flex}.chat-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text);resize:none;outline:none;flex:1;padding:8px 12px;font-family:DM Sans,sans-serif;font-size:13px;line-height:1.4;transition:border-color .15s}.chat-input:focus{border-color:var(--accent)}.chat-send-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;padding:8px 14px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:background .15s}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-save-btn{color:#3b9e6e;border-radius:var(--radius-sm);cursor:pointer;background:#ebf7f2;border:1.5px solid #3b9e6e;padding:8px 16px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.chat-save-btn:hover:not(:disabled){color:#fff;background:#3b9e6e}.chat-save-btn:disabled{opacity:.5;cursor:not-allowed}.dark .chat-save-btn{background:#0d2318}@media (width<=768px){:root{--header-h:calc(52px + env(safe-area-inset-top))}.header{padding:10px 14px}.logo{font-size:17px}.stage-pills,.total-hours{display:none}.progress-wrap{top:var(--header-h)}.controls{top:calc(var(--header-h) + 3px);-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;padding:8px 14px;overflow-x:auto}.controls::-webkit-scrollbar{display:none}.filter-btn,.filter-dropdown-wrap,.divider{flex-shrink:0}.view-toggle{flex-shrink:0;margin-left:8px}.main{padding:12px 14px}.kanban-view{grid-template-columns:1fr;gap:12px}.cat-breakdown{flex-direction:column}.mobile-col-tabs{background:var(--surface2);border-radius:var(--radius-sm);gap:0;margin-bottom:12px;padding:3px;display:flex}.mobile-col-tab{cursor:pointer;color:var(--text2);background:0 0;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:5px;padding:7px 6px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s;display:flex}.mobile-col-tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}.mobile-col-tab-count{background:var(--surface2);border-radius:20px;padding:1px 6px;font-size:10px;font-weight:700}.mobile-col-tab.active .mobile-col-tab-count{background:var(--border)}.column.mobile-hidden{display:none}.voice-transcript-overlay{font-size:14px;bottom:92px;left:12px;right:12px}.modal-body .field input,.modal-body .field textarea,.modal-body .field select{font-size:16px}.today-task{flex-wrap:wrap;align-items:center;gap:4px 8px}.today-rank{flex-shrink:0}.today-task-title{white-space:normal;flex:calc(100% - 40px);min-width:0}.queue-card{padding:7px 10px}.queue-card-top{align-items:flex-start}.queue-card-top-left{flex-wrap:wrap;gap:3px 5px}.queue-card-title{white-space:normal;text-overflow:clip;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex-basis:100%;font-size:13px;display:-webkit-box;overflow:hidden}.queue-card-hours{padding:1px 6px;font-size:11px}.queue-card-notes{margin-bottom:5px;font-size:10.5px}.task-card{padding:6px 8px}.task-card-top{align-items:flex-start}.task-card-top-left{flex-wrap:wrap;gap:3px 5px}.task-title{white-space:normal;text-overflow:clip;-webkit-line-clamp:2;text-align:center;-webkit-box-orient:vertical;flex-basis:100%;font-size:13px;display:-webkit-box;overflow:hidden}.task-hrs{padding:1px 6px;font-size:10px}.task-notes-small{font-size:10.5px}.pin-btn{font-size:17px}.status-action-btn{padding:6px 11px;font-size:11px}.board-status-btn{padding:5px 11px;font-size:11px}.mobile-status-btns{flex-wrap:wrap;justify-content:flex-end;gap:6px;margin-top:8px;display:flex}.ai-hours-row{flex-direction:column;align-items:stretch;gap:8px}.ai-generate-btn{width:100%;padding:11px}.ai-prompt-section{padding:16px}.overlay{padding:12px;overflow-x:hidden}.modal{box-sizing:border-box;width:calc(100vw - 24px);max-width:calc(100vw - 24px);max-height:95vh;overflow-x:hidden}.modal-header{box-sizing:border-box;padding:12px 16px}.modal-body{box-sizing:border-box;padding:14px 16px;overflow-x:hidden}.modal-body *{box-sizing:border-box;max-width:100%}.modal-body .field input,.modal-body .field textarea,.modal-body .field select{width:100%}.type-toggle{flex-direction:column;gap:5px}.type-btn{flex:none;width:100%}.assignee-toggle{flex-wrap:wrap}.assignee-btn{flex:calc(50% - 5px);min-width:0}.chat-body,.chat-messages{overflow-x:hidden}.chat-input-row{flex-wrap:wrap;gap:6px}.chat-input{width:100%}.modal-footer{flex-direction:column;gap:7px;padding:10px 16px}.modal-footer .btn-danger{width:100%;margin-right:0}.modal-footer .btn-secondary,.modal-footer .btn-primary,.modal-footer .chat-save-btn{width:100%}.field-row{grid-template-columns:1fr}}.auth-loading{background:var(--bg,#f7f5f2);min-height:100vh}.login-screen{background:#f7f5f2;justify-content:center;align-items:center;min-height:100vh;padding:24px;font-family:DM Sans,sans-serif;display:flex}.login-card{background:#fff;border-radius:20px;flex-direction:column;align-items:center;gap:12px;width:100%;min-width:320px;max-width:380px;padding:48px 40px;display:flex;box-shadow:0 4px 32px #00000014,0 1px 4px #0000000a}.login-logo{color:#1c1917;letter-spacing:-1px;font-family:Fraunces,serif;font-size:36px;line-height:1}.login-logo span{color:#e07b39}.login-tagline{color:#78716c;margin-bottom:16px;font-size:14px;font-weight:400}.login-form{flex-direction:column;gap:10px;width:100%;display:flex}.login-input{color:#1c1917;background:#f7f5f2;border:1.5px solid #e8e3dc;border-radius:10px;outline:none;width:100%;padding:11px 14px;font-family:DM Sans,sans-serif;font-size:14px;transition:border-color .15s,background .15s}.login-input:focus{background:#fff;border-color:#e07b39}.login-input::placeholder{color:#a8a29e}.login-submit-btn{color:#fff;cursor:pointer;background:#e07b39;border:none;border-radius:10px;width:100%;margin-top:2px;padding:12px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;transition:background .15s}.login-submit-btn:hover:not(:disabled){background:#c96a2a}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#dc2626;text-align:left;background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;padding:9px 12px;font-size:13px;line-height:1.45}.login-success{color:#3b9e6e;text-align:left;background:#ebf7f2;border:1px solid #86efac;border-radius:8px;padding:9px 12px;font-size:13px;line-height:1.45}.login-forgot-link{color:#a8a29e;cursor:pointer;text-align:right;background:0 0;border:none;align-self:flex-end;padding:0;font-family:DM Sans,sans-serif;font-size:12px;transition:color .15s}.login-forgot-link:hover{color:#78716c}.login-toggle{color:#78716c;align-items:center;gap:5px;font-size:13px;display:flex}.login-toggle-btn{color:#e07b39;cursor:pointer;background:0 0;border:none;padding:0;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;text-decoration:underline;transition:color .15s}.login-toggle-btn:hover{color:#c96a2a}.login-divider{color:#a8a29e;align-items:center;gap:10px;width:100%;font-size:12px;display:flex}.login-divider:before,.login-divider:after{content:"";background:#e8e3dc;flex:1;height:1px}.login-google-btn{color:#1c1917;cursor:pointer;background:#fff;border:1.5px solid #e8e3dc;border-radius:10px;justify-content:center;align-items:center;gap:10px;width:100%;padding:12px 24px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;transition:all .15s;display:flex}.login-google-btn:hover{border-color:#e07b39;box-shadow:0 2px 8px #00000014}.invite-btn{border:1.5px solid var(--border);cursor:pointer;color:var(--text2);background:0 0;border-radius:20px;padding:5px 12px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.invite-btn:hover{border-color:var(--accent);color:var(--accent)}.signout-btn{cursor:pointer;color:var(--text3);background:0 0;border:none;padding:5px 2px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;transition:color .15s}.signout-btn:hover{color:var(--text)}.app-footer{border-top:1px solid var(--border);grid-template-columns:1fr auto 1fr;align-items:center;margin-top:40px;padding:16px 24px;display:grid}.app-footer-feedback{cursor:pointer;color:var(--text3);text-underline-offset:3px;background:0 0;border:none;padding:0;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;text-decoration:underline;transition:color .15s}.app-footer-feedback:hover{color:var(--text2)}.app-footer-copy{color:var(--text3);font-size:12px}.invite-link-box{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:10px 12px;display:flex}.invite-link-text{color:var(--text2);word-break:break-all;flex:1;font-family:ui-monospace,Consolas,monospace;font-size:11px;line-height:1.45}.invite-copy-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;flex-shrink:0;padding:6px 14px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:background .15s}.invite-copy-btn:hover{background:var(--accent-hover)}.manage-section{border-bottom:1px solid var(--border);flex-direction:column;gap:8px;margin-bottom:18px;padding-bottom:18px;display:flex}.manage-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.manage-section-title{color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:2px;font-size:11px;font-weight:700}.manage-member-row{align-items:center;gap:10px;padding:8px 0;display:flex}.manage-member-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.manage-member-info{flex-direction:column;gap:2px;display:flex}.manage-member-email{color:var(--text);font-size:13px;font-weight:500}.manage-member-role{color:var(--text3);text-transform:capitalize;font-size:11px}.manage-remove-btn{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;margin-left:auto;padding:2px 6px;font-size:18px;line-height:1;transition:color .15s,background .15s}.manage-remove-btn:hover{color:#dc2626;background:#fef2f2}.manage-remove-confirm{flex-shrink:0;align-items:center;gap:6px;margin-left:auto;display:flex}.manage-remove-yes{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:4px;padding:3px 8px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600}.manage-remove-yes:hover{background:#b91c1c}.manage-remove-cancel{background:var(--surface2);color:var(--text2);border:1px solid var(--border);cursor:pointer;border-radius:4px;padding:3px 8px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:500}.manage-display-name-input{color:var(--text);background:0 0;border:none;border-bottom:1.5px solid #0000;outline:none;width:100%;padding:0 0 1px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;transition:border-color .15s}.manage-display-name-input:hover{border-bottom-color:var(--border)}.manage-display-name-input:focus{border-bottom-color:var(--accent)}.member-color-popover{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);width:132px;box-shadow:var(--shadow);z-index:200;flex-wrap:wrap;gap:6px;padding:8px;display:flex;position:absolute;top:calc(100% + 6px);left:0}.manage-color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:16px;height:16px;padding:0;transition:transform .1s,border-color .1s}.manage-color-swatch:hover{transform:scale(1.2)}.manage-color-swatch.selected{border-color:var(--text);transform:scale(1.15)}.notif-pref-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.notif-pref-row:last-child{border-bottom:none}.notif-pref-row.notif-pref-indent{border-bottom:none;padding-top:4px;padding-bottom:10px;padding-left:12px}.notif-pref-label{flex-direction:column;gap:2px;display:flex}.notif-pref-label span:first-child{color:var(--text);font-size:14px;font-weight:500}.notif-pref-desc{color:var(--text2);font-size:12px}.notif-toggle{background:var(--border);cursor:pointer;border:none;border-radius:11px;flex-shrink:0;width:40px;height:22px;padding:0;transition:background .2s;position:relative}.notif-toggle.on{background:var(--accent)}.notif-toggle-knob{background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;display:block;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.notif-toggle.on .notif-toggle-knob{transform:translate(18px)}.notif-time-select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer;padding:5px 8px;font-size:13px}
