:root{--bg:#eceef1;--surface:#fff;--surface-2:#f5f6f8;--surface-3:#f0f2f5;--ink:#181b22;--muted:#646b78;--hint:#9aa1ad;--line:#e3e6eb;--line-strong:#d1d6de;--accent:#0f6e56;--accent-2:#4fc3a1;--danger:#b43320;--warn:#8a5a0b;--info:#1c5689;--shadow:0 18px 50px #14181e24;--font-display:"Space Grotesk", "Noto Sans TC", system-ui, sans-serif;--font-body:"Noto Sans TC", "Space Grotesk", system-ui, sans-serif;--font-mono:"IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html,body,#root{min-height:100%}body{background:var(--bg);color:var(--ink);font-family:var(--font-body);-webkit-font-smoothing:antialiased;margin:0;font-size:15px;line-height:1.55}button,input,select,textarea{font:inherit}button{-webkit-tap-highlight-color:transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#cdd2da padding-box content-box;border:3px solid #0000;border-radius:999px}.icon{flex:none;display:block}.app-shell{background:linear-gradient(180deg, #ffffff47, transparent 240px), var(--bg);grid-template-columns:252px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{background:var(--surface);border-right:1px solid var(--line);z-index:30;flex-direction:column;height:100vh;display:flex;position:sticky;top:0;overflow:hidden}.brand-block{align-items:center;gap:10px;padding:20px 20px 16px;display:flex}.pulse-dot{background:var(--accent);border-radius:50%;flex:none;width:9px;height:9px;position:relative}.pulse-dot:after{border:1.5px solid var(--accent);content:"";opacity:0;border-radius:50%;animation:2.6s ease-out infinite pulse;position:absolute;inset:-5px}@keyframes pulse{0%{opacity:.7;transform:scale(.6)}to{opacity:0;transform:scale(1.7)}}.brand-title{font-family:var(--font-display);letter-spacing:0;font-size:18px;font-weight:600}.nav-stack{padding:4px 12px 0}.nav-row,.cat-row{color:var(--muted);cursor:pointer;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:11px;width:100%;min-height:38px;padding:8px 11px;transition:background .14s,color .14s;display:flex}.nav-row:hover,.cat-row:hover,.nav-row.is-active,.cat-row.is-active{background:var(--surface-3);color:var(--ink)}.nav-row span,.cat-row span:nth-child(2){text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.nav-row b,.cat-row b{color:var(--hint);font-family:var(--font-mono);font-size:12px;font-weight:500}.sidebar-label{color:var(--hint);font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;padding:18px 23px 8px;font-size:11px;font-weight:700}.cat-list{flex:1;padding:0 12px;overflow-y:auto}.cat-dot{border-radius:3px;flex:none;width:8px;height:8px}.all-dot{background:linear-gradient(135deg,#1c5689,#0f6e56 52%,#b43320)}.sidebar-footer{border-top:1px solid var(--line);padding:14px 16px}.progress-label{color:var(--muted);justify-content:space-between;align-items:baseline;margin-bottom:7px;font-size:12px;display:flex}.progress-label b{color:var(--hint);font-family:var(--font-mono);font-size:11.5px;font-weight:500}.progress-track{background:#e8ebef;border-radius:999px;height:6px;margin-bottom:12px;overflow:hidden}.progress-track span{background:linear-gradient(90deg, var(--accent), var(--accent-2));border-radius:inherit;height:100%;transition:width .8s cubic-bezier(.2,.7,.2,1);display:block}.footer-actions{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.footer-actions button,.icon-button{background:var(--surface-2);border:1px solid var(--line);color:var(--muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;padding:0;transition:background .14s,border-color .14s,color .14s,transform .12s;display:inline-flex}.footer-actions button:hover,.icon-button:hover{background:var(--surface-3);border-color:var(--line-strong);color:var(--ink)}.icon-button:active,.primary-button:active,.command-button:active{transform:scale(.97)}.icon-button.danger:hover{color:var(--danger);background:#fae9e5;border-color:#f1cfc7}.sidebar-scrim{display:none}.main-pane{flex-direction:column;min-width:0;height:100vh;display:flex;overflow-y:auto}.topbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);z-index:20;background:#eceef1d4;align-items:center;gap:12px;padding:14px 28px;display:flex;position:sticky;top:0}.rail-toggle{display:none}.top-title{min-width:0}.top-title h1{font-family:var(--font-display);letter-spacing:0;margin:0;font-size:20px;font-weight:600;line-height:1.2}.top-title p{color:var(--hint);font-family:var(--font-mono);align-items:center;gap:7px;margin:1px 0 0;font-size:11.5px;display:flex}.topbar-spacer{flex:1}.command-button,.primary-button{cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:8px;min-height:36px;padding:8px 12px;font-size:13px;transition:filter .14s,transform .12s,border-color .14s;display:inline-flex}.command-button{background:var(--surface);border:1px solid var(--line-strong);color:var(--hint)}.command-button:hover{color:var(--muted);border-color:#b9bec7}kbd{background:var(--surface-3);border:1px solid var(--line);color:var(--hint);font-family:var(--font-mono);border-radius:5px;padding:3px 7px;font-size:11px;font-weight:500;line-height:1}.primary-button{background:var(--accent);border:1px solid var(--accent);color:#fff;font-weight:600;box-shadow:0 2px 8px #0f6e5638}.primary-button:hover{filter:brightness(1.08)}.show-done-toggle{color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;align-items:center;gap:6px;font-size:12.5px;display:inline-flex}.show-done-toggle input{accent-color:var(--accent);width:15px;height:15px}.view-surface{flex:1;padding:24px 28px 100px}.today-view,.list-view,.timeline-view{max-width:860px}.today-hero{color:#fff;background:linear-gradient(135deg,#0f6e56,#0c5a47);border-radius:8px;grid-template-columns:minmax(0,1fr) auto;gap:20px;margin-bottom:22px;padding:24px 26px;display:grid;position:relative;overflow:hidden}.today-hero:after{content:"";opacity:.25;pointer-events:none;background-color:#0000;background-image:linear-gradient(90deg,#ffffff14 1px,#0000 1px),linear-gradient(0deg,#ffffff14 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:30px 30px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:absolute;inset:0;-webkit-mask-image:linear-gradient(90deg,#0000,#000);mask-image:linear-gradient(90deg,#0000,#000)}.today-hero>*{z-index:1;position:relative}.eyebrow{font-family:var(--font-mono);letter-spacing:.04em;opacity:.78;margin-bottom:6px;font-size:12px;display:block}.today-hero h2{font-family:var(--font-display);letter-spacing:0;max-width:620px;margin:0;font-size:25px;font-weight:600;line-height:1.25}.hero-metrics{grid-template-columns:repeat(3,minmax(74px,1fr));align-items:end;gap:12px;display:grid}.hero-metrics div{border-left:1px solid #ffffff3d;padding-left:14px}.hero-metrics b{font-family:var(--font-mono);font-size:25px;font-weight:500;line-height:1;display:block}.hero-metrics span{opacity:.76;white-space:nowrap;margin-top:6px;font-size:12px;display:block}.task-section{margin-bottom:24px}.section-head,.timeline-head{align-items:center;gap:9px;margin:0 2px 12px;display:flex}.section-head span{border-radius:3px;width:8px;height:8px}.section-head b,.timeline-head b{color:var(--muted);font-family:var(--font-display);letter-spacing:.03em;text-transform:uppercase;font-size:13px;font-weight:700}.section-head em,.timeline-head em{color:var(--hint);font-family:var(--font-mono);font-size:12px;font-style:normal}.section-head i{background:var(--line);flex:1;height:1px}.item-card{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--cat-color);cursor:pointer;border-radius:8px;gap:12px;margin-bottom:9px;padding:13px 14px;transition:border-color .14s,box-shadow .18s,opacity .18s,transform .18s;display:flex}.item-card:hover{border-color:var(--line-strong);transform:translateY(-1px);box-shadow:0 8px 22px #14181e14}.item-card.is-done{opacity:.56}.item-card.is-done .item-title{text-decoration:line-through}.item-card.is-dragging{opacity:.38}.check-button,.mini-check{background:var(--surface);border:1.6px solid var(--line-strong);color:#fff;cursor:pointer;border-radius:6px;flex:none;justify-content:center;align-items:center;padding:0;transition:background .14s,border-color .14s;display:flex}.check-button{width:21px;height:21px;margin-top:2px}.check-button:hover,.mini-check:hover{border-color:var(--accent)}.check-button .icon,.mini-check .icon{opacity:0}.check-button.is-on,.mini-check.is-on{background:var(--accent);border-color:var(--accent)}.check-button.is-on .icon,.mini-check.is-on .icon{opacity:1}.item-body{flex:1;min-width:0}.item-title-row{align-items:flex-start;gap:8px;display:flex}.cat-swatch{background:var(--cat-color);border-radius:3px;flex:none;width:8px;height:8px;margin-top:7px}.item-title{color:var(--ink);overflow-wrap:anywhere;flex:1;min-width:0;margin:0 0 4px;font-size:15px;font-weight:600;line-height:1.4}.item-next{color:var(--muted);overflow-wrap:anywhere;margin:0 0 9px;font-size:13px;line-height:1.52}.item-meta{flex-wrap:wrap;align-items:center;gap:7px;display:flex}.pill,.deadline-pill{white-space:nowrap;border-radius:999px;padding:4px 9px;font-size:11.5px;font-weight:600;line-height:1.2}.cat-pill{background:var(--surface-3);color:var(--muted)}.stage-pill{background:color-mix(in srgb, var(--stage-color) 13%, #fff);color:var(--stage-color)}.status-pill{color:var(--info);background:#e5eef7}.deadline-pill{background:var(--surface-3);color:var(--muted);font-family:var(--font-mono)}.deadline-pill.hot{color:var(--danger);background:#fae9e5}.deadline-pill.warn{color:var(--warn);background:#fbefd9}.subtask-meter{align-items:center;gap:7px;margin-top:9px;display:flex}.subtask-meter div{background:var(--surface-3);border-radius:999px;flex:1;height:4px;overflow:hidden}.subtask-meter span{background:var(--accent);border-radius:inherit;height:100%;display:block}.subtask-meter b{color:var(--hint);font-family:var(--font-mono);font-size:10.5px;font-weight:500}.board-view{grid-template-columns:repeat(4,minmax(220px,1fr));align-items:start;gap:14px;min-width:0;display:grid}.board-column{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;min-height:150px;padding:10px}.board-head{align-items:center;gap:8px;padding:4px 6px 10px;display:flex}.board-head span{border-radius:50%;width:8px;height:8px}.board-head b{color:var(--muted);font-family:var(--font-display);letter-spacing:.02em;text-transform:uppercase;flex:1;font-size:12.5px}.board-head em{color:var(--hint);font-family:var(--font-mono);font-size:12px;font-style:normal}.board-column .item-card{padding:11px 12px}.board-column .item-title{font-size:13.5px}.column-drop-zone{border-radius:8px;height:28px}.timeline-view{padding-left:8px}.timeline-bucket{border-left:2px solid var(--line);margin-bottom:26px;padding-left:26px;position:relative}.timeline-bucket:before{background:var(--bucket-color);border:2.5px solid var(--bg);content:"";border-radius:50%;width:12px;height:12px;position:absolute;top:2px;left:-7px}.timeline-head span{background:var(--bucket-color);border-radius:50%;width:8px;height:8px}.timeline-head b{color:var(--bucket-color)}.empty-state{border:1px dashed var(--line-strong);color:var(--muted);text-align:center;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-height:180px;padding:34px 16px;display:flex}.empty-state .icon{color:var(--accent)}.drawer-scrim,.palette-scrim,.shortcuts-scrim{background:#0a0c1057;border:0;padding:0;position:fixed;inset:0}.drawer-scrim{z-index:60}.drawer{background:var(--surface);z-index:61;flex-direction:column;width:460px;max-width:92vw;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-20px 0 60px #0a0c1038}.drawer-head{border-bottom:1px solid var(--line);align-items:center;gap:10px;padding:16px 20px;display:flex}.drawer-head b{color:var(--hint);font-family:var(--font-mono);letter-spacing:.03em;flex:1;font-size:12px;font-weight:500}.drawer-body{flex:1;padding:20px;overflow-y:auto}.title-input{color:var(--ink);font-family:var(--font-display);resize:none;background:0 0;border:1px solid #0000;border-radius:8px;width:calc(100% + 16px);margin:-6px -8px 14px;padding:6px 8px;font-size:19px;font-weight:600;line-height:1.3}.title-input:hover{background:#f7f8fa}.stage-switcher{background:var(--surface-3);border-radius:8px;grid-template-columns:repeat(4,1fr);gap:4px;margin-bottom:16px;padding:3px;display:grid}.stage-switcher button{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:7px;padding:7px 4px;font-size:12.5px}.stage-switcher button.is-on{background:var(--surface);color:var(--ink);box-shadow:0 1px 3px #14181e14}.form-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px;display:grid}.form-grid label,.field-stack{display:block}.form-grid span,.field-stack span,.subtask-head>span,.activity-log>span{color:var(--hint);margin-bottom:5px;font-size:11.5px;font-weight:600;display:block}.form-grid input,.form-grid select,.field-stack input,.field-stack textarea,.subtask-add{background:var(--surface);border:1px solid var(--line-strong);color:var(--ink);border-radius:8px;width:100%;padding:8px 10px;font-size:13.5px}.field-stack{margin-bottom:18px}.field-stack textarea{resize:vertical;line-height:1.5}.form-grid input:focus,.form-grid select:focus,.field-stack input:focus,.field-stack textarea:focus,.subtask-add:focus,.title-input:focus,.palette-input-row input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #e1f2ec}.subtask-head{align-items:center;gap:12px;margin-bottom:9px;display:flex}.subtask-head span{margin:0}.subtask-head div{background:var(--surface-3);border-radius:999px;flex:1;max-width:124px;height:5px;overflow:hidden}.subtask-head i{background:var(--accent);border-radius:inherit;height:100%;display:block}.subtask-list{margin-bottom:6px}.subtask-row{align-items:center;gap:9px;padding:6px 0;display:flex}.mini-check{width:18px;height:18px}.subtask-row span{color:var(--ink);overflow-wrap:anywhere;flex:1;font-size:13.5px}.subtask-row>button:last-child{color:#c3c8d0;cursor:pointer;background:0 0;border:0;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;padding:0;display:flex}.subtask-row>button:last-child:hover{color:var(--danger)}.subtask-add{background:0 0;border-style:dashed;margin-bottom:20px;font-size:13px}.activity-log{margin-top:4px}.log-row{gap:10px;padding:5px 0;display:flex}.log-row i{background:var(--line-strong);border-radius:50%;flex:none;width:6px;height:6px;margin-top:7px}.log-row b{color:var(--ink);font-size:13px;font-weight:500;display:block}.log-row time{color:var(--hint);font-family:var(--font-mono);font-size:11px;display:block}.drawer-footer{border-top:1px solid var(--line);gap:8px;padding:14px 20px;display:flex}.done-button{background:var(--accent);border:1px solid var(--accent);color:#fff;cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:8px;padding:10px;font-weight:600;display:flex}.done-button.is-done{background:var(--surface);color:var(--accent)}.palette-scrim,.shortcuts-scrim{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:80;justify-content:center;align-items:flex-start;padding:14vh 16px 16px;display:flex}.palette-panel{background:var(--surface);border:1px solid var(--line);border-radius:12px;width:100%;max-width:560px;overflow:hidden;box-shadow:0 30px 70px #0a0c1052}.palette-input-row{border-bottom:1px solid #eff1f4;align-items:center;gap:11px;padding:15px 18px;display:flex}.palette-input-row .icon{color:var(--hint)}.palette-input-row input{color:var(--ink);background:0 0;border:0;outline:none;flex:1;min-width:0;font-size:15px}.palette-list{max-height:46vh;padding:8px;overflow-y:auto}.palette-row{color:var(--ink);cursor:pointer;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:12px;width:100%;padding:10px 12px;display:flex}.palette-row.is-active,.palette-row:hover{background:var(--surface-3)}.palette-glyph{background:color-mix(in srgb, var(--glyph-color) 14%, white);color:var(--glyph-color);font-family:var(--font-mono);border-radius:8px;flex:none;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:600;display:flex}.palette-row span:nth-child(2){flex:1;min-width:0}.palette-row b,.palette-row em{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.palette-row b{font-size:14px;font-weight:600;line-height:1.3}.palette-row em{color:var(--hint);font-size:11.5px;font-style:normal}.palette-empty{color:var(--hint);text-align:center;padding:26px 16px;font-size:13.5px}.shortcuts-scrim{z-index:90;align-items:center}.shortcuts-panel{background:var(--surface);border-radius:12px;width:100%;max-width:420px;padding:22px;box-shadow:0 30px 70px #0a0c104d}.shortcuts-panel h2{font-family:var(--font-display);margin:0 0 16px;font-size:17px;font-weight:600}.shortcut-row{border-bottom:1px solid var(--surface-2);justify-content:space-between;align-items:center;padding:7px 0;display:flex}.shortcut-row span{color:var(--ink);font-size:13.5px}.toast-wrap{pointer-events:none;z-index:95;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:26px;left:50%;transform:translate(-50%)}.toast{background:var(--ink);color:#fff;pointer-events:auto;border-radius:8px;align-items:center;gap:14px;min-width:240px;padding:11px 14px 11px 16px;display:flex;box-shadow:0 12px 30px #0a0c1052}.toast span{flex:1;font-size:13.5px}.toast button{color:var(--accent-2);cursor:pointer;background:0 0;border:0;padding:2px 4px;font-weight:700}@media (width<=1080px){.board-view{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media (width<=880px){.app-shell{display:block}.sidebar{width:252px;max-width:calc(100vw - 56px);transition:transform .24s cubic-bezier(.2,.8,.2,1);position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.is-open{transform:none}.sidebar-scrim{opacity:0;pointer-events:none;z-index:25;background:#0a0c106b;border:0;transition:opacity .2s;display:block;position:fixed;inset:0}.sidebar-scrim.is-open{opacity:1;pointer-events:auto}.main-pane{min-height:100vh}.rail-toggle{display:inline-flex}.topbar{padding:12px 16px}.command-button span,.command-button kbd,.show-done-toggle span{display:none}.view-surface{padding:18px 16px 88px}.today-hero,.board-view{grid-template-columns:1fr}}@media (width<=580px){.topbar{gap:8px}.top-title h1{font-size:17px}.top-title p{font-size:10.5px}.primary-button span{display:none}.primary-button{padding:8px 10px}.today-hero{padding:20px}.today-hero h2{font-size:20px}.hero-metrics{gap:8px}.hero-metrics div{padding-left:10px}.hero-metrics b{font-size:21px}.item-card{padding:12px}.form-grid,.stage-switcher{grid-template-columns:1fr}.drawer{width:100vw;max-width:none}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}
