:root{--bg: #faf6f0;--bg-soft: #f2ebe0;--card: #fffdf9;--card-soft: #f6efe4;--line: #e7ddcd;--text: #2c2640;--text-dim: #6a6280;--text-faint: #9b93a6;--accent: #d98a2b;--accent-soft: #d98a2b22;--moon: #5b78e0;--good: #3a9d56;--bad: #d2603c;--streak: #d98a2b;--on-accent: #3a2406;--on-moon: #ffffff;--shadow: 0 6px 18px rgba(80, 60, 30, .16);--shadow-lift: 0 8px 20px rgba(80, 60, 30, .2);--radius: 16px;--radius-sm: 10px;--maxw: 480px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.45}.app{max-width:var(--maxw);margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:var(--bg);position:relative}.screen{flex:1;padding:20px 18px 96px;overflow-y:auto}.hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.hdr .date{font-size:15px;color:var(--text-dim);font-weight:600}.hdr .right{display:flex;align-items:center;gap:14px}.streak-pill{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--streak);font-weight:700}.reflect-hdr{justify-content:space-between}.reflect-hdr .date{flex:1;text-align:center}.navarrow{background:none;border:none;cursor:pointer;color:var(--text-dim);font-size:24px;line-height:1;padding:2px 10px;border-radius:var(--radius-sm);flex-shrink:0}.navarrow:hover:not(:disabled){color:var(--text);background:var(--card)}.navarrow:disabled{opacity:.2;cursor:default}.card{background:var(--card);border-radius:var(--radius);padding:16px;margin-bottom:14px;border:1px solid var(--line)}.intention-card{background:linear-gradient(135deg,var(--accent-soft),transparent);border:1px solid var(--accent)}.intention-card .label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:6px}.intention-card .text{font-size:18px;font-weight:600;line-height:1.3}.intention-card .win{margin-top:10px;font-size:14px;color:var(--text-dim);display:flex;align-items:center;gap:6px}.section-label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);font-weight:700;margin:18px 4px 8px}.row{display:flex;align-items:center;gap:12px;padding:13px 14px;background:var(--card);border-radius:var(--radius-sm);margin-bottom:8px;border:1px solid var(--line)}.row .check{width:24px;height:24px;border-radius:50%;border:2px solid var(--text-faint);flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.row .check.done{background:var(--good);border-color:var(--good)}.row .check.done:after{content:"✓";color:var(--bg);font-size:14px;font-weight:800}.row .cat-icon{font-size:16px;line-height:1;flex-shrink:0;width:20px;text-align:center}.row .label-text{flex:1;font-size:15px}.row.done .label-text{color:var(--text-faint);text-decoration:line-through}.row .tag{font-size:11px;color:var(--accent);background:var(--accent-soft);padding:2px 8px;border-radius:99px;font-weight:600}.row .mini-streak{font-size:12px;color:var(--streak);font-weight:700}.habit-count{font-size:12px;font-weight:700;color:var(--text-dim);background:var(--bg-soft);border-radius:99px;padding:1px 8px;font-variant-numeric:tabular-nums;flex-shrink:0}.row .carried-tag{font-size:11px;color:var(--text-faint);font-weight:600;background:var(--bg-soft);padding:2px 7px;border-radius:99px;flex-shrink:0;white-space:nowrap}.row .routine-time{font-size:12px;color:var(--text-faint);font-weight:600;font-variant-numeric:tabular-nums;flex-shrink:0}.row .time-gutter{width:56px;flex-shrink:0;text-align:right;font-size:12px;color:var(--text-faint);font-weight:600;font-variant-numeric:tabular-nums}.time-edit{width:92px;flex-shrink:0;font:inherit;font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text-dim);background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius-sm);padding:6px 8px}.time-edit:focus{outline:none;border-color:var(--text-faint);color:var(--text)}.seg.seg-three button{padding:9px 4px;font-size:13px;line-height:1.2}.wheel-time{margin-top:10px}.wheel-cols{display:flex;align-items:stretch;justify-content:center;gap:10px;padding:4px 0 2px}.wheel-sep{align-self:center;font-size:24px;font-weight:700;color:var(--text-faint);padding-bottom:22px}.wheel-col-wrap{position:relative;flex:1;min-width:0;max-width:180px;display:flex;flex-direction:column}.wheel-col-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);font-weight:700;text-align:center;margin-bottom:4px}.wheel-col{height:200px;overflow-y:scroll;scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--card);mask-image:linear-gradient(180deg,transparent 0,#000 30%,#000 70%,transparent 100%);-webkit-mask-image:linear-gradient(180deg,transparent 0,#000 30%,#000 70%,transparent 100%)}.wheel-col:focus{outline:2px solid var(--accent);outline-offset:2px}.wheel-col::-webkit-scrollbar{display:none}.wheel-col{scrollbar-width:none}.wheel-pad{height:80px;flex-shrink:0}.wheel-row{height:40px;line-height:40px;flex-shrink:0;scroll-snap-align:center;text-align:center;font-size:18px;font-weight:600;color:var(--text-dim);font-variant-numeric:tabular-nums;cursor:pointer;transition:color .12s ease}.wheel-row.sel{color:var(--text);font-weight:700}.wheel-row:hover{color:var(--text)}.wheel-band{pointer-events:none;position:absolute;left:0;right:0;top:98px;height:40px;background:var(--accent-soft);border-top:1px solid var(--accent);border-bottom:1px solid var(--accent);border-radius:0}.row .row-tap{flex:1;display:flex;align-items:center;gap:12px;background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;text-align:left;cursor:pointer;min-width:0}.row .row-tap .label-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.field-label{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);font-weight:700;margin:16px 2px 7px}.daypick{display:flex;gap:6px;margin-top:4px}.day-btn{flex:1;aspect-ratio:1;min-width:0;padding:0;border-radius:var(--radius-sm);cursor:pointer;background:var(--card);border:1px solid var(--line);color:var(--text-dim);font-size:14px;font-weight:700;font-family:inherit}.day-btn.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.row.routine .check.done{background:var(--streak);border-color:var(--streak)}.cal{max-height:60vh;overflow-y:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--card);scrollbar-width:none}.cal::-webkit-scrollbar{display:none}.cal-hour{display:flex;align-items:stretch;min-height:52px;border-bottom:1px solid var(--line)}.cal-hour:last-child{border-bottom:none}.cal-time{width:64px;flex-shrink:0;padding:6px 10px 0 0;text-align:right;font-size:11px;color:var(--text-faint);font-weight:600;font-variant-numeric:tabular-nums;border-right:1px solid var(--line)}.cal-lane{flex:1;display:flex;flex-direction:column;gap:4px;padding:5px 8px;min-width:0}.cal-event{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--card-soft);border:1px solid var(--line);border-radius:var(--radius-sm)}.cal-event .check{width:20px;height:20px;border-radius:50%;border:2px solid var(--text-faint);flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.cal-event .check.done{background:var(--streak);border-color:var(--streak)}.cal-event .check.done:after{content:"✓";color:var(--bg);font-size:12px;font-weight:800}.cal-event .cat-icon{font-size:15px;line-height:1;flex-shrink:0}.cal-event .ev-text{flex:1;font-size:14px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-event .ev-time{font-size:11px;color:var(--text-faint);font-variant-numeric:tabular-nums;flex-shrink:0}.cal-event.done .ev-text{color:var(--text-faint);text-decoration:line-through}.cal-now{height:2px;background:var(--accent);border-radius:2px;z-index:1}.cal-now:before{content:"";position:absolute;left:-4px;top:-3px;width:8px;height:8px;border-radius:50%;background:var(--accent)}.cal-empty{text-align:center;color:var(--text-faint);font-size:13px;padding:24px 12px}.cal-footer{font-size:13px;color:var(--text-faint);padding:10px 4px 2px}.row .drag-handle{flex-shrink:0;cursor:grab;color:var(--text-faint);font-size:16px;line-height:1;padding:0 2px;touch-action:none;-webkit-user-select:none;user-select:none}.row .drag-handle:active{cursor:grabbing}.row.dragging{border-color:var(--accent);box-shadow:var(--shadow-lift)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:15px;border-radius:var(--radius-sm);background:var(--accent);color:var(--on-accent);font-size:16px;font-weight:700;border:none;cursor:pointer;transition:filter .15s}.btn:hover{filter:brightness(1.05)}.btn.moon{background:var(--moon);color:var(--on-moon)}.btn.ghost{background:transparent;color:var(--text-dim);border:1px solid var(--line)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-link{background:none;border:none;color:var(--text-faint);font-size:14px;cursor:pointer;padding:10px;width:100%}input.field,textarea.field{width:100%;padding:14px;border-radius:var(--radius-sm);background:var(--bg-soft);border:1px solid var(--line);color:var(--text);font-size:16px;font-family:inherit;resize:none}input.field:focus,textarea.field:focus{outline:none;border-color:var(--accent)}.chips{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}.chip{padding:8px 14px;border-radius:99px;background:var(--card-soft);border:1px solid var(--line);color:var(--text-dim);font-size:14px;cursor:pointer}.chip:hover{border-color:var(--accent);color:var(--text)}.chip.add-more{border-style:dashed;border-color:var(--accent);color:var(--accent);background:transparent;font-weight:600}.chip.add-more:hover{background:var(--accent-soft)}.empty{text-align:center;padding:50px 20px;color:var(--text-dim)}.empty .big{font-size:20px;font-weight:600;margin-bottom:8px;color:var(--text)}.nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--maxw);display:flex;background:var(--bg-soft);border-top:1px solid var(--line);padding:8px 0 max(8px,env(safe-area-inset-bottom))}.nav button{flex:1;background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--text-faint);font-size:11px;font-weight:600;padding:4px}.nav button .ico{font-size:20px;line-height:1}.nav button.active{color:var(--accent)}.fab{position:fixed;bottom:78px;right:max(18px,calc(50% - var(--maxw)/2 + 18px));width:52px;height:52px;border-radius:50%;background:var(--accent);color:var(--on-accent);border:none;font-size:28px;cursor:pointer;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;z-index:20}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c264066;z-index:30;display:flex;align-items:flex-end;justify-content:center}.sheet{width:100%;max-width:var(--maxw);background:var(--bg-soft);border-radius:20px 20px 0 0;padding:22px 18px 28px;border-top:1px solid var(--line)}.sheet h3{font-size:17px;margin-bottom:14px}.seg{display:flex;gap:8px;margin-bottom:14px}.seg button{flex:1;padding:10px;border-radius:var(--radius-sm);cursor:pointer;background:var(--card);border:1px solid var(--line);color:var(--text-dim);font-size:14px;font-weight:600}.seg button.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.reflect-q{font-size:22px;font-weight:600;text-align:center;margin:28px 12px 24px;line-height:1.35}.feelings{display:flex;justify-content:space-between;gap:6px;margin:20px 0}.feeling{flex:1;aspect-ratio:1;border-radius:14px;border:2px solid var(--line);background:var(--card);font-size:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.feeling.sel{border-color:var(--moon);background:var(--card-soft);transform:scale(1.08)}.feeling-scale{display:flex;justify-content:space-between;color:var(--text-faint);font-size:12px;padding:0 4px}.mirror-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line)}.mirror-row:last-child{border-bottom:none}.mirror-row .ok{color:var(--good);font-weight:700}.mirror-row .no{color:var(--bad);font-weight:700}.mirror-toggle{width:100%;background:none;border:none;cursor:pointer;font:inherit;color:var(--text);text-align:left}.mirror-toggle.empty{cursor:default}.mirror-label{display:inline-flex;align-items:center;gap:6px}.chevron{display:inline-block;color:var(--text-faint);font-weight:700;transition:transform .15s;transform:rotate(0)}.chevron.open{transform:rotate(90deg)}.mirror-items{padding:8px 0 10px;border-bottom:1px solid var(--line)}.mirror-items:last-child{border-bottom:none}.mirror-item{display:flex;align-items:center;gap:8px;padding:3px 0;font-size:14px;color:var(--text-dim)}.mirror-item .tick{width:16px;flex-shrink:0;text-align:center;font-weight:700}.mirror-item .cat-icon{font-size:14px;flex-shrink:0}.mirror-item .item-text{flex:1}.mirror-item.done .tick{color:var(--good)}.mirror-item.done .item-text{color:var(--text)}.mirror-item.undone .tick,.mirror-item.undone .item-text{color:var(--text-faint)}.tieback{background:var(--card-soft);border-left:3px solid var(--moon);padding:14px;border-radius:var(--radius-sm);margin:16px 0;font-size:14px;color:var(--text-dim);line-height:1.5}.mood-chart{display:flex;align-items:flex-end;justify-content:flex-start;gap:8px;height:140px;padding:10px 0;margin-top:6px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-webkit-overflow-scrolling:touch}.mood-chart::-webkit-scrollbar{display:none}.mood-bar-wrap{flex:1 0 28px;min-width:28px;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}.mood-bar-wrap.tappable{background:none;border:none;padding:0;cursor:pointer;font:inherit;border-radius:var(--radius-sm);transition:background .15s}.mood-bar-wrap.tappable:hover{background:var(--card-soft)}.mood-bar-wrap.tappable:hover .mood-bar{opacity:1}.mood-bar-wrap.tappable.sel{background:var(--card-soft)}.mood-bar-wrap.tappable.sel .mood-bar{opacity:1;background:var(--accent)}.mood-dot{font-size:18px}.mood-bar{width:60%;background:var(--moon);border-radius:4px 4px 0 0;min-height:4px;opacity:.8;transition:opacity .15s}.mood-label{font-size:10px;color:var(--text-faint);white-space:nowrap}.day-card{position:relative;background:var(--card-soft);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px;animation:day-card-in .18s ease-out}@keyframes day-card-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.day-card-close{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--text-faint);font-size:14px;cursor:pointer;padding:4px}.day-card-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}.day-card-emoji{font-size:32px;line-height:1}.day-card-line{font-size:14px;color:var(--text-dim);margin-top:4px}.day-card-note{margin-top:10px;padding-left:10px;border-left:2px solid var(--moon);font-size:14px;color:var(--text-dim);font-style:italic}.day-card-link{margin-top:12px;background:none;border:none;cursor:pointer;color:var(--moon);font-size:14px;font-weight:600;padding:0}.routine-health{margin-bottom:10px}.routine-health .top{display:flex;justify-content:space-between;font-size:14px;margin-bottom:5px}.bar-track{height:8px;background:var(--bg-soft);border-radius:99px;overflow:hidden}.bar-fill{height:100%;background:var(--streak);border-radius:99px}.muted{color:var(--text-faint);font-size:13px}.center{text-align:center}.mt{margin-top:16px}.onboard{padding:28px 22px 40px;min-height:100vh;display:flex;flex-direction:column}.onboard-dots{display:flex;gap:8px;justify-content:center;margin-bottom:28px}.onboard-dots .dot{width:8px;height:8px;border-radius:50%;background:var(--line);transition:all .25s}.onboard-dots .dot.on{background:var(--accent);width:22px;border-radius:99px}.onboard-dots .dot.past{background:var(--accent);opacity:.5}.onboard-center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.onboard-mark{font-size:40px;margin-bottom:20px;letter-spacing:8px}.onboard-title{font-size:28px;font-weight:700;margin-bottom:16px}.onboard-sub{font-size:17px;color:var(--text-dim);line-height:1.6}.onboard-h2{font-size:23px;font-weight:700;line-height:1.3;margin-bottom:8px}.onboard-actions{margin-top:26px}
