:root{
  --cream:#FBF7F0; --ink:#1c1b1a; --muted:#6b6660;
  --cyan:#35C2D6; --pink:#F2789F; --amber:#F6B04E; --green:#37B87C; --red:#EE6C6C;
  --card:#ffffff; --line:#ECE4D8; --shadow:0 10px 40px rgba(28,27,26,.14);
  --grad:linear-gradient(135deg,var(--cyan),var(--pink) 55%,var(--amber));
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
[hidden]{display:none!important}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:var(--cream);color:var(--ink);
  background-image:radial-gradient(120% 60% at 50% -10%,rgba(242,120,159,.18),transparent 60%),
                   radial-gradient(120% 60% at 100% 0%,rgba(53,194,214,.16),transparent 55%);
  overscroll-behavior:none;
}
#app{max-width:480px;margin:0 auto;min-height:100dvh;padding:env(safe-area-inset-top) 18px env(safe-area-inset-bottom);display:flex;flex-direction:column}
.screen{display:none;flex:1;flex-direction:column;padding-top:14px}
.screen.active{display:flex}

/* budget */
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;letter-spacing:-.02em;padding:18px 0 4px}
.bunny-img{width:34px;height:34px;border-radius:9px;flex:none;box-shadow:0 3px 10px rgba(28,27,26,.18)}
.lede{font-size:26px;font-weight:700;letter-spacing:-.02em;margin:24px 0 18px;line-height:1.15}
.budget-grid{display:grid;gap:14px}
.budget{appearance:none;border:none;border-radius:22px;background:var(--card);box-shadow:var(--shadow);
  padding:22px;text-align:left;display:grid;grid-template-columns:auto 1fr;gap:4px 12px;align-items:baseline;cursor:pointer;transition:transform .12s}
