:root{--pink-500: #F7A6C1;--pink-600: #E88AAA;--pink-200: #FFD6E3;--cream: #FFF4EE;--cream-2: #FFF8F2;--brown: #6B4E3D;--brown-2: #4A352A;--tan: #EBC9A6;--bg: var(--cream-2);--surface: #ffffff;--text: var(--brown-2);--muted: #8B7568;--line: #F1E2D5;--shadow-sm: 0 1px 2px rgba(107, 78, 61, .06);--shadow-md: 0 6px 20px rgba(232, 138, 170, .15), 0 1px 3px rgba(107, 78, 61, .06);--shadow-lg: 0 18px 40px rgba(232, 138, 170, .22), 0 2px 6px rgba(107, 78, 61, .08);--radius-sm: 10px;--radius: 16px;--radius-lg: 22px;--radius-pill: 999px;--font-display: "Caveat", "Brush Script MT", cursive;--font-body: "Nunito", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--easing: cubic-bezier(.2, .9, .25, 1)}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--font-body);font-size:16px;line-height:1.5;color:var(--text);background:radial-gradient(1200px 600px at 110% -10%,var(--pink-200) 0%,transparent 60%),radial-gradient(900px 500px at -10% 10%,#FFE7D6 0%,transparent 55%),var(--bg);min-height:100%;-webkit-font-smoothing:antialiased}.bg-deco{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0}.blob{position:absolute;border-radius:50%;filter:blur(40px);opacity:.55}.blob--1{top:-80px;left:-60px;width:280px;height:280px;background:var(--pink-200)}.blob--2{bottom:10%;right:-80px;width:260px;height:260px;background:var(--tan);opacity:.35}.blob--3{top:40%;left:60%;width:200px;height:200px;background:var(--pink-500);opacity:.18}.app{position:relative;z-index:1;max-width:36rem;margin:0 auto;padding:clamp(1rem,3vw,2rem) clamp(1rem,4vw,1.5rem) 0;display:flex;flex-direction:column;gap:1rem;min-height:100vh}.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.brand{display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:center;padding:.25rem .25rem 0}.brand__mark{width:64px;height:64px;display:grid;place-items:center;background:var(--surface);border-radius:50%;box-shadow:var(--shadow-md);position:relative}.brand__mark:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px dashed var(--pink-200);animation:spin 18s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.brand__eyebrow{margin:0;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--pink-600);font-weight:700}.brand__wordmark{margin:-.1rem 0 0;font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,6vw,2.75rem);line-height:1;color:var(--pink-600);text-shadow:0 1px 0 rgba(255,255,255,.6)}.brand__date{margin:.25rem 0 0;font-size:.85rem;color:var(--muted);font-weight:600}.progress-card{background:linear-gradient(135deg,#fff,#fff8f2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1rem 1.1rem;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.progress-card:before{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;background:radial-gradient(circle,var(--pink-200),transparent 70%);opacity:.6}.progress-card__row{display:flex;justify-content:space-between;align-items:center;gap:1rem;position:relative}.progress-card__label{margin:0;font-size:1.05rem;font-weight:800;color:var(--brown-2)}.progress-card__sub{margin:.15rem 0 0;font-size:.85rem;color:var(--muted)}.progress-card__ring{position:relative;width:60px;height:60px;flex:none}.progress-card__pct{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:.78rem;font-weight:800;color:var(--pink-600)}#progress-ring{transition:stroke-dashoffset .7s var(--easing)}.add-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:.9rem;box-shadow:var(--shadow-md)}.add-card__row{display:flex;gap:.5rem;align-items:stretch}#new-text{flex:1;min-width:0;font:inherit;font-weight:600;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:var(--radius);background:var(--cream-2);color:var(--text);transition:border-color .2s var(--easing),background .2s var(--easing),box-shadow .2s var(--easing)}#new-text::placeholder{color:#b89e8c;font-weight:500}#new-text:focus{outline:none;border-color:var(--pink-500);background:#fff;box-shadow:0 0 0 4px #f7a6c140}.tags{display:flex;flex-wrap:wrap;gap:.4rem;border:0;padding:.75rem 0 0;margin:0}.tags input[type=radio]{position:absolute;opacity:0;pointer-events:none}.tag{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .7rem;font-size:.8rem;font-weight:700;border-radius:var(--radius-pill);border:1.5px solid var(--line);color:var(--muted);background:var(--cream-2);cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .15s var(--easing),border-color .15s var(--easing),color .15s var(--easing),background .15s var(--easing)}.tag:hover{transform:translateY(-1px)}.tag svg{display:block}.tag--heart{color:#c75a85}.tag--sip{color:#9c6b3d}.tag--treat{color:#6b4e3d}.tag--slice{color:#c75a85}.tags input:checked+.tag.tag--none{background:var(--brown);border-color:var(--brown);color:#fff}.tags input:checked+.tag.tag--heart{background:#ffe0ec;border-color:#f7a6c1;color:#c75a85}.tags input:checked+.tag.tag--sip{background:#fbead6;border-color:var(--tan);color:#8c5a2e}.tags input:checked+.tag.tag--treat{background:#efd9c6;border-color:var(--brown);color:var(--brown-2)}.tags input:checked+.tag.tag--slice{background:#ffe0ec;border-color:var(--pink-500);color:#c75a85}.tags input:focus-visible+.tag{outline:2px solid var(--pink-500);outline-offset:2px}.btn{display:inline-flex;align-items:center;gap:.35rem;font:inherit;font-weight:800;padding:.85rem 1.1rem;border-radius:var(--radius);border:0;cursor:pointer;transition:transform .15s var(--easing),box-shadow .15s var(--easing),background .2s var(--easing);white-space:nowrap}.btn:active{transform:translateY(1px)}.btn--primary{background:linear-gradient(135deg,var(--pink-500),var(--pink-600));color:#fff;box-shadow:0 6px 16px #e88aaa66}.btn--primary:hover{box-shadow:0 8px 22px #e88aaa8c;transform:translateY(-1px)}.btn--ghost{background:transparent;color:var(--muted);font-weight:700;padding:.55rem .8rem;border-radius:var(--radius-pill)}.btn--ghost:hover{background:var(--cream);color:var(--brown-2)}.btn--link{background:transparent;padding:0;color:var(--pink-600);text-decoration:underline;text-underline-offset:3px}.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.search{flex:1 1 200px;min-width:0;display:flex;align-items:center;gap:.4rem;padding:.55rem .8rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-pill);box-shadow:var(--shadow-sm);color:var(--muted);transition:border-color .15s var(--easing),box-shadow .15s var(--easing)}.search:focus-within{border-color:var(--pink-500);box-shadow:0 0 0 4px #f7a6c133}#search{flex:1;min-width:0;font:inherit;font-weight:600;border:0;background:transparent;outline:none;color:var(--text)}#search::placeholder{color:#b89e8c;font-weight:500}.filters{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-pill);padding:4px;box-shadow:var(--shadow-sm)}.filter{display:inline-flex;align-items:center;gap:.35rem;font:inherit;font-weight:700;font-size:.85rem;padding:.4rem .75rem;border:0;background:transparent;color:var(--muted);border-radius:var(--radius-pill);cursor:pointer;transition:background .2s var(--easing),color .2s var(--easing)}.filter:hover{color:var(--brown-2)}.filter.is-active{background:var(--brown);color:#fff;box-shadow:0 2px 8px #6b4e3d40}.count{display:inline-grid;place-items:center;min-width:18px;height:18px;font-size:.7rem;font-weight:800;padding:0 .35rem;border-radius:var(--radius-pill);background:var(--cream);color:var(--brown)}.filter.is-active .count{background:#ffffff40;color:#fff}.todo-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.55rem}.todo{display:flex;align-items:center;gap:.75rem;padding:.65rem .8rem;min-height:56px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform .2s var(--easing),box-shadow .2s var(--easing),opacity .25s var(--easing);animation:todoIn .3s var(--easing) both}@keyframes todoIn{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:none}}.todo:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.todo.is-leaving{opacity:0;transform:translate(20px) scale(.97);pointer-events:none}.todo__check{flex:none;align-self:center;width:32px;height:32px;display:grid;place-items:center;background:var(--cream-2);border:1.5px solid var(--line);border-radius:50%;color:var(--pink-500);cursor:pointer;transition:background .2s var(--easing),border-color .2s var(--easing),transform .2s var(--easing)}.todo__heart{display:block;transform:translateY(.5px)}.todo__check:hover{background:#ffe7ee;border-color:var(--pink-500)}.todo__check:active{transform:scale(.92)}.todo__check[aria-pressed=true]{background:linear-gradient(135deg,var(--pink-500),var(--pink-600));border-color:var(--pink-600);color:#fff;animation:pop .35s var(--easing)}.todo__check[aria-pressed=true] .todo__heart path{fill:currentColor}@keyframes pop{0%{transform:scale(.85)}50%{transform:scale(1.18)}to{transform:scale(1)}}.todo__body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:.25rem;min-height:32px}.todo__text{margin:0;font-weight:600;line-height:1.3;color:var(--text);word-break:break-word;transition:color .2s var(--easing),opacity .2s var(--easing)}.todo[data-done=true] .todo__text{color:var(--muted);text-decoration:line-through;text-decoration-color:var(--pink-500);text-decoration-thickness:2px}.todo__edit{font:inherit;font-weight:600;padding:.35rem .55rem;border:1.5px solid var(--pink-500);border-radius:8px;background:#fff;color:var(--text);outline:none;box-shadow:0 0 0 4px #f7a6c133}.todo__tag{align-self:flex-start;display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .55rem;font-size:.68rem;font-weight:800;letter-spacing:.04em;line-height:1.4;border-radius:var(--radius-pill);text-transform:uppercase}.todo__tag[data-tag=heart]{background:#ffe0ec;color:#c75a85}.todo__tag[data-tag=sip]{background:#fbead6;color:#8c5a2e}.todo__tag[data-tag=treat]{background:#efd9c6;color:var(--brown-2)}.todo__tag[data-tag=slice]{background:#ffd6e3;color:#c75a85}.todo__actions{flex:none;align-self:center;display:flex;align-items:center;gap:.15rem;opacity:0;transform:translate(4px);transition:opacity .2s var(--easing),transform .2s var(--easing)}.todo:hover .todo__actions,.todo:focus-within .todo__actions{opacity:1;transform:none}@media(hover:none){.todo__actions{opacity:1;transform:none}}.icon-btn{width:32px;height:32px;display:grid;place-items:center;background:transparent;color:var(--muted);border:0;border-radius:50%;cursor:pointer;transition:background .15s var(--easing),color .15s var(--easing)}.icon-btn svg{display:block}.icon-btn:hover{background:var(--cream);color:var(--brown-2)}.todo__del-btn:hover{background:#ffe0e0;color:#c75252}.empty{text-align:center;padding:2rem 1rem;color:var(--muted)}.empty h2{margin:.5rem 0 .25rem;font-family:var(--font-display);font-size:1.9rem;color:var(--pink-600);font-weight:700}.empty p{margin:0}.footer{margin-top:auto;padding-top:1.5rem;position:relative}.footer__scallop{display:block;width:100%;height:18px;margin-bottom:-1px}.footer__tag{margin:0;padding:.9rem 1rem 1.2rem;background:var(--pink-500);color:#fff;text-align:center;font-weight:700;font-size:.85rem;letter-spacing:.04em;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.footer__tag span{color:#fff}.toast{position:fixed;left:50%;bottom:1.5rem;transform:translate(-50%,80px);display:inline-flex;align-items:center;gap:.8rem;padding:.75rem 1rem;background:var(--brown-2);color:#fff;border-radius:var(--radius-pill);box-shadow:var(--shadow-lg);font-weight:600;opacity:0;transition:opacity .25s var(--easing),transform .25s var(--easing);z-index:10}.toast.is-visible{opacity:1;transform:translate(-50%)}.toast .btn--link{color:var(--pink-200);font-weight:800}.donut-burst{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:8;overflow:visible}.donut-burst__particle{position:fixed;left:0;top:0;font-size:var(--size, 1.1rem);line-height:1;will-change:transform,opacity;animation:donutBurst .78s var(--easing) var(--delay, 0s) forwards}@keyframes donutBurst{0%{opacity:0;transform:translate(-50%,-50%) scale(.15) rotate(-18deg)}12%{opacity:1;transform:translate(-50%,-50%) scale(1.12) rotate(6deg)}to{opacity:0;transform:translate(calc(-50% + var(--tx, 0px)),calc(-50% + var(--ty, 0px))) scale(.65) rotate(var(--spin, 24deg))}}:focus-visible{outline:2px solid var(--pink-500);outline-offset:2px;border-radius:6px}@media(max-width:480px){.toolbar{gap:.4rem}.filters{width:100%;justify-content:space-between}.add-card__row{flex-direction:column}.btn--primary{justify-content:center}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}}
