.navbar{position:sticky;top:0;left:0;right:0;z-index:100;height:var(--navbar-h);background:var(--navbar-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1.5px solid var(--border)}.navbar-inner{max-width:880px;margin:0 auto;padding:0 20px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:16px}.navbar-brand{display:inline-flex;align-items:baseline;gap:4px;font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--text-1);text-decoration:none;transition:opacity var(--transition)}.navbar-brand:hover{opacity:.8}.navbar-brand-accent{color:var(--accent)}.navbar-actions{display:flex;align-items:center;gap:8px}.palette-wrap{position:relative}.palette-trigger{width:auto;padding:0 10px}.palette-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:170px;padding:6px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);z-index:200;animation:palette-in var(--transition-fast) both}@keyframes palette-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.palette-label{display:block;font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);padding:6px 8px 4px}.palette-option{display:flex;align-items:center;gap:10px;width:100%;padding:7px 8px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text-2);text-align:left;transition:background var(--transition-fast),color var(--transition-fast)}.palette-option:hover{background:var(--bg-card-h);color:var(--text-1)}.palette-option.active{color:var(--text-1)}.palette-option-swatch{width:14px;height:14px;border-radius:50%;flex-shrink:0;box-shadow:0 1px 4px #0003}.palette-option-name{flex:1}.palette-option-check{width:14px;height:14px;color:var(--accent);flex-shrink:0}.icon-btn-square{width:36px;height:36px;padding:0}.storage-menu{position:relative}.storage-menu>.icon-btn{padding:0 10px;gap:8px}.storage-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}.storage-dot--ok{background:#10b981;box-shadow:0 0 6px #10b98180}.storage-dot--warn{background:#f5b730;box-shadow:0 0 6px #f5b73080}.storage-dot--muted{background:var(--text-3)}.storage-menu-panel{position:absolute;top:calc(100% + 8px);right:0;min-width:280px;max-width:320px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:14px;z-index:200;animation:fade-in var(--transition-fast) both}.storage-menu-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.storage-badge{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:var(--radius-pill)}.storage-badge--ok{background:#10b9811f;color:#10b981}.storage-badge--warn{background:#f5b7301f;color:#b98000}.storage-badge--muted{background:var(--bg-surface);color:var(--text-3)}.storage-menu-file{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--bg-surface);margin-bottom:12px}.storage-menu-filename{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.storage-menu-meta{font-size:11px;color:var(--text-3)}.storage-menu-note{margin:0 0 12px;font-size:12px;line-height:1.5;color:var(--text-2)}.storage-menu-actions{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.storage-menu-actions .btn-primary,.storage-menu-actions .btn-ghost{width:100%;height:36px}.storage-menu-hint{margin:0;font-size:11px;color:var(--text-3);line-height:1.4}.project-card{display:flex;align-items:center;gap:12px;padding:14px;margin-bottom:10px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-card);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition),background var(--transition),opacity var(--transition);position:relative;cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.project-card:active{cursor:grabbing}.project-card.is-drag-disabled,.project-card.is-drag-disabled:active{cursor:default;user-select:auto;-webkit-user-select:auto;touch-action:auto}.project-card.is-drag-disabled:hover{transform:none}.project-card:hover{transform:translateY(-1px);box-shadow:var(--shadow);border-color:var(--border-h);background:var(--bg-card-h)}.project-card.is-dragging{opacity:.35;box-shadow:none;border-style:dashed;background:var(--bg-surface)}.project-card.is-dragging:hover{transform:none}.project-card.is-drag-overlay{margin:0;cursor:grabbing;box-shadow:0 24px 44px -8px #00000047,0 10px 20px -6px #0000002e,0 0 0 1.5px var(--accent);background:var(--bg-card);border-color:var(--accent);opacity:1}.project-card__drag{display:inline-flex;align-items:center;justify-content:center;width:24px;height:32px;color:var(--text-3);flex-shrink:0;transition:color var(--transition);pointer-events:none}.project-card:hover .project-card__drag{color:var(--accent)}.project-card__drag--disabled{cursor:default;opacity:.35}.project-card__drag--disabled:hover{color:var(--text-3);background:transparent}.project-card__main{display:flex;align-items:center;gap:12px;flex:1;min-width:0;cursor:pointer;background:transparent;border:0;padding:0;text-align:left;color:inherit;font:inherit}.project-card__code{display:inline-flex;align-items:center;justify-content:center;min-width:46px;height:28px;padding:0 9px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.1em;flex-shrink:0;box-shadow:0 1px 4px #00000026}.project-card__name{flex:1;min-width:0;font-size:15px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card__status{display:inline-flex;align-items:center;height:20px;padding:0 8px;border-radius:var(--radius-pill);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.project-card__status--working{background:#3b82f624;color:#3b82f6}.project-card__status--planned{background:#f5b73029;color:#d4980f}.project-card__status--completed{background:#10b98124;color:#10b981}.project-card__priority{font-size:12px;font-weight:600;color:var(--text-3);font-variant-numeric:tabular-nums;flex-shrink:0}.project-card__progress{display:flex;align-items:center;gap:8px;width:110px;flex-shrink:0}.project-card__progress .progress{flex:1}.project-card__progress-num{font-size:11px;font-weight:600;color:var(--text-2);font-variant-numeric:tabular-nums;min-width:28px;text-align:right}.project-card__menu-wrap{position:relative;flex-shrink:0}.project-card__menu-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);color:var(--text-2);transition:background var(--transition),color var(--transition)}.project-card__menu-btn:hover{background:var(--bg-surface);color:var(--text-1)}.project-card__popover{position:absolute;top:calc(100% + 6px);right:0;min-width:140px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:6px;z-index:20;animation:fade-in var(--transition-fast) both}.project-card__popover button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text-1);transition:background var(--transition-fast),color var(--transition-fast);text-align:left}.project-card__popover button:hover{background:var(--bg-surface)}.project-card__popover button.danger{color:#e04b5d}.project-card__popover button.danger:hover{background:#e04b5d1a}@media (max-width: 520px){.project-card__progress{width:70px}.project-card__progress-num{display:none}}@media (max-width: 420px){.project-card__priority{display:none}}.add-project-modal{display:flex;flex-direction:column}.apm-field{margin-bottom:16px}.apm-field:last-of-type{margin-bottom:0}.apm-name-row{display:flex;gap:10px;align-items:flex-end}.apm-code-col{flex:0 0 96px}.apm-name-col{flex:1;min-width:0}.input-error{border-color:#f43f5e!important}.apm-error{margin:6px 0 0;font-size:12px;color:#f43f5e}.apm-code-input{font-family:var(--font-mono);font-weight:700;letter-spacing:.1em;text-align:center;text-transform:uppercase}.apm-field .label{display:flex;align-items:baseline;justify-content:space-between}.apm-completion-value{font-size:12px;font-weight:700;letter-spacing:0;text-transform:none;color:var(--text-1)}.apm-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:36px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M1 1.5l5 5 5-5'/></svg>");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}.apm-hint{margin:6px 0 0;font-size:12px;color:var(--text-3)}.apm-slider{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;padding:0;margin:6px 0 0;height:20px;cursor:pointer}.apm-slider:focus{outline:none}.apm-slider::-webkit-slider-runnable-track{height:6px;border-radius:var(--radius-pill);background:linear-gradient(to right,var(--accent) 0%,var(--accent) var(--apm-fill, 0%),var(--bg-surface) var(--apm-fill, 0%),var(--bg-surface) 100%)}.apm-slider::-moz-range-track{height:6px;border-radius:var(--radius-pill);background:var(--bg-surface)}.apm-slider::-moz-range-progress{height:6px;border-radius:var(--radius-pill);background:var(--accent)}.apm-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;margin-top:-6px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-card);box-shadow:var(--shadow-btn);cursor:pointer;transition:transform var(--transition-fast)}.apm-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-card);box-shadow:var(--shadow-btn);cursor:pointer;transition:transform var(--transition-fast)}.apm-slider:hover::-webkit-slider-thumb,.apm-slider:focus::-webkit-slider-thumb{transform:scale(1.1)}.apm-slider:hover::-moz-range-thumb,.apm-slider:focus::-moz-range-thumb{transform:scale(1.1)}.add-project-modal .btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.add-project-modal .btn-primary:disabled:hover{transform:none;background:var(--accent)}.tag-manager-list{display:flex;flex-direction:column;margin-bottom:8px}.tag-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-surface);margin-bottom:8px;transition:border-color var(--transition),background var(--transition)}.tag-row:hover{border-color:var(--border-h)}.tag-row-color{position:relative;flex-shrink:0}.tag-row-color-btn{width:22px;height:22px;border-radius:50%;padding:0;border:2px solid transparent;cursor:pointer;box-shadow:0 1px 4px #00000026;transition:transform var(--transition),border-color var(--transition)}.tag-row-color-btn:hover{transform:scale(1.08);border-color:var(--text-1)}.tag-row-color-pop{position:absolute;top:calc(100% + 8px);left:0;z-index:20;padding:10px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);animation:fade-in var(--transition-fast) both}.tag-row-color-pop .color-swatches{display:grid;grid-template-columns:repeat(5,22px);gap:8px}.tag-row-color-pop .color-swatch{width:22px;height:22px}.tag-row-input{flex:1;min-width:0;height:34px;padding:0 10px;border-radius:var(--radius-sm);border:1.5px solid transparent;background:transparent;color:var(--text-1);font-size:14px;font-weight:500;outline:none;transition:background var(--transition),border-color var(--transition)}.tag-row-input:hover{background:var(--bg-card-h)}.tag-row-input:focus{background:var(--bg-card);border-color:var(--accent)}.tag-row-delete{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:transparent;color:var(--text-2);flex-shrink:0;transition:background var(--transition),color var(--transition)}.tag-row-delete:hover{background:#f43f5e1f;color:#f43f5e}.tag-row-delete .icon{width:16px;height:16px}.tag-manager-empty{padding:16px 4px;text-align:center;color:var(--text-3);font-size:13px}.tag-manager-divider{height:1px;background:var(--border);margin:16px 0}.tag-manager-new-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.tag-manager-new-row .input{flex:1;min-width:0}.tag-manager-new-swatches{display:flex;gap:8px;flex-wrap:wrap}.tag-manager-new-swatches .color-swatch{width:22px;height:22px}.tag-manager-add-btn{display:inline-flex;align-items:center;justify-content:center;height:40px;width:40px;padding:0;border-radius:50%;background:var(--accent);color:#1a1a1a;font-weight:600;box-shadow:var(--shadow-btn);flex-shrink:0;transition:transform var(--transition),background var(--transition),box-shadow var(--transition),opacity var(--transition)}.tag-manager-add-btn:hover:not(:disabled){transform:translateY(-1px);background:var(--accent-dark)}.tag-manager-add-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.tag-manager-add-btn .icon{width:18px;height:18px}.home{display:flex;flex-direction:column;gap:12px}.home__toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.home__toolbar-spacer{flex:1}.home__count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:6px;border-radius:var(--radius-pill);background:var(--bg-surface);color:var(--text-3);font-size:11px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1}.segmented button.active .home__count{background:var(--bg-card-h);color:var(--text-2)}.home__manage{height:34px;padding:0 12px;font-size:13px;flex-shrink:0}.home__add{height:34px;padding:0 14px;font-size:13px;flex-shrink:0}.home__add .icon{width:15px;height:15px}.home__tags-row{display:flex}.home__tags{display:flex;align-items:center;gap:8px;flex:1;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:2px 0}.home__tags::-webkit-scrollbar{display:none}.home__tag-chip{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 11px;border-radius:var(--radius-pill);border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-2);font-size:12.5px;font-weight:500;white-space:nowrap;transition:background var(--transition),color var(--transition),border-color var(--transition);flex-shrink:0}.home__tag-chip:hover{border-color:var(--border-h);color:var(--text-1)}.home__tag-chip.active{background:var(--accent-soft);color:var(--accent);border-color:transparent}.home__tag-chip .color-dot{width:8px;height:8px}.home__tag-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:2px;border-radius:var(--radius-pill);background:var(--bg-surface);color:var(--text-3);font-size:10px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1}.home__tag-chip.active .home__tag-count{background:var(--bg-card);color:var(--accent)}.home__list{display:flex;flex-direction:column;margin-top:6px}.home__clear-filter{margin-top:12px;height:32px}@media (max-width: 520px){.home__add,.home__manage{padding:0 10px}}.login-root{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative;isolation:isolate}.login-root:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 0%,rgba(0,0,0,.15) 60%,rgba(0,0,0,.35) 100%);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);pointer-events:none;z-index:0}.login-wrap{position:relative;z-index:1}.login-wrap{width:min(400px,100% - 32px);display:flex;flex-direction:column;align-items:center}.login-brand-top{display:flex;align-items:baseline;justify-content:center;gap:10px;margin:0;font-size:40px;font-weight:800;color:var(--text-1);letter-spacing:-.025em;line-height:1.05}.login-brand-accent{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 4px 24px var(--accent-glow)}.login-subtitle{margin:8px 0 26px;font-size:14px;color:var(--text-3)}.login-card{width:100%;padding:34px 28px 28px;background:var(--bg-card);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-xl);box-shadow:0 50px 100px -20px #00000040,0 30px 60px -30px #0000004d,0 12px 24px -8px #0000001f,0 2px 4px #0000000f,0 0 80px -20px var(--accent-glow),inset 0 1px #fff9;display:flex;flex-direction:column;gap:24px;position:relative;overflow:hidden;transform:translateY(0);animation:login-card-in .42s cubic-bezier(.2,.7,.2,1) both}@keyframes login-card-in{0%{opacity:0;transform:translateY(18px) scale(.98);box-shadow:0 0 #0000}to{opacity:1;transform:translateY(0) scale(1)}}[data-theme=dark] .login-card{border-color:#ffffff0f;box-shadow:0 50px 100px -20px #0009,0 30px 60px -30px #0009,0 12px 24px -8px #00000059,0 2px 4px #0000004d,0 0 80px -20px var(--accent-glow),inset 0 1px #ffffff0f}.login-card:before{content:"";position:absolute;top:0;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent 0%,var(--accent) 50%,transparent 100%);opacity:.8;pointer-events:none}.lg-field{position:relative;padding-top:16px}.lg-input{width:100%;padding:10px 36px 8px 30px;border:0;background:transparent;font-size:15px;font-weight:500;color:var(--text-1);outline:none;border-radius:0;-webkit-appearance:none;caret-color:var(--accent)}.lg-input::placeholder{color:transparent}.lg-underline{position:absolute;left:0;right:0;bottom:0;height:1.5px;background:var(--border);overflow:hidden}.lg-underline:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent);transform:scaleX(0);transform-origin:center;transition:transform .26s cubic-bezier(.4,0,.2,1)}.lg-input:focus~.lg-underline:after{transform:scaleX(1)}.lg-label{position:absolute;left:30px;top:24px;font-size:15px;font-weight:500;color:var(--text-3);pointer-events:none;transform-origin:left center;transition:transform .18s cubic-bezier(.4,0,.2,1),color .18s cubic-bezier(.4,0,.2,1),letter-spacing .18s cubic-bezier(.4,0,.2,1)}.lg-input:focus~.lg-label,.lg-input:not(:placeholder-shown)~.lg-label{transform:translate(-28px,-22px) scale(.78);color:var(--accent);letter-spacing:.04em}.lg-input:not(:focus):not(:placeholder-shown)~.lg-label{color:var(--text-3)}.lg-field-icon{position:absolute;left:0;top:26px;width:18px;height:18px;color:var(--text-3);transition:color .18s ease;pointer-events:none}.lg-input:focus~.lg-field-icon,.lg-field:focus-within .lg-field-icon{color:var(--accent)}.lg-reveal{position:absolute;right:0;top:22px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text-3);transition:color .18s ease,background .18s ease;padding:0}.lg-reveal:hover{color:var(--text-1);background:var(--bg-surface)}.lg-reveal svg{width:16px;height:16px}.lg-input:-webkit-autofill,.lg-input:-webkit-autofill:hover,.lg-input:-webkit-autofill:focus{-webkit-text-fill-color:var(--text-1);-webkit-box-shadow:0 0 0 1000px var(--bg-card) inset;transition:background-color 5000s ease-in-out 0s;caret-color:var(--accent)}.lg-field--error .lg-underline{background:color-mix(in srgb,#f43f5e 45%,var(--border))}.lg-field--error .lg-underline:after{background:#f43f5e}.lg-field--error .lg-input:focus~.lg-label,.lg-field--error .lg-input:not(:placeholder-shown)~.lg-label{color:#f43f5e}.login-error{margin:-6px 0 0;font-size:13px;color:#f43f5e;padding-left:2px}.login-submit{width:100%;margin-top:8px;height:48px;font-size:15px;font-weight:700;gap:10px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);box-shadow:0 8px 24px var(--accent-glow),inset 0 1px #ffffff40;letter-spacing:.01em;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),filter .2s cubic-bezier(.4,0,.2,1)}.login-submit:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.05);box-shadow:0 14px 36px var(--accent-glow),inset 0 1px #ffffff4d}.login-submit:active:not(:disabled){transform:translateY(0);filter:brightness(.96)}.login-submit svg{width:18px;height:18px;transition:transform .22s cubic-bezier(.4,0,.2,1)}.login-submit:hover:not(:disabled) svg{transform:translate(4px)}.login-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.feature-item{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:6px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-sm);transition:background var(--transition),border-color var(--transition),box-shadow var(--transition);cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none}.feature-item:active{cursor:grabbing}.feature-item input,.feature-item .feature-item-name-input{user-select:text;-webkit-user-select:text;cursor:text}.feature-item:hover{background:var(--bg-card-h);border-color:var(--border-h)}.feature-item.is-dragging{opacity:.35;border-style:dashed;background:var(--bg-surface)}.feature-item.is-drag-overlay{margin:0;cursor:grabbing;box-shadow:0 16px 32px -6px #00000038,0 0 0 1.5px var(--accent);background:var(--bg-card);border-color:var(--accent);opacity:1}.feature-drag-handle:hover{transform:scale(1.08)}.feature-item.is-done .feature-item-name,.feature-item.is-done .feature-item-name-input{text-decoration:line-through;color:var(--text-3)}.feature-item.is-done{opacity:.7}.feature-drag-handle{display:inline-flex;align-items:center;justify-content:center;width:20px;height:22px;color:var(--text-3);transition:color var(--transition);pointer-events:none;flex-shrink:0}.feature-item:hover .feature-drag-handle{color:var(--accent)}.feature-check{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--border-h);background:transparent;color:transparent;transition:background var(--transition),border-color var(--transition),color var(--transition);flex-shrink:0}.feature-check:hover{border-color:var(--accent)}.feature-check.is-checked{background:var(--accent);border-color:var(--accent);color:#1a1a1a}.feature-check .icon{width:13px;height:13px}.feature-item-name{flex:1;min-width:0;font-size:14px;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:text;padding:2px 4px;border-radius:var(--radius-sm);transition:background var(--transition)}.feature-item-name:hover{background:var(--bg-surface)}.feature-item-name-input{flex:1;min-width:0;font-size:14px;color:var(--text-1);background:var(--bg-surface);border:1.5px solid var(--accent);border-radius:var(--radius-sm);padding:4px 8px;outline:none;font-family:inherit}.feature-priority{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--text-3);padding:2px 8px;border-radius:var(--radius-pill);background:var(--bg-surface);flex-shrink:0}.feature-edit-btn,.feature-delete-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-sm);color:var(--text-3);transition:color var(--transition),background var(--transition);flex-shrink:0}.feature-edit-btn:hover{color:var(--text-1);background:var(--bg-surface)}.feature-delete-btn:hover{color:#f43f5e;background:var(--bg-surface)}.feature-edit-btn .icon,.feature-delete-btn .icon{width:15px;height:15px}.detail-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.detail-delete-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-pill);border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-2);transition:background var(--transition),color var(--transition),border-color var(--transition)}.detail-delete-btn:hover{background:var(--bg-card-h);color:#f43f5e;border-color:#f43f5e}.detail-delete-btn .icon{width:17px;height:17px}.detail-header{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:24px;margin-bottom:28px}.detail-header-top{display:flex;align-items:center;gap:14px;margin-bottom:22px}.detail-header-dot{width:20px;height:20px;border-radius:50%;box-shadow:0 2px 8px #0003;flex-shrink:0}.detail-code-input{width:88px;flex-shrink:0;text-align:center;font-family:var(--font-mono);font-size:14px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-1);background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:6px 8px;outline:none;transition:border-color var(--transition),background var(--transition)}.detail-code-input:focus{border-color:var(--accent);background:var(--bg-card)}.detail-name-input{flex:1;min-width:0;font-family:inherit;font-size:22px;font-weight:700;color:var(--text-1);background:transparent;border:none;border-bottom:1.5px solid transparent;padding:4px 2px;outline:none;transition:border-color var(--transition),background var(--transition)}.detail-name-input:hover{border-bottom-color:var(--border)}.detail-name-input.input-error{border-bottom-color:#f43f5e}.detail-name-error{margin:4px 0 0 100px;font-size:12px;color:#f43f5e}.detail-name-input:focus{border-bottom-color:var(--accent)}.detail-fields{display:grid;grid-template-columns:1fr 1fr;gap:20px}.detail-field{display:flex;flex-direction:column;gap:8px}.detail-field-full{grid-column:1 / -1}@media (max-width: 560px){.detail-fields{grid-template-columns:1fr}}.tag-dropdown{position:relative}.tag-dropdown-btn{display:inline-flex;align-items:center;justify-content:space-between;gap:8px;width:100%;height:40px;padding:0 14px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-surface);color:var(--text-1);font-size:14px;transition:border-color var(--transition),background var(--transition)}.tag-dropdown-btn:hover{border-color:var(--border-h)}.tag-dropdown-btn.is-open{border-color:var(--accent);background:var(--bg-card)}.tag-dropdown-btn-left{display:inline-flex;align-items:center;gap:8px;min-width:0;overflow:hidden}.tag-dropdown-btn-left span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tag-dropdown-chevron{width:16px;height:16px;color:var(--text-3);transition:transform var(--transition);flex-shrink:0}.tag-dropdown-btn.is-open .tag-dropdown-chevron{transform:rotate(180deg)}.tag-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:20;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:6px;max-height:240px;overflow-y:auto;animation:fade-in .12s both}.tag-dropdown-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;color:var(--text-1);text-align:left;transition:background var(--transition)}.tag-dropdown-option:hover{background:var(--bg-card-h)}.tag-dropdown-option.is-active{background:var(--accent-soft);color:var(--text-1)}.tag-dropdown-option .color-dot{width:10px;height:10px}.tag-dropdown-option .option-check{margin-left:auto;width:14px;height:14px;color:var(--accent)}.completion-row{display:flex;align-items:center;gap:12px}.completion-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:linear-gradient(to right,var(--fill-color, var(--accent)) 0,var(--fill-color, var(--accent)) var(--fill-pct, 0%),var(--bg-surface) var(--fill-pct, 0%),var(--bg-surface) 100%);border-radius:var(--radius-pill);outline:none;cursor:pointer;transition:background .18s ease}.completion-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--fill-color, var(--accent));cursor:pointer;box-shadow:0 2px 8px #00000026;border:2px solid var(--bg-card);transition:transform var(--transition),background .18s ease}.completion-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.completion-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--fill-color, var(--accent));cursor:pointer;box-shadow:0 2px 8px #00000026;border:2px solid var(--bg-card);transition:transform var(--transition),background .18s ease}.completion-slider::-moz-range-thumb:hover{transform:scale(1.1)}.completion-value{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text-1);min-width:44px;text-align:right}.features-section{margin-top:4px}.features-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.features-header h2{margin:0;font-size:16px;font-weight:700;color:var(--text-1)}.features-count-pill{display:inline-flex;align-items:center;height:22px;padding:0 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;letter-spacing:.02em;background:var(--accent-soft);color:var(--accent-dark)}.features-list{display:flex;flex-direction:column}.features-empty{padding:22px 16px;text-align:center;color:var(--text-3);font-size:13px;background:var(--bg-surface);border:1.5px dashed var(--border);border-radius:var(--radius-sm);margin-bottom:8px}.add-feature-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-card);border:1.5px dashed var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition),background var(--transition)}.add-feature-row:focus-within{border-style:solid;border-color:var(--accent);background:var(--bg-card)}.add-feature-ghost{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;color:var(--text-3);flex-shrink:0}.add-feature-ghost .icon{width:16px;height:16px}.add-feature-input{flex:1;min-width:0;background:transparent;border:none;outline:none;font-size:14px;color:var(--text-1);font-family:inherit}.add-feature-input::placeholder{color:var(--text-3)}:root{--font-body: "DM Sans", "Noto Sans Khmer", "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-pill: 999px;--navbar-h: 64px;--transition: .2s cubic-bezier(.4, 0, .2, 1);--transition-fast: .14s cubic-bezier(.2, 0, .2, 1)}[data-theme=light]{--bg: #f5f5f5;--bg-surface: #efefef;--bg-card: #ffffff;--bg-card-h: #fdf8f0;--bg-warm: #fffbf4;--border: rgba(0, 0, 0, .1);--border-h: rgba(0, 0, 0, .2);--text-1: #1a1a1a;--text-2: #666666;--text-3: #aaaaaa;--shadow: 0 4px 32px rgba(0, 0, 0, .07);--shadow-card: 0 2px 16px rgba(0, 0, 0, .06);--navbar-bg: rgba(255, 255, 255, .9);--scrollbar: #e0e0e0;--overlay: rgba(0, 0, 0, .35)}[data-theme=dark]{--bg: #111111;--bg-surface: #1a1a1a;--bg-card: #222222;--bg-card-h: #2a2a2a;--bg-warm: #1f1a12;--border: rgba(255, 255, 255, .08);--border-h: rgba(255, 255, 255, .16);--text-1: #f2f2f2;--text-2: #a0a0a0;--text-3: #666666;--shadow: 0 4px 32px rgba(0, 0, 0, .4);--shadow-card: 0 2px 16px rgba(0, 0, 0, .3);--navbar-bg: rgba(20, 20, 20, .85);--scrollbar: #2a2a2a;--overlay: rgba(0, 0, 0, .6)}[data-palette=amber]{--accent: #f5b730;--accent-dark: #d4980f;--accent-soft: rgba(245, 183, 48, .12);--accent-glow: rgba(245, 183, 48, .3);--shadow-btn: 0 4px 16px rgba(245, 183, 48, .4);--glow-a: rgba(245, 183, 48, .35);--glow-b: rgba(232, 123, 58, .3);--glow-c: rgba(255, 220, 150, .3)}[data-palette=ocean]{--accent: #3b82f6;--accent-dark: #1d4ed8;--accent-soft: rgba(59, 130, 246, .12);--accent-glow: rgba(59, 130, 246, .3);--shadow-btn: 0 4px 16px rgba(59, 130, 246, .4);--glow-a: rgba(59, 130, 246, .35);--glow-b: rgba(139, 92, 246, .3);--glow-c: rgba(14, 165, 233, .3)}[data-palette=emerald]{--accent: #10b981;--accent-dark: #047857;--accent-soft: rgba(16, 185, 129, .12);--accent-glow: rgba(16, 185, 129, .3);--shadow-btn: 0 4px 16px rgba(16, 185, 129, .4);--glow-a: rgba(16, 185, 129, .35);--glow-b: rgba(20, 184, 166, .3);--glow-c: rgba(132, 204, 22, .3)}[data-palette=violet]{--accent: #8b5cf6;--accent-dark: #6d28d9;--accent-soft: rgba(139, 92, 246, .12);--accent-glow: rgba(139, 92, 246, .3);--shadow-btn: 0 4px 16px rgba(139, 92, 246, .4);--glow-a: rgba(139, 92, 246, .38);--glow-b: rgba(217, 70, 239, .3);--glow-c: rgba(99, 102, 241, .3)}[data-palette=rose]{--accent: #f43f5e;--accent-dark: #be123c;--accent-soft: rgba(244, 63, 94, .12);--accent-glow: rgba(244, 63, 94, .3);--shadow-btn: 0 4px 16px rgba(244, 63, 94, .4);--glow-a: rgba(244, 63, 94, .38);--glow-b: rgba(236, 72, 153, .3);--glow-c: rgba(249, 115, 22, .28)}[data-theme=dark][data-palette=amber]{--glow-a: rgba(245, 183, 48, .22);--glow-b: rgba(232, 123, 58, .18);--glow-c: rgba(255, 220, 150, .16)}[data-theme=dark][data-palette=ocean]{--glow-a: rgba(59, 130, 246, .22);--glow-b: rgba(139, 92, 246, .18);--glow-c: rgba(14, 165, 233, .18)}[data-theme=dark][data-palette=emerald]{--glow-a: rgba(16, 185, 129, .22);--glow-b: rgba(20, 184, 166, .18);--glow-c: rgba(132, 204, 22, .16)}[data-theme=dark][data-palette=violet]{--glow-a: rgba(139, 92, 246, .25);--glow-b: rgba(217, 70, 239, .2);--glow-c: rgba(99, 102, 241, .18)}[data-theme=dark][data-palette=rose]{--glow-a: rgba(244, 63, 94, .25);--glow-b: rgba(236, 72, 153, .18);--glow-c: rgba(249, 115, 22, .18)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-body);font-size:15px;line-height:1.5;color:var(--text-1);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--transition),color var(--transition)}button{font-family:inherit;color:inherit;background:none;border:none;cursor:pointer}input,textarea,select{font-family:inherit;color:inherit}a{color:var(--accent);text-decoration:none}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}.app-shell{min-height:100vh;display:flex;flex-direction:column;position:relative;isolation:isolate}.app-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;overflow:hidden;background:var(--bg)}.app-bg:before,.app-bg:after,.app-bg>.blob{content:"";position:absolute;border-radius:50%;filter:blur(100px);will-change:transform}.app-bg:before{width:60vmax;height:60vmax;top:-15vmax;left:-15vmax;background:radial-gradient(circle,var(--glow-a) 0%,transparent 70%);animation:bg-orbit-a 38s linear infinite}.app-bg:after{width:55vmax;height:55vmax;bottom:-20vmax;right:-15vmax;background:radial-gradient(circle,var(--glow-b) 0%,transparent 70%);animation:bg-orbit-b 52s linear infinite}.app-bg>.blob{width:45vmax;height:45vmax;top:30vh;left:40vw;background:radial-gradient(circle,var(--glow-c) 0%,transparent 70%);animation:bg-orbit-c 64s linear infinite;transform:translate(-50%,-50%)}@keyframes bg-orbit-a{0%{transform:rotate(0) translate(6vmax) rotate(0)}to{transform:rotate(360deg) translate(6vmax) rotate(-360deg)}}@keyframes bg-orbit-b{0%{transform:rotate(0) translate(10vmax) rotate(0)}to{transform:rotate(-360deg) translate(10vmax) rotate(360deg)}}@keyframes bg-orbit-c{0%{transform:translate(-50%,-50%) rotate(0) translate(8vmax) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg) translate(8vmax) rotate(-360deg)}}@media (prefers-reduced-motion: reduce){.app-bg:before,.app-bg:after,.app-bg>.blob{animation:none}}.page{flex:1;max-width:880px;width:100%;margin:0 auto;padding:calc(var(--navbar-h) + 14px) 20px 80px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 10px;border-radius:var(--radius-pill);border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-2);transition:background var(--transition),border-color var(--transition),color var(--transition);font-size:13px;font-weight:500}.icon-btn:hover{background:var(--bg-card-h);border-color:var(--accent);color:var(--text-1)}.icon-btn .icon{width:17px;height:17px;flex-shrink:0}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 18px;border-radius:var(--radius-pill);background:var(--accent);color:#1a1a1a;font-weight:600;font-size:14px;box-shadow:var(--shadow-btn);transition:transform var(--transition),box-shadow var(--transition),background var(--transition)}.btn-primary:hover{transform:translateY(-1px);background:var(--accent-dark)}.btn-primary:active{transform:translateY(0)}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 14px;border-radius:var(--radius-pill);border:1.5px solid var(--border);background:transparent;color:var(--text-2);font-weight:500;transition:background var(--transition),color var(--transition),border-color var(--transition)}.btn-ghost:hover{background:var(--bg-card-h);color:var(--text-1);border-color:var(--border-h)}.input{width:100%;height:40px;padding:0 14px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-surface);color:var(--text-1);font-size:14px;transition:border-color var(--transition),background var(--transition);outline:none}.input:focus{border-color:var(--accent);background:var(--bg-card)}.label{display:block;font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);margin-bottom:6px}.color-dot{display:inline-block;width:12px;height:12px;border-radius:50%;box-shadow:0 1px 4px #0003;flex-shrink:0}.tag-pill{display:inline-flex;align-items:center;gap:6px;height:22px;padding:0 9px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;letter-spacing:.02em;background:var(--bg-surface);color:var(--text-2);border:1px solid var(--border)}.tag-pill .color-dot{width:8px;height:8px}.progress{display:block;height:6px;width:100%;background:var(--bg-surface);border-radius:var(--radius-pill);overflow:hidden}.progress-fill{display:block;height:100%;background:var(--accent);border-radius:var(--radius-pill);transition:width var(--transition)}.empty{text-align:center;padding:60px 20px;color:var(--text-3);font-size:14px}.sr-only{position:absolute;width:1px;height:1px;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fade-in var(--transition) both}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:500;animation:fade-in .12s both}.modal{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);width:min(440px,calc(100% - 32px));padding:24px;animation:fade-in .14s both}.modal h2{margin:0 0 16px;font-size:18px;font-weight:700;color:var(--text-1)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.color-swatches{display:flex;flex-wrap:wrap;gap:8px}.color-swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform var(--transition),border-color var(--transition)}.color-swatch:hover{transform:scale(1.08)}.color-swatch.active{border-color:var(--text-1);transform:scale(1.08)}.segmented{display:inline-flex;padding:4px;background:var(--bg-surface);border-radius:var(--radius-pill);gap:2px}.segmented button{padding:6px 14px;border-radius:var(--radius-pill);font-size:13px;font-weight:500;color:var(--text-2);transition:background var(--transition),color var(--transition)}.segmented button.active{background:var(--bg-card);color:var(--text-1);box-shadow:var(--shadow-card)}.app-spinner{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:var(--bg)}.app-spinner-ring{width:24px;height:24px;border-radius:50%;border:2.5px solid var(--border);border-top-color:var(--accent);animation:app-spinner-rotate .8s linear infinite}@keyframes app-spinner-rotate{to{transform:rotate(360deg)}}
