@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Sora:wght@500;600;700&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.col-1{grid-column:1}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.flex{display:flex}.hidden{display:none}.inline-flex{display:inline-flex}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.line-through{text-decoration-line:line-through}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-light:#eff6ff;--color-surface:#fff;--color-surface-subtle:#f9fafb;--color-surface-muted:#f3f4f6;--color-border:#e5e7eb;--color-border-strong:#d1d5db;--color-text:#111827;--color-text-secondary:#4b5563;--color-text-muted:#6b7280;--color-text-inverse:#fff;--color-success:#16a34a;--color-warning:#d97706;--color-error:#dc2626;--color-accent:#0f766e;--color-accent-soft:#ccfbf1;--color-canvas:#f6f8fc;--color-canvas-deep:#edf2f8;--color-status-todo-bg:#f3f4f6;--color-status-todo-text:#374151;--color-status-in-progress-bg:#eff6ff;--color-status-in-progress-text:#1d4ed8;--color-status-done-bg:#f0fdf4;--color-status-done-text:#15803d;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--font-family-base:"Manrope", "Segoe UI", ui-sans-serif, system-ui, sans-serif;--font-family-display:"Sora", "Segoe UI", ui-sans-serif, system-ui, sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a}*,:before,:after{box-sizing:border-box}html{font-size:106.25%;font-family:var(--font-family-base);color:var(--color-text);background:var(--color-canvas);-webkit-font-smoothing:antialiased}body{background:radial-gradient(1200px 700px at 8% -10%, #2563eb24, transparent 60%), radial-gradient(900px 500px at 90% -20%, #0f766e1f, transparent 55%), linear-gradient(180deg, var(--color-canvas), var(--color-canvas-deep));min-height:100vh;margin:0;font-weight:400}#root{min-height:100vh}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:2px}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{min-height:100vh;padding:var(--spacing-lg);background:0 0;justify-content:center;align-items:center;display:flex}.auth-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--color-border);padding:var(--spacing-xl);background:#ffffffeb;border-radius:1rem;width:100%;max-width:400px;box-shadow:0 18px 45px #0f172a1f}.auth-title{font-family:var(--font-family-display);font-size:var(--font-size-2xl);letter-spacing:-.02em;margin:0 0 var(--spacing-lg);color:var(--color-text);font-weight:600}.auth-form{gap:var(--spacing-sm);flex-direction:column;display:flex}.auth-form label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-sm);font-weight:500}.auth-form input{border:1px solid var(--color-border-strong);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-surface);outline:none;padding:.5rem .75rem;transition:border-color .15s}.auth-form input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.auth-error{font-size:var(--font-size-sm);color:var(--color-error);margin:0}.auth-error p{margin:0}.auth-error-list{margin:.375rem 0 0;padding-left:1.125rem}.auth-footer{margin:var(--spacing-md) 0 0;font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.auth-footer a{color:var(--color-primary);text-decoration:none}.auth-footer a:hover{text-decoration:underline}.btn{border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.375rem;padding:.5rem 1rem;font-weight:500;transition:background .15s,border-color .15s,opacity .15s,transform .15s,box-shadow .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:var(--color-text-inverse);margin-top:var(--spacing-md);box-shadow:0 8px 18px #2563eb40}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 22px #2563eb4d}.btn-secondary{background:var(--color-surface-muted);color:var(--color-text);border-color:var(--color-border-strong)}.btn-secondary:hover:not(:disabled){background:var(--color-border)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-surface-subtle)}.btn-danger{background:var(--color-error);color:var(--color-text-inverse)}.btn-danger:hover:not(:disabled){background:#b91c1c}button:focus-visible,input:focus-visible,.task-title-btn:focus-visible,.task-menu-trigger:focus-visible,.task-icon-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@keyframes enter-up{0%{opacity:0;translate:0 8px}to{opacity:1;translate:0}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.task-row{border-radius:var(--radius-sm);align-items:center;gap:.75rem;transition:background .12s,border-color .12s,box-shadow .12s;display:flex}.task-row.todo-card{border-radius:var(--radius-md);box-shadow:none;background:#ffffffbf;border:none;border-bottom:1px solid #94a3b826;margin-bottom:2px;padding:.625rem 1rem}.task-row.todo-card.is-done{opacity:.88}.task-row:hover{z-index:1;background:#fffffff5;box-shadow:0 2px 10px #0f172a12}.task-row:last-child:not(.todo-card){border-bottom:none}.task-drag-handle{cursor:grab;width:16px;height:20px;color:var(--color-text-muted,#94a3b8);opacity:0;touch-action:none;-webkit-user-select:none;user-select:none;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:opacity .15s;display:flex}.task-row:hover .task-drag-handle,.task-drag-handle:focus-visible{opacity:1}.task-drag-handle:active{cursor:grabbing}.task-row.is-placeholder{border:2px dashed var(--color-border,#e2e8f0);border-radius:var(--radius-md);opacity:.5;pointer-events:none;background:0 0}.task-row.is-placeholder>*{visibility:hidden}.task-row.is-dragging{box-shadow:0 12px 32px #0f172a38, 0 4px 12px #0f172a1f, inset 0 0 0 2px var(--color-primary);border-color:var(--color-primary);opacity:1;transform-origin:50%;cursor:grabbing;z-index:999;scale:1.025}.task-checkbox{border:2px solid var(--color-text-muted,#64748b);border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.task-checkbox{border:2px solid color-mix(in srgb, var(--color-text-muted,#64748b) 82%, #000 18%)}}.task-checkbox{color:#0000;cursor:pointer;background:0 0;flex-shrink:0;transition:border-color .18s,background-color .18s,box-shadow .18s,transform .16s,color .12s;position:relative;box-shadow:0 0 #2563eb00}.task-checkbox-tooltip{min-width:160px;color:var(--color-text);text-align:left;white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;z-index:20;background:#f0f9fff5;border:1px solid #93c5fd4d;border-radius:10px;padding:.6rem .8rem;font-size:13px;line-height:1.5;transition:opacity .15s,visibility .15s;position:fixed;box-shadow:0 10px 22px #0f172a1f}.task-checkbox-tooltip span{display:block}.task-checkbox-tooltip span:first-child{color:var(--color-text);font-weight:700}.task-checkbox-tooltip span:last-child{color:var(--color-text-secondary);margin-top:6px;font-weight:500}.task-checkbox-tooltip-visible{opacity:1;visibility:visible}.task-checkbox.todo-checkbox-btn{width:22px;height:22px}.task-checkbox-mark{opacity:0;font-size:13px;line-height:1;transition:opacity .14s,transform .16s cubic-bezier(.22,1,.36,1);transform:scale(.45)}.task-row:hover .task-checkbox,.task-checkbox:hover{border-color:var(--color-primary)}@supports (color:color-mix(in lab, red, red)){.task-row:hover .task-checkbox,.task-checkbox:hover{border-color:color-mix(in srgb, var(--color-primary) 78%, #1e3a8a 22%)}}.task-row:hover .task-checkbox,.task-checkbox:hover{background:var(--color-primary)}@supports (color:color-mix(in lab, red, red)){.task-row:hover .task-checkbox,.task-checkbox:hover{background:color-mix(in srgb, var(--color-primary) 10%, white 90%)}}.task-row:hover .task-checkbox,.task-checkbox:hover{color:var(--color-primary)}@supports (color:color-mix(in lab, red, red)){.task-row:hover .task-checkbox,.task-checkbox:hover{color:color-mix(in srgb, var(--color-primary) 86%, #0f172a 14%)}}.task-row:hover .task-checkbox .task-checkbox-mark,.task-checkbox:hover .task-checkbox-mark{opacity:.68;transform:scale(.82)}.task-checkbox:active{transform:scale(.88)}.task-checkbox.todo-checkbox-btn.is-done{border-color:var(--color-primary);background:var(--color-primary);color:var(--color-text-inverse,#fff);animation:.24s cubic-bezier(.2,.9,.2,1) task-check-pop}.task-checkbox.todo-checkbox-btn.is-done .task-checkbox-mark{opacity:1;transform:scale(1)}@keyframes task-check-pop{0%{transform:scale(.72);box-shadow:0 0 #2563eb47}58%{transform:scale(1.08);box-shadow:0 0 0 6px #2563eb1a}to{transform:scale(1);box-shadow:0 0 #2563eb00}}.task-title-btn{text-align:left;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text);background:0 0;border:none;flex:1;padding:0;line-height:1.4}.task-icon-btn,.task-menu-trigger{cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;width:24px;font-size:1rem;line-height:1;transition:background .12s,color .12s}.task-star-btn:hover{background:#f59e0b1a;transform:scale(1.15)}.task-icon-btn:hover,.task-menu-trigger:hover{color:var(--color-text);background:#eef2ff}.task-menu-panel{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--color-border);background:#fffffffa;border-radius:.75rem;flex-direction:column;gap:.125rem;min-width:210px;padding:.25rem;animation:.12s fade-in;display:flex;box-shadow:0 18px 36px #0f172a29}.task-menu-divider{background:var(--color-border);height:1px;margin:.2rem .35rem}.task-menu-item{text-align:left;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;color:var(--color-text);background:0 0;border:none;justify-content:space-between;align-items:center;gap:.75rem;padding:.45rem .6rem;transition:background .12s,color .12s;display:flex}.task-menu-item:hover{background:var(--color-surface-subtle)}.task-menu-item.danger{color:var(--color-error)}.task-menu-item.danger:hover{background:#ef44441f}.task-menu-shortcut{font-size:var(--font-size-xs);color:var(--color-text-muted)}.task-title-btn.done{color:var(--color-text-muted);text-decoration:line-through}.task-subtask-badge{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-surface-muted);white-space:nowrap;border-radius:999px;padding:.125rem .5rem}.task-subtask-badge.all-done{color:var(--color-success);background:var(--color-status-done-bg)}.section-label{font-size:var(--font-size-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-secondary);margin:var(--spacing-lg) 0 var(--spacing-sm);font-weight:600}.page-header{align-items:baseline;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);animation:.3s both enter-up;display:flex}.view-switcher{gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);z-index:10;box-sizing:border-box;background:#fff9;border-bottom:1px solid #94a3b833;width:100%;display:flex;position:sticky;top:0}.view-switcher-tab{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:4px 4px 0 0;align-items:center;gap:4px;margin-bottom:-1px;font-weight:500;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.view-switcher-tab:hover{color:var(--color-text);background:#0000000d}.view-switcher-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.page-title{font-family:var(--font-family-display);font-size:var(--font-size-xl);letter-spacing:-.02em;color:#fff;margin:0;font-weight:600}.page-subtitle{font-size:var(--font-size-sm);color:#ffffffbf;margin:0}.page-inline-loading{font-size:var(--font-size-xs);color:#ffffffd9;align-items:center;gap:.4rem;margin-left:auto;font-weight:600;display:inline-flex}.page-content{padding:var(--spacing-lg) var(--spacing-xl) 0;background:inherit;box-sizing:border-box;flex-direction:column;flex:1;width:100%;max-width:100%;min-height:0;display:flex;position:relative;overflow:hidden}.page-content--with-add-bar:after{content:"";height:calc(4.85rem + var(--spacing-md) - 10px);-webkit-backdrop-filter:blur(12px)saturate(1.15);box-shadow:none;pointer-events:none;z-index:11;background:#7a9dbeb3;position:absolute;bottom:0;left:0;right:6px}.task-content-scroll{scrollbar-gutter:stable;min-height:0;margin-right:calc(-1 * var(--spacing-xl));padding-right:var(--spacing-xl);padding-bottom:calc(5rem + var(--spacing-xl));flex:1;overflow:hidden auto}.task-content-scroll .task-list{padding-bottom:var(--spacing-xs)}.state-loading-wrap{padding:var(--spacing-xl);text-align:center;place-items:center;min-height:180px;display:grid}.state-shell{text-align:center;background:linear-gradient(#ffffffb3,#ffffffeb);border:1px dashed #94a3b880;border-radius:.9rem;flex-direction:column;align-items:center;gap:.75rem;padding:2.5rem 1rem;display:flex}.state-empty{animation:.18s fade-in}.state-error{background:linear-gradient(#fef2f2b3,#fffffff2);border-color:#ef444466}.state-title{font-weight:700;font-size:var(--font-size-base);margin:0}.state-title-error{color:var(--color-error)}.state-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.state-description-strong{color:var(--color-text);opacity:.88}.state-action-btn{margin-top:.25rem}.spinner-wrap{display:inline-flex}.spinner-icon{color:var(--color-primary);animation:.8s linear infinite spin}.add-task-bar{border-radius:var(--radius-md);cursor:text;min-height:3.25rem;left:var(--spacing-xl);right:var(--spacing-xl);bottom:var(--spacing-md);z-index:12;background:#fffffffa;border:none;outline:1px solid #94a3b847;align-items:center;gap:.625rem;margin:0;padding:.8rem 1.15rem;transition:background .15s,box-shadow .15s,outline-color .15s;display:flex;position:absolute;box-shadow:0 8px 18px #0f172a24}.task-list{padding-bottom:var(--spacing-xs)}.add-task-bar:focus-within{outline:1.5px solid var(--color-primary);background:#fff;box-shadow:0 10px 22px #0f172a29}.add-task-bar input:focus-visible{outline:none}.add-task-icon{color:var(--color-primary);flex-shrink:0;font-size:1.25rem;font-weight:500;line-height:1}.add-task-input{font-size:var(--font-size-sm);color:var(--color-text);background:0 0;border:none;outline:none;flex:1;padding:.25rem 0}.add-task-input::placeholder{color:var(--color-text-muted)}.add-task-input:focus{box-shadow:none}.btn-add-task{font-size:var(--font-size-xs);border-radius:var(--radius-sm);margin-top:0;padding:.3rem .75rem}.layout-shell{gap:.75rem;height:100vh;padding:.75rem;display:flex;overflow:hidden}.layout-sidebar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:304px;padding:var(--spacing-md);gap:var(--spacing-sm);will-change:transform;isolation:isolate;background:#ffffffe0;border:1px solid #94a3b84d;border-radius:1rem;flex-direction:column;flex-shrink:0;display:flex;overflow:hidden;transform:translateZ(0);box-shadow:0 12px 28px #0f172a14}.layout-sidebar-top{flex-direction:column;gap:.9rem;display:flex}.layout-brand{font-family:var(--font-family-display);letter-spacing:-.02em;color:#0f172a;margin-bottom:.15rem;font-size:1.3rem;font-weight:700}.layout-sidebar-main{flex-direction:column;flex:1;gap:.125rem;min-height:0;padding-right:.125rem;display:flex;overflow-y:auto}.layout-sidebar-bottom{padding-top:var(--spacing-md);border-top:1px solid var(--color-border);flex-direction:column;flex-shrink:0;gap:.85rem;margin-top:0;display:flex}.layout-section-label{margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:700}.layout-project-row{flex-direction:column;gap:.125rem;display:flex}.layout-subview-list{flex-direction:column;gap:.125rem;padding-left:.75rem;display:flex}.layout-add-project-bar{border-radius:var(--radius-md);cursor:text;background:#ffffffbf;border-top:1px solid #94a3b82e;align-items:center;gap:.625rem;padding:.75rem 1rem;transition:border-color .15s,box-shadow .15s,background .15s;display:flex}.layout-add-project-bar:focus-within{outline:1px solid var(--color-primary);background:#ffffffe6}.layout-add-project-icon{color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;width:1.25rem;height:1.25rem;font-size:1.25rem;font-weight:500;line-height:1;display:inline-flex}.layout-add-project-input{font-size:var(--font-size-sm);color:var(--color-text);background:0 0;border:none;outline:none;flex:1;padding:.25rem 0}.layout-add-project-input::placeholder{color:var(--color-text-muted)}.layout-add-project-input:disabled{cursor:wait}.layout-add-project-input:focus-visible{outline:none}.layout-user-panel{align-items:center;gap:.75rem;display:flex}.layout-user-panel-top{cursor:pointer;color:var(--color-text);border-top:none;margin-top:0;padding:.25rem 0;transition:opacity .14s,color .14s}.layout-user-panel-top:hover{color:var(--color-primary-hover)}.layout-user-avatar{color:#0f172a;background:linear-gradient(135deg,#2563eb24,#0f766e1f);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:.95rem;font-weight:800;display:inline-flex}.layout-user-copy{flex-direction:column;gap:.12rem;min-width:0;display:flex}.layout-user-trigger{min-width:0;min-height:2.25rem;color:var(--color-text);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;gap:.15rem;padding:.125rem 0;transition:color .12s,opacity .12s;display:flex;overflow:hidden}.layout-user-trigger:hover{color:var(--color-primary-hover)}.layout-user-name,.layout-user-meta{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.layout-user-name{font-size:var(--font-size-sm);font-weight:600;line-height:1.2}.layout-user-meta{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:500;line-height:1.2}.layout-user-panel-top:hover .layout-user-meta{color:var(--color-text-secondary)}.settings-overlay{z-index:1200;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a6b;place-items:center;padding:1.5rem;display:grid;position:fixed;inset:0}.settings-dialog{background:#fff;border:1px solid #94a3b84d;border-radius:1.25rem;flex-direction:column;gap:1.25rem;width:min(520px,100%);padding:1.5rem 1.75rem;display:flex;box-shadow:0 24px 48px #0f172a2e}.settings-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding-bottom:1rem;display:flex}.settings-title{color:var(--color-text);font-family:var(--font-family-display);font-size:var(--font-size-lg);letter-spacing:-.01em;margin:0;font-weight:700}.settings-subtitle{color:var(--color-text-muted);font-size:var(--font-size-sm);margin:.3rem 0 0}.settings-close{border:1px solid var(--color-border);background:var(--color-surface);width:2rem;height:2rem;color:var(--color-text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;transition:background .15s,color .15s,border-color .15s;display:flex}.settings-close:hover{background:var(--color-surface-hover);border-color:var(--color-border-strong);color:var(--color-text)}.settings-section{flex-direction:column;gap:.7rem;display:flex}.settings-section-title{color:var(--color-text-secondary);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);margin:0;padding-bottom:.5rem;font-weight:700}.settings-kv{justify-content:space-between;align-items:center;gap:1rem;padding:.35rem 0;display:flex}.settings-kv-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);flex-shrink:0;font-weight:500}.settings-kv-value{color:var(--color-text);font-size:var(--font-size-sm);text-align:right;text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.settings-field-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.settings-field{flex-direction:column;gap:.35rem;display:flex}.settings-form{flex-direction:column;gap:.75rem;display:flex}.settings-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600}.settings-form input,.settings-select{border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:var(--font-size-sm);outline:none;padding:.5rem .7rem;transition:border-color .15s,box-shadow .15s}.settings-form input:focus,.settings-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.settings-errors{border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fecaca;padding:.55rem .7rem}.settings-errors p{color:var(--color-error);font-size:var(--font-size-sm);margin:0}.settings-errors p+p{margin-top:.25rem}.settings-success{color:#166534;border-radius:var(--radius-sm);font-size:var(--font-size-sm);background:#f0fdf4;border:1px solid #bbf7d0;margin:0;padding:.55rem .7rem}.settings-actions{justify-content:flex-end;padding-top:.25rem;display:flex}.logout-confirm-overlay{z-index:1300;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a73;place-items:center;display:grid;position:fixed;inset:0}.logout-confirm-dialog{background:#fff;border:1px solid #94a3b84d;border-radius:1rem;flex-direction:column;gap:.75rem;width:min(380px,100vw - 2rem);padding:1.75rem;display:flex;box-shadow:0 20px 40px #0f172a2e}.logout-confirm-title{font-size:var(--font-size-lg);color:var(--color-text);margin:0;font-weight:700}.logout-confirm-message{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;line-height:1.6}.logout-confirm-actions{justify-content:flex-end;gap:.6rem;padding-top:.5rem;display:flex}.layout-signout-btn{width:100%;min-height:2.25rem;color:var(--color-text-muted);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;opacity:.82;background:0 0;border:none;flex-shrink:0;justify-content:flex-start;align-items:center;gap:.45rem;padding:.4rem .5rem;transition:background .15s,color .15s;display:flex}.layout-signout-btn:hover{color:#ef4444;opacity:1;background:#ef44441a}.layout-signout-btn span{font-weight:500}.layout-main{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);contain:paint;isolation:isolate;background:#7a9dbe;border:1px solid #94a3b847;border-radius:1rem;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.suggestions-panel{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);width:340px;padding:var(--spacing-md);background:#ffffffd1;border:1px solid #94a3b847;border-radius:1rem;flex-direction:column;flex-shrink:0;gap:0;display:flex;overflow-y:auto}.suggestions-header{margin-bottom:var(--spacing-sm);justify-content:space-between;align-items:center;display:flex}.suggestions-title{font-size:var(--font-size-sm);color:var(--color-text);letter-spacing:.01em;font-weight:600}.suggestions-refresh-btn{cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-sm);background:0 0;border:none;padding:.125rem .25rem;font-size:1rem;line-height:1;transition:color .15s,background .15s}.suggestions-refresh-btn:hover{color:var(--color-primary);background:var(--color-surface-subtle)}.suggestions-loading,.suggestions-empty,.suggestions-error{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center;padding:var(--spacing-md) 0}.suggestions-error{color:var(--color-error)}.suggestions-section{margin-bottom:var(--spacing-xs)}.suggestions-section-title{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:.5rem 0 .25rem;padding:0 .25rem;font-weight:600}.suggestion-item{border-radius:var(--radius-sm);cursor:default;background:linear-gradient(#fff,#fcfdff);border:1px solid #94a3b840;align-items:center;gap:.5rem;margin-bottom:.375rem;padding:.5rem;transition:background .14s,border-color .14s,transform .14s,box-shadow .14s;display:flex;box-shadow:0 2px 6px #0f172a0a}.suggestion-item:hover{background:#fff;border-color:#2563eb38;transform:translateY(-1px);box-shadow:0 6px 16px #0f172a14}.suggestion-item.is-done{opacity:.82}.suggestion-checkbox{border:1.5px solid var(--color-border-strong);color:#0000;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:.6rem;font-weight:700;line-height:1;display:flex}.suggestion-item-body{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.suggestion-item-title{font-size:var(--font-size-sm);color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-weight:500;line-height:1.35;overflow:hidden}.suggestion-item-title.is-done{color:var(--color-text-secondary);text-decoration:line-through}.suggestion-item-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.suggestion-add-btn{cursor:pointer;width:22px;height:22px;color:var(--color-text-muted);opacity:0;background:0 0;border:1.5px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:opacity .15s,background .15s,color .15s,border-color .15s;display:flex}.suggestion-item:hover .suggestion-add-btn{opacity:1}.suggestion-add-btn:hover:not(:disabled){background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.suggestion-add-btn:focus-visible{opacity:1;outline:2px solid var(--color-primary);outline-offset:1px}.suggestion-add-btn:disabled{opacity:.5;cursor:default}.nav-item{text-align:left;border-radius:var(--radius-sm);cursor:pointer;width:100%;font-size:var(--font-size-sm);color:#000;-webkit-font-smoothing:antialiased;background:0 0;border:none;border-left:3px solid #0000;justify-content:space-between;align-items:center;gap:.75rem;padding:.375rem .625rem .375rem calc(.625rem - 3px);font-weight:500;transition:background .14s,color .14s,border-left-color .14s;display:flex}.nav-item-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.nav-item-count{text-align:right;font-variant-numeric:tabular-nums lining-nums;letter-spacing:.01em;color:#000;flex-shrink:0;min-width:1.6rem;font-family:Segoe UI Variable Text,Segoe UI,Helvetica Neue,Arial,sans-serif;font-size:.82rem;font-weight:600;line-height:1.1}.nav-item-count.active{color:#000}.nav-item:hover{color:#000;background:#2563eb0f}.nav-item.active{background:var(--color-primary-light);border-left-color:var(--color-primary);color:#000;font-weight:500}.nav-context-menu{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fffffffa;flex-direction:column;min-width:160px;padding:.25rem;display:flex;box-shadow:0 16px 34px #0f172a2e}@media (width<=900px){.layout-shell{gap:.5rem;padding:.5rem}.layout-sidebar{width:244px;padding:.75rem}.layout-main{border-radius:.75rem}.suggestions-panel{display:none}.page-header{flex-direction:column;align-items:flex-start;gap:.25rem}}.myday-date{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.myday-row{border-bottom:1px solid var(--color-border);border-radius:var(--radius-sm);align-items:center;gap:.75rem;padding:.625rem .5rem;transition:background .1s;display:flex}.myday-row:last-child{border-bottom:none}.myday-row:hover{background:var(--color-surface-subtle)}.myday-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-chip{font-size:var(--font-size-xs);white-space:nowrap;border-radius:999px;align-items:center;padding:.125rem .5rem;font-weight:500;display:inline-flex}.status-chip.TODO{background:var(--color-status-todo-bg);color:var(--color-status-todo-text)}.status-chip.IN_PROGRESS{background:var(--color-status-in-progress-bg);color:var(--color-status-in-progress-text)}.status-chip.DONE{background:var(--color-status-done-bg);color:var(--color-status-done-text)}.kanban-board{flex:1;padding:1.5rem;overflow-x:auto}.kanban-columns-row{align-items:flex-start;gap:1rem;min-height:400px;display:flex}.kanban-column{background:var(--color-surface-muted);border:2px solid #0000;border-radius:.75rem;flex-direction:column;flex-shrink:0;width:280px;min-height:200px;transition:border-color .15s;display:flex}.kanban-column--over{border-color:var(--color-primary)}.kanban-column-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.kanban-column-title{color:var(--color-text);font-size:.875rem;font-weight:600}.kanban-column-count{background:var(--color-border-strong);color:var(--color-text-secondary);border-radius:9999px;padding:.1rem .5rem;font-size:.75rem;font-weight:600}.kanban-column-body{flex-direction:column;flex:1;gap:.5rem;padding:.75rem;display:flex}.kanban-column-empty{color:var(--color-text-muted);text-align:center;border:2px dashed var(--color-border);border-radius:.5rem;padding:1rem 0;font-size:.8rem}.kanban-card{background:var(--color-surface);border:1px solid var(--color-border);cursor:grab;border-radius:.5rem;padding:.625rem .75rem;transition:box-shadow .15s,border-color .15s}.kanban-card:hover{border-color:var(--color-border-strong);box-shadow:0 2px 8px #00000014}.kanban-card:active{cursor:grabbing}.kanban-card--ghost{opacity:.4;box-shadow:0 4px 16px #0000001f}.kanban-card-title{color:var(--color-text);margin-bottom:.375rem;font-size:.875rem;line-height:1.4}.kanban-card-footer{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.kanban-card-status{text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}.kanban-card-subtasks{color:var(--color-text-muted);font-size:.7rem}.kanban-card-subtasks.all-done{color:var(--color-status-done-text);font-weight:600}.board-loading,.board-error{color:var(--color-text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3rem;display:flex}.gantt-container{background:var(--color-surface);flex-direction:column;flex:1;display:flex;overflow:hidden}.gantt-layout{flex:1;display:flex;overflow:hidden}.gantt-labels{border-right:2px solid var(--color-border-strong);background:var(--color-surface-subtle);z-index:1;flex-direction:column;display:flex}.gantt-corner{border-bottom:1px solid var(--color-border);background:var(--color-surface-muted)}.gantt-label-row{border:none;border-bottom:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;gap:.375rem;width:100%;padding:0 .75rem;transition:background .1s;display:flex}.gantt-label-row:hover{background:var(--color-surface-muted)}.gantt-label-text{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.8rem;overflow:hidden}.gantt-scroll{flex:1;overflow:auto}.gantt-header{background:var(--color-surface-muted);border-bottom:1px solid var(--color-border-strong)}.gantt-week-label{color:var(--color-text-secondary);white-space:nowrap;padding:0 4px;font-size:.7rem;position:absolute;top:50%;transform:translateY(-50%)}.gantt-grid{background:var(--color-surface)}.gantt-gridline{background:var(--color-border);width:1px;position:absolute;top:0}.gantt-today-line{background:var(--color-primary);opacity:.6;width:2px;position:absolute;top:0}.gantt-bar{white-space:nowrap;font-size:.72rem;box-shadow:0 1px 4px #0000001f}.gantt-bar:hover{opacity:.88}.gantt-bar-label{color:#fff;pointer-events:none;text-overflow:ellipsis;font-weight:500;overflow:hidden}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
