.setup{position:relative;align-self:start;justify-self:center;width:min(680px,100%);margin:0 auto;padding:48px 20px 80px;display:flex;flex-direction:column;gap:var(--space-4)}.setup .setup-cancel{position:absolute;top:18px;left:4px;background:transparent;border:none;font-family:var(--font-heading);font-style:italic;font-size:14px;color:var(--text-muted);cursor:pointer;padding:6px 8px}.setup .setup-cancel:hover{color:var(--text)}.setup .setup-archive-link{position:absolute;top:18px;right:4px;background:transparent;border:none;font-family:var(--font-heading);font-style:italic;font-size:14px;color:var(--text-muted);cursor:pointer;padding:6px 8px}.setup .setup-archive-link:hover{color:var(--text)}.setup .archive-screen-empty{font-family:var(--font-heading);font-style:italic;color:var(--text-muted);text-align:center;padding:8px}.setup .archive-list{display:flex;flex-direction:column;gap:6px}.setup .archive-item{display:flex;align-items:center;gap:var(--space-2);padding:10px var(--space-2);border-radius:var(--r-input)}.setup .archive-item:hover{background:#00000008}.setup .archive-item-name{flex:1;min-width:0;display:flex;flex-direction:column;font-family:var(--font-heading);font-weight:500;font-size:15px}.setup .archive-item-sub{font-size:12px;font-weight:400;font-style:italic;color:var(--text-muted)}.setup .archive-restore{background:transparent;border:1px solid rgba(0,0,0,.15);border-radius:var(--r-pill);padding:5px 14px;font-family:var(--font-heading);font-size:13px;color:var(--text);cursor:pointer;transition:background .15s ease,border-color .15s ease}.setup .archive-restore:hover{background:#0000000d;border-color:#0000004d}.setup .setup-head{text-align:center;padding:8px 8px 4px}.setup .brand{font-family:var(--font-heading);font-weight:700;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px}.setup .setup-head h1{font-family:var(--font-heading);font-weight:700;font-size:30px;letter-spacing:-.01em;margin-bottom:12px}.setup .setup-head .sub{font-family:var(--font-heading);font-style:italic;color:var(--text-muted);font-size:15px;max-width:30em;margin:0 auto}.setup .name-field{--accent: var(--accent-time);display:flex;flex-direction:column;gap:7px;align-items:center;max-width:22em;margin:22px auto 0}.setup .name-field input{text-align:center}.setup .card{background:var(--card);border-radius:var(--r-bubble);box-shadow:var(--shadow-rest);border:1px solid rgba(0,0,0,.05);padding:30px 32px}.setup .card[data-section=time]{--accent: var(--accent-time);background:var(--bg-time);border-color:var(--edge-time)}.setup .card[data-section=timeline]{--accent: var(--accent-timeline);background:var(--bg-timeline);border-color:var(--edge-timeline)}.setup .card[data-section=learning]{--accent: var(--accent-learning);background:var(--bg-learning);border-color:var(--edge-learning)}.setup .card-head{display:flex;align-items:center;gap:10px;margin-bottom:18px}.setup .card-head .dot{width:11px;height:11px;border-radius:50%;background:var(--accent);flex-shrink:0}.setup .card-head h2{font-family:var(--font-heading);font-weight:600;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.setup .q{font-family:var(--font-heading);font-size:15.5px;line-height:1.55;margin:22px 0 14px}.setup .q:first-of-type{margin-top:0}.setup .field-row{display:flex;gap:16px;flex-wrap:wrap}.setup .field{display:flex;flex-direction:column;gap:7px;flex:1;min-width:180px}.setup .lab{font-family:var(--font-heading);font-size:12.5px;font-style:italic;color:var(--text-muted);letter-spacing:.02em}.setup input[type=number],.setup input[type=text]{font-family:var(--font-heading);font-size:15px;color:var(--text);background:#ffffffbf;border:1px solid rgba(0,0,0,.1);border-radius:var(--r-input);padding:12px 14px;width:100%;transition:border-color .18s ease,box-shadow .18s ease}.setup input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 28%,transparent)}.setup input::placeholder{color:#0000004d}.setup .with-unit{position:relative;display:block}.setup .with-unit input{padding-right:62px}.setup .with-unit .unit{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-family:var(--font-heading);font-size:13px;font-style:italic;color:var(--text-muted);pointer-events:none}.setup .rows{display:flex;flex-direction:column;gap:10px}.setup .row{display:flex;align-items:center;gap:10px;cursor:grab;border-radius:var(--r-input);transition:opacity .16s ease,box-shadow .12s ease}.setup .row .grow{flex:1}.setup .row .days-input{width:104px;flex-shrink:0}.setup .row .days-input input{padding-right:46px}.setup .grip{width:18px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);opacity:.4;transition:opacity .16s ease}.setup .grip svg{width:10px;height:16px;fill:currentColor}.setup .row:hover .grip{opacity:.7}.setup .row.dragging{opacity:.45;cursor:grabbing}.setup .row.drop-before{box-shadow:inset 0 3px 0 var(--accent)}.setup .row.drop-after{box-shadow:inset 0 -3px 0 var(--accent)}.setup .level-select{font-family:var(--font-heading);font-size:14px;color:var(--text);background:#ffffffbf;border:1px solid rgba(0,0,0,.1);border-radius:var(--r-input);padding:12px 36px 12px 14px;width:178px;flex-shrink:0;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' fill='none' stroke='%238A8A8A' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 13px center;transition:border-color .18s ease,box-shadow .18s ease}.setup .level-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 28%,transparent)}.setup .icon-btn{width:34px;height:34px;flex-shrink:0;border:1px solid rgba(0,0,0,.12);background:#fff9;border-radius:var(--r-pill);color:var(--text-muted);font-size:16px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .16s ease,color .16s ease,border-color .16s ease,opacity .16s ease}.setup .icon-btn:hover:not(:disabled){color:var(--text);border-color:var(--accent)}.setup .icon-btn:disabled{opacity:.32;cursor:default}.setup .rows-foot{display:flex;align-items:baseline;justify-content:space-between;margin-top:14px;gap:12px}.setup .add{background:transparent;border:none;font-family:var(--font-heading);font-style:italic;font-size:14px;color:var(--text-muted);cursor:pointer;padding:8px 4px;border-radius:var(--r-input);transition:color .16s ease}.setup .add:hover{color:var(--text)}.setup .running-total{font-family:var(--font-heading);font-style:italic;font-size:14px;color:var(--text-muted);white-space:nowrap}.setup .running-total strong{font-style:normal;color:var(--accent)}.setup .recap-card{background:var(--sidebar-bg);border-color:#0000000f}.setup .recap{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.setup .recap-group{display:flex;flex-direction:column;gap:4px}.setup .recap-group .glabel{font-family:var(--font-heading);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);display:inline-flex;align-items:center;gap:7px}.setup .recap-group .glabel .gdot{width:9px;height:9px;border-radius:50%}.setup .g-time .gdot{background:var(--accent-time)}.setup .g-timeline .gdot{background:var(--accent-timeline)}.setup .g-learning .gdot{background:var(--accent-learning)}.setup .recap-group .gtext{font-family:var(--font-heading);font-size:15px;line-height:1.5}.setup .recap-group .gtext em{color:var(--text-muted);font-style:italic}.setup .recap-chip{display:inline-block;font-family:var(--font-heading);font-size:13px;padding:4px 11px;margin:3px 5px 0 0;border-radius:var(--r-pill);background:#ffffffb3;border:1px solid rgba(0,0,0,.07)}.setup .cta{font-family:var(--font-heading);font-weight:700;font-size:16px;color:#fff;background:var(--accent-time);border:none;border-radius:var(--r-pill);padding:15px 30px;cursor:pointer;box-shadow:0 8px 22px #f4845f59;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.setup .cta:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 30px #f4845f6b}.setup .cta:disabled{opacity:.45;cursor:default;box-shadow:none}.setup .hint{font-family:var(--font-heading);font-size:13px;font-style:italic;color:var(--accent-time);margin-top:12px;min-height:18px}@media(prefers-reduced-motion:reduce){.setup *{transition:none!important}}@font-face{font-family:Libre Baskerville;src:url(/assets/LibreBaskerville-VariableFont_wght-BrzLHfEG.ttf) format("truetype");font-weight:400 700;font-style:normal;font-display:swap}@font-face{font-family:Libre Baskerville;src:url(/assets/LibreBaskerville-Italic-VariableFont_wght-CSg2dQZ1.ttf) format("truetype");font-weight:400 700;font-style:italic;font-display:swap}:root{--bg: #E5DCC8;--text: #2D2D2D;--text-muted: #8A8A8A;--card: #FFFFFF;--sidebar-bg: #F0EDE7;--accent-time: #F4845F;--accent-timeline: #7BC8B2;--accent-learning: #B8A9C9;--accent-task: #F7D774;--frustration-tint: #D6E4F0;--ink-timeline: #3F9B82;--ink-learning: #8B79A3;--bg-time: #FCE7DA;--bg-timeline: #DDEFE7;--bg-learning: #EBE3F0;--bg-task: #FBF1D2;--edge-time: rgba(244, 132, 95, .28);--edge-timeline: rgba(123, 200, 178, .32);--edge-learning: rgba(184, 169, 201, .38);--edge-task: rgba(218, 178, 70, .32);--r-bubble: 32px;--r-pill: 9999px;--r-input: 16px;--shadow-rest: 0 18px 44px rgba(58, 42, 20, .14), 0 4px 12px rgba(58, 42, 20, .06);--shadow-hover: 0 24px 56px rgba(58, 42, 20, .18), 0 6px 16px rgba(58, 42, 20, .08);--shadow-sidebar: 0 18px 44px rgba(58, 42, 20, .1), 0 4px 12px rgba(58, 42, 20, .05);--space-1: 8px;--space-2: 12px;--space-3: 16px;--space-4: 20px;--space-5: 24px;--space-6: 28px;--space-7: 32px;--font-heading: "Libre Baskerville", Georgia, serif;--font-body: "Libre Baskerville", Georgia, serif}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:grid;place-items:center;min-height:100vh}.app{display:grid;grid-template-columns:220px 1fr;gap:var(--space-5);width:80vw;height:80vh}.sidebar{background:var(--sidebar-bg);border-radius:var(--r-bubble);padding:var(--space-6) var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-label{font-family:var(--font-heading);font-weight:600;font-size:14px;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;padding:0 var(--space-3);margin-bottom:var(--space-3)}.sidebar-toggle{display:flex;align-items:center;gap:6px;width:fit-content;background:transparent;border:none;cursor:pointer;transition:color .15s ease}.sidebar-toggle:hover{color:var(--text)}.toggle-glyph{font-size:12px;opacity:.55}.project-pill{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--r-pill);font-family:var(--font-heading);font-weight:500;font-size:14px;color:var(--text);cursor:pointer;transition:background .2s ease,color .2s ease;-webkit-user-select:none;user-select:none}.project-pill:hover{background:#0000000a}.project-pill.active{color:#fff;background:#6b7fa3}.project-pill.dragging{cursor:grabbing}.project-pill.drop-before{box-shadow:inset 0 2px #00000059}.project-pill.drop-after{box-shadow:inset 0 -2px #00000059}.pill-dot{width:10px;height:10px;border-radius:50%;background:var(--pill-accent);flex-shrink:0}.project-pill.active .pill-dot{background:#ffffffb3}.project-pills{display:flex;flex-direction:column;gap:var(--space-1)}.pill-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pill-rename{flex:1;min-width:0;font:inherit;color:inherit;background:#ffffff40;border:none;border-radius:6px;padding:2px 6px;outline:none}.pill-act{flex-shrink:0;width:18px;height:18px;display:grid;place-items:center;border:none;background:transparent;color:inherit;opacity:0;line-height:1;border-radius:50%;cursor:pointer;transition:opacity .15s ease,background .15s ease}.pill-del{font-size:16px}.project-pill:hover .pill-act{opacity:.5}.pill-act:hover{opacity:1;background:#0000001a}.project-pill.active .pill-act:hover{background:#ffffff40}.pill-archive-icon{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}.project-pill .pill-archive{opacity:.5}.project-pill:hover .pill-archive{opacity:.7}.pill-archive:hover{opacity:1}.archived-pill{cursor:default}.archived-pill .pill-name{display:flex;flex-direction:column;align-items:flex-start;line-height:1.25;white-space:normal}.pill-sub{font-size:11px;font-weight:400;font-style:italic;color:var(--text-muted)}.archived-pill .pill-restore{opacity:.6}.archived-pill:hover .pill-restore{opacity:.9}.archived-pill .pill-restore:hover{opacity:1}.archive-empty{margin:var(--space-2) var(--space-3);font-family:var(--font-heading);font-style:italic;font-size:13px;line-height:1.5;color:var(--text-muted)}.new-pill{width:100%;border:1px dashed rgba(0,0,0,.18);background:transparent;color:var(--text-muted);font-style:italic;margin-top:var(--space-1)}.new-pill:hover{background:#0000000a;color:var(--text)}.pill-plus{font-style:normal;font-weight:600}.sidebar-signout{margin:0 var(--space-3);padding:10px 0;background:transparent;border:none;border-top:1px solid rgba(0,0,0,.08);font-family:var(--font-heading);font-style:italic;font-size:13px;color:var(--text-muted);text-align:left;cursor:pointer}.dashboard{display:grid;grid-template-rows:auto minmax(0,1fr);gap:var(--space-4);min-height:0}.dashboard.depth{grid-template-rows:minmax(0,1.7fr) minmax(0,1fr)}.project-load-state{grid-row:1 / -1;display:grid;place-items:center;min-height:100%;font-family:var(--font-heading);font-style:italic;color:var(--text-muted);text-align:center}.upper-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-4);min-height:0}.bubble{background:var(--card);border-radius:var(--r-bubble);padding:var(--space-7);box-shadow:var(--shadow-rest);border:1px solid rgba(0,0,0,.04);transition:box-shadow .3s ease,transform .3s ease,border-color .3s ease;display:flex;flex-direction:column;min-height:0}.bubble:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.bubble-time{background:var(--bg-time);border-color:var(--edge-time)}.bubble-timeline{background:var(--bg-timeline);border-color:var(--edge-timeline)}.bubble-learning{background:var(--bg-learning);border-color:var(--edge-learning)}.bubble-task{background:var(--bg-task);border-color:var(--edge-task)}.bubble-header{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.bubble-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.bubble-title{font-family:var(--font-heading);font-weight:600;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.glance-card .bubble-header,.glance-card .glance{cursor:pointer}.glance-cue{margin-left:auto;font-size:15px;line-height:1;color:var(--text-muted);opacity:.45;transition:opacity .2s ease}.glance-card:hover .glance-cue{opacity:.85}.glance{display:flex;flex-direction:column;margin-top:var(--space-3);flex-shrink:0}.depth .glance{padding-bottom:var(--space-3);border-bottom:1px solid rgba(0,0,0,.06)}.glance-eyebrow{font-family:var(--font-heading);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.glance-hero-row{display:flex;align-items:flex-start;gap:var(--space-2);margin-top:5px}.glance-hero{font-family:var(--font-heading);font-size:30px;font-weight:400;line-height:1.25;color:var(--text);letter-spacing:-.01em;flex:1;min-width:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;height:75px}.glance-hero-input{font-family:var(--font-heading);font-size:30px;font-weight:400;line-height:1.25;color:var(--text);letter-spacing:-.01em;background:transparent;border:none;outline:none;padding:0;flex:1;min-width:0;width:100%;height:75px}.glance-hero-input-narrow{width:4ch;flex:none;height:auto}.bubble-time .glance-hero{display:flex;align-items:baseline}.glance .cslider{flex:none;width:100%;margin-top:var(--space-2);height:5px}.glance .cslider:before{top:-7px;right:0;bottom:-12px;left:0}.glance .cslider .cslider-knob{opacity:1}.glance-bar-wrap{height:5px;border-radius:var(--r-pill);background:#00000017;overflow:hidden;margin-top:var(--space-2);flex-shrink:0}.glance-bar-fill{height:100%;border-radius:var(--r-pill);transition:width .4s ease}.glance-spark{display:flex;align-items:flex-end;gap:4px;height:36px;flex-shrink:0}.glance-bar{width:7px;border-radius:3px;background:var(--accent-time);opacity:.4;min-height:3px}.glance-bar.today{opacity:.95}.glance-clock{flex-shrink:0;width:36px;height:36px;border-radius:50%;border:none;background:var(--accent-time);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #f4845f66;transition:transform .16s ease,box-shadow .16s ease}.glance-clock:hover{transform:scale(1.06)}.glance-clock:focus-visible{outline:none;box-shadow:0 0 0 3px #f4845f80}.glance-clock svg{width:13px;height:13px;fill:#fff}.panel-scroll{margin-top:var(--space-3);overflow-y:auto;min-height:0;flex:1;scrollbar-width:none}.panel-scroll::-webkit-scrollbar{display:none}.dashboard .col-head{display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-2) var(--space-1);margin-bottom:2px;font-family:var(--font-heading);font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted)}.dashboard .list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.dashboard .row{display:flex;align-items:center;gap:var(--space-2);padding:9px var(--space-2);border-radius:var(--r-input);transition:background .15s ease}.dashboard .row:hover{background:#ffffff73}.dashboard .row.dragging{background:#ffffffb3;box-shadow:var(--shadow-rest)}.dashboard .row.drop-before{box-shadow:inset 0 2px #00000059}.dashboard .row.drop-after{box-shadow:inset 0 -2px #00000059}.dashboard .row-handle{width:8px;height:14px;fill:var(--text);opacity:.16;cursor:grab;flex-shrink:0;transition:opacity .2s ease}.dashboard .row:hover .row-handle{opacity:.42}.dashboard .row-handle:active{cursor:grabbing}.dashboard .row-name{flex:1;min-width:0;font-family:var(--font-body);font-size:14px;color:var(--text);line-height:1.35;cursor:text;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard .row-name-input{flex:1;min-width:0;font:inherit;font-size:14px;color:inherit;background:#ffffffb3;border:none;border-radius:8px;padding:2px 6px;outline:none}.dashboard .row-del{background:transparent;border:none;color:var(--text-muted);font-size:17px;line-height:1;cursor:pointer;padding:0 2px;flex-shrink:0;opacity:0;transition:opacity .15s ease,color .15s ease}.dashboard .row:hover .row-del{opacity:.7}.dashboard .row-del:hover{color:var(--text)}.dashboard .row-add{display:flex;align-items:center;gap:var(--space-2);background:transparent;border:none;font-family:var(--font-heading);font-style:italic;font-size:13px;color:var(--text-muted);cursor:pointer;padding:9px var(--space-2);margin-top:4px;border-radius:var(--r-input);text-align:left;transition:color .2s ease,background .2s ease;width:fit-content}.dashboard .row-add:hover{color:var(--text);background:#ffffff80}.dashboard input.row-add{color:var(--text);font-family:var(--font-body);font-size:14px;font-style:normal}.dashboard input.row-add::placeholder{color:var(--text-muted);font-style:italic;opacity:1}.cslider{position:relative;flex:1;min-width:0;height:7px;align-self:center;border-radius:var(--r-pill);background:#0000001a;cursor:pointer;touch-action:none}.cslider:before{content:"";position:absolute;top:-8px;right:0;bottom:-8px;left:0}.cslider:focus-visible{outline:none;box-shadow:0 0 0 3px #0000001a}.cslider-fill{position:absolute;left:0;top:0;height:100%;border-radius:var(--r-pill);pointer-events:none}.cslider-knob{position:absolute;top:50%;width:15px;height:15px;border-radius:50%;border:2px solid #fff;box-shadow:0 1px 3px #3a2a1438;transform:translate(-50%,-50%);pointer-events:none;opacity:0;transition:opacity .16s ease}.row:hover .cslider-knob,.cslider:focus-visible .cslider-knob{opacity:1}.bubble-learning .cslider-knob{opacity:1}.time-date{flex:1;min-width:0;font-family:var(--font-heading);font-size:14px;color:var(--text)}.time-date .dow{color:var(--text-muted)}.time-hours{width:56px;flex-shrink:0;text-align:right;font-family:var(--font-heading);font-weight:700;font-size:13px;color:var(--text);letter-spacing:-.01em;font-variant-numeric:tabular-nums}.time-hours.editable{cursor:text}.time-hours.editable:hover{text-decoration:underline dotted var(--text-muted);text-underline-offset:3px}.time-hours-input{width:56px;flex-shrink:0;text-align:right;font-family:var(--font-heading);font-weight:700;font-size:13px;color:var(--text);letter-spacing:-.01em;font-variant-numeric:tabular-nums;background:transparent;border:none;border-bottom:1.5px dotted var(--text-muted);border-radius:0;padding:0 0 1px;outline:none}.time-foot{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-2);margin-top:var(--space-2);padding:var(--space-2) var(--space-2) 0;border-top:1px solid rgba(0,0,0,.06);font-family:var(--font-heading);font-size:12px;color:var(--text-muted);flex-shrink:0}.time-foot b{font-weight:700;color:var(--text);font-style:normal}.hist-toggle{display:inline-flex;align-items:center;gap:4px;background:transparent;border:none;padding:0;cursor:pointer;font-family:var(--font-heading);font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);transition:color .15s ease}.hist-toggle:hover{color:var(--text)}.ph-state{width:18px;height:18px;flex-shrink:0;border-radius:50%;border:1.5px solid rgba(0,0,0,.22);background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:border-color .2s ease,background .2s ease}.ph-state:hover{border-color:var(--accent-timeline)}.row.done .ph-state{background:var(--accent-timeline);border-color:var(--accent-timeline)}.ph-state svg{width:10px;height:10px;stroke:#fff;stroke-width:2.4;fill:none;stroke-linecap:round;stroke-linejoin:round;opacity:0;transition:opacity .2s ease}.row.done .ph-state svg{opacity:1}.row.done .row-name{color:var(--text-muted);text-decoration:line-through;text-decoration-color:#00000040}.row.current{background:#7bc8b229}.row.current:hover{background:#7bc8b23d}.now-tag{flex-shrink:0;font-family:var(--font-heading);font-style:italic;font-size:11px;color:var(--ink-timeline);letter-spacing:.03em}.ph-main{flex:1;min-width:0}.ph-title{display:flex;align-items:baseline;gap:var(--space-1);min-width:0}.ph-days{flex-shrink:0;font-family:var(--font-heading);font-weight:700;font-size:13px;color:var(--text);cursor:text}.ph-days:hover{text-decoration:underline dotted var(--text-muted);text-underline-offset:3px}.ph-days-input{width:40px;height:20px;line-height:20px;font-family:var(--font-heading);font-weight:700;font-size:13px;text-align:right;color:var(--text);background:transparent;border:none;border-bottom:1.5px dotted var(--text-muted);border-radius:0;padding:0 0 1px;outline:none;-moz-appearance:textfield}.ph-days-input::-webkit-outer-spin-button,.ph-days-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.dashboard .row-name.lr-name,.dashboard .row-name-input.lr-name{flex:0 1 auto;max-width:120px}.lr-slider-wrap{flex:1;min-width:60px;display:flex;align-items:center}.lr-pct{width:38px;flex-shrink:0;text-align:right;font-family:var(--font-heading);font-weight:700;font-size:13px;color:var(--text);font-variant-numeric:tabular-nums}.focus-target{flex-shrink:0;width:18px;height:18px;border-radius:50%;border:1.5px solid rgba(0,0,0,.18);background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;position:relative;transition:border-color .18s ease}.focus-target:after{content:"";width:8px;height:8px;border-radius:50%;background:transparent;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:background .18s ease}.focus-target:hover{border-color:var(--accent-learning)}.focus-target:hover:after{background:#b8a9c973}.row.focus .focus-target{border-color:var(--accent-learning)}.row.focus .focus-target:after{background:var(--accent-learning)}.focus-target svg{width:10px;height:10px;stroke:#fff;stroke-width:2.4;fill:none;stroke-linecap:round;stroke-linejoin:round;opacity:0;transition:opacity .2s ease}.row.done .focus-target{background:var(--accent-learning);border-color:var(--accent-learning);cursor:default}.row.done .focus-target:after{display:none}.row.done .focus-target svg{opacity:1}.focus-tag{flex-shrink:0;font-family:var(--font-heading);font-style:italic;font-size:11px;color:var(--ink-learning);letter-spacing:.03em}.task-prompt{font-family:var(--font-heading);font-style:italic;font-size:15px;color:var(--text);opacity:.75;margin-top:var(--space-3);margin-bottom:var(--space-4);flex-shrink:0}.task-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px;flex:1;min-height:0;overflow-y:auto;scrollbar-width:none}.task-list::-webkit-scrollbar{display:none}.task-item{display:flex;align-items:center;gap:var(--space-3);padding:10px var(--space-3);border-radius:var(--r-input);transition:background .15s ease}.task-item:hover{background:#00000008}.task-check{width:22px;height:22px;border-radius:50%;border:1.5px solid rgba(0,0,0,.22);background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;transition:border-color .2s ease,background .2s ease}.task-check:hover{border-color:var(--accent-task)}.task-item.checked .task-check{background:var(--accent-task);border-color:var(--accent-task)}.task-check svg{width:12px;height:12px;stroke:var(--text);stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round;opacity:0;transition:opacity .2s ease}.task-item.checked .task-check svg{opacity:1}.task-text{flex:1;font-family:var(--font-body);font-size:15px;color:var(--text);line-height:1.4}.task-item.checked .task-text{text-decoration:line-through;text-decoration-color:#0000004d;color:var(--text-muted)}.task-handle{width:8px;height:14px;fill:var(--text);opacity:.18;cursor:grab;flex-shrink:0;transition:opacity .2s ease}.task-item:hover .task-handle{opacity:.45}.task-add{flex:1;background:transparent;border:none;font-family:var(--font-heading);font-style:italic;font-size:14px;color:var(--text-muted);cursor:pointer;padding:0;text-align:left;outline:none;transition:color .2s ease}.task-add:hover,input.task-add,textarea.task-add{color:var(--text)}.task-add-row.adding{background:#00000008}.panel-toggle{display:flex;align-items:center;gap:2px;margin-left:auto;background:#0000000d;border-radius:var(--r-pill);padding:3px}.panel-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:22px;border:none;border-radius:999px;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .15s ease,color .15s ease;padding:0}.panel-toggle-btn svg{width:16px;height:13px}.panel-toggle-btn:hover{color:var(--text)}.panel-toggle-btn.active{background:var(--bg-task);color:var(--text);box-shadow:0 1px 3px #3a2a141f}.th-log{display:flex;flex-direction:column;flex:1;min-height:0;margin-top:var(--space-3)}.th-feed{list-style:none;margin:0;padding:0;flex:1;min-height:0;overflow-y:auto;scrollbar-width:none;display:flex;flex-direction:column;gap:4px}.th-feed::-webkit-scrollbar{display:none}.th-row{display:flex;align-items:flex-start;gap:var(--space-2);padding:10px var(--space-2) 10px var(--space-3);border-radius:var(--r-input);transition:background .15s ease;position:relative}.th-row:hover{background:#00000008}.th-row.th-selected{background:#f7d7742e}.th-row.drop-before{box-shadow:inset 0 2px 0 var(--accent-task)}.th-row.drop-after{box-shadow:inset 0 -2px 0 var(--accent-task)}.th-check{flex-shrink:0;width:15px;height:15px;margin-top:3px;accent-color:var(--accent-task);cursor:pointer;opacity:0;transition:opacity .15s ease}.th-row:hover .th-check,.th-row.th-selected .th-check{opacity:1}.th-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.th-title{font-family:var(--font-heading);font-size:12px;font-weight:600;color:var(--text);letter-spacing:.02em;cursor:text;align-self:flex-start;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.th-title-empty{font-weight:400;font-style:italic;color:var(--text-muted);opacity:0;transition:opacity .15s ease}.th-row:hover .th-title-empty{opacity:.6}.th-title-input{font-weight:600;background:#ffffffa6;border:none;border-radius:6px;padding:1px 5px;outline:none;width:100%}.th-text{font-family:var(--font-body);font-size:14px;color:var(--text);line-height:1.5;cursor:text;word-break:break-word;margin:0}.th-text-input{width:100%;resize:none;font:inherit;font-size:14px;color:inherit;background:#ffffffa6;border:none;border-radius:8px;padding:3px 6px;outline:none;min-height:48px;line-height:1.5}.th-del{flex-shrink:0;background:transparent;border:none;color:var(--text-muted);font-size:17px;line-height:1;cursor:pointer;padding:0 2px;opacity:0;transition:opacity .15s ease,color .15s ease;margin-top:1px}.th-row:hover .th-del{opacity:.7}.th-del:hover{color:var(--text);opacity:1!important}.th-handle{flex-shrink:0;width:8px;height:14px;fill:var(--text);opacity:0;cursor:grab;margin-top:4px;transition:opacity .2s ease}.th-row:hover .th-handle{opacity:.35}.th-handle:active{cursor:grabbing}.th-pop{flex-shrink:0;background:transparent;border:none;cursor:pointer;padding:0 2px;opacity:0;transition:opacity .15s ease;margin-top:2px}.th-row:hover .th-pop{opacity:.6}.th-pop:hover{opacity:1}.th-pop-icon{width:13px;height:13px;fill:none;stroke:var(--text-muted);stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}.th-pop:hover .th-pop-icon{stroke:var(--text)}.th-group{border:1.5px dashed rgba(0,0,0,.18);border-radius:var(--r-input);padding:var(--space-2);display:flex;flex-direction:column;gap:2px;transition:border-color .15s ease}.th-group:hover{border-color:#00000047}.th-group.th-dragging{opacity:.5}.th-group.th-group-selected{border-style:solid;border-color:var(--accent-task);background:#f7d7741a}.th-group-check{flex-shrink:0;width:15px;height:15px;accent-color:var(--accent-task);cursor:pointer;opacity:0;transition:opacity .15s ease}.th-group-header:hover .th-group-check,.th-group-selected .th-group-check{opacity:1}.th-group-header:hover .th-handle{opacity:.35}.th-group.drop-before{box-shadow:inset 0 2px 0 var(--accent-task)}.th-group.drop-after{box-shadow:inset 0 -2px 0 var(--accent-task)}.th-group-header{display:flex;align-items:center;gap:var(--space-2);padding:4px var(--space-1);cursor:default}.th-group-chip{font-family:var(--font-heading);font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--text-muted);background:#0000000f;border-radius:var(--r-pill);padding:2px 8px;white-space:nowrap;flex-shrink:0}.th-group-name{font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:text}.th-group-name-input{flex:1;min-width:0;font:inherit;font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--text);background:#ffffffb3;border:none;border-radius:8px;padding:2px 6px;outline:none}.th-ungroup{flex-shrink:0;background:transparent;border:none;font-family:var(--font-heading);font-size:12px;color:var(--text-muted);cursor:pointer;padding:2px 6px;border-radius:var(--r-pill);transition:background .15s ease,color .15s ease}.th-ungroup:hover{background:#0000000f;color:var(--text)}.th-group-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.th-group-list .th-row{border-radius:10px}.th-action-bar{display:flex;align-items:center;gap:var(--space-2);padding:8px var(--space-3);background:#f7d77440;border-radius:var(--r-input);flex-shrink:0;margin-top:4px}.th-action-count{font-family:var(--font-heading);font-size:13px;color:var(--text-muted);flex:1}.th-action-btn{background:var(--accent-task);border:none;border-radius:var(--r-pill);font-family:var(--font-heading);font-size:13px;font-weight:600;color:var(--text);padding:5px 14px;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.th-action-btn:hover{transform:translateY(-1px);box-shadow:0 3px 8px #dab24666}.th-action-btn-ghost{background:transparent;border:1.5px solid rgba(0,0,0,.18);color:var(--text-muted)}.th-action-btn-ghost:hover{background:#0000000a;color:var(--text);box-shadow:none}.th-action-clear{background:transparent;border:none;font-size:18px;color:var(--text-muted);cursor:pointer;padding:0 2px;line-height:1;transition:color .15s ease}.th-action-clear:hover{color:var(--text)}.th-add-row{align-items:center}.th-add-row.adding{background:#00000008}.th-add-btn{flex:1;background:transparent;border:none;font-family:var(--font-heading);font-style:italic;font-size:14px;color:var(--text-muted);cursor:pointer;padding:0;text-align:left;transition:color .2s ease}.th-add-btn:hover{color:var(--text)}.th-add-input{flex:1;font-family:var(--font-body);font-size:14px;color:var(--text);background:transparent;border:none;outline:none;padding:0}@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
