@import "https://fonts.googleapis.com/css2?family=Caveat:wght@500;700&display=swap";:root{--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;font:18px/145% var(--sans);letter-spacing:.18px;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (width<=1024px){:root{font-size:16px}}h1,h2{font-family:var(--heading);color:var(--text);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}:root{--bg:#fff6ed;--surface:#fff;--text:#4a3f45;--primary:#ff8fab;--success:#4cd97b;--shadow:0 6px 16px #ff8fab2e;--font-hand:"Caveat", "Comic Sans MS", "Segoe Print", cursive, Inter, system-ui, sans-serif;--checkbox-border:#4a3f4559;--checkbox-fill:#4a3f450d}[data-theme=dark]{--bg:#211a2b;--surface:#302640;--text:#f5e9f0;--primary:#ffb4c6;--success:#63e39a;--shadow:0 6px 16px #00000059;--checkbox-border:#ffffff80;--checkbox-fill:#ffffff0f}*{box-sizing:border-box}html,body{background:var(--bg);max-width:100%;color:var(--text);margin:0;font-family:Inter,system-ui,sans-serif;overflow-x:hidden}#root{min-height:100vh}.app{max-width:1100px;margin:0 auto;padding:24px}@media (width<=480px){.app{padding:16px}}.header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.brand-wordmark{font-family:var(--font-hand);color:var(--text);letter-spacing:.2px;align-items:center;margin:0;font-size:30px;font-weight:700;line-height:44px;display:flex}.brand-paw{margin:0 1px;font-size:16px;display:inline-block;transform:rotate(-12deg)translateY(-2px)}.header-actions{align-items:center;gap:8px;display:flex}.signout-btn{background:var(--surface);cursor:pointer;min-height:44px;color:var(--text);box-shadow:var(--shadow);border:none;border-radius:12px;padding:0 14px;font-size:14px;font-weight:600}.app-loading{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;font-size:48px;display:flex}.signin-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.signin-card{background:var(--surface);text-align:center;width:100%;max-width:360px;box-shadow:var(--shadow);border-radius:24px;padding:40px 28px}.signin-emoji{margin:0 0 8px;font-size:48px}.signin-title{color:var(--text);margin:0 0 8px;font-size:32px}.signin-subtitle{opacity:.8;margin:0 0 24px;font-size:14px}.signin-btn{background:var(--primary);color:#fff;cursor:pointer;width:100%;min-height:48px;box-shadow:var(--shadow);border:none;border-radius:14px;padding:0 20px;font-size:15px;font-weight:700}.theme-button{background:var(--surface);cursor:pointer;min-width:44px;min-height:44px;box-shadow:var(--shadow);border:none;border-radius:12px;justify-content:center;align-items:center;font-size:18px;display:flex}.view-toggle{background:var(--surface);box-shadow:var(--shadow);border-radius:999px;gap:8px;margin-bottom:16px;padding:6px;display:flex}.view-toggle-btn{cursor:pointer;min-height:40px;font-family:var(--font-hand);color:var(--text);opacity:.6;background:0 0;border:none;border-radius:999px;flex:1;font-size:18px;font-weight:700;transition:background .15s,opacity .15s,color .15s}.view-toggle-btn--active{background:var(--primary);color:#fff;opacity:1}.stats-strip{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.stats-chip{background:var(--surface);font-family:var(--font-hand);box-shadow:var(--shadow);border-radius:999px;padding:8px 14px;font-size:17px;font-weight:600}.progress-bar{margin-bottom:20px}.progress-bar-track{background:var(--surface);height:12px;box-shadow:var(--shadow);border-radius:999px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--primary), var(--success));border-radius:999px;height:100%;transition:width .3s}.progress-bar-label{margin-top:6px;font-size:13px;font-weight:600;display:block}.progress-empty{opacity:.75;margin:0 0 20px;font-size:13px}.empty-state{background:var(--surface);text-align:center;opacity:.85;box-shadow:var(--shadow);border-radius:16px;padding:20px;font-size:14px}.placeholder-card{background:var(--surface);box-shadow:var(--shadow);border-radius:16px;padding:24px;font-weight:600}.quick-add-row{align-items:center;gap:10px;margin-bottom:20px;display:flex}.checklist-new-input{margin-bottom:20px}.quick-add{background:var(--surface);width:100%;color:var(--text);box-shadow:var(--shadow);border:none;border-radius:16px;flex:1;padding:14px 16px;font-size:16px}.calendar-trigger-btn{background:var(--surface);cursor:pointer;min-width:48px;min-height:48px;box-shadow:var(--shadow);border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.calendar-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.calendar-popover{background:var(--surface);border-radius:20px;width:100%;max-width:320px;padding:18px;box-shadow:0 12px 32px #0000004d}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.calendar-nav-btn{background:var(--bg);cursor:pointer;min-width:32px;min-height:32px;color:var(--primary);border:none;border-radius:10px;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.calendar-month-label{font-family:var(--font-hand);color:var(--text);font-size:20px;font-weight:700}.calendar-weekday-row{grid-template-columns:repeat(7,1fr);margin-bottom:4px;display:grid}.calendar-weekday{text-align:center;opacity:.6;padding:4px 0;font-size:11px;font-weight:700}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.calendar-cell{aspect-ratio:1;color:var(--text);background:#b496dc1f;border-radius:10px;justify-content:center;align-items:center;font-size:13px;font-weight:600;transition:background .15s;display:flex}.calendar-cell:nth-child(7n+1),.calendar-cell:nth-child(7n+2){background:#ff8fab1a}.calendar-cell:nth-child(7n+5),.calendar-cell:nth-child(7n+6){background:#63e39a1f}.calendar-cell:hover{background:var(--primary);color:#fff;cursor:default}.calendar-cell--empty,.calendar-cell--empty:hover{background:0 0}.calendar-cell--today{background:var(--primary);color:#fff;box-shadow:0 0 0 2px var(--surface) inset}.calendar-close-btn{background:var(--bg);width:100%;min-height:40px;color:var(--text);cursor:pointer;border:none;border-radius:12px;margin-top:16px;font-size:14px;font-weight:600}.task-list{flex-direction:column;gap:12px;display:flex}.task-card-swipe-container{border-radius:16px;max-width:100%;transition:max-height .22s,opacity .22s,margin .22s;position:relative;overflow:hidden}.task-card-swipe-container--deleting{opacity:0}.task-card-swipe-container+.task-card-swipe-container{margin-top:12px}.task-card-delete-reveal{color:#fff;cursor:pointer;touch-action:pan-y;background:linear-gradient(90deg,#e2415a,#ff5c72);justify-content:flex-end;align-items:center;padding-right:28px;font-size:20px;display:flex;position:absolute;inset:0}.task-card{background:var(--surface);overflow-wrap:anywhere;max-width:100%;box-shadow:var(--shadow);touch-action:pan-y;will-change:transform;border-radius:16px;flex-direction:column;padding:12px 16px;display:flex;position:relative}.task-card--completing{opacity:.4;transform:scale(.96)!important}.section{margin-top:28px}.section h2{font-family:var(--font-hand);margin-bottom:12px;font-size:26px}.check-btn{border:2px solid var(--checkbox-border);background:var(--checkbox-fill);cursor:pointer;color:#fff;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:24px;min-width:24px;height:24px;min-height:24px;margin-right:12px;transition:background .15s,border-color .15s;display:flex}.check-btn--checked{border-color:var(--primary);background:var(--primary)}.check-btn-icon{color:#fff;width:14px;height:14px}.check-btn--small{border-radius:6px;width:20px;min-width:20px;height:20px;min-height:20px;margin-right:10px}.checklist-badge{font-family:var(--font-hand);color:var(--primary);background:#ff8fab29;border-radius:999px;flex-shrink:0;margin-left:8px;padding:2px 8px;font-size:15px;font-weight:700}.checklist-section{flex-direction:column;gap:6px;font-size:14px;display:flex}.checklist-swipe-container{border-radius:10px;position:relative;overflow:hidden}.checklist-delete-reveal{color:#fff;cursor:pointer;background:linear-gradient(90deg,#e2415a,#ff5c72);justify-content:flex-end;align-items:center;padding-right:14px;font-size:14px;display:flex;position:absolute;inset:0}.checklist-row{background:var(--bg);touch-action:pan-y;border-radius:10px;align-items:center;gap:8px;padding:6px 8px;display:flex;position:relative}.checklist-item-input{min-width:0;color:var(--text);background:0 0;border:none;flex:1;padding:4px 0;font-family:inherit;font-size:14px}.checklist-item-input--done{opacity:.55;text-decoration:line-through}.checklist-add-input{background:var(--bg);color:var(--text);border:none;border-radius:10px;min-height:40px;padding:10px 12px;font-family:inherit;font-size:14px}.task-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.task-header>div{overflow-wrap:anywhere;align-items:center;min-width:0;display:flex}.expand-btn{cursor:pointer;min-height:32px;color:var(--primary);background:0 0;border:none;align-self:flex-start;margin-top:4px;padding:0;font-size:12px;font-weight:600}.task-details{border-top:1px solid #80808033;flex-direction:column;gap:8px;margin-top:12px;padding-top:12px;font-size:14px;display:flex}.due-date-picker{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.due-date-btn{cursor:pointer;background:var(--bg);color:var(--text);border:none;border-radius:10px;padding:6px 10px;font-size:13px}.due-date-input{background:var(--bg);color:var(--text);border:none;border-radius:10px;padding:6px 10px;font-size:13px}.notes-preview{flex-direction:column;gap:4px;margin-top:10px;display:flex}.note-preview-item{color:var(--text);opacity:.8;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;display:-webkit-box;overflow:hidden}.notes-more-badge{color:var(--primary);font-size:12px}.notes-timeline{flex-direction:column;gap:8px;display:flex}.note-item{background:var(--bg);color:var(--text);text-align:left;cursor:pointer;white-space:pre-wrap;overflow-wrap:anywhere;border:none;border-radius:10px;padding:10px 12px;font-family:inherit;font-size:14px}.note-textarea{background:var(--bg);color:var(--text);resize:vertical;border:none;border-radius:10px;min-height:44px;padding:10px 12px;font-family:inherit;font-size:14px}