.budget:active{transform:scale(.97)}
.budget b{font-size:40px;grid-row:span 2;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.budget span{font-weight:700;color:var(--muted)}
.budget em{grid-column:2;font-style:normal;color:var(--muted);font-size:14px}
.ghost{margin-top:auto;align-self:center;background:none;border:none;color:var(--muted);font-size:15px;padding:18px;cursor:pointer}

/* bars */
.bar{display:flex;align-items:center;gap:10px;padding:6px 0 12px;font-weight:700}
.spacer{flex:1}
.icon-btn{appearance:none;border:1px solid var(--line);background:var(--card);border-radius:12px;min-width:40px;height:40px;padding:0 10px;font-size:16px;font-weight:700;cursor:pointer}
.timer{font-size:32px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.timer.low{color:var(--red)}
.sprint-progress{height:6px;background:var(--line);border-radius:999px;overflow:hidden;margin-bottom:14px}
#sprint-bar{height:100%;width:0;background:var(--grad);transition:width .4s}

/* task card */
.card-wrap{flex:1;min-height:300px;position:relative}
.tcard{background:var(--card);border-radius:24px;box-shadow:var(--shadow);padding:22px;display:flex;flex-direction:column;gap:2px}
.pills{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.pill{font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:6px 11px;border-radius:999px;color:#fff}
.pill.kind{background:var(--ink)}
.pill.area{background:var(--cyan)}
.pill.area.kwelity{background:var(--pink)} .pill.area.thryve{background:var(--amber)} .pill.area.appointment{background:var(--cyan)}
.pill.area.pixels{background:#7C6BF2} .pill.area.family{background:var(--green)}
.pill.owner{background:#fff;color:var(--ink);border:1px solid var(--line);text-transform:none;letter-spacing:0;font-weight:700}
.imp{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.imp .dot{width:10px;height:10px;border-radius:50%}
.imp.High{color:var(--red)} .imp.High .dot{background:var(--red)}
.imp.Medium{color:var(--amber)} .imp.Medium .dot{background:var(--amber)}
.imp.Low{color:var(--muted)} .imp.Low .dot{background:var(--muted)}
.tcard h2{font-size:25px;line-height:1.2;letter-spacing:-.02em;margin:14px 0 6px}
.support{color:var(--ink);font-size:14px;font-weight:600;margin:0 0 8px}
.support b{color:var(--muted);font-weight:600}
.tcard .detail{color:var(--muted);font-size:16px;line-height:1.5;margin:0;flex:0 1 auto;overflow:auto}
.metarow{display:flex;gap:16px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--line);color:var(--muted);font-size:14px;font-weight:600}
.metarow b{color:var(--ink)}
.due-today{color:var(--red)!important}
.defer-why{margin:12px 0 0;padding:11px 13px;background:linear-gradient(135deg,rgba(246,176,78,.16),rgba(242,120,159,.12));border:1px solid rgba(246,176,78,.45);border-radius:14px;font-size:14px;line-height:1.4;color:var(--ink)}
.defer-why b{color:var(--amber)}
.card-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--muted);gap:8px;padding:30px}

.tcard{will-change:transform;touch-action:none}
.stamp{position:absolute;top:30px;font-size:22px;font-weight:900;border:4px solid;border-radius:12px;padding:4px 14px;opacity:0;pointer-events:none;z-index:5}
.stamp.s-done{right:30px;color:var(--green);border-color:var(--green);transform:rotate(12deg)}
.stamp.s-drop{left:30px;color:var(--red);border-color:var(--red);transform:rotate(-12deg)}
.stamp.s-defer{left:50%;top:24px;translate:-50% 0;color:var(--amber);border-color:var(--amber)}
.stamp.s-delegate{left:50%;bottom:24px;top:auto;translate:-50% 0;color:var(--cyan);border-color:var(--cyan)}
.swipe-legend{margin-top:2px;font-size:12px}
.swipe-legend b{color:var(--ink)}

/* nudge */
.nudge{margin:12px 0 4px;background:linear-gradient(135deg,rgba(246,176,78,.18),rgba(242,120,159,.18));border:1px solid rgba(246,176,78,.5);border-radius:16px;padding:13px 15px;font-size:14px;font-weight:600;line-height:1.4;display:flex;gap:9px;align-items:flex-start}

/* the 4 D's */
.dactions{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin:14px 0 2px}
.d{appearance:none;border:none;border-radius:16px;background:var(--card);box-shadow:var(--shadow);
  padding:13px 4px;font-size:13px;font-weight:800;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:5px;transition:transform .1s}
.d span{font-size:21px}
.d:active{transform:scale(.93)}
.d.done{color:var(--green)} .d.defer{color:var(--amber)} .d.delegate{color:var(--cyan)} .d.drop{color:var(--red)}
.hint{text-align:center;color:var(--muted);font-size:13px;margin:10px 0 4px}

/* modals */
.cta{appearance:none;border:none;border-radius:18px;background:var(--ink);color:#fff;font-weight:700;font-size:17px;padding:16px;margin:12px 0 4px;cursor:pointer;width:100%}
.cta:active{transform:scale(.98)}
.modal{position:fixed;inset:0;background:rgba(28,27,26,.5);display:flex;align-items:flex-end;justify-content:center;z-index:50;backdrop-filter:blur(3px)}
.sheet{background:var(--cream);width:100%;max-width:480px;border-radius:28px 28px 0 0;padding:24px 20px calc(22px + env(safe-area-inset-bottom));box-shadow:var(--shadow);animation:rise .22s ease;max-height:92dvh;overflow:auto}
@keyframes rise{from{transform:translateY(100%)}}
.sheet h2{font-size:23px;margin:2px 0 10px;letter-spacing:-.02em}
.modal-task{color:var(--muted);margin:0 0 14px;font-weight:600}
textarea,input,select{width:100%;border:1px solid var(--line);border-radius:14px;padding:13px;font-size:16px;font-family:inherit;background:#fff;resize:none}
.time-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:12px 0}
.time-row label{color:var(--muted);font-weight:600}
.time-row input{width:90px;text-align:center}
.fld{display:block;font-size:13px;font-weight:700;color:var(--muted);margin:10px 0 0}
.fld input,.fld textarea,.fld select{margin-top:6px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.seg{display:flex;gap:8px;margin-top:6px}
.seg button{flex:1;border:1px solid var(--line);background:#fff;border-radius:12px;padding:11px;font-weight:700;font-size:14px;cursor:pointer;color:var(--muted)}
.seg button.on{background:var(--ink);color:#fff;border-color:var(--ink)}
/* defer reason quick-chips */
.defer-quick{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 12px}
.defer-quick button{flex:1 1 calc(50% - 8px);border:1px solid var(--line);background:#fff;border-radius:12px;padding:11px 10px;font-weight:700;font-size:13px;cursor:pointer;color:var(--ink);text-align:left}
.defer-quick button:active{transform:scale(.97)}
/* defer "bring it back" snooze picker */
.defer-when{margin:0 0 12px}
.dw-label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:7px;line-height:1.3}
.defer-when-chips{display:flex;gap:8px;margin-bottom:8px}
.defer-when-chips button{flex:1;border:1px solid var(--line);background:#fff;border-radius:12px;padding:10px;font-weight:700;font-size:13px;cursor:pointer;color:var(--ink)}
.defer-when-chips button.on{background:var(--amber);color:#fff;border-color:var(--amber)}
#defer-date{width:100%}

/* stats */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px}
.stat{background:var(--card);border-radius:18px;box-shadow:var(--shadow);padding:16px}
.stat b{display:block;font-size:32px;letter-spacing:-.02em}
.stat span{color:var(--muted);font-size:13px;font-weight:600}
h3{font-size:15px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:22px 0 10px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chips span{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-size:14px;font-weight:600}
.chips b{color:var(--pink)}
.methods{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.methods li{background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:14px 16px}
.methods .mt{font-weight:700;font-size:15px;margin-bottom:3px}
.methods .mm{color:var(--muted);font-size:14px;line-height:1.45}
.methods .badge{display:inline-block;background:var(--red);color:#fff;font-size:12px;font-weight:800;border-radius:999px;padding:2px 9px;margin-left:6px}
.empty-note{color:var(--muted);font-size:14px}

/* list view */
.icon-btn.danger{color:var(--red);border-color:rgba(238,108,108,.4)}
.list-body{flex:1;overflow:auto;display:flex;flex-direction:column;gap:18px;padding-bottom:20px}
.list-group h4{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0 0 8px}
.list-row{background:var(--card);border-radius:14px;box-shadow:var(--shadow);padding:12px 14px;display:flex;align-items:center;gap:10px;margin-bottom:8px}
.list-row .lt{flex:1;min-width:0}
.list-row .lt b{display:block;font-size:15px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-row .lt small{display:block;color:var(--muted);font-size:12px;font-weight:600}
.list-row .lt small.why{color:var(--amber);font-style:normal;margin-top:2px}
.list-row .st{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:4px 9px;border-radius:999px;color:#fff;white-space:nowrap}
.st.done{background:var(--green)} .st.delegated{background:var(--cyan)} .st.deferred{background:var(--amber)}
.st.dropped{background:var(--red)} .st.pending{background:var(--ink)}
.restore{appearance:none;border:1px solid var(--line);background:#fff;border-radius:10px;width:36px;height:36px;font-size:16px;cursor:pointer;flex:none}

/* undo bar */
.undobar{position:fixed;left:50%;bottom:calc(20px + env(safe-area-inset-bottom));translate:-50% 0;background:var(--ink);color:#fff;padding:10px 12px 10px 18px;border-radius:14px;font-weight:600;font-size:14px;z-index:65;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;max-width:92%}
.undobar button{appearance:none;border:none;background:rgba(255,255,255,.16);color:#fff;font-weight:800;border-radius:10px;padding:8px 14px;cursor:pointer}

/* version stamp — always-visible so you know what's rendered */
.ver{position:fixed;left:0;right:0;bottom:2px;text-align:center;font-size:10px;font-weight:600;color:var(--muted);opacity:.55;pointer-events:none;z-index:40;letter-spacing:.02em}

/* toast */
.toast{position:fixed;left:50%;bottom:calc(20px + env(safe-area-inset-bottom));translate:-50% 0;background:var(--ink);color:#fff;padding:12px 18px;border-radius:14px;font-weight:600;font-size:14px;z-index:60;box-shadow:var(--shadow);max-width:90%;text-align:center}

/* v1.7 — all-tasks from home + tap-to-close */
.ghost.tight{margin-top:0;padding-top:6px}
.row-done{appearance:none;border:1px solid #bfe5cd;background:#e8f6ee;color:#1d7a43;border-radius:10px;width:36px;height:36px;font-size:16px;font-weight:800;cursor:pointer;flex:none}
.row-done:active{transform:scale(.94)}

/* v1.8 — auto stopwatch + estimate-vs-reality */
.tracked-hint{margin:2px 0 10px;font-size:13px;font-weight:700;color:#1d7a43;background:#e8f6ee;border-radius:10px;padding:8px 12px}
.stat.acc b{color:#b4541f}

/* v1.9 — edit any task + real due dates */
.due-chips{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:-4px 0 14px}
.due-chips button{appearance:none;border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 12px;font-size:13px;font-weight:700;cursor:pointer}
.due-chips button.on{background:#1c1b1a;color:#fff;border-color:#1c1b1a}
.due-chips input[type=date],#defer-date{border:1px solid var(--line);border-radius:10px;padding:7px 10px;font-size:13px;background:#fff}
.list-row .lt{cursor:pointer}

/* v2.0 — search + owner filters on All Tasks */
.list-tools{display:flex;flex-direction:column;gap:8px;margin:0 0 12px}
.list-tools input[type=search]{appearance:none;-webkit-appearance:none;border:1px solid var(--line);border-radius:12px;padding:11px 14px;font-size:15px;background:#fff;width:100%;box-sizing:border-box}
.owner-chips{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;-webkit-overflow-scrolling:touch}
.owner-chips .ochip{appearance:none;border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 11px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;flex:none}
.owner-chips .ochip.on{background:#1c1b1a;color:#fff;border-color:#1c1b1a}

/* v2.1 — method recall · today view · officer hand-off · weekly scoreboard */
.recall{margin:10px 0 0;font-size:13px;font-weight:600;color:#5b4a9f;background:#efeafe;border-radius:10px;padding:9px 12px;line-height:1.35}
.due-over{color:#c0392b;font-weight:800}
.ghost.fire{color:#c0392b;font-weight:700}
.officer-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:8px 0 14px}
.officer-grid button{appearance:none;border:1px solid var(--line);background:#fff;border-radius:14px;padding:14px 10px;font-size:15px;font-weight:800;cursor:pointer;display:flex;flex-direction:column;gap:3px;align-items:center}
.officer-grid button small{font-size:11px;font-weight:600;color:var(--muted)}
.officer-grid button:active{transform:scale(.96)}
.hint-mic{display:block;color:var(--muted);font-size:11px;font-weight:600;margin-top:4px}
.stat.wk b{color:#1d7a43}

/* v2.2 — quick 4-D sheet */
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0 6px}
.quick-grid .qd{appearance:none;border:none;border-radius:14px;padding:16px 10px;font-size:16px;font-weight:800;cursor:pointer;color:#fff;display:flex;flex-direction:column;align-items:center;gap:4px}
.quick-grid .qd span{font-size:22px}
.qd.done{background:#1d7a43}.qd.defer{background:#b4541f}.qd.delegate{background:#5b4a9f}.qd.drop{background:#c0392b}
.quick-grid .qd:active{transform:scale(.96)}

/* v2.3 — Ask Kelyn chat */
.chat-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:4px 0 12px;-webkit-overflow-scrolling:touch}
.msg{max-width:82%;padding:10px 14px;border-radius:16px;font-size:15px;line-height:1.4;white-space:pre-wrap;word-break:break-word}
.msg.me{align-self:flex-end;background:#1c1b1a;color:#fff;border-bottom-right-radius:4px}
.msg.kelyn{align-self:flex-start;background:#fff;box-shadow:var(--shadow);border-bottom-left-radius:4px}
.msg.kelyn.pending{color:var(--muted);font-style:italic}
.chat-input{display:flex;gap:8px;padding:4px 0 10px;position:sticky;top:0;z-index:5;background:var(--cream);border-bottom:1px solid var(--line);margin-bottom:6px}
.chat-input input{flex:1;appearance:none;-webkit-appearance:none;border:1px solid var(--line);border-radius:999px;padding:12px 16px;font-size:15px;background:#fff}
.chat-input button{appearance:none;border:none;background:#1c1b1a;color:#fff;border-radius:50%;width:46px;height:46px;font-size:17px;cursor:pointer;flex:none}
