@import "https://fonts.googleapis.com/css2?family=Fraunces:wght@600;700&family=Sora:wght@400;600;700&display=swap";:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f2eee5;--card:#fffaf2;--panel:#fffbf4;--panel-strong:#fff;--panel-soft:#fffaf2;--surface:#fff;--surface-muted:#fffdf8;--surface-soft:#fff7ed;--surface-active:#efe0c9;--surface-drag:#eefaf8;--surface-drop:#fffdf8;--surface-raise:#fff2e2;--ink:#1f1a14;--muted:#6f6155;--accent:#0f766e;--accent-soft:#d7f0ea;--border:#e5dccf;--shadow:0 14px 40px #1f1a141f;--status-panel-border:#0f172a1f;--chip-border:#0f172a1f;--chip-border-strong:#0f172a4d;--filter-all-bg:#fff7ed;--toast-bg:#f8fafc;--toast-border:#e2e8f0;--alert-error-bg:#fee2e2;--alert-error-ink:#991b1b;--alert-error-border:#fecaca;--alert-info-bg:#dbeafe;--alert-info-ink:#1d4ed8;--alert-info-border:#bfdbfe;--page-glow-1:#fff3cc;--page-glow-2:#dff2ed;--card-gradient:linear-gradient(180deg, #fff 0%, #fff5ea 100%);--status-backlog:#94a3b8;--status-todo:#f59e0b;--status-inprogress:#3b82f6;--status-review:#a855f7;--status-done:#22c55e}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0f1115;--card:#151a22;--panel:#161c24;--panel-strong:#1b2230;--panel-soft:#151a22;--surface:#1b2230;--surface-muted:#151a22;--surface-soft:#222a36;--surface-active:#243043;--surface-drag:#1f2a38;--surface-drop:#19212d;--surface-raise:#222a36;--ink:#f5f6f8;--muted:#9aa4b2;--accent:#38bdf8;--accent-soft:#0b2b3a;--border:#2b3544;--shadow:0 16px 40px #00000073;--status-panel-border:#94a3b833;--chip-border:#94a3b840;--chip-border-strong:#94a3b866;--filter-all-bg:#1f2a38;--toast-bg:#1a2230;--toast-border:#2b3544;--alert-error-bg:#3b1d23;--alert-error-ink:#fca5a5;--alert-error-border:#7f1d1d;--alert-info-bg:#172a42;--alert-info-ink:#93c5fd;--alert-info-border:#1d4ed8;--page-glow-1:#38bdf82e;--page-glow-2:#10b9811f;--card-gradient:linear-gradient(180deg, #1a202b 0%, #151a22 100%)}[data-theme=dark] .project-item:not(.project-item--active):not(.project-item--dragging){border-color:#94a3b852}[data-theme=dark] .project-filter-pill{border-color:#94a3b838}[data-theme=dark] .project-filter-pill.is-active{box-shadow:0 8px 16px #00000059}[data-theme=dark] .project-count{color:var(--ink);background:#94a3b838;border:1px solid #94a3b84d}[data-theme=dark] .project-status-select{background:var(--surface-soft);color:var(--muted);border-color:#94a3b859}[data-theme=dark] .project-status-select--backlog{border-color:color-mix(in srgb, var(--status-backlog) 55%, var(--border));background:color-mix(in srgb, var(--status-backlog) 18%, var(--surface-soft));color:color-mix(in srgb, var(--status-backlog) 70%, var(--ink))}[data-theme=dark] .project-status-select--todo{border-color:color-mix(in srgb, var(--status-todo) 55%, var(--border));background:color-mix(in srgb, var(--status-todo) 18%, var(--surface-soft));color:color-mix(in srgb, var(--status-todo) 70%, var(--ink))}[data-theme=dark] .project-status-select--inprogress{border-color:color-mix(in srgb, var(--status-inprogress) 55%, var(--border));background:color-mix(in srgb, var(--status-inprogress) 18%, var(--surface-soft));color:color-mix(in srgb, var(--status-inprogress) 70%, var(--ink))}[data-theme=dark] .project-status-select--review{border-color:color-mix(in srgb, var(--status-review) 55%, var(--border));background:color-mix(in srgb, var(--status-review) 18%, var(--surface-soft));color:color-mix(in srgb, var(--status-review) 70%, var(--ink))}[data-theme=dark] .project-status-select--done{border-color:color-mix(in srgb, var(--status-done) 55%, var(--border));background:color-mix(in srgb, var(--status-done) 18%, var(--surface-soft));color:color-mix(in srgb, var(--status-done) 70%, var(--ink))}[data-theme=dark] .priority-select{background:var(--surface-soft);color:var(--ink);border-color:#94a3b859}[data-theme=dark] .priority-select--low{color:#cbd5e1;background:#1f2937;border-color:#475569}[data-theme=dark] .priority-select--medium{color:#fcd34d;background:#3f2d16;border-color:#a16207}[data-theme=dark] .priority-select--high{color:#fda4af;background:#3f1d27;border-color:#be123c}*{box-sizing:border-box}button,input,select,textarea{font:inherit;min-width:0}body{background:radial-gradient(circle at 12% 8%, var(--page-glow-1), transparent 42%), radial-gradient(circle at 90% 0%, var(--page-glow-2), transparent 45%), var(--bg);color:var(--ink);margin:0;font-family:Sora,sans-serif}.app-page{justify-content:center;align-items:flex-start;min-height:100vh;padding:32px 16px 64px;display:flex}.app-layout{flex-direction:column;gap:16px;width:100%;max-width:78rem;display:flex}.app-header{border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow);border-radius:20px;justify-content:space-between;align-items:center;gap:18px;padding:20px 22px;display:flex}.app-header-kicker{text-transform:uppercase;letter-spacing:.5px;color:var(--accent);margin:0 0 4px;font-size:11px;font-weight:700}.app-header-title{color:var(--ink);margin:0 0 6px;font-family:Fraunces,serif;font-size:clamp(24px,2.1vw,30px);line-height:1.1}.app-header-subtitle{color:var(--muted);max-width:48ch;margin:0;font-size:14px}.app-header-actions{align-items:center;gap:10px;display:flex}.app-header-button{border:1px solid var(--border);background:var(--surface);color:var(--ink);cursor:pointer;border-radius:999px;padding:9px 16px;font-size:13px;font-weight:700;transition:border-color .15s,box-shadow .15s,transform .15s}.app-header-button:hover{border-color:#0f766e66;transform:translateY(-1px);box-shadow:0 8px 16px #0f766e29}.app-shell{align-items:flex-start;gap:20px;width:100%;display:flex}.app-shell--focus{justify-content:center}.app-card{background:var(--card-gradient);border:1px solid var(--border);width:100%;min-width:0;max-width:none;box-shadow:var(--shadow);border-radius:20px;flex:1 1 0;padding:28px}.project-sidebar{border:1px solid var(--border);background:var(--panel);border-radius:18px;width:100%;max-width:17rem;padding:20px;position:relative;box-shadow:0 10px 26px #1f1a1414}.project-dropzone{background:color-mix(in srgb, var(--surface) 90%, transparent);color:var(--accent);letter-spacing:.4px;text-transform:uppercase;pointer-events:none;z-index:2;border:2px dashed #0f766e80;border-radius:14px;place-items:center;font-size:12px;font-weight:700;display:grid;position:absolute;inset:10px}.project-sidebar-header{justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.project-sidebar-header>div:first-child{min-width:0}.project-sidebar-title-row{align-items:center;gap:8px;display:flex}.project-focus-badge{text-transform:uppercase;letter-spacing:.6px;color:var(--accent);background:var(--accent-soft);border-radius:999px;padding:2px 8px;font-size:10px;font-weight:700}.project-sidebar-actions{align-items:center;gap:8px;display:flex;position:relative}.project-focus-toggle{background:var(--surface-raise);color:var(--accent);cursor:pointer;border:1px solid #0000;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700;transition:border-color .15s,box-shadow .15s,color .15s}.project-focus-toggle:hover{color:var(--accent)}.project-focus-toggle.is-active{border-color:var(--accent);color:var(--accent);background:var(--surface);box-shadow:0 8px 16px #0f766e29}.project-filter-toggle{border:1px solid var(--border);background:var(--panel-strong);color:var(--muted);cursor:pointer;border-radius:999px;align-items:center;gap:8px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.project-filter-toggle:hover{color:var(--ink)}.project-header-button{border:1px solid var(--border);background:var(--panel-strong);color:var(--muted);cursor:pointer;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600}.project-header-button:hover{color:var(--ink)}.project-header-button:disabled{opacity:.6;cursor:not-allowed}.project-actions-trigger{border:1px solid var(--border);background:var(--panel-strong);color:var(--muted);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.project-actions-trigger:hover{color:var(--ink)}.project-actions-menu{background:var(--panel-strong);border:1px solid var(--border);z-index:3;border-radius:12px;gap:6px;min-width:170px;padding:8px;display:grid;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 12px 24px #1f1a1424}.project-actions-item{background:var(--panel-soft);color:var(--ink);text-align:left;cursor:pointer;border:1px solid #0000;border-radius:10px;padding:6px 10px;font-size:12px;font-weight:600}.project-actions-item:hover{background:var(--surface-drag);border-color:#0f766e40}.project-actions-item:disabled{opacity:.6;cursor:not-allowed}.project-filter-panel{border:1px solid var(--border);background:var(--panel-strong);border-radius:14px;margin-bottom:16px;padding:12px;box-shadow:0 8px 18px #1f1a1414}.status-panel{border:1px solid var(--status-panel-border);box-shadow:none;background:0 0;border-radius:14px;margin-bottom:16px;padding:12px}.app-title-actions{align-items:center;gap:10px;display:flex}.app-title-action{border:1px solid var(--border);background:var(--panel-strong);color:var(--ink);cursor:pointer;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:700}.app-title-action:hover{border-color:#0f766e59}.settings-panel{background:var(--panel);border:1px solid var(--border);border-radius:18px;gap:20px;padding:18px;display:grid}.settings-modal-overlay{z-index:30;background:#0f172a66;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.settings-modal{background:var(--panel);border:1px solid var(--border);border-radius:20px;gap:16px;width:min(520px,100%);padding:20px;display:grid;box-shadow:0 24px 48px #1f1a1433}.settings-modal-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.settings-close{border:1px solid var(--border);background:var(--surface);width:32px;height:32px;color:var(--muted);cursor:pointer;border-radius:10px;font-weight:700}.settings-close:hover{color:var(--ink)}.settings-header{gap:6px;display:grid}.settings-kicker{text-transform:uppercase;letter-spacing:.4px;color:var(--accent);margin:0;font-size:11px;font-weight:700}.settings-title{margin:0;font-size:20px}.settings-subtitle{color:var(--muted);margin:0;font-size:13px}.settings-section{border:1px solid var(--border);background:var(--panel-strong);border-radius:14px;padding:12px}.settings-section--danger{border-color:color-mix(in srgb, var(--border) 60%, #fca5a5)}.settings-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.settings-label{font-size:13px;font-weight:700;display:block}.settings-hint{color:var(--muted);margin-top:4px;font-size:12px;display:block}.settings-toggle{border:1px solid var(--border);background:var(--panel-soft);color:var(--muted);cursor:pointer;border-radius:999px;align-items:center;gap:10px;padding:6px 10px;font-size:11px;font-weight:700;display:inline-flex}.settings-toggle.is-on{color:var(--accent);border-color:#0f766e59}.settings-toggle-track{background:#0f172a1a;border-radius:999px;width:32px;height:16px;position:relative}.settings-toggle.is-on .settings-toggle-track{background:#0f766e4d}.settings-toggle-thumb{background:var(--panel-strong);border-radius:999px;width:12px;height:12px;transition:transform .15s;position:absolute;top:2px;left:2px}.settings-toggle.is-on .settings-toggle-thumb{transform:translate(14px)}.settings-logout{color:#dc2626;cursor:pointer;background:0 0;border:1px solid #b91c1c80;border-radius:999px;padding:6px 14px;font-size:11px;font-weight:700}.settings-logout:hover{background:#dc26261f}.settings-secondary-button{border:1px solid var(--border);background:var(--surface);color:var(--ink);cursor:pointer;border-radius:999px;padding:6px 14px;font-size:11px;font-weight:700}.settings-secondary-button:hover{color:var(--accent);border-color:#0f766e59}.settings-select{border:1px solid var(--border);background:var(--surface);color:var(--ink);border-radius:10px;min-width:140px;padding:6px 10px;font-size:12px;font-weight:600}.settings-select:focus-visible{outline:2px solid color-mix(in srgb, var(--accent) 35%, transparent);outline-offset:2px}.status-panel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.status-panel-title{text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-size:11px;font-weight:600}.status-panel-switch{border:1px solid var(--chip-border);color:var(--muted);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:8px;padding:3px 8px 3px 6px;font-size:11px;font-weight:600;display:inline-flex}.status-panel-switch.is-on{color:var(--ink);border-color:var(--chip-border-strong)}.status-panel-switch-track{border:1px solid var(--chip-border);border-radius:999px;align-items:center;width:28px;height:14px;padding:1px;display:inline-flex;position:relative}.status-panel-switch-thumb{background:var(--muted);border-radius:999px;width:10px;height:10px;transition:transform .15s,background .15s;transform:translate(0)}.status-panel-switch.is-on .status-panel-switch-thumb{background:var(--ink);transform:translate(12px)}.status-panel-switch-label{color:inherit}.status-panel-editor{gap:8px;display:grid}.status-edit-list{gap:6px;margin:0;padding:0;list-style:none;display:grid}.status-edit-row{border:1px solid var(--chip-border);background:0 0;border-radius:12px;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;padding:6px 8px;display:grid}.status-edit-row.is-dragging{border-color:var(--chip-border-strong);background:color-mix(in srgb, var(--surface-soft) 60%, transparent)}.status-drag-handle{color:var(--muted);cursor:grab;background:0 0;border:none;padding:0 4px;font-weight:700}.status-drag-handle:active{cursor:grabbing}.status-edit-label{color:var(--ink);font-size:12px;font-weight:600}.status-color-controls{align-items:center;gap:6px;display:inline-flex}.status-color{color:var(--muted);align-items:center;gap:4px;font-size:10px;display:inline-flex}.status-color input[type=color]{border:1px solid var(--chip-border);background:0 0;border-radius:6px;width:20px;height:20px;padding:0}.project-status-panel{gap:10px;display:grid}.project-filter-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.project-filter-title{text-transform:uppercase;letter-spacing:.6px;color:var(--muted);font-size:11px;font-weight:600}.project-filter-options{flex-wrap:wrap;gap:6px;display:flex}.project-filter-pill{--filter-color:#94a3b8;border:1px solid var(--chip-border);color:var(--muted);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:600;transition:background .15s,box-shadow .15s,border-color .15s;display:inline-flex;position:relative}.project-filter-count{background:color-mix(in srgb, var(--surface) 70%, transparent);min-width:16px;height:16px;color:inherit;border-radius:999px;justify-content:center;align-items:center;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.project-filter-pill.is-active{background:color-mix(in srgb, var(--filter-color) 18%, var(--surface));border-color:var(--filter-color);box-shadow:0 8px 16px color-mix(in srgb, var(--ink) 12%, transparent);color:var(--filter-color);font-weight:700}.project-filter-pill--all{--filter-color:var(--accent)}.project-filter-pill--backlog{--filter-color:var(--status-backlog)}.project-filter-pill--todo{--filter-color:var(--status-todo)}.project-filter-pill--inprogress{--filter-color:var(--status-inprogress)}.project-filter-pill--review{--filter-color:var(--status-review)}.project-filter-pill--done{--filter-color:var(--status-done)}.task-status-list{flex-wrap:wrap;gap:6px;display:flex}.task-status-chip{border:1px solid var(--chip-border);color:var(--ink);background:0 0;border-radius:999px;align-items:center;gap:6px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex}.task-status-remove{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:13px;line-height:1}.task-status-remove:hover{color:#b91c1c}.task-status-remove:disabled{opacity:.4;cursor:not-allowed}.task-status-add{gap:8px;display:flex}.task-status-input{border:1px solid var(--chip-border);background:0 0;border-radius:10px;flex:1;padding:6px 10px;font-size:12px}.task-status-input:focus{border-color:var(--chip-border-strong);box-shadow:none;outline:none}.task-status-add-button{border:1px solid var(--chip-border);color:var(--ink);cursor:pointer;background:0 0;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:600}.task-status-add-button:hover{border-color:var(--chip-border-strong);box-shadow:none}.project-sidebar-title{margin:0 0 4px;font-family:Fraunces,serif;font-size:18px}.project-sidebar-subtitle{color:var(--muted);margin:0;font-size:12px}.project-create{flex-direction:column;margin-bottom:16px;display:flex}.project-create-input{padding:8px 12px;font-size:13px}.project-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.project-item{border:1px solid var(--border);background:var(--surface);border-radius:14px;padding:10px;transition:box-shadow .15s,border-color .15s,background .15s,transform .15s,opacity .15s,border-radius .15s;animation:.24s both rise-in;position:relative}.project-item--active{background:linear-gradient(180deg, var(--surface) 0%, var(--surface-active) 100%);border-color:#0f766ebf;box-shadow:0 10px 22px #1f1a142e,0 0 0 2px #0f766e2e}.project-item--active:not(.project-item--dragging){border-color:#0f766ecc}.project-item--active .project-name{color:var(--accent);font-weight:750}.project-item--active:before{content:none}.project-item--dragging{opacity:1;background:linear-gradient(180deg, var(--surface) 0%, var(--surface-drag) 100%);z-index:1;border-color:#0f766e73;border-radius:18px;transform:translateY(-3px);box-shadow:0 16px 28px #0f766e2e,0 0 0 3px #0f766e29}.project-item--active.project-item--dragging{border-color:#0f766e99;box-shadow:0 18px 30px #0f766e38,0 0 0 4px #0f766e2e}.project-item--dragging-inactive{outline-offset:3px;border-color:#0f766e59;outline:2px solid #0f766e1f;box-shadow:0 16px 28px #0f766e2e,0 0 0 4px #0f766e1f}.project-item:not(.project-item--active):not(.project-item--dragging){background:var(--surface-muted);border-color:var(--chip-border);box-shadow:none}.project-item:not(.project-item--active) .project-name{color:var(--muted)}.project-item--over{border-color:var(--border);transform:translateY(-2px);box-shadow:0 10px 20px #1f1a141f}.project-item--over:before,.project-item--over:after{content:none}.project-row{flex-direction:column;gap:10px;display:flex}.project-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.project-status-select{border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:999px;max-width:100%;padding:4px 10px;font-size:11px;font-weight:600}.project-status-select--backlog{border-color:color-mix(in srgb, #cbd5f5 60%, var(--border));background:color-mix(in srgb, #f1f5f9 35%, var(--surface));color:color-mix(in srgb, #475569 70%, var(--ink))}.project-status-select--todo{border-color:color-mix(in srgb, #fcd34d 60%, var(--border));background:color-mix(in srgb, #fef3c7 35%, var(--surface));color:color-mix(in srgb, #92400e 70%, var(--ink))}.project-status-select--inprogress{border-color:color-mix(in srgb, #bfdbfe 60%, var(--border));background:color-mix(in srgb, #dbeafe 35%, var(--surface));color:color-mix(in srgb, #1d4ed8 70%, var(--ink))}.project-status-select--review{border-color:color-mix(in srgb, #e9d5ff 60%, var(--border));background:color-mix(in srgb, #f3e8ff 35%, var(--surface));color:color-mix(in srgb, #7e22ce 70%, var(--ink))}.project-status-select--done{border-color:color-mix(in srgb, #bbf7d0 60%, var(--border));background:color-mix(in srgb, #dcfce7 35%, var(--surface));color:color-mix(in srgb, #166534 70%, var(--ink))}.project-main{text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:100%;min-width:0;padding:0;display:flex}.project-dot{border-radius:999px;flex-shrink:0;width:10px;height:10px}.project-name{color:var(--ink);overflow-wrap:anywhere;word-break:break-word;flex:1;font-size:13px;font-weight:600}.project-count{background:color-mix(in srgb, var(--surface) 70%, transparent);border-radius:999px;padding:2px 6px;font-size:11px;font-weight:700}.project-rename-input{border:1px solid var(--border);border-radius:10px;width:100%;padding:8px 10px;font-size:13px}.project-rename-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #0f766e2e}.project-actions{align-items:center;gap:6px;margin-left:auto;display:flex}.project-icon-button{border:1px solid var(--border);background:var(--surface);width:28px;height:28px;color:var(--muted);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.project-drag-handle{width:34px;height:34px;color:var(--accent);cursor:grab;border-color:#0000;border-radius:12px;transition:border-color .15s,background .15s,box-shadow .15s,transform .15s}.project-drag-handle:active{cursor:grabbing}.project-drag-handle:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.project-drag-handle:hover{background:var(--surface-drag);border-color:#0f766e40;transform:translateY(-1px);box-shadow:0 6px 14px #0f766e1f}.project-sidebar--dragging .project-drag-handle:hover{background:var(--surface);box-shadow:none;border-color:#0000;transform:none}.project-sidebar--dragging .project-item:not(.project-item--dragging){opacity:.7;filter:saturate(.85);background:var(--surface-drop);border-color:var(--border);box-shadow:none;border-radius:14px;padding:10px}.project-sidebar--dragging .project-item--active{background:var(--surface-drop);border-color:var(--border);box-shadow:none}.project-sidebar--dragging .project-item--active .project-name{color:var(--ink);font-weight:600}.project-sidebar--dragging .project-item:not(.project-item--dragging) .project-row{gap:10px}.project-sidebar--dragging .project-item:not(.project-item--dragging) .project-main{gap:8px}.project-sidebar--dragging .project-item:not(.project-item--dragging) .project-meta{gap:10px}.project-drag-handle:focus-visible{outline:none;box-shadow:0 0 0 3px #0f766e33}.project-drag-handle svg{width:18px;height:18px}.project-icon-button svg{width:14px;height:14px}.project-icon-button:disabled{opacity:.45;cursor:not-allowed}.project-color-swatch{border:1px solid var(--border);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.project-color-swatch--main{border-radius:999px;width:14px;height:14px}.project-color-input{opacity:0;border:0;width:0;height:0;padding:0}.app-title{letter-spacing:-.7px;overflow-wrap:anywhere;word-break:break-word;margin:0 0 4px;font-family:Fraunces,serif;font-size:30px}.app-title-row{justify-content:space-between;align-items:center;gap:12px;margin-bottom:4px;display:flex}.app-title-group{flex:1}.app-title-button{cursor:text;text-align:left;background:0 0;border:none;width:100%;padding:0}.focus-exit-button{border:1px solid var(--border);color:var(--accent);background:var(--surface);cursor:pointer;white-space:nowrap;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:700;transition:box-shadow .15s,border-color .15s,transform .15s}.focus-exit-button:hover{border-color:#0f766e66;transform:translateY(-1px);box-shadow:0 8px 16px #0f766e29}.app-title-button:focus-visible{border-radius:6px;outline:none;box-shadow:0 0 0 3px #0f766e33}.app-title-textarea{letter-spacing:-.7px;color:var(--ink);min-height:52px;padding:6px 10px;font-family:Fraunces,serif;font-size:30px}.app-subtitle{color:var(--muted);margin:0 0 18px}.app-description-row,.app-description-add-row{margin:0 0 18px}.app-description-add{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px}.app-description-add:hover{color:var(--ink);text-decoration:underline}.app-description-button{text-align:left;width:100%}.app-description-text{color:var(--ink);white-space:pre-wrap;overflow-wrap:anywhere;font-size:14px;line-height:1.6}.app-description-text--placeholder{color:var(--muted)}.app-description-textarea{min-height:64px;font-size:14px;line-height:1.6}.filter-row{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:10px;display:flex}.sort-row{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:18px;display:flex}.export-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:18px;display:flex}.export-trigger{border:1px solid var(--border);color:var(--accent);background:var(--surface);cursor:pointer;border-radius:999px;padding:6px 14px;font-size:12px;font-weight:700;transition:box-shadow .15s,border-color .15s,transform .15s}.export-trigger:hover{border-color:#0f766e66;transform:translateY(-1px);box-shadow:0 8px 16px #0f766e29}.export-trigger:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.export-hint{color:var(--muted);font-size:12px;font-weight:600}.sort-heading{flex-wrap:wrap;align-items:baseline;gap:12px;display:flex}.sort-hint{color:var(--muted);font-size:12px;font-weight:600}.sort-controls{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.sort-options{flex-wrap:wrap;gap:8px;display:flex}.sort-option{border:1px solid var(--border);color:var(--ink);background:var(--surface);cursor:pointer;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;transition:transform .15s,box-shadow .15s,border-color .15s}.sort-option--active{background:var(--accent-soft);color:var(--accent);border-color:#0f766e80;transform:translateY(-1px);box-shadow:0 10px 18px #0f766e2e}.sort-option:focus-visible{outline:none;box-shadow:0 0 0 3px #0f766e33}.sort-direction{border:1px solid var(--border);color:var(--ink);background:var(--surface);cursor:pointer;border-radius:12px;align-items:center;gap:8px;padding:6px 12px;font-size:12px;font-weight:700;transition:box-shadow .15s,border-color .15s;display:inline-flex}.sort-direction--locked{opacity:.6;cursor:not-allowed}.sort-direction:focus-visible{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #0f766e33}.filter-control{background:0 0;border:none;border-radius:14px;flex-wrap:wrap;align-items:center;gap:4px;padding:0;display:flex}.filter-option{--filter-color:#94a3b8;cursor:pointer;border:1px solid var(--chip-border);background:var(--surface);border-radius:999px;justify-content:center;align-items:center;height:26px;padding:0 10px;transition:background .15s,box-shadow .15s,border-color .15s,transform .15s;display:inline-flex;position:relative}.filter-option--dense{height:22px;padding:0 6px}.filter-option--dense .filter-text{text-overflow:ellipsis;white-space:nowrap;max-width:80px;overflow:hidden}.filter-option--dense .filter-badge{min-width:14px;height:14px;font-size:9px}.filter-option:before{content:"";background:var(--filter-color);opacity:.55;border-radius:999px;width:4px;height:4px;margin-right:6px;transition:opacity .15s,transform .15s}.filter-option input{opacity:0;pointer-events:none;position:absolute}.filter-text{color:var(--muted);font-size:11px;font-weight:600}.filter-badge{background:color-mix(in srgb, var(--surface) 70%, transparent);min-width:18px;height:18px;color:var(--muted);border-radius:999px;justify-content:center;align-items:center;margin-left:6px;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.filter-option--active .filter-badge{color:var(--filter-color);background:#0f172a1a}.filter-option--active{background:color-mix(in srgb, var(--filter-bg,var(--surface-soft)) 70%, var(--surface));border-color:color-mix(in srgb, var(--filter-color) 55%, var(--surface));transform:translateY(-1px);box-shadow:0 8px 18px #0f172a14}.filter-option--active .filter-text{color:var(--filter-color);font-weight:700}.filter-option--active:before{opacity:1;transform:scale(1.35)}.filter-option input:focus-visible+.filter-text{color:var(--ink)}.filter-option:hover{border-color:var(--chip-border-strong);box-shadow:0 6px 14px #0f172a14}@media (width<=720px){.filter-control{gap:4px 6px}.filter-option{height:24px;padding:0 8px}}@media (width<=520px){.filter-control{gap:4px}.filter-badge{min-width:16px;height:16px;font-size:9px}}.filter-option--all{--filter-color:var(--accent)}.filter-option--backlog{--filter-color:var(--status-backlog)}.filter-option--todo{--filter-color:var(--status-todo)}.filter-option--inprogress{--filter-color:var(--status-inprogress)}.filter-option--review{--filter-color:var(--status-review)}.filter-option--done{--filter-color:var(--status-done)}.filter-option--custom{--filter-color:#64748b}.filter-option--all.filter-option--active{background:color-mix(in srgb, var(--filter-all-bg) 70%, var(--surface))}.filter-option--backlog.filter-option--active,.filter-option--todo.filter-option--active,.filter-option--inprogress.filter-option--active,.filter-option--review.filter-option--active,.filter-option--done.filter-option--active{background:color-mix(in srgb, var(--filter-bg,var(--surface-soft)) 70%, var(--surface))}.filter-option--custom.filter-option--active{background:color-mix(in srgb, #e2e8f0 40%, var(--surface))}.textbox-input{border:1px solid var(--border);resize:none;border-radius:14px;width:100%;padding:12px 16px;font-size:16px;line-height:1.5;transition:border-color .15s,box-shadow .15s;overflow:hidden}.textbox-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #ea580c2e}.listbox{width:100%;margin:16px 0 0;padding:0;list-style:none}.listbox-empty{border:1px dashed var(--border);color:var(--muted);background:var(--panel-soft);text-align:center;border-radius:12px;padding:16px}.listbox-item{border:1px solid var(--border);background:var(--surface-muted);border-radius:14px;padding:12px 14px;transition:transform .18s,box-shadow .18s,border-color .18s;animation:.24s both rise-in;box-shadow:0 6px 16px #0f766e14}.listbox-item:hover{border-color:#0f766e59;transform:translateY(-1px);box-shadow:0 10px 20px #0f766e24}.listbox-item+.listbox-item{margin-top:8px}.listbox-text{white-space:pre-wrap;overflow-wrap:anywhere;font-weight:600}.listbox-main{flex-direction:column;gap:12px;display:flex}.listbox-text-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.listbox-text-row--editing{align-items:flex-start}.listbox-text-button{text-align:left;font:inherit;color:inherit;cursor:text;white-space:normal;background:0 0;border:none;flex:1;padding:0}.listbox-text-button:hover .listbox-text{-webkit-text-decoration:underline #ea580c80;text-decoration:underline #ea580c80}.listbox-textarea{border:1px solid var(--border);resize:none;border-radius:10px;width:100%;min-height:44px;padding:8px 10px;font-family:inherit;font-size:15px;line-height:1.4;overflow:hidden}.listbox-textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #ea580c2e}.listbox-controls{flex-direction:column;gap:10px;display:flex}.task-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.toolbar-actions{align-items:center;gap:8px;display:inline-flex}.priority-select{border:1px solid var(--border);color:var(--ink);background:var(--surface);border-radius:999px;min-width:92px;padding:4px 10px;font-size:12px;font-weight:600}.priority-select--low{border-color:color-mix(in srgb, #cbd5f5 60%, var(--border));background:color-mix(in srgb, #f1f5f9 35%, var(--surface));color:color-mix(in srgb, #475569 70%, var(--ink))}.priority-select--medium{border-color:color-mix(in srgb, #fcd34d 60%, var(--border));background:color-mix(in srgb, #fef3c7 35%, var(--surface));color:color-mix(in srgb, #92400e 70%, var(--ink))}.priority-select--high{border-color:color-mix(in srgb, #fca5a5 60%, var(--border));background:color-mix(in srgb, #fee2e2 35%, var(--surface));color:color-mix(in srgb, #b91c1c 70%, var(--ink))}.priority-select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #ea580c33}.status-control{border:1px solid var(--chip-border);background:linear-gradient(135deg, var(--surface), var(--surface-muted));box-shadow:inset 0 1px 0 color-mix(in srgb, var(--surface) 60%, transparent);border-radius:999px;flex-wrap:wrap;align-items:center;gap:4px;padding:3px 4px;display:inline-flex}.status-option{--status-color:#94a3b8;cursor:pointer;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;height:24px;padding:0 8px;transition:background .15s,box-shadow .15s,border-color .15s,transform .15s;display:inline-flex;position:relative}.status-option input{opacity:0;pointer-events:none;position:absolute}.status-label{color:var(--muted);font-size:11px;font-weight:600;transition:color .15s}.status-option input:checked+.status-label{color:var(--status-color);font-weight:700}.status-option input:focus-visible+.status-label{color:var(--ink)}.status-option--backlog{--status-color:var(--status-backlog)}.status-option--todo{--status-color:var(--status-todo)}.status-option--inprogress{--status-color:var(--status-inprogress)}.status-option--review{--status-color:var(--status-review)}.status-option--done{--status-color:var(--status-done)}.status-option--custom{--status-color:#64748b}.status-option--active{border-color:var(--status-color);box-shadow:none;background:color-mix(in srgb, var(--status-bg,var(--surface-soft)) 70%, var(--surface));transform:none}.export-overlay{z-index:10;background:#1f1a1459;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.export-dialog{background:var(--panel);border:1px solid var(--border);border-radius:18px;width:min(520px,100%);padding:20px;box-shadow:0 24px 48px #1f1a142e}.export-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.export-title{margin:0 0 6px;font-family:Fraunces,serif;font-size:18px}.export-subtitle{color:var(--muted);margin:0;font-size:12px}.export-close{border:1px solid var(--border);background:var(--surface);width:30px;height:30px;color:var(--muted);cursor:pointer;border-radius:10px;font-weight:700}.export-close:hover{color:var(--ink)}.export-section{border:1px solid var(--border);background:var(--surface);border-radius:14px;margin-bottom:12px;padding:12px}.export-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin:0 0 8px;font-size:11px;font-weight:700}.export-options{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px 12px;display:grid}.export-option{color:var(--ink);align-items:center;gap:8px;font-size:12px;font-weight:600;display:flex}.export-preview-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.export-preview-toggle{border:1px solid var(--border);background:var(--surface-soft);border-radius:999px;gap:2px;padding:2px;display:inline-flex}.export-preview-button{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700}.export-preview-button--active{background:var(--surface);color:var(--accent);box-shadow:0 6px 12px #0f766e1f}.export-preview{border:1px solid var(--border);background:var(--surface-muted);color:var(--ink);white-space:pre-wrap;border-radius:12px;max-height:220px;margin:0;padding:10px 12px;font-family:Sora,sans-serif;font-size:12px;line-height:1.6;overflow:auto}.export-preview-formatted{white-space:normal}.export-preview-formatted h1,.export-preview-formatted h2,.export-preview-formatted h3{color:var(--ink);margin:0 0 8px;font-family:Fraunces,serif}.export-preview-formatted h1{font-size:18px}.export-preview-formatted h2{font-size:15px}.export-preview-formatted h3{font-size:13px}.export-preview-formatted p{margin:0 0 8px}.export-preview-list{margin:0 0 8px;padding-left:18px}.export-preview-empty{color:var(--muted);margin:0}.export-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;margin-top:12px;display:flex}.export-status{color:var(--muted);min-height:16px;margin-right:auto;font-size:12px;font-weight:600}.export-cancel,.export-secondary,.export-confirm{border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:999px;padding:6px 14px;font-size:12px;font-weight:700}.export-secondary{background:var(--surface);color:var(--accent);border-color:#0f766e59}.export-confirm{background:var(--accent-soft);color:var(--accent);border-color:#0f766e80}.export-confirm:disabled{opacity:.6;cursor:not-allowed}.delete-button{--hold-progress:0;background:var(--surface);color:#b91c1c;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none;border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;width:34px;height:34px;transition:border-color .15s,background .15s,box-shadow .15s,transform .15s;display:inline-flex;position:relative}.delete-button:after{content:"";transform-origin:0;height:2px;transform:scaleX(var(--hold-progress));background:#ef4444;border-radius:999px;position:absolute;bottom:4px;left:8px;right:8px}.delete-button:hover{background:color-mix(in srgb, #fff1f2 50%, var(--surface));border-color:#fecaca;transform:translateY(-1px);box-shadow:0 6px 14px #be123c26}.delete-button--active{background:color-mix(in srgb, #fee2e2 55%, var(--surface));border-color:#fca5a5}.delete-button:focus-visible{outline:none;box-shadow:0 0 0 3px #ea580c40}.delete-icon{width:18px;height:18px;transform:translateY(-1px)}.sr-only{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.undo-toast-stack{z-index:20;flex-direction:column;align-items:flex-end;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.undo-toast{background:var(--toast-bg);border:1px solid var(--toast-border);border-radius:12px;align-items:center;gap:10px;max-width:min(90vw,420px);padding:10px 12px;font-size:13px;animation:.22s toast-rise,8s linear toast-fade;display:inline-flex;box-shadow:0 10px 22px #0f172a1a}.undo-message{align-items:center;gap:8px;min-width:0;display:inline-flex}.undo-dot{background:var(--muted);border-radius:999px;flex-shrink:0;width:8px;height:8px}.undo-text{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;max-width:320px;overflow:hidden}.undo-button{color:var(--accent);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 4px;font-weight:600}.undo-button:focus-visible{outline:none;box-shadow:0 0 0 3px #ea580c40}@keyframes toast-fade{0%,85%{opacity:1}to{opacity:0}}@keyframes rise-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes toast-rise{0%{opacity:0;transform:translateY(6px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.project-item,.listbox-item,.undo-toast{transition:none;animation:none}}@media (width<=960px){.app-shell{flex-direction:column}.project-sidebar{max-width:none}}@media (width<=720px){.app-header{flex-direction:column;align-items:flex-start;gap:12px;padding:16px 18px}.app-header-title{font-size:24px}.app-header-subtitle{font-size:13px}.app-header-button{padding:8px 14px;font-size:12px}.app-header-actions{justify-content:flex-end;width:100%}.settings-row{flex-direction:column;align-items:flex-start}.privacy-modal-overlay{padding:14px}.privacy-modal-header{padding:16px 16px 10px}.privacy-content{padding:8px 16px 16px}}.auth-shell{place-items:center;min-height:100vh;padding:32px 16px 64px;display:grid}.auth-card{background:var(--panel);border:1px solid var(--border);width:min(420px,100%);box-shadow:var(--shadow);border-radius:22px;gap:20px;padding:28px;display:grid}.auth-header{gap:8px;display:grid}.auth-kicker{letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin:0;font-size:12px}.auth-title{color:var(--ink);margin:0;font-family:Fraunces,serif;font-size:28px}.auth-subtitle{color:var(--muted);margin:0;font-size:14px}.auth-form{gap:14px;display:grid}.auth-field{color:var(--muted);gap:6px;font-size:13px;display:grid}.auth-field input{border:1px solid var(--border);background:var(--surface);border-radius:12px;padding:10px 12px;font-family:inherit;font-size:14px}.auth-field input:focus{border-color:var(--accent);outline:2px solid #0f766e33}.auth-consent{border:1px solid var(--border);background:var(--surface-muted);border-radius:12px;gap:8px;padding:10px 12px;display:grid}.auth-consent-check{color:var(--muted);cursor:pointer;align-items:flex-start;gap:8px;font-size:12px;display:flex}.auth-consent-check input{margin-top:1px}.auth-inline-link{width:fit-content;color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px;font-weight:700}.auth-inline-link:hover{text-decoration:underline}.auth-actions{gap:10px;display:grid}.auth-actions button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:10px 16px;font-weight:600}.auth-actions button:disabled{opacity:.6;cursor:not-allowed}.auth-alert{border:1px solid #0000;border-radius:12px;padding:10px 12px;font-size:12px}.auth-alert--error{background:var(--alert-error-bg);color:var(--alert-error-ink);border-color:var(--alert-error-border)}.auth-alert--info{background:var(--alert-info-bg);color:var(--alert-info-ink);border-color:var(--alert-info-border)}.auth-footer{flex-wrap:wrap;justify-content:flex-start;gap:10px;display:flex}.auth-link{color:var(--accent);cursor:pointer;background:0 0;border:none;min-width:0;padding:0;font-size:12px;font-weight:600}.auth-link:hover{text-decoration:underline}.privacy-modal-overlay{z-index:40;background:#0f172a80;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.privacy-modal{background:var(--panel);border:1px solid var(--border);border-radius:20px;grid-template-rows:auto minmax(0,1fr);width:min(720px,100%);max-height:min(82vh,860px);display:grid;box-shadow:0 24px 48px #1f1a1440}.privacy-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:12px;padding:20px 20px 12px;display:flex}.privacy-kicker{text-transform:uppercase;letter-spacing:.4px;color:var(--accent);margin:0;font-size:11px;font-weight:700}.privacy-title{color:var(--ink);margin:4px 0;font-family:Fraunces,serif;font-size:22px}.privacy-subtitle{color:var(--muted);margin:0;font-size:12px}.privacy-close{border:1px solid var(--border);background:var(--surface);width:32px;height:32px;color:var(--muted);cursor:pointer;border-radius:10px;font-weight:700}.privacy-close:hover{color:var(--ink)}.privacy-content{gap:14px;padding:8px 20px 20px;display:grid;overflow:auto}.privacy-section{border:1px solid var(--border);background:var(--panel-strong);border-radius:12px;padding:12px}.privacy-section h3{color:var(--ink);margin:0 0 8px;font-size:15px}.privacy-section p{color:var(--muted);margin:0;font-size:13px;line-height:1.45}.privacy-section p+p{margin-top:8px}.status-drag-handle:disabled{opacity:.45;cursor:not-allowed}@media (pointer:coarse){.project-dropzone{display:none}.project-drag-handle:hover,.delete-button:hover,.sort-option--active,.export-trigger:hover,.focus-exit-button:hover,.app-header-button:hover{box-shadow:none;transform:none}}
