:root{--color-bg-deep:#2d2b4e;--color-bg-surface:#3a3760;--color-bg-elevated:#4a4678;--color-bg-input:#353258;--color-ember:#f4733b;--color-ember-soft:#f4733b22;--color-ember-hover:#ff8a54;--color-peach:#fe9677;--color-peach-soft:#fe967722;--color-spark-gold:#f5a623;--color-spark-gold-soft:#f5a62322;--color-plum:#984063;--color-plum-soft:#98406333;--color-text-primary:#f0ede8;--color-text-secondary:#b0a8c0;--color-text-tertiary:#7a7394;--color-text-on-accent:#fff;--color-border:#4a4678;--color-divider:#3e3b65;--color-success:#4ade80;--color-warning:#fbbf24;--color-error:#f87171;--color-spark-friend:#f5a623;--color-spark-chef:#fe9677;--color-spark-study:#4ecdc4;--color-spark-music:#b388ff;--color-spark-story:#b25a86;--color-spark-checkin:#7cb98b;--color-spark-bedtime:#c9b1ff;--shadow-card:0 4px 24px rgba(25,23,48,.5);--shadow-elevated:0 8px 32px rgba(25,23,48,.6);--shadow-glow-ember:0 0 20px rgba(244,115,59,.22);--shadow-glow-peach:0 0 20px hsla(14,99%,73%,.15);--shadow-glow-gold:0 0 20px rgba(245,166,35,.15);--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--font-display:"Plus Jakarta Sans",system-ui,sans-serif;--font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;--radius-sm:0.5rem;--radius-md:0.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-full:9999px;--transition-fast:150ms ease;--transition-base:250ms ease;--transition-slow:400ms ease;--bg:var(--color-bg-deep);--panel:var(--color-bg-surface);--border:var(--color-border);--accent:var(--color-ember);--accent-soft:var(--color-ember-hover);--text:var(--color-text-primary);--muted:var(--color-text-secondary);--radius:var(--radius-lg);--spark-accent:var(--color-ember)}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font-body);height:100%}.app-title,.char-card-name,.onboarding-title{font-family:var(--font-display)}.page{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:560px;margin:0 auto;padding:10px 12px 14px;gap:10px}.app-header{position:relative;display:flex;align-items:center;justify-content:center;min-height:40px;padding:2px 2px 0}.app-title{margin:0;font-size:18px;font-weight:700;letter-spacing:.3px;text-align:center}.text-btn{position:absolute;left:0;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--color-text-secondary);font-size:14px;font-weight:600;padding:8px 6px;cursor:pointer;transition:color var(--transition-fast)}.text-btn:hover{color:var(--color-text-primary)}.icon-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text);background:transparent;border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:background .15s ease}.icon-btn:hover{background:hsla(0,0%,100%,.06)}.hero{position:relative;flex:1 1;min-height:0;background:radial-gradient(120% 100% at 50% 0,var(--color-bg-elevated) 0,var(--color-bg-surface) 70%);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:50%;transition:filter 1.5s ease;pointer-events:none}.hero-grade{transition:background 1.5s ease,box-shadow 1.5s ease}.embers,.hero-grade{position:absolute;inset:0;z-index:1;pointer-events:none}.embers{overflow:hidden}.ember{position:absolute;top:-14px;border-radius:50%;background:currentColor;box-shadow:0 0 7px 1px currentColor;opacity:0;will-change:transform,opacity;animation:ember-fall var(--dur) linear var(--delay) infinite}@keyframes ember-fall{0%{transform:translate(0) scale(1);opacity:0}12%{opacity:var(--o)}88%{opacity:var(--o)}to{transform:translate(calc(var(--driftvw) * 1vw),112vh) scale(.5);opacity:0}}@media (prefers-reduced-motion:reduce){.embers{display:none}}.avatar-panel{width:100%;height:100%;position:relative;z-index:2;display:flex;align-items:center;justify-content:center}.avatar-3d{position:absolute;inset:0}.avatar-note{position:absolute;top:12px;left:12px;right:12px;text-align:center;font-size:12px;color:var(--muted);background:rgba(0,0,0,.4);padding:6px 10px;border-radius:8px}.clock{font-size:13px;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--color-text-secondary)}.hero-clock{position:absolute;top:12px;right:12px;z-index:3;color:var(--color-text-primary);background:rgba(0,0,0,.4);padding:4px 10px;border-radius:var(--radius-full);pointer-events:none}.settings-hint{color:var(--color-text-tertiary);font-style:normal;font-size:12px}.pin-overlay{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;background:rgba(20,18,38,.7);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:24px}.pin-sheet{width:100%;max-width:340px;background:var(--color-surface,#2d2b4e);border-radius:var(--radius-lg,20px);padding:28px 22px;box-shadow:0 18px 50px rgba(0,0,0,.45)}.pinpad{text-align:center}.pinpad-title{font-size:20px;font-weight:700;margin:0 0 4px}.pinpad-sub{font-size:13px;color:var(--color-text-secondary);margin:0 0 12px;word-break:break-all}.pin-dots{display:flex;justify-content:center;gap:16px;margin:12px 0 16px}.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--color-ember,#f4733b);background:transparent;transition:background .15s ease}.pin-dot.filled{background:var(--color-ember,#f4733b)}.pin-keys{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px;margin-top:12px}.pin-key{height:60px;border-radius:var(--radius-full,999px);border:none;background:hsla(0,0%,100%,.08);color:var(--color-text-primary);font-size:22px;font-weight:600;cursor:pointer;transition:background .12s ease,transform .08s ease}.pin-key:active{transform:scale(.95);background:hsla(0,0%,100%,.16)}.pin-key:disabled{opacity:.5;cursor:default}.pin-key-text{font-size:14px}.pin-key-empty{background:transparent;pointer-events:none}.app-header.conv-accent{border-bottom:2px solid var(--color-active-accent,var(--border))}.app-header.conv-accent .app-title{color:var(--color-active-accent,var(--color-text-primary))}.spark-types{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:6px 0 14px}.spark-type-tab{padding:8px 18px;border-radius:var(--radius-full);border:1px solid var(--border);background:transparent;color:var(--color-text-secondary);font-weight:600;font-size:14px;cursor:pointer;transition:all .15s ease}.spark-type-tab.active{background:var(--color-bg-elevated);color:var(--color-text-primary);border-color:var(--color-text-tertiary)}.spark-traits{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:0 0 18px}.spark-trait{padding:7px 16px;border-radius:var(--radius-full);border:none;background:var(--color-bg-elevated);color:var(--color-text-secondary);font-weight:600;font-size:13px;cursor:pointer;transition:all .15s ease}.spark-trait.active{background:var(--color-ember);color:#fff}.spark-empty{text-align:center;color:var(--color-text-secondary);font-size:14px;padding:40px 0}.tcard-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:14px;gap:14px;width:100%}@media (min-width:768px){.tcard-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:360px){.tcard-grid{grid-template-columns:1fr;max-width:280px;margin:0 auto}}.tcard{--accent:var(--color-ember);display:flex;flex-direction:column;background:var(--color-bg-surface);border:2px solid var(--border);border-radius:20px;overflow:hidden;cursor:pointer;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.tcard.active{border-color:var(--accent);box-shadow:0 0 22px color-mix(in srgb,var(--accent) 35%,transparent);transform:scale(1.02)}.tcard.locked{opacity:.62;cursor:default}.tcard-art{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--color-bg-deep,#1a1830)}.tcard-img,.tcard-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .16s ease}.tcard-placeholder{position:absolute;inset:0}.tcard-initial,.tcard-placeholder{display:flex;align-items:center;justify-content:center}.tcard-initial{width:86px;height:86px;border-radius:50%;font-family:var(--font-display);font-size:38px;font-weight:800;color:#fff;background:radial-gradient(circle at 30% 30%,var(--accent),color-mix(in srgb,var(--accent) 45%,#000))}.tcard-badge{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.55);color:var(--color-text-primary);font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--radius-full)}.tcard-info{flex:1 1;display:flex;flex-direction:column;gap:6px;padding:14px 16px 16px}.tcard-name{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--accent);margin:0}.tcard-oneliner{flex:1 1;font-size:13px;font-style:italic;color:var(--color-text-secondary);line-height:1.4;margin:0}.tcard-hint{display:flex;align-items:center;gap:6px;min-height:16px;font-size:12px;color:var(--color-text-tertiary);margin:2px 0 4px}.tcard-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:tcard-pulse 2s ease-in-out infinite}@keyframes tcard-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.tcard-select{width:100%;padding:10px 0;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:700;cursor:pointer;transition:opacity .15s ease}.tcard-select:hover{opacity:.9}.tcard-select:disabled{background:var(--color-bg-elevated);color:var(--color-text-tertiary);cursor:default}.beehiiv-embed{width:100%;margin-top:14px;display:flex;justify-content:center}.beehiiv-embed iframe{max-width:100%}.studio{min-height:100dvh;display:flex;flex-wrap:wrap;gap:24px;padding:24px;background:var(--color-bg-deep);color:var(--color-text-primary)}.studio-stage{position:relative;width:420px;max-width:100%;aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;background:radial-gradient(120% 100% at 50% 0,var(--color-bg-elevated) 0,var(--color-bg-surface) 70%)}.studio-controls{flex:1 1 320px;max-width:460px}.studio-controls h1{font-family:var(--font-display);font-size:28px;margin:0 0 8px}.studio-field{display:flex;flex-direction:column;gap:6px;margin:16px 0;font-size:14px;font-weight:600}.studio-hint{font-size:13px;line-height:1.5;color:var(--color-text-secondary);margin:8px 0}.studio-buttons{display:flex;gap:12px;margin-top:16px}.chat-area{flex:0 0 38%;min-height:0;display:flex;flex-direction:column;gap:10px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.transcript{flex:1 1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:4px}.transcript-empty{color:var(--muted);font-size:14px;margin:auto;text-align:center}.bubble{display:flex;flex-direction:column;gap:2px;max-width:85%;padding:8px 12px;border-radius:12px;font-size:14px;line-height:1.4}.bubble.user{align-self:flex-end;background:var(--color-bg-elevated)}.bubble.assistant{align-self:flex-start;background:var(--color-ember-soft)}.bubble.interim{opacity:.6;font-style:italic}.bubble-speaker{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.caret{display:inline-block;width:2px;height:1em;margin-left:1px;background:var(--accent-soft);vertical-align:text-bottom;animation:caret-blink .9s steps(1) infinite}@keyframes caret-blink{50%{opacity:0}}.composer{gap:10px}.composer,.composer-form{display:flex;align-items:center}.composer-form{flex:1 1;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:999px;padding:4px 4px 4px 14px}.composer-input{flex:1 1;background:transparent;border:none;outline:none;color:var(--text);font-size:15px;padding:8px 0}.composer-input::placeholder{color:var(--muted)}.composer-send{width:38px;height:38px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:var(--accent);color:var(--color-text-on-accent);cursor:pointer;transition:opacity .15s ease,transform .05s ease}.composer-send:active{transform:scale(.95)}.composer-send:disabled{opacity:.4;cursor:not-allowed}.mic-btn{width:56px;height:56px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:var(--accent);color:var(--color-text-on-accent);cursor:pointer;transition:transform .05s ease,background .2s ease,box-shadow .2s ease}.mic-btn:active{transform:scale(.96)}.mic-btn:disabled{opacity:.5;cursor:not-allowed}.mic-btn.listening{background:var(--color-ember-hover);color:#fff;box-shadow:0 0 0 0 rgba(255,107,74,.6);animation:mic-pulse 1.4s infinite}@keyframes mic-pulse{0%{box-shadow:0 0 0 0 rgba(244,115,59,.55)}70%{box-shadow:0 0 0 14px rgba(244,115,59,0)}to{box-shadow:0 0 0 0 rgba(244,115,59,0)}}.status-indicator{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--muted)}.status-dot{width:10px;height:10px;border-radius:50%;background:#64748b}.status-listening .status-dot{background:#22c55e;animation:pulse 1.2s infinite}.status-processing .status-dot{background:#eab308;animation:pulse .7s infinite}.status-speaking .status-dot{background:var(--accent-soft);animation:pulse .5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.banner{padding:10px 14px;border-radius:10px;font-size:14px}.banner.error{background:#7f1d1d;color:#fecaca}.hearth{gap:14px}.text-btn-right{left:auto;right:0}.text-btn-spacer{width:60px}.hearth-greeting{margin:0;font-size:16px;color:var(--color-text-secondary)}.spark-list{display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding-bottom:8px}.spark-card{display:flex;align-items:center;gap:14px;padding:14px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--panel);color:var(--text);cursor:pointer;text-align:left;box-shadow:var(--shadow-card);transition:transform .08s ease,box-shadow .15s ease}.spark-card:hover{transform:translateY(-2px)}.spark-card-avatar{width:56px;height:56px;flex:0 0 auto;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;font-family:var(--font-display);color:var(--color-text-on-accent)}.spark-card-info{min-width:0}.spark-card-name{font-family:var(--font-display);font-weight:700;font-size:17px}.spark-card-badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin:1px 0 3px}.spark-card-desc{font-size:13px;line-height:1.35}.add-spark-card,.spark-card-desc{color:var(--color-text-secondary)}.add-spark-card{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;border-radius:var(--radius-lg);border:1px dashed var(--border);background:transparent;font-size:15px;font-weight:600;cursor:pointer;transition:color .15s ease,border-color .15s ease}.add-spark-card:hover{color:var(--accent);border-color:var(--accent)}.add-spark-plus{font-size:22px;line-height:1}.bottom-nav{position:fixed;left:50%;transform:translateX(-50%);bottom:0;width:100%;max-width:560px;display:flex;background:var(--color-bg-surface);border-top:1px solid var(--color-border);padding:6px 8px calc(8px + env(safe-area-inset-bottom));z-index:50}.nav-tab{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:3px;background:transparent;border:none;color:var(--color-text-tertiary);font-size:11px;font-weight:600;padding:6px 0;cursor:pointer;transition:color var(--transition-fast)}.nav-tab.active{color:var(--color-ember)}.hearth,.mystuff-page,.settings-page{padding-bottom:78px}.hearth-subgreeting{margin:0 0 4px;color:var(--color-text-secondary);font-size:14px}.settings-scroll{flex:1 1;overflow-y:auto;display:flex;flex-direction:column;gap:18px}.settings-heading{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);margin:0 0 8px 2px}.settings-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;width:100%;border:none;background:transparent;color:var(--text);font-size:15px;text-align:left;border-bottom:1px solid var(--color-divider)}.settings-row:last-child{border-bottom:none}.toggle-row{cursor:pointer}.settings-row.link:disabled{opacity:.6;cursor:not-allowed}.settings-field{display:flex;flex-direction:column;gap:6px;padding:14px}.settings-field>span{font-size:13px;color:var(--color-text-secondary)}.settings-input{background:var(--color-bg-input);border:1px solid var(--border);border-radius:10px;padding:10px 12px;color:var(--text);font-size:15px;outline:none}.settings-input:focus{border-color:var(--accent)}.settings-value{color:var(--color-text-secondary);font-size:14px}.toggle{width:42px;height:24px;border-radius:999px;background:var(--color-bg-elevated);border:1px solid var(--border);position:relative;flex:0 0 auto;transition:background var(--transition-fast)}.toggle.on{background:var(--color-spark-gold)}.toggle-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:left var(--transition-fast)}.toggle.on .toggle-knob{left:20px}.mystuff-scroll{flex:1 1;overflow-y:auto}.quick-cards{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px;margin-bottom:18px}.quick-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--panel)}.quick-card.disabled{opacity:.55}.quick-card-icon{font-size:24px}.quick-card-label{font-weight:700;font-size:14px}.quick-card-note{font-size:11px;color:var(--color-text-tertiary)}.mystuff-empty{color:var(--color-text-secondary);font-size:14px;line-height:1.5}.kitchen-card{padding:12px}.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.chip{display:inline-flex;gap:6px;padding:6px 6px 6px 12px;border-radius:var(--radius-full);background:var(--color-bg-elevated);font-size:13px}.chip,.chip-x{align-items:center}.chip-x{width:18px;height:18px;display:flex;justify-content:center;border:none;border-radius:50%;background:hsla(0,0%,100%,.08);color:var(--color-text-secondary);font-size:14px;line-height:1;cursor:pointer}.chip-empty{color:var(--color-text-tertiary);font-size:13px;font-style:italic}.chip-add{display:flex;gap:8px}.chip-add .settings-input{flex:1 1}.chip-add-btn{flex:0 0 auto;padding:0 16px;border:none;border-radius:10px;background:var(--accent);color:var(--color-text-on-accent);font-weight:600;cursor:pointer}.chip-add-btn:disabled{opacity:.4;cursor:not-allowed}.stepper{display:inline-flex;align-items:center;gap:14px}.stepper button{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--color-bg-elevated);color:var(--text);font-size:18px;cursor:pointer}.stepper-value{min-width:18px;text-align:center;font-weight:700}.bg-switcher-backdrop{position:fixed;inset:0;z-index:40}.bg-switcher{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:41;background:var(--color-bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px;box-shadow:var(--shadow-elevated)}.bg-switcher-title{margin:0 0 8px;font-size:13px;color:var(--color-text-secondary)}.bg-switcher-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px}.bg-thumb{position:relative;aspect-ratio:16/10;border-radius:10px;border:2px solid transparent;background-size:cover;background-position:50%;display:flex;align-items:flex-end;padding:6px;cursor:pointer;overflow:hidden}.bg-thumb:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.6))}.bg-thumb.current{border-color:var(--color-spark-gold)}.bg-thumb-name{position:relative;z-index:1;font-size:11px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6)}.msg-group{gap:6px}.msg-group,.recipe-card{display:flex;flex-direction:column}.recipe-card{align-self:flex-start;max-width:90%;border:1px solid var(--color-spark-chef);border-radius:14px;background:var(--panel);padding:12px;gap:10px}.recipe-card-title{font-family:var(--font-display);font-weight:700;font-size:16px}.recipe-card-meta{font-size:12px;color:var(--color-text-secondary)}.recipe-card-actions{display:flex;gap:8px}.recipe-btn{border:none;border-radius:10px;padding:9px 14px;font-size:14px;font-weight:600;cursor:pointer}.recipe-btn.primary{background:var(--color-spark-chef);color:#fff}.recipe-btn.primary.big{flex:1 1;padding:14px;font-size:15px}.recipe-btn.ghost{background:transparent;border:1px solid var(--border);color:var(--text)}.recipe-btn:disabled{opacity:.5;cursor:default}.recipe-list-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--panel);margin-bottom:10px}.recipe-list-info{min-width:0}.recipe-list-actions{display:flex;gap:6px;flex:0 0 auto}.recipe-list-actions .recipe-btn{padding:8px 12px;font-size:13px}.chef-actions{align-self:flex-start;display:flex;gap:8px;flex-wrap:wrap}.chef-action{border:1px solid var(--color-spark-chef);color:var(--color-spark-chef);background:transparent;border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease}.chef-action:hover:not(:disabled){background:var(--color-ember-soft)}.chef-action:disabled{opacity:.5;cursor:default}.chat-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}.goodbye-btn{background:transparent;border:none;color:var(--color-text-secondary);font-size:13px;font-weight:600;cursor:pointer;padding:4px}.goodbye-btn:hover{color:var(--color-text-primary)}.goodbye-btn:disabled{opacity:.6}.toast{position:fixed;bottom:92px;left:50%;transform:translateX(-50%);background:var(--color-bg-elevated);border:1px solid var(--border);color:var(--text);padding:10px 18px;border-radius:999px;font-size:14px;z-index:90;box-shadow:var(--shadow-elevated)}.grocery-list{list-style:none;padding:0;margin:0 0 8px;display:flex;flex-direction:column;gap:6px}.grocery-list li label{display:flex;align-items:center;gap:10px;font-size:15px;cursor:pointer}.grocery-list li.checked{opacity:.5;text-decoration:line-through}.grocery-list input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-spark-chef)}.sheet-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:60}.sheet{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:560px;height:78vh;background:var(--color-bg-surface);border-radius:20px 20px 0 0;box-shadow:var(--shadow-elevated);z-index:61;display:flex;flex-direction:column;padding:8px 16px calc(16px + env(safe-area-inset-bottom))}.sheet-grip{width:44px;height:4px;border-radius:999px;background:var(--color-border);margin:6px auto 10px;cursor:pointer;flex:0 0 auto}.sheet-scroll{flex:1 1;overflow-y:auto}.sheet-title{font-family:var(--font-display);font-size:22px;margin:0 0 4px}.sheet-desc{color:var(--color-text-secondary);font-size:14px;line-height:1.5;margin:0 0 12px}.sheet-heading{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-spark-chef);margin:16px 0 8px}.servings-adjuster{display:flex;align-items:center;justify-content:space-between;background:var(--color-bg-elevated);border-radius:12px;padding:10px 14px;margin-bottom:8px}.ingredient-list,.step-list{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:8px;font-size:15px;line-height:1.45}.ingredient-list{list-style:none;padding-left:0}.ing-amount{font-weight:700;color:var(--color-spark-gold)}.step-time{color:var(--color-text-tertiary);font-size:13px}.sheet-actions{flex:0 0 auto;display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--color-divider)}.cook-mode{position:fixed;inset:0;z-index:80;background:var(--color-bg-deep);display:flex;flex-direction:column;padding:16px calc(16px + env(safe-area-inset-right)) calc(16px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left));max-width:640px;margin:0 auto}.cook-header{display:flex;align-items:center;justify-content:space-between}.cook-step-count{font-size:14px;color:var(--color-text-secondary);font-weight:600}.cook-body{flex:1 1;display:flex;flex-direction:column;justify-content:center;gap:24px}.cook-step-text{font-size:26px;line-height:1.4;font-weight:600}.cook-timer{display:flex;align-items:center;gap:16px;background:var(--color-bg-surface);border:1px solid var(--border);border-radius:16px;padding:16px 20px}.cook-timer.done{border-color:var(--color-spark-gold)}.cook-timer-time{font-size:32px;font-weight:800;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.cook-nav{display:flex;gap:12px}.cook-nav-btn{flex:1 1;min-height:56px;border:1px solid var(--border);border-radius:14px;background:var(--color-bg-surface);color:var(--text);font-size:17px;font-weight:700;cursor:pointer}.cook-nav-btn.next{background:var(--color-spark-chef);color:#fff;border-color:var(--color-spark-chef)}.cook-nav-btn:disabled{opacity:.4}.splash{flex:1 1;display:flex;align-items:center;justify-content:center;font-size:32px;color:var(--muted)}.front{height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;color:var(--color-text-primary);background:radial-gradient(ellipse 120% 80% at 50% -8%,rgba(244,115,59,.18) 0,rgba(152,64,99,.08) 34%,var(--color-bg-deep) 70%)}.front-hero{position:relative;min-height:88dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;padding:32px 24px}.front-glow{position:absolute;top:10%;left:50%;width:min(340px,70vw);height:min(340px,70vw);transform:translateX(-50%);border-radius:50%;background:radial-gradient(circle,rgba(244,115,59,.38) 0,rgba(244,115,59,0) 70%);filter:blur(24px);pointer-events:none;z-index:0;animation:front-pulse 6s ease-in-out infinite}@keyframes front-pulse{0%,to{opacity:.55;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.08)}}.front-logo{position:relative;z-index:1;margin:0;font-family:var(--font-display);font-size:clamp(42px,13vw,70px);font-weight:800;letter-spacing:-.5px;line-height:1}.front-logo .spark{background:linear-gradient(120deg,var(--color-spark-gold),var(--color-ember));-webkit-background-clip:text;background-clip:text;color:transparent}.gate-logo{font-size:clamp(32px,9vw,44px);margin-bottom:10px}.legal{min-height:100dvh;background:var(--color-bg-deep);color:var(--color-text-primary);padding:32px 20px 64px}.legal-inner{max-width:720px;margin:0 auto}.legal-home{display:inline-block;font-family:var(--font-display);font-size:22px;font-weight:800;text-decoration:none;color:var(--color-text-primary);margin-bottom:24px}.legal-home .spark{background:linear-gradient(120deg,var(--color-spark-gold),var(--color-ember));-webkit-background-clip:text;background-clip:text;color:transparent}.legal h1{font-family:var(--font-display);font-size:clamp(28px,7vw,38px);margin:0 0 4px}.legal-updated{color:var(--color-text-tertiary);font-size:13px;margin:0 0 24px}.legal h2{font-size:19px;font-weight:700;margin:28px 0 8px}.legal li,.legal p{color:var(--color-text-secondary);font-size:15px;line-height:1.65}.legal ul{padding-left:20px;margin:8px 0}.legal li{margin-bottom:6px}.legal a{color:var(--color-ember);text-decoration:none}.legal a:hover{text-decoration:underline}.legal strong{color:var(--color-text-primary)}.front-headline{position:relative;z-index:1;margin:6px 0 0;font-family:var(--font-display);font-size:clamp(25px,7vw,40px);font-weight:700;line-height:1.15;max-width:16ch}.front-subhead{margin:0;font-size:clamp(15px,4.2vw,18px);line-height:1.55;color:var(--color-text-secondary);max-width:32ch}.front-cta,.front-subhead{position:relative;z-index:1}.front-cta{display:flex;flex-direction:column;gap:12px;width:100%;max-width:300px;margin-top:10px}.front-inner{max-width:760px;margin:0 auto;padding:0 24px 56px}.front-section{padding:44px 0;border-top:1px solid var(--border)}.front-eyebrow{margin:0 0 18px;text-align:center;text-transform:uppercase;letter-spacing:2.5px;font-size:12px;font-weight:700;color:var(--color-ember)}.front-grid{display:grid;grid-gap:14px;gap:14px}.front-sparks{display:grid;grid-gap:12px;gap:12px}@media (min-width:620px){.front-grid{grid-template-columns:repeat(3,1fr)}.front-sparks{grid-template-columns:repeat(2,1fr)}}.front-card{padding:20px;border-radius:var(--radius);background:hsla(0,0%,100%,.04);border:1px solid var(--border)}.front-card h3{margin:0 0 6px;font-size:17px;font-weight:700}.front-card p{margin:0;font-size:14px;line-height:1.5;color:var(--color-text-secondary)}.front-spark{display:flex;flex-direction:column;gap:4px;padding:16px 18px;border-radius:var(--radius);background:hsla(0,0%,100%,.04);border:1px solid var(--border);border-left:3px solid var(--color-ember)}.front-spark .name{font-weight:700;font-size:16px}.front-spark .desc{font-size:13px;line-height:1.45;color:var(--color-text-secondary)}.front-closing{text-align:center;padding:52px 0 8px}.front-closing h2{margin:0 0 18px;font-family:var(--font-display);font-size:clamp(24px,6vw,34px);font-weight:700}.front-closing .btn-primary{max-width:300px;margin:0 auto}.front-foot{margin:26px 0 0;color:var(--color-text-tertiary);font-size:12px;line-height:1.7}.front-foot .trust{color:var(--color-text-secondary);font-size:13px}.front-foot a{color:var(--color-text-tertiary);text-decoration:none}.front-foot a:hover{text-decoration:underline}.waitlist-form{display:flex;flex-direction:column;gap:12px;width:100%}.front-signin{background:none;border:none;color:var(--color-text-secondary);font-size:14px;font-weight:600;cursor:pointer;padding:6px}.front-signin:hover{color:var(--color-text-primary)}.waitlist-done{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.waitlist-done-title{font-family:var(--font-display);font-size:22px;font-weight:800;margin:0}.waitlist-position{margin:0;font-size:15px;color:var(--color-spark-gold);font-weight:700}.waitlist-sub{margin:0;font-size:14px;color:var(--color-text-secondary)}.waitlist-link{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border);background:hsla(0,0%,100%,.06);color:var(--color-text-primary);font-size:13px;cursor:pointer;text-align:left}.waitlist-link>span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.waitlist-copy{flex-shrink:0;color:var(--color-ember);font-weight:700}.waitlist-fineprint{margin:0;font-size:12px;line-height:1.5;color:var(--color-text-tertiary)}.landing{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;text-align:center}.landing-bg{background:radial-gradient(ellipse at center,rgba(244,115,59,.12) 0,rgba(152,64,99,.06) 30%,var(--color-bg-deep) 72%)}.landing-inner{width:100%;max-width:420px;gap:8px}.landing-inner,.landing-mark{display:flex;flex-direction:column;align-items:center}.landing-mark{gap:2px;margin-bottom:6px}.landing-spark{font-size:40px;color:var(--color-spark-gold);text-shadow:var(--shadow-glow-gold)}.landing-logo{margin:0;font-family:var(--font-display);font-size:34px;font-weight:800;letter-spacing:.3px}.landing-tagline{margin:0 0 18px;color:var(--color-ember);font-size:16px;font-weight:600}.landing-valueprop{margin:0 0 28px;color:var(--color-text-secondary);font-size:16px;line-height:1.5}.landing-cta{width:100%;display:flex;flex-direction:column;gap:12px}.btn-ghost{font-size:16px;font-weight:600;padding:14px 20px;border-radius:12px;background:transparent;border:1px solid var(--color-plum);color:var(--color-text-secondary);cursor:pointer}.btn-ghost:hover{color:var(--color-text-primary);border-color:var(--color-ember)}.landing-trust{margin:22px 0 0;color:var(--color-text-secondary);font-size:13px}.landing-footer{margin:2px 0 0;color:var(--color-text-tertiary);font-size:12px}.login-inner{position:relative;width:100%;max-width:380px;display:flex;flex-direction:column;gap:14px;text-align:left}.gate-inner{text-align:center;align-items:center}.gate-inner .auth-email-form{width:100%}.login-inner .text-btn{position:static;transform:none;align-self:flex-start;padding:0 0 4px}.login-title{font-family:var(--font-display);font-size:26px;margin:4px 0 8px}.login-options{display:flex;flex-direction:column;gap:12px}.auth-btn{font-size:16px;font-weight:600;padding:14px 18px;border-radius:12px;border:1px solid var(--color-border);background:var(--color-bg-surface);color:var(--color-text-primary);cursor:pointer}.auth-btn.google{background:#fff;color:#1f1f1f;border-color:#fff}.auth-btn:disabled{opacity:.6}.auth-email-form{display:flex;flex-direction:column;gap:12px}.auth-toggle{background:none;border:none;color:var(--color-ember);font-size:14px;cursor:pointer;padding:4px}.auth-note{color:var(--color-text-secondary);font-size:14px;line-height:1.5}.auth-error{color:var(--color-error);font-size:14px}.onboarding{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(120% 90% at 50% 0,var(--color-bg-elevated) 0,var(--color-bg-deep) 70%)}.onboarding-inner{position:relative;width:100%;max-width:420px;text-align:center}.onboarding-inner.wide{max-width:640px}.onboarding-back{position:absolute;top:-4px;left:0;font-size:14px;font-weight:600;color:var(--color-text-secondary);background:transparent;border:none;padding:8px 6px;cursor:pointer;transition:color var(--transition-fast)}.onboarding-back:hover{color:var(--color-text-primary)}.onboarding-emoji{font-size:44px;margin-bottom:8px}.onboarding-title{font-size:24px;font-weight:700;margin:0 0 6px;line-height:1.25}.onboarding-sub{color:var(--muted);margin:0 0 24px;font-size:15px}.onboarding-form{display:flex;flex-direction:column;gap:12px}.onboarding-input{width:100%;font-size:17px;padding:14px 16px;border-radius:12px;border:1px solid var(--border);background:var(--panel);color:var(--text);outline:none;text-align:center}.onboarding-input:focus{border-color:var(--accent)}.btn-primary{font-size:16px;font-weight:700;padding:14px 20px;border:none;border-radius:12px;background:var(--accent);color:var(--color-text-on-accent);cursor:pointer;box-shadow:var(--shadow-glow-ember);transition:transform .05s ease,opacity .2s ease}.btn-primary:active{transform:scale(.99)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.card-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:12px;gap:12px;margin-bottom:20px}.char-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 14px;border-radius:16px;border:1px solid var(--border);background:var(--panel);color:var(--text);cursor:pointer;text-align:center;transition:transform .08s ease,box-shadow .15s ease}.char-card:not(.locked):hover{transform:translateY(-2px);box-shadow:var(--shadow-card)}.char-card.locked{cursor:not-allowed;opacity:.5;border-color:var(--border)!important}.coming-soon{position:absolute;top:8px;right:8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-secondary);background:var(--color-bg-elevated);padding:3px 7px;border-radius:var(--radius-full)}.char-card-avatar{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800;color:var(--color-text-on-accent);background:linear-gradient(160deg,var(--color-spark-gold) 0,var(--color-ember) 100%);background-size:cover;background-position:50%}.char-card-name{font-weight:700;font-size:16px}.char-card-desc{font-size:12px;color:var(--muted);line-height:1.35}.card-grid.vibes{margin-bottom:20px}.vibe-card{position:relative;aspect-ratio:16/10;border-radius:14px;border:2px solid transparent;background-size:cover;background-position:50%;cursor:pointer;display:flex;align-items:flex-end;padding:10px;color:#fff;overflow:hidden}.vibe-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.6))}.vibe-card.selected{border-color:var(--accent-soft)}.vibe-name{position:relative;z-index:1;font-weight:700;font-size:14px;text-shadow:0 1px 3px rgba(0,0,0,.6)}