:root{--paper: #fbf8f2;--paper-2: #f4efe4;--paper-3: #ece5d6;--ink: #211e1a;--ink-soft: #6f675b;--ink-faint: #a9a093;--line: #e4ddce;--line-strong: #d6cdba;--progress: #1e6e58;--progress-tint: #1e6e5814;--distraction: #c4683b;--distraction-tint: #c4683b14;--row-label: 132px;--radius: 12px;--radius-sm: 8px;--maxw: 1140px;--font-display: "Fraunces", Georgia, "Times New Roman", serif;--font-body: "Hanken Grotesk", system-ui, sans-serif;--shadow-soft: 0 1px 2px rgba(40, 33, 22, .04), 0 8px 24px rgba(40, 33, 22, .05)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-body);color:var(--ink);background-color:var(--paper);background-image:radial-gradient(var(--line) 1px,transparent 1px);background-size:22px 22px;background-attachment:fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.5}button{font-family:inherit;cursor:pointer}.app{max-width:var(--maxw);margin:0 auto;padding:40px 28px 56px}.header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-bottom:22px;margin-bottom:26px;border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:14px}.brand__dot{width:18px;height:18px;border-radius:50%;background:var(--progress);flex:none;margin-top:4px;box-shadow:0 0 0 5px var(--progress-tint)}.brand__name{font-family:var(--font-display);font-weight:500;font-size:27px;letter-spacing:-.01em;margin:0;line-height:1.05}.brand__tag{margin:2px 0 0;color:var(--ink-soft);font-size:14px;font-style:italic;font-family:var(--font-display)}.datenav{display:flex;align-items:center;gap:8px}.datenav__arrow{width:38px;height:38px;border-radius:50%;border:1px solid var(--line-strong);background:var(--paper);color:var(--ink);font-size:22px;line-height:1;display:grid;place-items:center;transition:background .15s ease,transform .15s ease,border-color .15s ease}.datenav__arrow:hover{background:var(--paper-2);border-color:var(--ink-faint)}.datenav__arrow:active{transform:scale(.94)}.datenav__center{text-align:center;min-width:188px}.datenav__date{display:block;font-family:var(--font-display);font-size:18px;font-weight:500}.datenav__today{margin-top:2px;border:none;background:none;color:var(--progress);font-size:12.5px;font-weight:600;letter-spacing:.02em;padding:2px 4px}.datenav__today:hover:not(:disabled){text-decoration:underline}.datenav__today.is-current{color:var(--ink-faint);cursor:default}.layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:28px;align-items:start}.board{min-width:0}.hint{position:relative;border:1px dashed var(--line-strong);border-radius:var(--radius);padding:16px 18px;margin-bottom:18px;background:#ffffff73}.hint__dismiss{position:absolute;top:8px;right:10px;border:0;background:none;padding:0 4px;line-height:1;font-size:18px;color:var(--ink-faint);cursor:pointer}.hint__dismiss:hover{color:var(--ink)}.hint-show{border:0;background:none;padding:0;margin-bottom:18px;font:inherit;font-size:13px;color:var(--ink-faint);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.hint-show:hover{color:var(--ink)}.hint__lead{margin:0 0 4px;font-family:var(--font-display);font-size:16px;font-weight:500}.hint__body{margin:0;color:var(--ink-soft);font-size:14px}.grid{display:flex;flex-direction:column;gap:8px}.grid__row{display:grid;gap:8px;animation:rise .4s ease both}.grid__row--head{animation:none;margin-bottom:2px}.grid__colhead{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);text-align:center;padding:4px 0}.grid__rowhead{display:flex;align-items:center;font-family:var(--font-display);font-weight:500;font-size:15px;padding-right:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell{position:relative;min-height:78px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#ffffff8c;padding:9px 9px 7px;display:flex;flex-direction:column;justify-content:space-between;transition:border-color .14s ease,background .14s ease,box-shadow .14s ease}.cell:hover{border-color:var(--ink-faint);background:#fff;box-shadow:var(--shadow-soft)}.cell:after{content:"+";position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:22px;color:var(--ink-faint);opacity:0;transition:opacity .14s ease;pointer-events:none}.cell:hover:after{opacity:.35}.cell:active{background:var(--progress-tint)}.cell__marks{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:5px;align-content:flex-start}.mark{width:12px;height:12px;padding:0;border:none;background:var(--progress);border-radius:50%;transition:transform .12s ease,filter .12s ease;animation:pop .18s ease}.mark:hover{transform:scale(1.25);filter:saturate(1.2)}.mark--distraction{background:var(--distraction);border-radius:2px;transform:rotate(45deg)}.mark--distraction:hover{transform:rotate(45deg) scale(1.25)}.cell__overflow{font-size:11px;color:var(--ink-faint);align-self:center;font-weight:600}.cell__footer{position:relative;z-index:1;display:flex;align-items:center;gap:6px;margin-top:6px;min-height:18px}.count{font-size:11px;font-weight:700;font-variant-numeric:tabular-nums;padding:1px 6px;border-radius:999px}.count--progress{color:var(--progress);background:var(--progress-tint)}.count--distraction{color:var(--distraction);background:var(--distraction-tint)}.cell__distract{margin-left:auto;width:20px;height:20px;border-radius:50%;border:1px solid var(--line-strong);background:var(--paper);color:var(--distraction);font-size:15px;line-height:1;display:grid;place-items:center;opacity:0;transition:opacity .14s ease,background .14s ease}.cell:hover .cell__distract{opacity:1}.cell__distract:hover{background:var(--distraction-tint)}.legend{display:flex;flex-wrap:wrap;gap:6px 18px;margin:18px 2px 0;font-size:12.5px;color:var(--ink-soft)}.legend span{display:inline-flex;align-items:center;gap:6px}.legend__sw{width:10px;height:10px;display:inline-block}.legend__sw--progress{background:var(--progress);border-radius:50%}.legend__sw--distraction{background:var(--distraction);border-radius:2px;transform:rotate(45deg)}.sidebar{display:flex;flex-direction:column;gap:18px;position:sticky;top:24px}.panel{border:1px solid var(--line);border-radius:var(--radius);background:#ffffff9e;padding:16px 16px 18px}.panel__head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:12px}.panel__title{font-family:var(--font-display);font-size:16px;font-weight:500;margin:0}.panel__sub{font-size:12px;color:var(--ink-faint);font-variant-numeric:tabular-nums}.panel__note,.panel__sub{font-weight:500}.panel__note{margin:-4px 0 12px;font-size:12.5px;color:var(--ink-soft);line-height:1.45}.totals{display:flex;gap:10px;margin-bottom:14px}.total{flex:1;border-radius:var(--radius-sm);background:var(--paper-2);padding:10px 12px}.total__num{display:block;font-family:var(--font-display);font-size:26px;font-weight:600;line-height:1;font-variant-numeric:tabular-nums}.total__num--progress{color:var(--progress)}.total__num--distraction{color:var(--distraction)}.total__label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}.spark{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;align-items:end}.spark__col{display:flex;flex-direction:column;align-items:center;gap:5px;margin:0;padding:0;border:0;background:none;font:inherit;cursor:pointer}.spark__col:hover .spark__bar{outline:2px solid var(--ink-faint);outline-offset:1px}.spark__col:focus-visible{outline:2px solid var(--ink);outline-offset:2px;border-radius:4px}.spark__bar{width:100%;height:46px;border-radius:4px;background:var(--paper-3);display:flex;flex-direction:column-reverse;overflow:hidden}.spark__col.is-selected .spark__bar{outline:2px solid var(--ink);outline-offset:1px}.spark__seg{display:block;width:100%;min-height:2px}.spark__seg--progress{background:var(--progress)}.spark__seg--distraction{background:var(--distraction)}.spark__day{font-size:10px;color:var(--ink-faint);font-weight:600;text-transform:uppercase}.spark__day.is-today{color:var(--ink)}.arealist{list-style:none;margin:0 0 12px;padding:0;display:flex;flex-direction:column;gap:2px}.arearow{display:flex;align-items:center;gap:8px;border-radius:var(--radius-sm);padding:2px 4px 2px 6px;transition:background .12s ease}.arearow:hover{background:var(--paper-2)}.arearow.is-hidden{opacity:.55}.arearow__name{flex:1;text-align:left;border:none;background:none;color:var(--ink);font-size:14px;font-weight:500;padding:5px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.arearow__name:hover{color:var(--progress)}.arearow__actions{display:flex;align-items:center;gap:1px;opacity:0;transition:opacity .12s ease}.arearow:hover .arearow__actions,.arearow:focus-within .arearow__actions,.arearow.is-hidden .arearow__actions{opacity:1}.arearow__move,.arearow__delete{border:none;background:none;color:var(--ink-faint);font-size:13px;line-height:1;padding:4px;transition:color .12s ease,opacity .12s ease}.arearow__move:hover{color:var(--ink)}.arearow__move:disabled{opacity:.3;cursor:default}.arearow__delete:hover{color:var(--distraction)}.arearow__toggle{border:none;background:none;color:var(--ink-faint);font-size:11.5px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;padding:4px;transition:color .12s ease}.arearow__toggle:hover{color:var(--ink)}.arearow.is-hidden .arearow__toggle{color:var(--progress)}.linkbtn--block{display:block;margin-top:10px}.create-row{display:flex;gap:8px}.input{flex:1;min-width:0;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--paper);color:var(--ink);font-size:14px;padding:8px 10px;font-family:inherit}.input:focus{outline:none;border-color:var(--progress);box-shadow:0 0 0 3px var(--progress-tint)}.input::placeholder{color:var(--ink-faint)}.btn{border:1px solid var(--ink);background:var(--ink);color:var(--paper);font-size:13px;font-weight:600;padding:8px 14px;border-radius:var(--radius-sm);transition:opacity .14s ease,transform .12s ease}.btn:hover{opacity:.88}.btn:active{transform:scale(.97)}.datactl{display:flex;flex-direction:column;gap:8px}.btn--soft{background:var(--paper);color:var(--ink);border-color:var(--line-strong);text-align:center}.btn--soft:hover{background:var(--paper-2);opacity:1}.btn--danger{background:var(--paper);border-color:var(--distraction);color:var(--distraction);text-align:center}.btn--danger:hover{background:var(--distraction-tint);opacity:1}.linkbtn{border:none;background:none;color:var(--ink-soft);font-size:12px;font-weight:600;padding:0}.linkbtn:hover{color:var(--ink);text-decoration:underline}.empty{border:1px dashed var(--line-strong);border-radius:var(--radius);padding:30px 24px;text-align:center}.empty__title{font-family:var(--font-display);font-size:17px;margin:0 0 6px}.empty__body{margin:0 auto;max-width:360px;color:var(--ink-soft);font-size:14px}.foot{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center;margin-top:44px;padding-top:18px;border-top:1px solid var(--line);color:var(--ink-faint);font-size:12.5px}.foot__sep{color:var(--line-strong)}@keyframes pop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.25)}to{transform:scale(1);opacity:1}}.mark--distraction{animation-name:pop-diamond}@keyframes pop-diamond{0%{transform:rotate(45deg) scale(0);opacity:0}60%{transform:rotate(45deg) scale(1.25)}to{transform:rotate(45deg) scale(1);opacity:1}}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.grid__row,.mark{animation:none!important}}@media (max-width: 880px){.layout{grid-template-columns:1fr}.sidebar{position:static;flex-direction:column}:root{--row-label: 104px}}@media (max-width: 560px){.app{padding:24px 16px 40px}.board{overflow-x:auto}.grid{min-width:520px}}
