:root{--bone-0: oklch(99% .004 240);--bone-50: oklch(97.5% .005 240);--bone-100: oklch(95% .006 240);--bone-200: oklch(91% .008 240);--bone-300: oklch(84% .01 240);--bone-400: oklch(68% .012 240);--bone-500: oklch(52% .014 240);--bone-700: oklch(26% .018 240);--bone-900: oklch(12% .012 240);--cobalt: oklch(55% .17 255);--cobalt-soft: oklch(92% .04 255);--cobalt-ink: oklch(35% .15 255);--amber: oklch(72% .15 65);--amber-soft: oklch(94% .05 75);--amber-ink: oklch(48% .13 55);--sage: oklch(70% .09 160);--sage-soft: oklch(94% .03 160);--sage-ink: oklch(42% .09 160);--rose: oklch(68% .15 15);--yellow: oklch(80% .16 88);--violet: oklch(58% .18 295);--sky: oklch(60% .15 230);--sand: oklch(74% .08 80);--bg: var(--bone-50);--surface: #ffffff;--surface-2: var(--bone-100);--ink: var(--bone-900);--ink-2: var(--bone-700);--ink-3: var(--bone-500);--ink-4: var(--bone-400);--hairline: var(--bone-200);--hairline-strong: var(--bone-300);--accent: var(--cobalt);--accent-soft: var(--cobalt-soft);--accent-ink: var(--cobalt-ink);--r-2: 6px;--r-3: 10px;--r-4: 14px;--r-pill: 999px;--shadow-1: 0 1px 0 rgba(16, 24, 40, .03), 0 1px 2px rgba(16, 24, 40, .04);--shadow-2: 0 1px 0 rgba(16, 24, 40, .04), 0 6px 16px -6px rgba(16, 24, 40, .08), 0 2px 4px -2px rgba(16, 24, 40, .06);--shadow-3: 0 2px 0 rgba(16, 24, 40, .04), 0 20px 40px -12px rgba(16, 24, 40, .18), 0 8px 16px -8px rgba(16, 24, 40, .08);--font-ui: "Inter Tight", ui-sans-serif, system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace}html[data-theme=dark]{--bg: oklch(14% .012 240);--surface: oklch(18% .014 240);--surface-2: oklch(22% .014 240);--ink: oklch(97% .004 240);--ink-2: oklch(88% .006 240);--ink-3: oklch(70% .01 240);--ink-4: oklch(55% .012 240);--hairline: oklch(26% .014 240);--hairline-strong: oklch(34% .016 240);--accent: oklch(72% .15 255);--accent-soft: oklch(28% .08 255);--accent-ink: oklch(88% .09 255);--amber: oklch(80% .14 70);--amber-soft: oklch(32% .08 65);--amber-ink: oklch(88% .1 75);--sage: oklch(76% .09 160);--sage-soft: oklch(28% .05 160);--sage-ink: oklch(86% .08 160);--yellow: oklch(84% .15 90);--sky: oklch(68% .14 230);--violet: oklch(68% .17 295);--shadow-1: 0 1px 0 rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.35);--shadow-3: 0 2px 0 rgba(0,0,0,.5), 0 24px 48px -12px rgba(0,0,0,.6)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:var(--font-ui);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;letter-spacing:-.01em;min-height:100vh;position:relative;overflow-x:hidden}body:before,body:after{content:"";position:fixed;z-index:0;pointer-events:none;border-radius:50%;filter:blur(120px);opacity:.55}body:before{width:620px;height:620px;top:-240px;right:-160px;background:radial-gradient(circle,var(--cobalt-soft),transparent 70%)}body:after{width:520px;height:520px;bottom:-200px;left:-140px;background:radial-gradient(circle,var(--amber-soft),transparent 70%)}html[data-theme=dark] body:before,html[data-theme=dark] body:after{opacity:.28}.mono{font-family:var(--font-mono)}.app-wrap{position:relative;z-index:1;min-height:100vh;box-sizing:border-box;padding:10vh 10vw;display:flex;flex-direction:column}.app-frame{flex:1;display:flex;flex-direction:column;border:1px solid var(--hairline);border-radius:var(--r-4);overflow:hidden;background:var(--surface);box-shadow:var(--shadow-3)}.app-chrome{padding:12px 16px;border-bottom:1px solid var(--hairline);background:var(--surface-2);display:flex;align-items:center;gap:12px;font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.app-chrome .dots{display:flex;gap:6px}.app-chrome .dots i{width:10px;height:10px;border-radius:50%;background:var(--hairline-strong);display:block}.app-chrome .url{padding:4px 10px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-pill)}.app-chrome .theme-btn{margin-left:auto;padding:4px 10px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-pill);font-family:var(--font-mono);font-size:11px;color:var(--ink-3);cursor:pointer}.app-chrome .theme-btn:hover{color:var(--ink);border-color:var(--hairline-strong)}.app-body{display:grid;grid-template-columns:240px 1fr;flex:1}.sb{border-right:1px solid var(--hairline);padding:20px 16px;display:flex;flex-direction:column;gap:20px;background:color-mix(in oklch,var(--bg) 50%,var(--surface))}.sb-brand{display:flex;align-items:center;gap:10px;padding:0 8px 16px;border-bottom:1px solid var(--hairline)}.sb-brand .m{width:22px;height:22px;border-radius:5px;background:var(--ink);position:relative}.sb-brand .m:after{content:"";position:absolute;top:4px;right:5px;bottom:5px;left:5px;border-left:1.5px solid var(--surface);border-bottom:1.5px solid var(--surface);transform:rotate(-45deg);border-radius:1px;width:12px;height:6px}.sb-brand .name{font-weight:600;font-size:14px;letter-spacing:-.02em}.sb-group{display:flex;flex-direction:column;gap:2px}.sb-group-title{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);text-transform:uppercase;letter-spacing:.12em;padding:0 8px 6px;display:flex;justify-content:space-between;align-items:center}.sb-group-title .count{color:var(--ink-3)}.sb-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-2);font-size:13px;color:var(--ink-2);cursor:pointer;transition:background .12s}.sb-item:hover{background:var(--surface);color:var(--ink)}.sb-item.active{background:var(--surface);color:var(--ink);font-weight:500;box-shadow:var(--shadow-1)}.sb-item .ico{width:14px;height:14px;flex-shrink:0;color:var(--ink-3);stroke:currentColor;stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}.sb-item.active .ico{color:var(--accent)}.sb-item .cnt{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--ink-4)}.sb-item .swatch-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sb-item--project{position:relative}.sb-item--project .sb-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-item--project .cnt{margin-left:0}.sb-del-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:var(--r-2);background:none;border:none;cursor:pointer;color:var(--ink-4);flex-shrink:0;opacity:0;transition:opacity .12s,background .12s;padding:0;margin-left:4px}.sb-item--project:hover .sb-del-btn{opacity:1}.sb-del-btn:hover{background:color-mix(in oklch,var(--rose) 14%,var(--surface));color:var(--rose)}.sb-add-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:var(--r-2);background:none;border:none;cursor:pointer;color:var(--ink-4);transition:background .12s,color .12s;padding:0}.sb-add-btn:hover{background:var(--surface);color:var(--ink)}.sb-add-form{padding:2px 4px 6px}.sb-add-input{width:100%;box-sizing:border-box;background:var(--surface);border:1px solid var(--hairline-strong);border-radius:var(--r-2);padding:5px 8px;font-family:var(--font-sans);font-size:13px;color:var(--ink);outline:none}.sb-add-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.sb-empty-hint{font-family:var(--font-mono);font-size:11px;color:var(--ink-4);padding:4px 10px}.sb-color-row{display:flex;gap:6px;padding:6px 2px 2px}.sb-color-dot{width:18px;height:18px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;flex-shrink:0;transition:transform .1s,box-shadow .1s;outline:none}.sb-color-dot:hover{transform:scale(1.15)}.sb-color-dot.selected{box-shadow:0 0 0 2px var(--surface),0 0 0 4px currentColor;transform:scale(1.1)}.sb-add-actions{display:flex;gap:6px;justify-content:flex-end;padding-top:6px}.del-dialog{max-width:400px}.del-dialog-project{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;margin-bottom:12px}.del-dialog-warning{font-size:13px;color:var(--ink-3);line-height:1.6;margin:0 0 16px}.confirm-dialog{max-width:380px}.confirm-dialog-body{padding-bottom:4px}.confirm-dialog-msg{font-size:13px;color:var(--ink-3);line-height:1.65;margin:0}.proj-color-grid{display:flex;flex-wrap:wrap;gap:8px;padding:4px 0}.proj-color-btn{width:28px;height:28px;border-radius:50%;background:var(--dot-color);border:2px solid transparent;cursor:pointer;padding:0;outline:none;transition:transform .12s,box-shadow .12s;position:relative}.proj-color-btn:hover{transform:scale(1.15)}.proj-color-btn.selected{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--dot-color);transform:scale(1.08)}.proj-platform-chips{display:flex;flex-wrap:wrap;gap:6px;padding:4px 0 8px}.proj-platform-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px 3px 10px;border-radius:var(--r-pill);background:color-mix(in oklch,var(--accent) 10%,var(--surface));border:1px solid color-mix(in oklch,var(--accent) 30%,transparent);color:var(--accent-ink);font-size:12px;font-weight:500}.proj-platform-chip-del{display:flex;align-items:center;justify-content:center;width:14px;height:14px;padding:0;background:none;border:none;cursor:pointer;color:var(--accent-ink);opacity:.6;border-radius:50%;transition:opacity .1s,background .1s}.proj-platform-chip-del:hover{opacity:1;background:color-mix(in oklch,var(--accent) 20%,transparent)}.proj-platform-add{display:flex;gap:8px;align-items:center}.app-main{padding:28px 32px;display:flex;flex-direction:column;gap:24px;min-width:0}.app-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px}.app-head .t .date{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}.app-head .t h2{font-size:26px;letter-spacing:-.03em;font-weight:500;margin:0}.app-head .t h2 span{color:var(--ink-3);font-weight:400}.app-head .actions{display:flex;gap:8px}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:var(--r-pill);font-family:var(--font-ui);font-size:13px;font-weight:500;letter-spacing:-.01em;border:1px solid transparent;cursor:pointer;transition:all .15s ease;line-height:1}.btn-primary{background:var(--ink);color:var(--surface)}.btn-primary:hover{background:var(--bone-700)}.btn-ghost{background:transparent;color:var(--ink-2);border-color:var(--hairline-strong)}.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}.i{width:14px;height:14px;stroke:currentColor;stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}.card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-3);box-shadow:var(--shadow-1)}.progress-card{display:flex;align-items:center;gap:20px;padding:18px 22px}.ring{position:relative;width:56px;height:56px;flex-shrink:0}.ring svg{transform:rotate(-90deg);width:56px;height:56px}.ring .bg{stroke:var(--hairline);fill:none;stroke-width:5}.ring .fg{stroke:var(--accent);fill:none;stroke-width:5;stroke-linecap:round;transition:stroke-dasharray .5s cubic-bezier(.4,0,.2,1)}.ring .pct{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;font-weight:500}.progress-card .info{flex:1}.progress-card .info .t{font-size:14px;font-weight:600;letter-spacing:-.01em}.progress-card .info .s{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);margin-top:3px}.progress-card .bars{display:flex;gap:4px;align-items:flex-end;height:36px}.progress-card .bars i{width:5px;border-radius:2px;background:var(--hairline-strong);display:block}.progress-card .bars i.hi{background:var(--accent)}.progress-card .bars i.md{background:var(--accent-soft)}.add-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border:1px dashed var(--hairline-strong);border-radius:var(--r-3);color:var(--ink-3);font-size:13px;cursor:text;transition:all .15s;background:color-mix(in oklch,var(--surface) 70%,transparent)}.add-row:hover,.add-row:focus-within{border-style:solid;border-color:var(--accent);background:var(--surface)}.add-row input{flex:1;border:none;outline:none;background:transparent;font:inherit;color:var(--ink);letter-spacing:-.01em}.add-row input::placeholder{color:var(--ink-4)}.add-row .shortcuts{font-family:var(--font-mono);font-size:11px;color:var(--ink-4)}.add-row .plus{width:18px;height:18px;border-radius:5px;border:1.5px dashed var(--hairline-strong);position:relative;flex-shrink:0}.add-row .plus:before,.add-row .plus:after{content:"";position:absolute;background:var(--ink-3)}.add-row .plus:before{left:50%;top:4px;bottom:4px;width:1.5px;transform:translate(-50%)}.add-row .plus:after{top:50%;left:4px;right:4px;height:1.5px;transform:translateY(-50%)}.app-section-label{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3);padding:4px 0 10px}.app-section-label .line{flex:1;height:1px;background:var(--hairline)}.app-section-label .count{color:var(--ink-4)}.cb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;border-radius:5px;border:1.5px solid var(--hairline-strong);background:var(--surface);cursor:pointer;position:relative;transition:all .18s cubic-bezier(.4,0,.2,1);flex-shrink:0}.cb:hover{border-color:var(--accent)}.cb:checked{background:var(--accent);border-color:var(--accent)}.cb:checked:after{content:"";position:absolute;left:4px;top:1px;width:6px;height:10px;border-right:2px solid white;border-bottom:2px solid white;transform:rotate(45deg)}.cb.round{border-radius:50%}.cb.round:checked:after{left:5px;top:2px;width:5px;height:9px;border-width:1.5px}.cb.prio:checked{background:var(--amber);border-color:var(--amber)}.task-table-wrap{overflow:hidden}.task-table{width:100%;border-collapse:collapse}.task-table thead tr{border-bottom:2px solid var(--hairline);background:color-mix(in oklch,var(--bg) 60%,var(--surface))}.task-table th{padding:10px 14px;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-4);font-weight:500;text-align:left;white-space:nowrap;-webkit-user-select:none;user-select:none}.th-col{cursor:pointer;transition:color .12s}.th-col:hover{color:var(--ink-2)}.th-active{color:var(--accent)!important}.th-check,.th-actions{width:48px}.sort-icon{font-size:10px;opacity:.35}.sort-active{opacity:1;color:var(--accent)}.th-inner{display:inline-flex;align-items:center;gap:4px}.th-label{cursor:pointer;white-space:nowrap}.th-label:hover{color:var(--ink-2)}.th-sort-active{color:var(--accent)!important}.th-filter-active{background:color-mix(in oklch,var(--accent) 7%,transparent)}.th-filter-btn{display:flex;align-items:center;position:relative;padding:2px 3px;border-radius:3px;border:none;background:transparent;color:var(--ink-4);cursor:pointer;transition:color .12s,background .12s;flex-shrink:0}.th-filter-btn:hover{color:var(--ink-2);background:var(--surface-2)}.th-filter-btn-active{color:var(--accent)!important}.th-filter-badge{position:absolute;top:-5px;right:-5px;width:14px;height:14px;border-radius:50%;background:var(--accent);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;pointer-events:none}.section-filter-btn{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:var(--r-pill);border:1px solid var(--hairline-strong);background:var(--surface);font-family:var(--font-mono);font-size:10px;color:var(--ink-3);cursor:pointer;transition:all .12s;letter-spacing:.06em}.section-filter-btn:hover{border-color:var(--accent);color:var(--accent)}.section-filter-btn-active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.section-filter-reset{background:none;border:none;cursor:pointer;font-family:var(--font-mono);font-size:10px;color:var(--rose);padding:0 2px;letter-spacing:.04em}.section-filter-reset:hover{text-decoration:underline}.filter-panel{width:300px}.fp-section{border-bottom:1px solid var(--hairline)}.fp-section:last-child{border-bottom:none}.fp-section-head{display:flex;align-items:center;justify-content:space-between;padding:12px 20px 8px}.fp-section-title{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);display:flex;align-items:center;gap:6px}.fp-section-badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--accent);color:#fff;font-size:9px;font-weight:700}.fp-clear{font-family:var(--font-mono);font-size:10px;color:var(--rose);background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:3px;transition:background .1s}.fp-clear:hover{background:color-mix(in oklch,var(--rose) 10%,var(--surface))}.fp-option-list{padding:2px 0 10px}.fp-option{display:flex;align-items:center;gap:10px;padding:7px 20px;cursor:pointer;font-size:13px;color:var(--ink-2);transition:background .1s;-webkit-user-select:none;user-select:none}.fp-option:hover{background:var(--surface-2);color:var(--ink)}.fp-option-all{color:var(--ink-3);font-size:12px;border-bottom:1px solid var(--hairline);margin-bottom:2px;padding-bottom:8px}.fp-option input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.td-empty-row{padding:28px 16px;text-align:center;font-family:var(--font-mono);font-size:12px;color:var(--ink-4)}.link-btn{background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit;color:var(--accent);text-decoration:underline;padding:0}.task-row{border-top:1px solid var(--hairline);transition:background .12s;cursor:pointer}.task-row:first-child{border-top:none}.task-row:hover{background:var(--surface-2)}.task-row.pinned td.td-check{box-shadow:inset 3px 0 0 var(--amber)}.task-row.done .task-title{color:var(--ink-4);text-decoration:line-through;text-decoration-color:var(--ink-4);text-decoration-thickness:1px}.task-row.done .task-meta{opacity:.55}.td-check{padding:0 8px 0 16px;width:48px;vertical-align:middle}.td-title{padding:12px 14px}.td-created,.td-platform,.td-priority,.td-status,.td-file{padding:12px 14px;white-space:nowrap;vertical-align:middle}.td-actions{padding:10px 14px 10px 4px;width:36px;text-align:right}.td-file-name{max-width:160px;overflow:hidden;text-overflow:ellipsis;display:inline-block;vertical-align:middle}.task-title{font-size:14px;font-weight:500;color:var(--ink);letter-spacing:-.01em}.task-meta{display:flex;gap:8px;align-items:center;margin-top:3px;font-family:var(--font-mono);font-size:11px;color:var(--ink-3);flex-wrap:wrap}.task-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.td-mono{font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.td-chip{font-family:var(--font-mono);font-size:11px;padding:2px 8px;border-radius:var(--r-pill);background:var(--surface-2);border:1px solid var(--hairline);color:var(--ink-2);text-transform:capitalize}.td-empty{color:var(--ink-4);font-family:var(--font-mono);font-size:11px}.del{opacity:0;border:none;background:transparent;cursor:pointer;color:var(--ink-4);padding:4px;border-radius:4px;transition:all .12s}.task-row:hover .del{opacity:1}.del:hover{color:var(--rose);background:var(--surface-2)}.tag{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:var(--r-pill);font-family:var(--font-mono);font-size:11px;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--hairline);font-weight:500}.tag .dot{width:6px;height:6px;border-radius:50%;background:var(--ink-3)}.tag.cobalt{background:var(--cobalt-soft);color:var(--cobalt-ink);border-color:color-mix(in oklch,var(--cobalt) 20%,transparent)}.tag.cobalt .dot{background:var(--cobalt)}.tag.amber{background:var(--amber-soft);color:var(--amber-ink);border-color:color-mix(in oklch,var(--amber) 25%,transparent)}.tag.amber .dot{background:var(--amber)}.tag.sage{background:var(--sage-soft);color:var(--sage-ink);border-color:color-mix(in oklch,var(--sage) 25%,transparent)}.tag.sage .dot{background:var(--sage)}.empty{padding:40px 20px;text-align:center;font-family:var(--font-mono);font-size:12px;color:var(--ink-4)}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:var(--r-pill);font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.04em;white-space:nowrap;border:1px solid transparent}.badge .badge-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0000002e;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:overlay-in .18s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.panel{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:95vw;background:var(--surface);border-left:1px solid var(--hairline);box-shadow:var(--shadow-3);display:flex;flex-direction:column;z-index:101;animation:panel-in .22s cubic-bezier(.4,0,.2,1);overflow:hidden}@keyframes panel-in{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.panel-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--hairline);flex-shrink:0}.panel-header .panel-title{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:-.01em;flex:1}.panel-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--ink-3);cursor:pointer;border-radius:var(--r-2);transition:all .12s}.panel-close:hover{background:var(--surface-2);color:var(--ink)}.panel-body{flex:1;overflow-y:auto;padding:24px 20px;display:flex;flex-direction:column;gap:20px}.panel-body::-webkit-scrollbar{width:4px}.panel-body::-webkit-scrollbar-thumb{background:var(--hairline-strong);border-radius:4px}.panel-footer{padding:14px 20px;border-top:1px solid var(--hairline);display:flex;gap:8px;justify-content:flex-end;flex-shrink:0}.field-row{display:flex;flex-direction:column;gap:6px}.field-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-4)}.field-input{width:100%;padding:8px 12px;background:var(--surface-2);border:1px solid var(--hairline);border-radius:var(--r-2);font-family:var(--font-ui);font-size:13px;color:var(--ink);letter-spacing:-.01em;outline:none;transition:border-color .12s;resize:none}.field-input:focus{border-color:var(--accent);background:var(--surface)}.field-input::placeholder{color:var(--ink-4)}.field-row-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field-title{font-size:18px;font-weight:600;letter-spacing:-.02em;padding:10px 12px;border-radius:var(--r-3)}select.field-input{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;cursor:pointer}select.field-input option{background:var(--surface);color:var(--ink)}.file-upload{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px dashed var(--hairline-strong);border-radius:var(--r-3);cursor:pointer;transition:all .15s}.file-upload:hover{border-color:var(--accent);background:var(--surface-2)}.file-upload input[type=file]{display:none}.file-upload .file-label{font-family:var(--font-mono);font-size:11px;color:var(--ink-3)}.file-upload .file-name{font-size:12px;color:var(--ink-2);font-family:var(--font-mono);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-remove{border:none;background:transparent;cursor:pointer;color:var(--ink-4);padding:2px 4px;border-radius:3px;font-size:12px;transition:color .12s}.file-remove:hover{color:var(--rose)}@media(max-width:860px){.app-body{grid-template-columns:1fr}.sb{display:none}.app-head{flex-direction:column;align-items:stretch}.app-main{padding:20px}.app-wrap{padding:16px;min-height:100vh}.progress-grid{grid-template-columns:1fr!important}.panel{width:100%}.td-created,.td-platform,.td-file,.th-col.th-created,.th-col.th-platform,.th-col.th-file{display:none}}.sb{display:flex;flex-direction:column}.sb-user{margin-top:auto;padding:10px 12px;border-top:1px solid var(--hairline);display:flex;align-items:center;gap:8px;flex-shrink:0}.sb-user-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.sb-user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-ui)}.sb-user-details{display:flex;flex-direction:column;min-width:0}.sb-user-name{font-size:12px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-user-email{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-logout-btn{flex-shrink:0;width:28px;height:28px;border:none;background:transparent;color:var(--ink-4);cursor:pointer;border-radius:var(--r-2);display:flex;align-items:center;justify-content:center;transition:all .12s}.sb-logout-btn:hover{background:color-mix(in oklch,var(--rose) 10%,var(--surface));color:var(--rose)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-4, 12px);box-shadow:0 4px 24px #00000014;overflow:hidden}.auth-form{display:flex;flex-direction:column;padding:36px 32px;gap:16px}.auth-header{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:8px;text-align:center}.auth-logo{width:36px;height:36px;background:var(--ink);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:4px;position:relative}.auth-logo .m{width:18px;height:12px;background:var(--surface);position:relative}.auth-logo .m:before,.auth-logo .m:after{content:"";position:absolute;top:-1.5px;width:1.5px;height:15px;background:var(--ink)}.auth-logo .m:before{left:5px;transform:rotate(-12deg)}.auth-logo .m:after{right:5px;transform:rotate(12deg)}.auth-title{font-size:20px;font-weight:700;letter-spacing:-.03em;color:var(--ink);margin:0}.auth-subtitle{font-family:var(--font-mono);font-size:11px;color:var(--ink-4);text-transform:uppercase;letter-spacing:.1em;margin:0}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-label{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-4)}.auth-input{padding:9px 12px;background:var(--surface-2);border:1px solid var(--hairline);border-radius:var(--r-2);font-family:var(--font-ui);font-size:14px;color:var(--ink);outline:none;transition:border-color .12s,background .12s;width:100%;box-sizing:border-box}.auth-input:focus{border-color:var(--accent);background:var(--surface)}.auth-input::placeholder{color:var(--ink-4)}.auth-btn{padding:10px 16px;background:var(--ink);color:var(--surface);border:none;border-radius:var(--r-2);font-family:var(--font-ui);font-size:14px;font-weight:500;cursor:pointer;transition:opacity .12s;letter-spacing:-.01em;margin-top:4px}.auth-btn:hover:not(:disabled){opacity:.85}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-links{display:flex;flex-direction:column;align-items:center;gap:8px}.auth-link{background:none;border:none;cursor:pointer;font-family:var(--font-ui);font-size:12px;color:var(--ink-3);padding:2px;transition:color .1s}.auth-link:hover{color:var(--accent)}.auth-error{background:color-mix(in oklch,var(--rose) 10%,var(--surface));border:1px solid color-mix(in oklch,var(--rose) 25%,transparent);border-radius:var(--r-2);padding:10px 14px;font-family:var(--font-mono);font-size:12px;color:var(--rose)}.auth-success{background:color-mix(in oklch,var(--sage) 10%,var(--surface));border:1px solid color-mix(in oklch,var(--sage) 25%,transparent);border-radius:var(--r-2);padding:12px 14px;font-size:13px;color:var(--sage-ink);line-height:1.5}.auth-hint{font-size:13px;color:var(--ink-3);line-height:1.5;margin:0}.auth-btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--hairline-strong)}.auth-btn--ghost:hover:not(:disabled){opacity:1;border-color:var(--accent);color:var(--accent)}.auth-warning{background:color-mix(in oklch,var(--amber) 10%,var(--surface));border:1px solid color-mix(in oklch,var(--amber) 30%,transparent);border-radius:var(--r-2);padding:10px 14px;font-size:13px;color:var(--amber-ink);line-height:1.5;display:flex;flex-direction:column;gap:6px}.auth-resend-inline{background:none;border:none;cursor:pointer;font-size:12px;font-family:var(--font-ui);color:var(--accent);padding:0;text-decoration:underline;text-align:left}.auth-verify-box{background:var(--surface-2);border:1px solid var(--hairline);border-radius:var(--r-3);padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.auth-verify-icon{font-size:32px;line-height:1}.auth-verify-text{font-size:13px;color:var(--ink-2);line-height:1.6;margin:0}.auth-verify-hint{font-family:var(--font-mono);font-size:11px;color:var(--ink-4);margin:0}.auth-verify-spinner{width:24px;height:24px;border:2px solid var(--hairline-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
