*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #ffffff;--color-surface: #ffffff;--color-surface-hover: #eeeee8;--color-border: #d4d4cc;--color-text: #1a1a1a;--color-text-muted: #6b6b6b;--color-primary: #e84e1b;--color-primary-hover: #cc3d10;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--color-status-backlog: #8c8c8c;--color-status-todo: #6b9fd6;--color-status-in-progress: #2563eb;--color-status-done: #116932;--color-status-blocked: #b93a3a;--color-status-canceled: #6b6b6b;--color-priority-none: #8c8c8c;--color-priority-low: #2563eb;--color-priority-medium: #e88a1b;--color-priority-high: #e84e1b;--color-priority-urgent: #dc2626;--color-actor-human: #2563eb;--color-actor-agent: #9333ea;--color-actor-system: #8c8c8c;--color-recurrence-active: #22a050;--color-recurrence-paused: #e88a1b;--color-recurrence-failing: #dc2626;--radius: 8px;--radius-sm: 4px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--bottom-nav-clearance: calc(80px + env(safe-area-inset-bottom, 0px)) ;--bottom-nav-clearance-fab: calc(140px + env(safe-area-inset-bottom, 0px)) ;--font-size-body: .875rem;--font-size-label: .6875rem;--font-size-control: .8125rem;--font-weight-bold: 700;--font-weight-black: 900;--letter-spacing-label: .08em;--letter-spacing-control: .04em;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;color:var(--color-text);background-color:var(--color-bg);color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100dvh}h1{font-size:2rem;font-weight:900;text-transform:uppercase;letter-spacing:-.03em}h2{font-size:1.5rem;font-weight:900;text-transform:uppercase;letter-spacing:-.02em}h3{font-size:var(--font-size-control);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);color:var(--color-text-muted)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.text-muted{color:var(--color-text-muted);font-size:.875rem}.text-danger{color:var(--color-danger)}button,.btn-primary,.btn-secondary,.btn-danger,.btn-link{font-family:inherit;cursor:pointer;border:none;border-radius:var(--radius);font-size:var(--font-size-control);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-control);min-height:44px;padding:10px 20px;transition:background-color .15s,opacity .15s}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:var(--color-danger-hover)}.btn-link{background:none;color:var(--color-primary);padding:0;min-height:auto;font-weight:700;text-transform:none;letter-spacing:normal}.btn-link:hover{text-decoration:underline}.btn-small{min-height:36px;padding:6px 14px;font-size:.8125rem}.btn-full{width:100%}.btn-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-height:auto;padding:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;color:var(--color-text);cursor:pointer;transition:background-color .15s,border-color .15s;margin-bottom:var(--spacing-md)}.btn-back:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.form-group label{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-label)}input,textarea,select{width:100%;padding:10px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:inherit;font-size:1rem;min-height:44px}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #e84e1b33}textarea{resize:vertical;min-height:80px}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b6b6b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.custom-select{position:relative;width:100%}.custom-select-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:inherit;font-size:var(--font-size-control);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-control);min-height:44px;cursor:pointer;text-align:left}.custom-select-trigger:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #e84e1b33}.custom-select-arrow{font-size:1.125rem;color:var(--color-text-muted);margin-left:var(--spacing-sm);flex-shrink:0}.custom-select-menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);list-style:none;padding:var(--spacing-xs) 0;margin:0;z-index:9999;max-height:320px;overflow-y:auto;box-shadow:0 4px 16px #0000001a}.custom-select-option{padding:8px 12px;cursor:pointer;font-size:var(--font-size-control);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-control);color:var(--color-text);transition:background-color .1s}.custom-select-option:hover{background:var(--color-surface-hover)}.custom-select-option.selected{color:var(--color-primary);font-weight:600}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-actions{display:flex;gap:var(--spacing-sm);justify-content:space-between;margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);margin-left:calc(-1 * var(--spacing-lg));margin-right:calc(-1 * var(--spacing-lg));padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:50vh;color:var(--color-text-muted)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted)}.error-banner{background:#dc262614;border:1px solid var(--color-danger);border-radius:var(--radius);color:var(--color-danger);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);font-size:.875rem}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:var(--spacing-md)}.auth-card{width:100%;max-width:400px;background:var(--color-surface);border-radius:var(--radius);padding:var(--spacing-xl)}.auth-card h1{margin-bottom:var(--spacing-xs)}.auth-subtitle{color:var(--color-text-muted);margin-bottom:var(--spacing-lg)}.btn-google{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);background:#fff;color:#3c4043;border:1px solid #dadce0;font-weight:500;font-size:.9375rem;text-transform:none;letter-spacing:normal}.btn-google:hover{background:#f7f8f8}.auth-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0;color:var(--color-text-muted);font-size:.8125rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-switch{text-align:center;margin-top:var(--spacing-lg);color:var(--color-text-muted);font-size:.875rem}.onboard-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:var(--spacing-md)}.onboard-card{width:100%;max-width:480px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-md)}.onboard-logo{width:120px;height:120px}.onboard-auth-header{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.onboard-instruction{color:var(--color-text-muted);font-size:1rem;line-height:1.5}.onboard-key-block{display:flex;align-items:center;gap:var(--spacing-sm);background:#1a1a1a;color:#e0e0e0;border-radius:var(--radius);padding:var(--spacing-md);width:100%}.onboard-key-block code{flex:1;min-width:0;font-family:SF Mono,Fira Code,Fira Mono,Menlo,Consolas,monospace;font-size:.875rem;white-space:nowrap;overflow-x:auto;scrollbar-width:none;line-height:1.6;-webkit-user-select:all;user-select:all}.onboard-key-block code::-webkit-scrollbar{display:none}.onboard-warning{font-size:var(--font-size-body);font-weight:var(--font-weight-bold);color:var(--color-primary)}.onboard-steps{width:100%;text-align:left;display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.onboard-steps p{color:var(--color-text-muted);font-size:var(--font-size-body);line-height:1.6}.onboard-existing-keys{display:flex;flex-direction:column;gap:var(--spacing-xs)}.onboard-existing-key{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.onboard-key-name{font-weight:500;font-size:var(--font-size-body)}.onboard-key-prefix{font-size:.8125rem;color:var(--color-text-muted)}.header-home-link{text-decoration:none;color:inherit}.header-home-link:hover{text-decoration:none;opacity:.8}.landing{display:flex;flex-direction:column;align-items:center;min-height:100dvh;padding:var(--spacing-xl) var(--spacing-md);max-width:640px;margin:0 auto}.landing-header{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-xl);margin-bottom:var(--spacing-xl);text-align:center}.landing-logo{width:120px;height:120px}.landing-header h1{margin:0}.landing-tagline{color:var(--color-text-muted);font-size:1.125rem}.landing-hero{width:100%;display:flex;flex-direction:column;gap:var(--spacing-lg)}.landing-description{font-size:1rem;line-height:1.7;color:var(--color-text);text-align:center}.landing-screenshot{width:100%;border-radius:var(--radius);box-shadow:0 4px 24px #0000001f}.landing-agent-count{display:inline-flex;align-items:center;align-self:center;gap:6px;padding:6px 14px;border-radius:999px;background:#22a05014;font-size:.8125rem;letter-spacing:.01em}.landing-agent-count-dot{width:7px;height:7px;border-radius:50%;background:#22a050;animation:agent-pulse 2s ease-in-out infinite;flex-shrink:0}@keyframes agent-pulse{0%,to{opacity:1}50%{opacity:.4}}.landing-agent-count-number{font-weight:700;color:#22a050;line-height:1}.landing-agent-count-label{color:var(--color-text-muted)}.landing-install{display:flex;flex-direction:column;gap:var(--spacing-sm)}.landing-install h2{font-size:1.25rem}.landing-install-hint{color:var(--color-text-muted);font-size:var(--font-size-body)}.landing-code-block{display:flex;align-items:center;gap:var(--spacing-sm);background:#1a1a1a;color:#e0e0e0;border-radius:var(--radius);padding:var(--spacing-md)}.landing-code-block code{flex:1;min-width:0;font-family:SF Mono,Fira Code,Fira Mono,Menlo,Consolas,monospace;font-size:.8125rem;white-space:nowrap;overflow-x:auto;scrollbar-width:none;line-height:1.6}.landing-code-block code::-webkit-scrollbar{display:none}.landing-copy-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;min-height:auto;padding:0;background:#ffffff1a;border:none;border-radius:var(--radius-sm);color:#e0e0e0;cursor:pointer;flex-shrink:0;transition:background-color .15s;text-transform:none;letter-spacing:normal}.landing-copy-btn:hover{background:#fff3}.landing-cta{width:100%;margin-top:var(--spacing-xl)}.landing-cta .btn-primary{display:flex;align-items:center;justify-content:center;text-decoration:none;background:#c33}.landing-cta .btn-primary:hover{background:#b52d2d}.landing-footer{width:100%;margin-top:auto;padding-top:var(--spacing-lg);padding-bottom:var(--spacing-xl)}.dashboard{padding:var(--spacing-md);padding-bottom:var(--bottom-nav-clearance-fab);max-width:1200px;margin:0 auto}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.dashboard-header h1{display:flex;align-items:center;gap:var(--spacing-sm)}.header-logo{width:48px;height:48px}.header-actions{display:flex;gap:var(--spacing-sm)}.kebab-wrapper{position:relative;display:none}.kebab-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-height:auto;padding:0;background:none;border:1px solid var(--color-border);border-radius:50%;color:var(--color-text-muted);cursor:pointer;transition:background-color .15s,color .15s,border-color .15s;text-transform:none;letter-spacing:normal}.kebab-btn:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted);color:var(--color-text)}.kebab-menu{position:absolute;top:calc(100% + var(--spacing-xs));right:0;min-width:180px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 4px 16px #0000001f;padding:var(--spacing-xs) 0;z-index:200}.kebab-menu-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;border-radius:0;color:var(--color-text);font-family:inherit;font-size:var(--font-size-body);font-weight:500;text-transform:none;letter-spacing:normal;cursor:pointer;min-height:40px;transition:background-color .1s;text-align:left}.kebab-menu-item:hover{background:var(--color-surface-hover)}.kebab-menu-item svg{flex-shrink:0;color:var(--color-text-muted)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.page-header h1{margin:0}.filters-bar{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.filters-bar .custom-select{flex:1;min-width:120px}.priority-board{display:flex;flex-direction:column;gap:var(--spacing-md)}.priority-group{padding-left:var(--spacing-md);border-left:3px solid var(--color-border)}.priority-group-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.priority-group-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.priority-group-header h3{margin:0}.priority-group-count{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);color:var(--color-text-muted);background:var(--color-surface-hover);padding:1px 8px;border-radius:9999px;margin-left:var(--spacing-xs)}.priority-group-tasks{display:flex;flex-direction:column;gap:var(--spacing-sm)}.priority-group-empty{color:var(--color-text-muted);font-style:italic;font-size:var(--font-size-body);padding:var(--spacing-xs) 0}.task-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.task-card-body{display:flex;align-items:stretch;gap:var(--spacing-sm)}.task-card-content{flex:1;min-width:0}.task-card-reorder{display:flex;flex-direction:column;justify-content:center;gap:2px;flex-shrink:0}.task-card-reorder button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;min-height:auto;padding:0;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:color .15s,background-color .15s;text-transform:none;letter-spacing:normal}.task-card-reorder button:hover:not(:disabled){color:var(--color-primary);background:var(--color-surface-hover)}.task-card-reorder button:disabled{opacity:.2;cursor:not-allowed}.task-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);cursor:pointer;transition:background-color .15s,border-color .15s}.task-card:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.task-card.task-overdue{border-left:3px solid var(--color-danger)}.task-card-top{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-label);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);margin-bottom:var(--spacing-sm)}.task-card-overdue{color:var(--color-danger)}.task-card-project-pill{display:inline-block;font-size:var(--font-size-label);font-weight:var(--font-weight-bold);padding:1px 8px;border-radius:9999px;color:#fff;letter-spacing:var(--letter-spacing-label);margin-left:auto}.actor-bg-human{background:var(--color-actor-human)}.actor-bg-agent{background:var(--color-actor-agent)}.actor-bg-system{background:var(--color-actor-system)}.task-card-title{font-size:1rem;font-weight:var(--font-weight-bold);line-height:1.4}.task-card-desc{color:var(--color-text-muted);font-size:var(--font-size-body);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:2px}.task-card-due{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);margin-top:var(--spacing-xs)}.task-card-subtasks{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-xs)}.task-card-subtask-count{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);flex-shrink:0}.task-card-progress-bar{flex:1;height:4px;border-radius:2px;overflow:hidden;display:flex}.task-card-progress-segment{height:100%;transition:width .3s ease}.status-badge,.priority-badge,.overdue-badge,.project-badge{display:inline-block;font-size:var(--font-size-label);font-weight:var(--font-weight-bold);padding:2px 8px;border-radius:9999px;color:#fff;text-transform:uppercase;letter-spacing:var(--letter-spacing-control)}.overdue-badge{background:var(--color-danger)}.project-badge{background:var(--color-surface-hover);color:var(--color-text);border:1px solid var(--color-border)}.fab-backdrop{position:fixed;inset:0;background:#0003;z-index:99}.fab-dial{position:fixed;bottom:calc(64px + env(safe-area-inset-bottom,0px) + var(--spacing-md));right:var(--spacing-lg);z-index:100;width:56px;height:56px}.fab{position:relative;width:56px;height:56px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:1.75rem;line-height:1;border:none;cursor:pointer;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;justify-content:center;padding:0;min-height:auto;transition:transform .25s cubic-bezier(.4,0,.2,1),background-color .15s;z-index:2}.fab:hover{background:var(--color-primary-hover)}.fab-dial--open .fab{transform:rotate(45deg)}.fab-action{position:absolute;bottom:6px;right:6px;width:44px;height:44px;border-radius:50%;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);box-shadow:0 2px 10px #00000026;cursor:pointer;min-height:auto;padding:0;display:flex;align-items:center;justify-content:center;opacity:0;transform:translate(0) scale(0);pointer-events:none;transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .2s,background-color .15s;transition-delay:0s;z-index:1;text-transform:none;letter-spacing:normal;font-weight:400}.fab-action:hover{background:var(--color-surface-hover);border-color:var(--color-primary);color:var(--color-primary)}.fab-dial--open .fab-action{opacity:1;transform:translate(var(--x),var(--y)) scale(1);pointer-events:auto;transition-delay:var(--delay, 0s)}.fab-action[data-tooltip]:after{content:attr(data-tooltip);position:absolute;top:50%;left:50%;transform:translate(var(--tip-x, calc(-100% - 12px) ),var(--tip-y, -50%));padding:4px 10px;border-radius:var(--radius-sm);background:#1a1a1a;color:#fff;font-size:var(--font-size-label);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .1s}.fab-dial--open .fab-action[data-tooltip]:hover:after{opacity:1}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:0;overflow:hidden}.modal-content{background:var(--color-surface);border-radius:var(--radius) var(--radius) 0 0;padding:var(--spacing-lg);padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom,0px));width:100%;max-height:95dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.modal-content h2{margin-bottom:var(--spacing-md)}.modal-content--wide{max-width:720px}.priority-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.priority-modal-header h2{margin-bottom:0}.confirm-modal{max-width:400px}.confirm-modal-message{color:var(--color-text-muted);font-size:.9375rem;margin-bottom:var(--spacing-lg)}.page-container{padding:var(--spacing-md);padding-bottom:var(--bottom-nav-clearance);max-width:1200px;margin:0 auto}.task-detail{display:flex;flex-direction:column;gap:var(--spacing-lg)}.task-detail-main{display:flex;flex-direction:column;gap:var(--spacing-md)}.task-detail-top{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-label);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label)}.task-detail-overdue{color:var(--color-danger)}.task-detail-project{display:inline-flex;align-items:center;gap:var(--spacing-sm)}.task-detail-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.task-detail-header .btn-back,.task-detail-header .parent-link{flex-shrink:0;margin-bottom:0}.task-detail-header-spacer{width:40px;flex-shrink:0}.task-detail-title{flex:1;min-width:0;font-size:1.25rem;line-height:1.3;text-align:center;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.task-detail-desc{margin-bottom:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.task-detail-desc h3{margin-bottom:var(--spacing-xs)}.task-detail-desc p{color:var(--color-text-muted);font-size:var(--font-size-body);white-space:pre-wrap;line-height:1.6;margin:0}.task-detail-divider{border:none;border-top:1px solid var(--color-border);margin:var(--spacing-sm) calc(-1 * var(--spacing-md));width:calc(100% + 2 * var(--spacing-md))}.task-detail-meta{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface)}.task-detail-meta-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.task-detail-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);flex-wrap:wrap}.task-form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.task-form-header .task-form-heading{margin-bottom:0}.delete-confirm-sheet{display:flex;flex-direction:column;gap:var(--spacing-md)}.delete-confirm-message{color:var(--color-text-muted);font-size:var(--font-size-body);line-height:1.5}.delete-confirm-actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.meta-label{display:block;font-size:var(--font-size-label);font-weight:var(--font-weight-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-label)}.task-detail-meta-item>span,.task-detail-meta-item>button{font-size:var(--font-size-body);font-weight:500;line-height:1.4}.task-detail-recurrence{grid-column:1 / -1}.task-detail-recurrence-value{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.task-detail-recurrence-icon{color:var(--color-text-muted);flex-shrink:0}.task-detail-status-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:0;border:none;border-radius:0;background:none;cursor:pointer;min-height:auto;text-transform:none;letter-spacing:normal}.task-detail-status-pill{padding:3px 10px;border-radius:9999px;color:#fff;transition:opacity .15s}.task-detail-status-pill.status-backlog{background:var(--color-status-backlog)}.task-detail-status-pill.status-todo{background:var(--color-status-todo)}.task-detail-status-pill.status-in_progress{background:var(--color-status-in-progress)}.task-detail-status-pill.status-done{background:var(--color-status-done)}.task-detail-status-pill.status-blocked{background:var(--color-status-blocked)}.task-detail-status-pill.status-canceled{background:var(--color-status-canceled)}.task-detail-status-btn:hover .task-detail-status-pill{opacity:.85}.task-detail-status-icon{color:var(--color-text-muted);flex-shrink:0;transition:color .15s}.task-detail-status-btn:hover .task-detail-status-icon{color:var(--color-primary)}.status-sheet-list{display:flex;flex-direction:column}.status-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md);background:none;border:none;border-bottom:1px solid var(--color-border);border-radius:0;color:var(--color-text);font-family:inherit;font-size:1rem;font-weight:500;text-transform:uppercase;letter-spacing:var(--letter-spacing-control);cursor:pointer;min-height:48px;transition:background-color .1s}.status-option:last-child{border-bottom:none}.status-option:hover{background:var(--color-surface-hover)}.status-option--selected{color:var(--color-primary);font-weight:700}.status-option-left{display:flex;align-items:center;gap:var(--spacing-sm)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.status-backlog{background:var(--color-status-backlog)}.status-dot.status-todo{background:var(--color-status-todo)}.status-dot.status-in_progress{background:var(--color-status-in-progress)}.status-dot.status-done{background:var(--color-status-done)}.status-dot.status-blocked{background:var(--color-status-blocked)}.status-dot.status-canceled{background:var(--color-status-canceled)}.status-option-check{font-size:1.125rem;color:var(--color-primary)}.event-timeline{margin-top:var(--spacing-md)}.event-timeline h3{margin-bottom:var(--spacing-md)}.comment-sheet-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.comment-sheet-form textarea{min-height:120px}.comment-sheet-actions{display:flex;justify-content:flex-end}.events-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.events-load-more{margin-top:var(--spacing-sm);font-size:var(--font-size-body)}.event-item{border-left:3px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md)}.event-comment{border-left-color:var(--color-primary)}.event-change{border-left-color:var(--color-text-muted)}.event-header{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs);font-size:.8125rem}.actor-badge{display:inline-block;font-size:.625rem;font-weight:700;padding:1px 6px;border-radius:9999px;color:#fff;text-transform:uppercase;letter-spacing:.08em}.actor-human{background:var(--color-actor-human)}.actor-agent{background:var(--color-actor-agent)}.actor-system{background:var(--color-actor-system)}.actor-type-toggle{display:flex;gap:0;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.actor-type-toggle button{flex:1;min-height:40px;padding:8px 16px;background:var(--color-surface);color:var(--color-text);border:none;border-radius:0;font-size:var(--font-size-control);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-control);cursor:pointer;transition:background-color .15s,color .15s}.actor-type-toggle button:first-child{border-right:1px solid var(--color-border)}.actor-type-toggle button:hover:not(.active){background:var(--color-surface-hover)}.actor-type-toggle button.active{background:var(--color-primary);color:#fff}.event-type{font-weight:500;color:var(--color-text)}.event-time{color:var(--color-text-muted);font-size:.75rem}.event-content{font-size:.875rem;white-space:pre-wrap}.event-diff{display:flex;flex-direction:column;gap:2px;font-size:.8125rem}.event-diff-item{color:var(--color-text-muted)}.diff-old{color:var(--color-danger);text-decoration:line-through}.diff-new{color:var(--color-status-done)}.settings-section{margin-top:var(--spacing-lg)}.settings-section h2{margin-bottom:var(--spacing-sm)}.settings-section.collapsible{border:1px solid var(--color-border);border-radius:var(--radius);padding:0}.settings-section.collapsible>summary{list-style:none;cursor:pointer;padding:var(--spacing-md) var(--spacing-lg);display:flex;align-items:center;justify-content:space-between;-webkit-user-select:none;user-select:none}.settings-section.collapsible>summary::-webkit-details-marker{display:none}.settings-section.collapsible>summary:after{content:"";width:8px;height:8px;border-right:2px solid var(--color-text-muted);border-bottom:2px solid var(--color-text-muted);transform:rotate(-45deg);transition:transform .2s;flex-shrink:0}.settings-section.collapsible[open]>summary:after{transform:rotate(45deg)}.settings-section.collapsible>summary h2{margin-bottom:0}.settings-section.collapsible>summary:hover{background:var(--color-surface-hover)}.settings-section-content{padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg)}.key-generate{display:flex;flex-direction:column;gap:var(--spacing-sm);margin:var(--spacing-md) 0}.new-key-banner{background:#e84e1b14;border:1px solid var(--color-primary);border-radius:var(--radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.new-key-banner p{margin-bottom:var(--spacing-sm)}.key-display{display:flex;gap:var(--spacing-sm);align-items:center;background:var(--color-bg);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius);margin-bottom:var(--spacing-sm);overflow-x:auto}.key-display code{font-size:.8125rem;word-break:break-all;flex:1}.keys-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.key-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md)}.key-info{display:flex;flex-direction:column;gap:2px;min-width:0}.key-name{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:500}.key-prefix{font-size:.8125rem;color:var(--color-text-muted)}.usage-guide{margin-top:var(--spacing-xl)}.usage-guide h3{margin-bottom:var(--spacing-sm)}.profile-section{margin-top:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-lg)}.profile-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.profile-label{font-size:.6875rem;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}.usage-guide pre{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);overflow-x:auto;font-size:.8125rem;line-height:1.6;margin-top:var(--spacing-sm)}.task-form{width:100%}.form-readonly-value{font-size:var(--font-size-body);color:var(--color-text-muted);padding:10px 0}.title-locked{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;padding:var(--spacing-xs) 0}.title-locked:hover .title-locked-icon{color:var(--color-primary)}.title-locked-text{font-size:1.125rem;font-weight:700;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.title-locked-icon{flex-shrink:0;color:var(--color-text-muted);transition:color .15s}.task-form .form-field-collapsible{transition:opacity .25s,max-height .3s ease,margin .3s ease;max-height:200px;overflow:hidden;opacity:1}.task-form.desc-expanded .form-field-collapsible{max-height:0;opacity:0;margin:0;pointer-events:none}.task-form .form-field-desc textarea{transition:min-height .3s ease}.task-form.desc-expanded .form-field-desc textarea{min-height:25dvh}.task-form.date-expanded .form-field-collapsible{max-height:0;opacity:0;margin:0;pointer-events:none}.task-form.date-expanded .form-field-desc,.task-form.desc-expanded .form-field-date,.task-form.desc-expanded .form-field-project,.task-form.date-expanded .form-field-project{max-height:0;opacity:0;margin:0;overflow:hidden;pointer-events:none;transition:opacity .25s,max-height .3s ease,margin .3s ease}.task-form.project-expanded .form-field-collapsible{max-height:0;opacity:0;margin:0;pointer-events:none}.task-form.project-expanded .form-field-desc,.task-form.project-expanded .form-field-date{max-height:0;opacity:0;margin:0;overflow:hidden;pointer-events:none;transition:opacity .25s,max-height .3s ease,margin .3s ease}.projectpicker-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:inherit;font-size:.875rem;font-weight:500;text-transform:none;letter-spacing:normal;min-height:44px;cursor:pointer;text-align:left}.projectpicker-trigger:hover{border-color:var(--color-primary)}.projectpicker-trigger-icon{flex-shrink:0;color:var(--color-text-muted)}.projectpicker-panel{display:flex;flex-direction:column;gap:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);box-shadow:0 2px 8px #0000000f}.projectpicker-filter{width:100%}.projectpicker-list{display:flex;flex-direction:column;max-height:40dvh;overflow-y:auto;scrollbar-width:none}.projectpicker-list::-webkit-scrollbar{display:none}.projectpicker-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;border-bottom:1px solid var(--color-border);border-radius:0;color:var(--color-text);font-family:inherit;font-size:.9375rem;font-weight:500;text-transform:none;letter-spacing:normal;text-align:left;cursor:pointer;min-height:44px;transition:background-color .1s}.projectpicker-item-name{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:500}.projectpicker-item-desc{font-size:.8125rem;font-weight:400;color:var(--color-text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.projectpicker-item:last-child{border-bottom:none}.projectpicker-item:hover{background:var(--color-surface-hover)}.projectpicker-item--selected{color:var(--color-primary);font-weight:600}.projectpicker-empty{padding:var(--spacing-md);text-align:center;color:var(--color-text-muted);font-size:.875rem}.datepicker-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:inherit;font-size:.875rem;font-weight:500;text-transform:none;letter-spacing:normal;min-height:44px;cursor:pointer;text-align:left}.datepicker-trigger:hover{border-color:var(--color-primary)}.datepicker-trigger-icon{font-size:1rem;flex-shrink:0}.datepicker-panel{display:flex;flex-direction:column;gap:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);box-shadow:0 2px 8px #0000000f}.datepicker-presets{display:flex;gap:var(--spacing-sm)}.datepicker-preset{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-sm) var(--spacing-xs);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;min-height:auto;font-family:inherit;text-transform:none;letter-spacing:normal;transition:border-color .15s,background-color .15s}.datepicker-preset:hover{border-color:var(--color-primary);background:var(--color-surface-hover)}.datepicker-preset--selected{border-color:var(--color-primary);background:#e84e1b14}.datepicker-preset-label{font-size:.8125rem;font-weight:700;color:var(--color-text)}.datepicker-preset-date{font-size:.6875rem;color:var(--color-text-muted)}.datepicker-calendar{max-height:40dvh;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-lg);scrollbar-width:none}.datepicker-calendar::-webkit-scrollbar{display:none}.datepicker-month-label{font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--spacing-sm);color:var(--color-text)}.datepicker-weekdays,.datepicker-week{display:grid;grid-template-columns:repeat(7,1fr);text-align:center}.datepicker-weekday{font-size:.6875rem;font-weight:700;color:var(--color-text-muted);padding:var(--spacing-xs) 0}.datepicker-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.8125rem;font-weight:500;background:none;border:2px solid transparent;color:var(--color-text);cursor:pointer;padding:0;min-height:auto;text-transform:none;letter-spacing:normal;transition:background-color .1s,border-color .1s}.datepicker-day:hover:not(:disabled){background:var(--color-surface-hover)}.datepicker-day--today{border-color:var(--color-primary)}.datepicker-day--selected{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.datepicker-day--selected:hover:not(:disabled){background:var(--color-primary-hover)}.datepicker-day--past{color:var(--color-text-muted);opacity:.4;cursor:default}.datepicker-day--outside{color:var(--color-text-muted);opacity:.3}.datepicker-load-more{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:inherit;font-size:.875rem;font-weight:600;text-transform:none;letter-spacing:normal;cursor:pointer;min-height:44px;transition:background-color .15s,border-color .15s}.datepicker-load-more:hover{border-color:var(--color-primary);background:var(--color-surface-hover)}.picker-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.picker-footer .btn-link{font-size:.8125rem;color:var(--color-text-muted);text-decoration:underline}.picker-footer .btn-secondary{margin-left:auto}.done-page{padding:var(--spacing-md);padding-bottom:var(--bottom-nav-clearance);max-width:1200px;margin:0 auto}.done-timeline{display:flex;flex-direction:column;gap:var(--spacing-lg)}.done-date-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.done-date-label{margin:0}.done-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.done-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius);cursor:pointer;transition:background-color .15s}.done-item:hover{background:var(--color-surface-hover)}.done-item-status{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);flex-shrink:0;min-width:64px}.done-item-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-body);font-weight:500}.done-item-subtasks{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);color:var(--color-text-muted);flex-shrink:0;white-space:nowrap}.done-item-date{font-size:var(--font-size-label);color:var(--color-text-muted);flex-shrink:0;white-space:nowrap}.recurring-page{padding:var(--spacing-md);padding-bottom:var(--bottom-nav-clearance);max-width:1200px;margin:0 auto}.recurring-timeline{display:flex;flex-direction:column;gap:var(--spacing-lg)}.recurring-frequency-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.recurring-frequency-label{margin:0}.recurring-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.recurring-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius);cursor:pointer;transition:background-color .15s}.recurring-item:hover{background:var(--color-surface-hover)}.recurring-item-status{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);flex-shrink:0;min-width:64px}.recurring-item-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-body);font-weight:500}.recurring-item-rule{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);color:var(--color-text-muted);flex-shrink:0;white-space:nowrap}.recurring-item-project{font-size:var(--font-size-label);color:var(--color-text-muted);flex-shrink:0;white-space:nowrap}.recurring-item-subtasks{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);color:var(--color-text-muted);flex-shrink:0;white-space:nowrap}.recurring-item-last-run{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-label);color:var(--color-text-muted);flex-shrink:0;white-space:nowrap}.recurring-item-next-run{font-size:var(--font-size-label);color:var(--color-text-muted);flex-shrink:0;white-space:nowrap}.recurring-item-actions{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;margin-left:auto}.recurrence-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.recurrence-status-dot--active{background:var(--color-recurrence-active)}.recurrence-status-dot--paused{background:var(--color-recurrence-paused)}.recurrence-status-dot--failing{background:var(--color-recurrence-failing)}.recurrence-status-pill{display:inline-block;padding:3px 10px;border-radius:9999px;font-size:var(--font-size-label);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);color:#fff;cursor:pointer;border:none;background:none;min-height:auto;transition:opacity .15s}.recurrence-status-pill:hover{opacity:.85}.recurrence-status-pill--active{background:var(--color-recurrence-active)}.recurrence-status-pill--paused{background:var(--color-recurrence-paused)}.recurrence-status-pill--failing{background:var(--color-recurrence-failing)}.run-history{border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);background:var(--color-surface)}.run-history h3{margin-bottom:var(--spacing-sm)}.run-history-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.run-history-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0;font-size:var(--font-size-body);flex-wrap:wrap}.run-history-duration{font-size:var(--font-size-label);color:var(--color-text-muted)}.run-history-time{font-size:var(--font-size-label);color:var(--color-text-muted);margin-left:auto}.run-history-error{width:100%;font-size:var(--font-size-label);color:var(--color-danger);margin-top:2px}.run-outcome--success{color:var(--color-recurrence-active)}.run-outcome--failure{color:var(--color-recurrence-failing)}.run-outcome--skipped{color:var(--color-recurrence-paused)}.recurring-timeline-view{display:flex;flex-direction:column;gap:var(--spacing-md)}.recurring-timeline-header{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-sm) 0}.recurring-timeline-date{font-size:1rem;font-weight:var(--font-weight-bold);min-width:200px;text-align:center}.recurring-timeline-hour{display:flex;gap:var(--spacing-md);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border)}.recurring-timeline-hour:last-child{border-bottom:none}.recurring-timeline-hour-label{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);min-width:80px;padding-top:var(--spacing-xs);flex-shrink:0}.recurring-timeline-hour-tasks{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1}.recurring-timeline-task-card{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;transition:background-color .15s,border-color .15s}.recurring-timeline-task-card:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.recurring-timeline-task-title{font-size:var(--font-size-body);font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.view-toggle{display:flex;gap:0;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;flex-shrink:0}.view-toggle button{flex:1;min-height:40px;padding:8px 16px;background:var(--color-surface);color:var(--color-text);border:none;border-radius:0;font-size:var(--font-size-control);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-control);cursor:pointer;transition:background-color .15s,color .15s}.view-toggle button:first-child{border-right:1px solid var(--color-border)}.view-toggle button:hover:not(.active){background:var(--color-surface-hover)}.view-toggle button.active{background:var(--color-primary);color:#fff}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;min-height:auto;padding:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:background-color .15s,color .15s,border-color .15s;text-transform:none;letter-spacing:normal}.btn-icon:hover{background:var(--color-surface-hover);color:var(--color-primary);border-color:var(--color-primary)}.event-recurrence{border-left-color:var(--color-recurrence-active)}.parent-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-height:auto;padding:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;color:var(--color-text);text-decoration:none;transition:background-color .15s,border-color .15s;margin-bottom:0}.parent-link:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted);text-decoration:none}.subtask-progress-badge{display:inline-block;font-size:var(--font-size-label);font-weight:var(--font-weight-bold);background:var(--color-surface-hover);padding:1px 8px;border-radius:9999px;margin-left:var(--spacing-sm);vertical-align:middle}.subtask-section{margin-top:var(--spacing-md)}.subtask-section h3{margin-bottom:var(--spacing-sm)}.subtask-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.subtask-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius);cursor:pointer;transition:background-color .15s}.subtask-item:hover{background:var(--color-surface-hover)}.subtask-item-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.subtask-item-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.subtask-item-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-body);font-weight:500}.subtask-item-desc{font-size:var(--font-size-label);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.subtask-item-status{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label);color:var(--color-text-muted);flex-shrink:0}.subtask-closed-heading{margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm)}.subtask-item-closed{opacity:.6}.subtask-reorder{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.subtask-reorder button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;min-height:auto;padding:0;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:color .15s,background-color .15s;text-transform:none;letter-spacing:normal}.subtask-reorder button:hover:not(:disabled){color:var(--color-primary);background:var(--color-surface-hover)}.subtask-reorder button:disabled{opacity:.2;cursor:not-allowed}.subtask-add-btn{margin-top:var(--spacing-sm);background:var(--color-surface);color:var(--color-text-muted);border:1px dashed var(--color-border);border-radius:var(--radius);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-body);font-weight:500;text-transform:none;letter-spacing:normal;min-height:40px;width:100%;cursor:pointer;transition:border-color .15s,color .15s}.subtask-add-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(64px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-evenly;z-index:150}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;min-height:48px;padding:var(--spacing-xs) 0;background:none;border:none;border-radius:0;color:var(--color-text-muted);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:color .15s}.bottom-nav-item:hover{color:var(--color-text)}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-item svg{flex-shrink:0}.legal-content{line-height:1.8;font-size:.9375rem}.legal-content h2{margin-top:var(--spacing-xl);margin-bottom:var(--spacing-sm)}.legal-content h2:first-child{margin-top:0}.legal-content h3{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-xs);color:var(--color-text);font-size:.9375rem}.legal-content p{margin-bottom:var(--spacing-md);color:var(--color-text-muted)}.legal-content ul{margin-bottom:var(--spacing-md);padding-left:var(--spacing-lg);color:var(--color-text-muted)}.legal-content ul li{margin-bottom:var(--spacing-xs)}.legal-content hr{border:none;border-top:1px solid var(--color-border);margin:var(--spacing-xl) 0}.legal-updated{font-size:var(--font-size-body);font-style:italic}.profile-legal-links{display:flex;flex-direction:column;gap:var(--spacing-sm)}.landing-copyright{font-size:var(--font-size-body);color:var(--color-text-muted);text-align:center}.landing-legal{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-top:var(--spacing-md);font-size:var(--font-size-body);color:var(--color-text-muted)}.landing-legal a{color:var(--color-text-muted);text-decoration:none}.landing-legal a:hover{text-decoration:underline}.landing-legal-sep{color:var(--color-border)}.kanban-board{display:none}.kanban-column{flex:1;min-width:0;display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius)}.kanban-column-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-bottom:1px solid var(--color-border);flex-shrink:0}.kanban-column-header h3{margin:0}.kanban-column-count{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);color:var(--color-text-muted);background:var(--color-surface-hover);padding:1px 8px;border-radius:9999px;margin-left:var(--spacing-xs)}.kanban-column-body{flex:1;overflow-y:auto;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-sm);scrollbar-width:thin}.kanban-column-body::-webkit-scrollbar{width:4px}.kanban-column-body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.kanban-card{position:relative}.kanban-card .task-card,.kanban-card .task-card-title{font-size:var(--font-size-body)}.kanban-card .task-card-reorder{display:none}.kanban-card-desc{color:var(--color-text-muted);font-size:var(--font-size-body);margin-top:2px;white-space:pre-wrap;line-height:1.5}.task-card-priority{font-size:var(--font-size-label);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label)}.kanban-card-footer{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.kanban-card-archive-row{display:flex;justify-content:flex-end;margin-top:var(--spacing-sm);opacity:0;transition:opacity .15s}.kanban-card:hover .kanban-card-archive-row{opacity:1}.kanban-card-archive-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);min-height:auto;padding:4px 10px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:color .15s,background-color .15s,border-color .15s;font-size:var(--font-size-label);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-label)}.kanban-card-archive-btn:hover{color:var(--color-primary);background:var(--color-surface-hover);border-color:var(--color-primary)}.kanban-card-dragging{opacity:.4}.kanban-column-drag-over{background:#e84e1b0a;border-color:var(--color-primary);box-shadow:inset 0 0 0 1px var(--color-primary)}.archive-toggle{display:flex;align-items:center;gap:var(--spacing-sm);min-height:36px;padding:6px 14px;flex-shrink:0;font-size:var(--font-size-control);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-control);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;transition:background-color .15s,border-color .15s,color .15s}.archive-toggle:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.archive-toggle.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.archived-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.archived-card{display:flex;align-items:center;gap:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--spacing-md);cursor:pointer;transition:background-color .15s}.archived-card:hover{background:var(--color-surface-hover)}.archived-card-content{flex:1;min-width:0}.archived-card-title{font-weight:var(--font-weight-bold);font-size:var(--font-size-body)}.archived-card-meta{font-size:var(--font-size-label);color:var(--color-text-muted);margin-top:2px}.archived-card-unarchive{display:flex;align-items:center;justify-content:center;min-height:36px;padding:6px 14px;font-size:var(--font-size-control);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-control);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);cursor:pointer;flex-shrink:0;transition:background-color .15s,color .15s}.archived-card-unarchive:hover{background:var(--color-surface-hover);color:var(--color-primary)}.desktop-only{display:none}@media(min-width:1280px){h1{font-size:2.5rem}h2{font-size:1.75rem}.dashboard,.done-page,.recurring-page{padding:var(--spacing-xl)}.modal-overlay{align-items:center;padding:var(--spacing-lg)}.modal-content{max-width:560px;border-radius:var(--radius)}.task-detail{flex-direction:row}.task-detail-main{flex:2}.task-detail-sidebar{flex:1;min-width:300px}.key-generate{flex-direction:row;align-items:flex-end}.key-generate input{flex:1}.page-container{padding:var(--spacing-xl);max-width:1600px}.fab-dial{bottom:var(--spacing-xl);right:var(--spacing-xl)}.fab-action.desktop-only{display:flex}.mobile-only{display:none}.desktop-only{display:block}.filters-bar.desktop-only{display:flex;align-items:center}.filter-pills.desktop-only{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.filter-pill{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);color:var(--color-text-muted);font-size:.85rem;cursor:pointer;transition:all .15s ease;white-space:nowrap}.filter-pill:hover{border-color:var(--color-text-muted);color:var(--color-text)}.filter-pill--active{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.filter-pill--active:hover{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text);opacity:.9}.filter-pill--add{border-style:dashed}.bottom-nav{display:none}.kebab-wrapper{display:block}.kanban-board{display:flex;gap:var(--spacing-md);align-items:stretch;min-height:calc(100dvh - 220px)}.dashboard{max-width:1600px}.recurring-timeline-hour{display:grid;grid-template-columns:100px 1fr;gap:var(--spacing-lg)}.recurring-timeline-hour-tasks{flex-direction:row;flex-wrap:wrap}.recurring-timeline-task-card{max-width:320px}}
