:root{--primary:#7e90a0;--primary-deep:#5a6b7a;--on-primary:#fff;--accent:#5bbfa5;--on-accent:#fff;--ink:#2a3540;--ink-soft:#5a6b7a;--bg:#f4f6f8;--card:#fff;--line:#dce3e9;--warn-bg:#f6e3c5;--warn-ink:#7a5a1e;--hero-from:#7e90a0;--hero-to:#5a6b7a;--hero-text:#fff;--tabbar-bg:#ffffffeb;--primary-soft:color-mix(in srgb, var(--primary) 16%, var(--card));--primary-fog:color-mix(in srgb, var(--primary) 7%, var(--card));--accent-soft:color-mix(in srgb, var(--accent) 18%, var(--card));--radius:20px;--shadow:0 2px 10px #2a354014;--tap:52px}@media (prefers-color-scheme:dark){:root{--primary:#9fb2c1;--primary-deep:#c3d1dc;--on-primary:#22303b;--ink:#e7edf3;--ink-soft:#a9b8c4;--bg:#2a3540;--card:#34414d;--line:#46535f;--warn-bg:#4a3d22;--warn-ink:#ebc98b;--hero-from:#3a4855;--hero-to:#2e3944;--hero-text:#e7edf3;--tabbar-bg:#2a3540eb;--shadow:0 2px 10px #00000047}}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);overscroll-behavior-y:none;font-family:ui-rounded,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.45}#root{min-height:100dvh}.app-shell{max-width:560px;padding:env(safe-area-inset-top) 16px calc(88px + env(safe-area-inset-bottom));margin:0 auto}h1,h2,h3{letter-spacing:-.01em;margin:0;font-weight:800}h1{font-size:26px}h2{font-size:19px}h3{font-size:16px}p{margin:0}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:14px;padding:16px}.card-title{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.card-title h2{align-items:center;gap:8px;display:flex}.hero{background:linear-gradient(135deg, var(--hero-from) 0%, var(--hero-to) 100%);color:var(--hero-text);border-radius:var(--radius);margin-top:14px;padding:18px}.hero .muted{color:color-mix(in srgb, var(--hero-text) 82%, transparent)}button{font:inherit;cursor:pointer;min-height:var(--tap);border:none;border-radius:16px;padding:0 18px;font-weight:700;transition:transform 60ms}button:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:var(--on-primary);width:100%;font-size:17px}.btn-soft{background:var(--primary-soft);color:var(--primary-deep)}.btn-ghost{color:var(--primary-deep);background:0 0}.btn-danger-ghost{color:var(--warn-ink);background:0 0}.btn-row{gap:10px;margin-top:10px;display:flex}.btn-row>*{flex:1}.check-row{min-height:var(--tap);border-bottom:1px solid var(--line);align-items:center;gap:12px;padding:8px 0;display:flex}.check-row:last-child{border-bottom:none}.check-row .grow{flex:1;min-width:0}.check-row .sub{color:var(--ink-soft);font-size:13px}.slot-chips{gap:8px;display:flex}.slot-chip{width:var(--tap);height:var(--tap);background:var(--primary-fog);border:2px solid var(--line);color:var(--ink-soft);border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:20px;font-weight:800;display:flex}.slot-chip.done{background:var(--accent);border-color:var(--accent);color:var(--on-accent);animation:.25s pop}@keyframes pop{0%{transform:scale(.6)}60%{transform:scale(1.15)}to{transform:scale(1)}}.chip{background:var(--primary-soft);color:var(--primary-deep);border-radius:999px;align-items:center;gap:6px;padding:5px 12px;font-size:13px;font-weight:700;display:inline-flex}.chip.warm{background:var(--warn-bg);color:var(--warn-ink)}.chip.reward{background:var(--accent);color:var(--on-accent)}.muted{color:var(--ink-soft);font-size:14px}.big-number{font-size:42px;font-weight:900;line-height:1.1}.progress-track{background:color-mix(in srgb, var(--hero-text) 22%, transparent);border-radius:999px;height:14px;margin-top:12px;position:relative}.progress-fill{background:linear-gradient(90deg, color-mix(in srgb, var(--accent) 55%, white), var(--accent));border-radius:999px;height:100%;transition:width .6s}.progress-walker{font-size:22px;transition:left .6s;position:absolute;top:-16px;transform:translate(-50%)}input[type=range]{width:100%;height:var(--tap);appearance:none;background:0 0}input[type=range]::-webkit-slider-runnable-track{background:linear-gradient(90deg,#a7d7b8,#ecd9a0,#e4a2a2);border-radius:999px;height:12px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--card);border:3px solid var(--primary);width:34px;height:34px;box-shadow:var(--shadow);border-radius:50%;margin-top:-11px}.segmented{gap:6px;display:flex}.segmented button{background:var(--primary-fog);min-height:44px;color:var(--ink-soft);border-radius:12px;flex:1;padding:0 6px;font-size:14px}.segmented button.on{background:var(--primary);color:var(--on-primary)}.emoji-row{justify-content:space-between;gap:6px;display:flex}.emoji-row button{background:0 0;border-radius:12px;flex:1;min-height:48px;padding:0;font-size:26px}.emoji-row button.on{background:var(--primary-soft)}input[type=text],input[type=number],input[type=date],input[type=time],input[type=datetime-local],input[type=email],input[type=password],select,textarea{font:inherit;border:2px solid var(--line);background:var(--card);width:100%;min-height:48px;color:var(--ink);border-radius:14px;padding:10px 14px}input:focus,select:focus,textarea:focus{border-color:var(--primary);outline:none}label.field{color:var(--ink-soft);margin-top:12px;font-size:13px;font-weight:700;display:block}label.field>*{margin-top:4px}.field-row{gap:10px;display:flex}.field-row>label{flex:1}.timer-ring{width:168px;height:168px;margin:8px auto;position:relative}.timer-ring svg{transform:rotate(-90deg)}.timer-ring .time{flex-direction:column;justify-content:center;align-items:center;font-size:34px;font-weight:900;display:flex;position:absolute;inset:0}.timer-ring .time .muted{font-size:13px}.accent-row{gap:10px;margin-top:12px;display:flex}.accent-swatch{background:var(--primary-fog);border:2px solid var(--line);border-radius:16px;flex-direction:column;flex:1;align-items:center;gap:8px;min-height:104px;padding:14px 6px;display:flex}.accent-swatch.on{border-color:var(--primary);background:var(--primary-soft)}.accent-swatch .dot{border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;font-weight:900;display:flex}.accent-swatch .nm{color:var(--ink);font-size:12px;font-weight:700}.accent-swatch .bl{color:var(--ink-soft);font-size:11px}.tabbar{background:var(--tabbar-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom);z-index:40;display:flex;position:fixed;bottom:0;left:0;right:0}.tabbar a{color:var(--ink-soft);flex-direction:column;flex:1;align-items:center;gap:2px;padding:10px 0 8px;font-size:11px;font-weight:700;text-decoration:none;display:flex}.tabbar a.active{color:var(--primary-deep)}.tabbar a .ico{font-size:22px;line-height:1}.sheet-backdrop{z-index:50;background:#141b2273;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.sheet{background:var(--bg);width:100%;max-width:560px;max-height:88dvh;padding:20px 16px calc(20px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0;overflow-y:auto}.pin-dots{justify-content:center;gap:14px;margin:18px 0;display:flex}.pin-dot{background:var(--line);border-radius:50%;width:16px;height:16px}.pin-dot.filled{background:var(--primary)}.pin-pad{grid-template-columns:repeat(3,1fr);gap:10px;max-width:280px;margin:0 auto;display:grid}.pin-pad button{background:var(--card);min-height:62px;box-shadow:var(--shadow);color:var(--ink);font-size:24px}.profile-grid{flex-direction:column;gap:12px;margin-top:24px;display:flex}.profile-tile{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);text-align:left;width:100%;min-height:76px;color:var(--ink);align-items:center;gap:14px;padding:16px;font-size:18px;font-weight:800;display:flex}.profile-tile .avatar{background:var(--primary-soft);border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:28px;display:flex}.photo-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-top:12px;display:grid}.photo-cell{background:var(--primary-fog);border:none;border-radius:16px;padding:0;overflow:hidden}.photo-cell img{aspect-ratio:3/4;object-fit:cover;width:100%;display:block}.photo-cell .lbl{color:var(--ink-soft);padding:6px 8px;font-size:12px;font-weight:700;display:block}.photo-viewer{z-index:60;scroll-snap-type:x mandatory;background:#141b22;display:flex;position:fixed;inset:0;overflow-x:auto}.photo-viewer figure{scroll-snap-align:center;flex-direction:column;justify-content:center;align-items:center;min-width:100vw;margin:0;display:flex}.photo-viewer img{object-fit:contain;max-width:100vw;max-height:80dvh}.photo-viewer figcaption{color:#c3d1dc;padding:12px;font-weight:700}.photo-viewer .close{top:calc(12px + env(safe-area-inset-top));color:#fff;background:#ffffff26;border-radius:50%;width:44px;height:44px;min-height:44px;padding:0;font-size:20px;position:fixed;right:12px}.toast{left:50%;bottom:calc(100px + env(safe-area-inset-bottom));background:var(--ink);color:var(--bg);z-index:70;text-align:center;border-radius:16px;max-width:90vw;padding:12px 18px;font-weight:700;animation:.3s toast-in;position:fixed;transform:translate(-50%);box-shadow:0 6px 24px #00000040}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.confetti-canvas{pointer-events:none;z-index:80;position:fixed;inset:0}.center{text-align:center}.spacer{height:8px}.list-plain{margin:0;padding:0;list-style:none}.done-banner{border-radius:var(--radius);background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 38%, var(--card)), color-mix(in srgb, var(--accent) 16%, var(--card)));color:var(--ink);text-align:center;margin-top:14px;padding:18px;font-size:18px;font-weight:800}
