*,*: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: #2563eb;--color-status-in-progress: #e84e1b;--color-status-done: #16a34a;--color-status-canceled: #dc2626;--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;--radius: 8px;--radius-sm: 4px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--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-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-footer{width:100%;margin-top:var(--spacing-xl);padding-bottom:var(--spacing-xl)}.landing-footer .btn-primary{display:block;text-align:center;text-decoration:none}.dashboard{padding:var(--spacing-md);padding-bottom:140px;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)}.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-xs)}.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)}.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{position:fixed;bottom:calc(64px + env(safe-area-inset-bottom,0px) + var(--spacing-md));right:var(--spacing-lg);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;z-index:100;padding:0;min-height:auto}.fab:hover{background:var(--color-primary-hover);transform:scale(1.05)}.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)}.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:100px;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-title{font-size:1.5rem;line-height:1.2}.task-detail-desc{color:var(--color-text-muted);font-size:var(--font-size-body);white-space:pre-wrap;line-height:1.6}.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-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-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-canceled{background:var(--color-status-canceled)}.status-option-check{font-size:1.125rem;color:var(--color-primary)}.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:50dvh}.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:100px;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-date{font-size:var(--font-size-label);color:var(--color-text-muted);flex-shrink:0;white-space:nowrap}.parent-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-body);font-weight:500;color:var(--color-text-muted);text-decoration:none;margin-bottom:var(--spacing-md)}.parent-link:hover{color:var(--color-primary);text-decoration:none}.parent-link svg{flex-shrink:0}.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}@media(min-width:768px){h1{font-size:2.5rem}h2{font-size:1.75rem}.dashboard,.done-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)}.fab{bottom:calc(64px + env(safe-area-inset-bottom,0px) + var(--spacing-lg));right:var(--spacing-xl)}}
