@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-vietnamese-wght-normal-CnvboYUG.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-ext-wght-normal-Ca2vKHc0.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-wght-normal-ukD16Tqj.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans Variable;font-style:normal;font-display:swap;font-weight:100 1000;src:url(/assets/dm-sans-latin-ext-wght-normal-BOFOeGcA.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans Variable;font-style:normal;font-display:swap;font-weight:100 1000;src:url(/assets/dm-sans-latin-wght-normal-Xz1IZZA0.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--oat: #f4ede4;--oat-2: #efe6da;--porcelain: #fbf7f0;--sand: #ede3d6;--terracotta: #c77b53;--terracotta-deep: #b56a44;--accent-strong: #9a4f2a;--sage: #7c8c6b;--amber: #d9a441;--ink: #3a332c;--muted: #6f6456;--hairline: rgba(58, 51, 44, .1);--danger: #b4543f;--bg: var(--oat);--surface: var(--porcelain);--surface-2: var(--sand);--text: var(--ink);--text-muted: var(--muted);--accent: var(--terracotta);--glow: rgba(199, 123, 83, .08);--font-display: "Fraunces Variable", "Fraunces", "Iowan Old Style", Georgia, serif;--font-body: "DM Sans Variable", "DM Sans", system-ui, -apple-system, "Segoe UI", sans-serif;--r-sm: 10px;--r-md: 16px;--r-lg: 22px;--r-xl: 30px;--shadow-soft: 0 6px 20px rgba(58, 44, 32, .1);--shadow-card: 0 8px 26px rgba(58, 44, 32, .12);--shadow-lift: 0 14px 40px rgba(58, 44, 32, .18);--maxw: 480px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}@media(prefers-color-scheme:dark){:root{--oat: #2a2420;--oat-2: #251f1b;--porcelain: #332c27;--sand: #3c342e;--ink: #f1e9df;--muted: #b3a594;--hairline: rgba(241, 233, 223, .12);--bg: var(--oat);--surface: var(--porcelain);--surface-2: var(--sand);--text: var(--ink);--text-muted: var(--muted);--glow: rgba(217, 164, 65, .06);--shadow-soft: 0 6px 20px rgba(0, 0, 0, .35);--shadow-card: 0 8px 26px rgba(0, 0, 0, .4);--shadow-lift: 0 14px 40px rgba(0, 0, 0, .5)}}*{box-sizing:border-box}html,body{margin:0;height:100%}body{background:radial-gradient(135% 65% at 50% 6%,var(--oat-2) 0%,transparent 58%),radial-gradient(85% 45% at 50% 82%,var(--glow) 0%,transparent 72%),var(--bg);background-attachment:fixed;color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overscroll-behavior:none;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;z-index:5;pointer-events:none;opacity:.06;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}#app{height:100%;height:100dvh}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}h1,h2,h3{font-family:var(--font-display);font-weight:600;letter-spacing:-.015em;margin:0;font-optical-sizing:auto;font-variation-settings:"opsz" 144,"SOFT" 24}.screen{max-width:var(--maxw);margin:0 auto;height:100%;display:flex;flex-direction:column;padding:calc(var(--safe-top) + 18px) 18px calc(var(--safe-bottom) + 16px)}.shelf-header{display:flex;align-items:center;justify-content:space-between}.brand{font-size:38px;letter-spacing:-.025em}.tagline{margin:1px 0 8px;color:var(--text-muted);font-size:15px;font-family:var(--font-display);font-style:italic}.shelf-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:16px;align-content:start;overflow-y:auto;flex:1;min-height:0;padding-bottom:12px}.shelf-grid.is-empty{display:flex}.jar-card{display:flex;flex-direction:column;align-items:center;gap:8px;background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--hairline);border-radius:var(--r-lg);padding:18px 12px 16px;box-shadow:0 12px 24px -8px #3a2c2038,var(--shadow-card),inset 0 1px #ffffff80;transition:transform .16s ease,box-shadow .16s ease}.jar-card:active{transform:scale(.97)}.jar-thumb{height:132px;display:flex;align-items:flex-end;justify-content:center}.thumb-glass{position:relative;width:74px;height:118px;border-radius:10px 10px 26px 26px;background:linear-gradient(160deg,#ffffff47,#ffffff14);border:1px solid rgba(255,255,255,.55);box-shadow:inset 0 2px 5px #ffffffb3,inset 0 -10px 16px #3a2c2014,var(--shadow-soft);overflow:hidden;display:flex;align-items:flex-end}.thumb-fill{width:100%;border-radius:0 0 25px 25px;background-image:radial-gradient(circle at 30% 30%,rgba(255,255,255,.35) 0 18%,transparent 22%),radial-gradient(circle at 70% 60%,rgba(255,255,255,.22) 0 14%,transparent 18%);background-size:22px 22px;transition:height .5s cubic-bezier(.2,.8,.2,1)}.card-meta{display:flex;flex-direction:column;align-items:center;gap:1px}.card-name{font-family:var(--font-display);font-size:15px;font-weight:600}.card-sub{color:var(--text-muted);font-size:12px;font-variant-numeric:tabular-nums}.card-count{color:var(--text);font-weight:600}.shelf-footer{text-align:center;padding:16px 0 calc(var(--safe-bottom) + 8px);margin:0;font-family:var(--font-display);font-style:italic;font-size:14px;color:var(--text-muted)}.add-card{justify-content:center;border:1.5px dashed var(--hairline);background:transparent;box-shadow:none;color:var(--text-muted);min-height:172px;gap:6px}.add-plus{font-size:34px;font-weight:300;line-height:1;color:var(--accent)}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;padding:20px}.empty-jar{color:var(--accent);opacity:.85}.empty-state h2{font-size:27px}.empty-state p{color:var(--text-muted);max-width:280px;margin:0}.empty-state .btn{margin-top:8px}.jar-header{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:8px}.jar-title{text-align:center;min-width:0}.jar-title h1{font-size:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.identity{margin:1px 0 0;font-size:13px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icon-btn{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;color:var(--text-muted);transition:background .16s ease}.icon-btn:active{background:var(--surface-2)}.streak-badge{display:flex;align-items:center;justify-content:center;gap:6px;height:22px;margin:8px 0 2px;font-size:13px;color:var(--text-muted);white-space:nowrap;overflow:hidden}.streak-flame{display:inline-flex;color:var(--amber)}.jar-stage{position:relative;flex:1;min-height:280px;margin:2px 0;touch-action:none;-webkit-user-select:none;user-select:none;background:radial-gradient(56% 44% at 50% 58%,var(--glow),transparent 72%)}.jar-layer{position:absolute;inset:0}.jar-back{z-index:1;pointer-events:none}.jar-mid{z-index:2}.jar-front{z-index:3;pointer-events:none}.affirm-line{text-align:center;min-height:24px;margin:4px 0;font-family:var(--font-display);font-size:16px;color:var(--text);opacity:0;transform:translateY(5px);transition:opacity .4s ease,transform .4s ease}.affirm-line.show{opacity:.92;transform:translateY(0)}.jar-actions{display:flex;align-items:center;justify-content:center;gap:12px;padding-top:4px}.btn{border-radius:999px;font-weight:600;font-size:15px;padding:15px 22px;transition:transform .14s ease,background .2s ease,box-shadow .2s ease}.btn:active{transform:scale(.97)}.btn.primary{color:#fff;background:linear-gradient(180deg,#b06440,var(--accent-strong));border:1px solid rgba(255,255,255,.16);box-shadow:var(--shadow-soft),inset 0 1px #ffffff47,inset 0 -2px 4px #48221040}.jar-actions .btn.primary{flex:1}.btn.primary.done{background:var(--surface-2);color:var(--text-muted);box-shadow:none}.btn.ghost{width:54px;height:54px;border-radius:50%;padding:0;display:grid;place-items:center;background:linear-gradient(180deg,var(--surface),var(--surface-2));border:1px solid var(--hairline);color:var(--text-muted);box-shadow:var(--shadow-soft),inset 0 1px #ffffff80}.btn.ghost.active{background:var(--sage);border-color:transparent;color:#fff}.btn.full{width:100%}.btn.danger{color:var(--danger)}button:disabled{cursor:default}.sheet-backdrop{position:fixed;inset:0;z-index:50;display:flex;align-items:flex-end;justify-content:center;background:#1c16125c;opacity:0;transition:opacity .24s ease}.sheet-backdrop.open{opacity:1}.sheet-panel{width:100%;max-width:var(--maxw);max-height:88vh;overflow-y:auto;background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:8px 18px calc(var(--safe-bottom) + 22px);box-shadow:var(--shadow-lift);transform:translateY(100%);transition:transform .28s cubic-bezier(.2,.85,.25,1)}.sheet-backdrop.open .sheet-panel{transform:translateY(0)}.sheet-grip{width:42px;height:4px;border-radius:2px;background:var(--hairline);margin:6px auto}.sheet-head{display:flex;align-items:center;justify-content:space-between}.sheet-title{font-size:21px}.sheet-body{display:flex;flex-direction:column;gap:12px;padding-top:10px}.sheet-divider{height:1px;background:var(--hairline);margin:6px 0}.icon-btn.big{font-size:26px}.field{width:100%;padding:13px 14px;border-radius:var(--r-md);border:1px solid var(--hairline);background:var(--bg);color:var(--text);font-size:16px}.field:focus{outline:none;border-color:var(--accent)}.field-label{font-size:13px;color:var(--text-muted);margin-top:2px}.swatch-row{display:flex;gap:10px;flex-wrap:wrap}.swatch{width:42px;height:42px;border-radius:50%;border:none;box-shadow:var(--shadow-soft);transition:transform .14s ease,box-shadow .16s ease;background-image:radial-gradient(circle at 34% 30%,#ffffff80,#fff0 32%),radial-gradient(circle at 68% 74%,#00000029,#0000 60%)}.swatch.selected{transform:scale(1.1);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--accent-strong)}.chip-row{display:flex;gap:8px}.chip{padding:11px 16px;border-radius:999px;background:var(--bg);border:1px solid var(--hairline);color:var(--text-muted);font-weight:500}.chip.selected{background:var(--accent-strong);color:#fff;border-color:transparent}.goal-custom{margin-top:6px}.swatch.rainbow{background-image:radial-gradient(circle at 34% 30%,#ffffff80,#fff0 32%),conic-gradient(from 20deg,#e0a445,#8fa67e,#6e8aa6,#9a6b86,#d58a6b,#e0a445)}.goal-progress{display:flex;align-items:center;gap:9px;width:min(80%,320px);margin:3px auto 2px}.goal-track{flex:1;height:9px;border-radius:999px;background:var(--surface-2);box-shadow:inset 0 1px 2px #3a2c2029;overflow:hidden}.goal-fill{height:100%;width:0%;border-radius:999px;box-shadow:inset 0 1px #fff6;transition:width .6s cubic-bezier(.2,.8,.2,1)}.goal-label{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;min-width:48px;text-align:right}.goal-label strong{color:var(--text);font-weight:600}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.switch{width:48px;height:28px;border-radius:999px;background:var(--hairline);position:relative;transition:background .2s ease}.switch.on{background:var(--sage)}.switch.disabled{opacity:.4}.switch-knob{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000040;transition:transform .2s ease}.switch.on .switch-knob{transform:translate(20px)}.about{font-size:12px;color:var(--text-muted);margin:2px 0 0}.toast{position:fixed;left:50%;bottom:calc(var(--safe-bottom) + 96px);transform:translate(-50%) translateY(10px);background:var(--ink);color:var(--oat);padding:11px 18px;border-radius:999px;font-size:14px;box-shadow:var(--shadow-lift);opacity:0;transition:opacity .3s ease,transform .3s ease;z-index:60;max-width:88%;text-align:center}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.celebrate{position:fixed;inset:0;z-index:55;display:flex;align-items:center;justify-content:center;padding:30px;pointer-events:none;opacity:0;transition:opacity .5s ease}.celebrate.show{opacity:1}.celebrate-msg{font-family:var(--font-display);font-size:25px;line-height:1.3;text-align:center;color:var(--text);background:var(--surface);padding:24px 28px;border-radius:var(--r-lg);box-shadow:var(--shadow-lift);max-width:330px;transform:scale(.9);transition:transform .5s cubic-bezier(.2,.85,.25,1)}.celebrate.show .celebrate-msg{transform:scale(1)}.confetti-canvas{position:fixed;inset:0;width:100%;height:100%;pointer-events:none;z-index:54}.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.hidden{display:none!important}.field-hint{font-size:12px;color:var(--text-muted);margin:-6px 0 2px}.undo-link{align-self:center;margin:0 0 6px;padding:6px 10px;font-size:13px;color:var(--text-muted);text-decoration:underline;text-underline-offset:3px}.undo-link.is-hidden{visibility:hidden}.btn.danger.armed{background:#b4543f1f;color:var(--danger);font-weight:600}html.reduced-motion .thumb-fill,html.reduced-motion .sheet-panel,html.reduced-motion .celebrate-msg,html.reduced-motion .affirm-line{transition-duration:.05s}@media(prefers-reduced-motion:reduce){.thumb-fill,.sheet-panel,.celebrate-msg,.affirm-line,.jar-card,.btn{transition-duration:.05s!important}}
