@import"https://fonts.googleapis.com/css2?family=Caveat:wght@500;600&family=Dancing+Script:wght@500;600&family=Playfair+Display:ital,wght@0,400;0,600;1,400&family=Lora:ital,wght@0,400;0,600;1,400&family=Montserrat:ital,wght@0,400;0,500;0,600;1,400&display=swap";.music-player{position:fixed;bottom:80px;right:16px;width:280px;background:var(--surface);border:1px solid var(--border-dark);border-radius:8px;overflow:hidden;box-shadow:0 4px 20px #3a2e2633;z-index:200;transition:width .2s ease}.music-player.minimized{width:220px}.music-player-header{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--surface-warm);border-bottom:1px solid var(--border);cursor:default}.music-icon{font-size:14px;color:var(--accent);flex-shrink:0}.music-label{flex:1;font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.music-min-btn,.music-close-btn{background:none;border:none;color:var(--text-dim);font-size:11px;cursor:pointer;padding:2px 5px;border-radius:4px;flex-shrink:0;line-height:1}.music-min-btn:hover,.music-close-btn:hover{color:var(--text);background:#3a2e261a}.music-frame{display:block;width:100%;height:158px;border:none;background:#1a1a1a}.music-fallback{padding:16px;text-align:center}.music-fallback p{font-size:12px;color:var(--text-dim);margin:0 0 10px}.music-fallback a{font-size:13px;color:var(--accent);text-decoration:none}.music-fallback a:hover{text-decoration:underline}.music-player-compact{position:static;width:auto;max-width:85%;box-shadow:0 2px 12px #0000004d}.music-player-compact .music-frame-hidden{position:absolute;left:-9999px;width:158px;height:158px;pointer-events:none;visibility:hidden}.music-player-compact-bar{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;background:#3a2e26eb;border-radius:8px;border:1px solid var(--border-dark)}.music-player-compact-bar .music-label{flex:1;font-size:.8rem;color:var(--bg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.music-player-compact-bar .music-close-btn{color:#fffc;font-size:14px}.music-player-compact-bar .music-close-btn:hover{color:#fff}:root{--bg: #FBF4E9;--surface: #F3E8D5;--surface-warm: #EBE0CC;--border: #D6C7A8;--border-dark: #C4A86C;--accent: #D95B43;--accent-dim: #C04A34;--text: #3A2E26;--text-dim: #8A7A66;--green: #5A8A5A;--red: #C04A34;--gold: #D4A535;--amber: #D95B43;--amber-dim: #C04A34}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);background-image:linear-gradient(180deg,rgba(212,165,53,.03) 0%,transparent 50%),linear-gradient(90deg,rgba(212,165,53,.04) 0%,transparent 50%);color:var(--text);font-family:Montserrat,sans-serif;min-height:100vh}.app{max-width:980px;margin:0 auto;padding:1.5rem 1.25rem;display:flex;flex-direction:column;gap:1.5rem;min-height:100vh}.main{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.main>.main-camera{width:100%;max-width:540px}.main-home{flex:1;display:flex;justify-content:center;align-items:center;padding:2rem 1rem}.home-books{display:flex;gap:2.5rem;justify-content:center;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.home-books::-webkit-scrollbar{display:none}.home-book{flex-shrink:0}.home-book{position:relative;width:280px;height:380px;border-radius:6px 14px 14px 6px;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;padding:3rem 1.5rem 2rem;font-family:Montserrat,sans-serif;text-align:center;transition:transform .18s,box-shadow .18s;box-shadow:3px 4px 12px #0003,inset -2px 0 6px #ffffff26;overflow:hidden}.home-book:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.08'/%3E%3C/svg%3E");pointer-events:none}.home-book:hover{transform:translateY(-6px) rotate(-1deg);box-shadow:5px 8px 20px #00000040}.home-book:active{transform:translateY(-2px)}.home-book-spine{position:absolute;left:0;top:0;bottom:0;width:22px;background:#00000026;border-radius:6px 0 0 6px}.home-book-oval{background:#ffffffe0;border-radius:50%;width:190px;height:140px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;box-shadow:0 1px 4px #0000001a;flex-shrink:0}.home-book-oval span{font-family:Brush Script MT,Brush Script Std,Dancing Script,cursive;font-size:1.85rem;color:#2a2a2a;line-height:1.2}.home-book-desc{font-size:.95rem;color:#ffffffeb;line-height:1.4;font-style:italic}.home-book-follow{background:#e8734a}.home-book-record{background:#e8b84a}.home-book-library{background:#4a9de8}.follow-panel{width:100%;max-width:520px;display:flex;flex-direction:column;gap:.75rem}.follow-back{align-self:flex-start;background:none;border:none;color:var(--text-dim);font-family:Montserrat,sans-serif;font-size:.95rem;cursor:pointer;padding:.25rem 0}.follow-back:hover{color:var(--text)}.follow-title{font-family:Brush Script MT,Brush Script Std,Dancing Script,cursive;font-size:2rem;color:var(--text);margin:0 0 .25rem}@media(max-width:780px){.home-books{justify-content:flex-start}.home-book{width:220px;height:300px;flex-shrink:0;padding:2.5rem 1.25rem 1.5rem;border-radius:4px 12px 12px 4px}.home-book-spine{width:18px;border-radius:4px 0 0 4px}.home-book-oval{width:150px;height:110px;margin-bottom:1.25rem}.home-book-oval span{font-size:1.5rem}.home-book-desc{font-size:.85rem}}.main-cooking{display:grid;grid-template-columns:220px 1fr 280px;grid-template-rows:auto 1fr;gap:2.25rem 1.5rem;align-items:start;margin-top:1rem}.main-cooking>.main-camera{max-width:none;grid-column:1 / 3}.main-cooking .camera-container{height:290px;aspect-ratio:unset}.main-camera{min-width:0;position:relative}.camera-overlay-timers{position:absolute;top:.5rem;right:.5rem;z-index:10;max-width:180px}.camera-overlay-music{position:absolute;bottom:.5rem;left:.5rem;z-index:10}.main-conversation{display:flex;flex-direction:column;gap:0;overflow:hidden}.main-ingredients{position:sticky;top:1.5rem}.main-ingredients .ingredients-panel{font-size:.8rem}.main-ingredients .ingredient-item{font-size:.8rem;flex-wrap:wrap;padding:.15rem 0;gap:.25rem}.main-ingredients .ingredient-amount{min-width:unset;font-size:.8rem}.main-ingredients .steps-heading{font-size:.75rem}.main-recipe{grid-column:2 / 4;min-width:0}.current-step-callout{display:flex;flex-direction:column;gap:.5rem;background:#d95b4314;border:1px solid rgba(217,91,67,.25);border-radius:6px;padding:.5rem .75rem;margin-top:.75rem;overflow:hidden}.current-step-callout-orange{background:#e85c2b;border-color:#d94a2a;color:#fff;box-shadow:0 2px 12px #0003}.current-step-callout-orange .current-step-label{color:#fffffff2;font-size:1.1rem}.current-step-callout-orange .current-step-text{color:#fff;font-size:1.5rem;line-height:1.3}.current-step-callout-orange .current-step-images{margin-top:.35rem}.current-step-callout-orange .current-step-img{max-height:200px}.current-step-images{display:flex;gap:.5rem;flex-wrap:wrap}.current-step-img{width:100%;max-height:220px;object-fit:cover;border-radius:4px}.current-step-images .current-step-img{flex:1 1 45%;min-width:120px}.current-step-images .current-step-img:only-child{flex:1 1 100%}.current-step-img.nonna-photo{border:2px solid var(--accent, #D95B43)}.current-step-content{display:flex;gap:.75rem;align-items:center}.current-step-label{font-size:1.1rem;font-weight:700;color:var(--accent);flex-shrink:0;line-height:1}.current-step-text{font-size:.875rem;color:var(--text);line-height:1.4}@media(max-width:780px){.app{max-width:480px;padding:1.5rem 1rem}.main-cooking{grid-template-columns:1fr;grid-template-rows:auto;gap:1rem}.main-cooking>.main-camera{order:1}.main-cooking>.main-conversation{order:2;max-height:200px!important}.main-cooking>.main-ingredients{order:3;position:static}.main-cooking>.main-recipe{order:4;grid-column:1}}.header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.header-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.library-btn{font-family:Montserrat,sans-serif;font-size:.85rem;font-weight:500;letter-spacing:.03em;color:var(--text);background:var(--surface);border:1px solid var(--border-dark);border-radius:6px;padding:.5rem 1rem;cursor:pointer;transition:border-color .15s,background .15s,color .15s;box-shadow:0 1px 2px #3a2e260f}.library-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--surface-warm)}.library-btn-signout{color:var(--text-dim)}.library-btn-signout:hover{border-color:var(--red);color:var(--red)}.library-btn-signin{color:var(--text-dim)}.library-btn-signin:hover{border-color:var(--accent);color:var(--accent)}.header-btn{font-family:Montserrat,sans-serif;font-size:.85rem;font-weight:500;letter-spacing:.03em;padding:.5rem 1rem;border-radius:6px;cursor:pointer;border:1px solid transparent}.header-btn-save{background:var(--surface);color:var(--green);border-color:var(--green)}.header-btn-save:hover:not(:disabled){background:var(--green);color:var(--bg)}.header-btn-save:disabled{opacity:.7;cursor:default}.header-btn-end{background:var(--accent);color:var(--bg);border-color:var(--accent-dim)}.header-btn-end:hover{background:var(--accent-dim);border-color:var(--accent-dim);color:var(--bg)}.logo{font-family:Brush Script MT,Brush Script Std,Dancing Script,cursive;font-size:2.5rem;font-weight:400;color:#d95b43;letter-spacing:.02em;text-shadow:0 2px 4px rgba(58,46,38,.2)}.logo-easter{cursor:pointer;-webkit-user-select:none;user-select:none}.toast-easter{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--accent);color:var(--accent);padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-family:Montserrat,sans-serif;z-index:1000;cursor:pointer;box-shadow:0 4px 16px #3a2e2633}.tagline{font-size:.85rem;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase}.camera-container{position:relative;width:100%;aspect-ratio:4/3;background:var(--surface);border-radius:20px;overflow:hidden;border:none;box-shadow:0 0 0 6px #f5ebd7,0 0 0 12px #d4a535,0 0 0 18px #d95b43,0 4px 20px #3a2e2626}.camera-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;pointer-events:none;z-index:10;animation:camera-flash-out .55s ease-out forwards}@keyframes camera-flash-out{0%{opacity:.9}to{opacity:0}}.camera-feed{width:100%;height:100%;object-fit:cover}.camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-start;justify-content:center;background:#3a2e26a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-y:auto;padding:1rem 0}.setup-panel{display:flex;flex-direction:column;gap:.75rem;width:85%;max-height:100%}.recipe-input{background:var(--surface-warm);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:Montserrat,sans-serif;font-size:.9rem;line-height:1.5;padding:.625rem .75rem;resize:none;width:100%}.recipe-input::placeholder{color:var(--text-dim)}.recipe-input:focus{border-color:var(--accent);outline:none}.start-btn{background:var(--accent);color:var(--bg);border:none;padding:.875rem 2rem;border-radius:8px;font-family:Montserrat,sans-serif;font-size:1rem;font-weight:600;cursor:pointer;letter-spacing:.02em;transition:background .15s;box-shadow:0 2px 4px #3a2e2626}.start-btn:hover{background:var(--accent-dim)}.setup-actions{display:flex;gap:.5rem;align-items:center}.setup-actions .start-btn{flex:1}.hidden-file-input{display:none}.upload-photo-btn{background:var(--surface);color:var(--text);border:2px solid var(--border-dark);padding:.875rem 1rem;border-radius:8px;font-family:Montserrat,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s;white-space:nowrap}.upload-photo-btn:hover{border-color:var(--text);background:var(--surface-warm)}.recipe-images-grid{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;width:100%}.recipe-image-thumb{position:relative;width:80px;height:80px;border-radius:6px;overflow:hidden;border:2px solid var(--border-dark);flex-shrink:0}.recipe-image-thumb img{width:100%;height:100%;object-fit:cover;display:block}.recipe-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--surface)}.recipe-image-remove{position:absolute;top:2px;right:2px;background:#0009;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.recipe-image-remove:hover{background:#000000d9}.recipe-image-add{width:80px;height:80px;border-radius:6px;border:2px dashed var(--border-dark);background:transparent;color:var(--text-dim);font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s;flex-shrink:0}.recipe-image-add:hover{border-color:var(--text);color:var(--text)}.start-btn-secondary{background:transparent;color:var(--text);border:2px solid var(--border-dark)}.start-btn-secondary:hover{border-color:var(--text);background:var(--surface)}.persona-toggle{display:flex;gap:.5rem}.persona-btn{flex:1;background:var(--surface-warm);border:1px solid var(--border);border-radius:6px;color:var(--text-dim);font-family:Montserrat,sans-serif;font-size:.85rem;padding:.5rem;cursor:pointer;transition:all .15s}.persona-btn:hover{border-color:var(--accent);color:var(--text)}.persona-btn.active{background:#d95b431f;border-color:var(--accent);color:var(--accent);font-weight:600}.pantry-recipe-btn{background:transparent;color:var(--accent);border:1px solid var(--accent);padding:.625rem;border-radius:6px;font-family:Montserrat,sans-serif;font-size:.85rem;cursor:pointer;transition:all .15s}.pantry-recipe-btn:hover:not(:disabled){background:#d95b4314}.pantry-recipe-btn:disabled{opacity:.5;cursor:default}.suggestions{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.suggestions-empty{font-size:.85rem;color:var(--text-dim);text-align:center;padding:.5rem 0}.suggestion-card{background:var(--surface-warm);border:1px solid var(--border);border-radius:6px;padding:.625rem .75rem;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:.2rem;transition:border-color .15s;width:100%}.suggestion-card:hover{border-color:var(--accent)}.suggestion-name{font-size:.9rem;color:var(--text);font-weight:500}.suggestion-desc{font-size:.8rem;color:var(--text-dim);line-height:1.4}.suggestion-missing{font-size:.75rem;color:var(--accent-dim);margin-top:.1rem}.suggestion-url{font-size:.7rem;color:var(--text-dim);opacity:.6;margin-top:.1rem}.connecting-label{color:var(--accent);font-size:.95rem;letter-spacing:.05em}.camera-overlay.recipe-search-failed .connecting-label{color:var(--red)}.reconnecting-overlay{background:#3a2e2680;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);align-items:center;justify-content:center;z-index:10}.reconnecting-indicator{display:flex;align-items:center;gap:.6rem;color:var(--text);font-size:.9rem;font-weight:600;letter-spacing:.02em}.reconnecting-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.status-dot{position:absolute;top:12px;right:12px;width:10px;height:10px;border-radius:50%;background:var(--text-dim);transition:background .3s}.status-dot.connecting{background:var(--amber);animation:pulse 1s infinite}.status-dot.connected{background:var(--green)}.status-dot.error{background:var(--red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.transcript{display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;flex:1;padding-right:2px}.msg{font-size:.85rem;line-height:1.5;padding:.5rem .75rem;border-radius:6px;transition:opacity .3s;white-space:pre-wrap}.msg.assistant{background:var(--surface);border-left:3px solid var(--accent);color:var(--text)}.main-conversation .msg:first-child{font-size:.95rem;font-weight:600;opacity:1}.main-conversation .msg:nth-child(2){opacity:.6}.main-conversation .msg:nth-child(3){opacity:.45}.main-conversation .msg:nth-child(n+4){opacity:.3}.msg.system{background:transparent;color:var(--text-dim);font-style:italic;font-size:.8rem;text-align:center;border-left:none;padding:.25rem .75rem}.stop-btn{background:transparent;color:var(--text-dim);border:1px solid var(--border);padding:.75rem;border-radius:6px;font-family:Montserrat,sans-serif;font-size:.9rem;cursor:pointer;transition:all .15s}.stop-btn:hover{border-color:var(--red);color:var(--red)}.timer-panel{display:flex;flex-direction:column;gap:.5rem}.camera-overlay-timers .timer-panel{gap:.35rem}.camera-overlay-timers .timer-card{padding:.4rem .5rem;font-size:.8rem}.camera-overlay-timers .timer-label{font-size:.75rem}.camera-overlay-timers .timer-time{font-size:.9rem}.timer-card{position:relative;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--gold);border-radius:6px;overflow:hidden;display:flex;align-items:center;padding:.625rem .75rem;gap:.75rem;box-shadow:0 1px 3px #3a2e260f}.timer-card.done{border-color:var(--green)}.timer-card.pending{border-style:dashed}.timer-card.pending .timer-time{color:var(--text-dim);font-size:.85rem}.timer-card-stopwatch{border-style:solid}.timer-card-stopwatch .timer-time{color:var(--accent);font-variant-numeric:tabular-nums}.timer-progress{position:absolute;left:0;top:0;bottom:0;background:#d95b431f;transition:width 1s linear;pointer-events:none}.timer-card.done .timer-progress{background:#4caf7d26}.timer-content{display:flex;justify-content:space-between;align-items:center;flex:1;position:relative;gap:.75rem}.timer-label{font-size:.9rem;color:var(--text)}.timer-time{font-size:1.1rem;font-variant-numeric:tabular-nums;color:var(--accent);font-weight:600}.timer-card.done .timer-time{color:var(--green)}.timer-dismiss{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.8rem;padding:.25rem;position:relative}.timer-dismiss:hover{color:var(--red)}.pantry-panel{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:.875rem;box-shadow:0 1px 3px #3a2e260f}.pantry-list{list-style:none;display:flex;flex-direction:column;gap:.25rem}.pantry-item{display:flex;gap:.5rem;align-items:center;font-size:.875rem;padding:.2rem 0}.pantry-status{font-size:.7rem;width:1rem;text-align:center;flex-shrink:0}.pantry-status-btn{background:none;border:none;cursor:pointer;font-size:.7rem;width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;border-radius:3px;flex-shrink:0;transition:background .1s}.pantry-status-btn:hover{background:#3a2e2614}.pantry-name{color:var(--text-dim);flex:1}.pantry-delete-btn{background:none;border:none;cursor:pointer;color:var(--text-dim);font-size:1rem;line-height:1;padding:0 .25rem;opacity:0;transition:opacity .15s,color .15s;flex-shrink:0}.pantry-item:hover .pantry-delete-btn{opacity:1}.pantry-delete-btn:hover{color:var(--red)}.pantry-have .pantry-status-btn{color:var(--green)}.pantry-have .pantry-name{color:var(--text)}.pantry-out .pantry-status-btn,.pantry-out .pantry-name{color:var(--text-dim)}.pantry-add{display:flex;gap:.4rem;margin-top:.6rem}.pantry-add-input{flex:1;background:var(--surface-warm);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:Montserrat,sans-serif;font-size:.85rem;padding:.35rem .6rem}.pantry-add-input::placeholder{color:var(--text-dim)}.pantry-add-input:focus{outline:none;border-color:var(--accent)}.pantry-add-btn{background:var(--accent);color:var(--bg);border:none;border-radius:6px;width:1.8rem;font-size:1.1rem;cursor:pointer;transition:background .15s;flex-shrink:0}.pantry-add-btn:hover:not(:disabled){background:var(--accent-dim)}.pantry-add-btn:disabled{opacity:.35;cursor:default}.ingredients-panel{background:var(--surface);border:1px solid var(--border);border-top:2px solid var(--gold);border-radius:6px;padding:1rem;box-shadow:0 1px 3px #3a2e260f}.ingredients-list{list-style:none;display:flex;flex-direction:column;gap:.25rem}.ingredient{display:flex;gap:.625rem;padding:.25rem 0;font-size:.875rem;line-height:1.4}.ingredient-amount{color:var(--amber);min-width:4.5rem;font-variant-numeric:tabular-nums;flex-shrink:0}.ingredient-name{color:var(--text-dim)}.ingredient-item{display:flex;gap:.5rem .75rem;align-items:baseline;flex-wrap:wrap;padding:.25rem 0;font-size:.875rem;line-height:1.45}.ingredient-item .ingredient-amount{flex-shrink:0}.ingredient-main{flex:1;min-width:0}.ingredient-prep{color:var(--text-dim);opacity:.9}.recipe-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:.35rem;font-size:.875rem;color:var(--text-dim)}.recipe-meta-sep{color:var(--text-dim);opacity:.6;-webkit-user-select:none;user-select:none}.recipe-meta-item{font-variant-numeric:tabular-nums}.step-badges{display:inline-flex;align-items:center;gap:.35rem;margin-left:.5rem;font-variant-numeric:tabular-nums}.step-timer{font-size:.8rem;color:var(--amber-dim)}.step-visual-check{opacity:.8}.recipe-steps{background:var(--surface);border:1px solid var(--border);border-top:2px solid var(--gold);border-radius:6px;padding:1rem 1.125rem;box-shadow:0 1px 3px #3a2e260f}.steps-heading{font-family:Montserrat,sans-serif;font-size:.9rem;color:var(--gold);margin-bottom:.625rem;font-weight:400;letter-spacing:.06em;text-transform:uppercase}.steps-list{list-style:none;display:flex;flex-direction:column;gap:.375rem}.step{display:flex;gap:.625rem;align-items:flex-start;padding:.375rem 0;border-radius:4px;transition:opacity .2s}.step-done{opacity:.4}.step-current .step-text{color:var(--text)}.step-num{font-size:.75rem;color:var(--text-dim);min-width:1.25rem;padding-top:.1rem;font-variant-numeric:tabular-nums}.step-current .step-num{color:var(--amber)}.step-done .step-num{color:var(--green)}.step-body{display:flex;flex-direction:column;gap:.4rem;flex:1;min-width:0}.step-text{font-size:.875rem;color:var(--text-dim);line-height:1.4}.step-images{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.3rem}.step-img{width:100%;max-width:280px;height:auto;border-radius:6px;object-fit:cover}.step-images .step-img{flex:1 1 45%;min-width:100px;max-width:180px}.step-img.nonna-photo{border:2px solid var(--accent, #D95B43)}.library-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#3a2e2699;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;overflow:auto}.library-panel{background:var(--surface);border:1px solid var(--border-dark);border-radius:8px;width:100%;max-width:420px;max-height:calc(100vh - 2rem);display:flex;flex-direction:column;box-shadow:0 8px 32px #3a2e2640,0 1px #ffffff4d inset}.library-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.library-title{font-family:Montserrat,sans-serif;font-size:1.35rem;font-weight:600;color:var(--accent);letter-spacing:-.02em;margin:0}.library-close{background:none;border:none;color:var(--text-dim);font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;border-radius:6px;transition:color .15s,background .15s}.library-close:hover{color:var(--text);background:var(--border)}.library-list{overflow-y:auto;max-height:calc(100vh - 8rem);padding:.75rem 1rem 1rem;display:flex;flex-direction:column;gap:.75rem}.library-empty{color:var(--text-dim);font-size:.9rem;line-height:1.5;padding:1.5rem .5rem;text-align:center;margin:0}.library-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .2s;flex-shrink:0}.library-card:hover{border-color:#d95b4366}.library-card-preview{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.875rem 1rem;cursor:pointer}.library-card-preview:focus{outline:none}.library-card-preview:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.library-card-preview .library-card-meta{flex:1;min-width:0}.library-card-arrow{color:var(--text-dim);font-size:1rem;flex-shrink:0}.library-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#3a2e26b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:101;display:flex;align-items:center;justify-content:center;padding:1rem;overflow:auto}.library-detail-modal{background:var(--surface);border:1px solid var(--border-dark);border-radius:8px;width:100%;max-width:420px;max-height:calc(100vh - 2rem);display:flex;flex-direction:column;box-shadow:0 8px 32px #3a2e264d,0 1px #ffffff4d inset}.library-detail-header{position:relative;display:flex;flex-wrap:wrap;align-items:flex-start;gap:.35rem .75rem;padding:1rem 2.75rem 1rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0}.library-detail-title{flex:1;min-width:0;margin:0;font-family:Montserrat,sans-serif;font-size:1.15rem;font-weight:600;color:var(--text)}.library-detail-name-btn{background:none;border:none;padding:0;font:inherit;color:inherit;cursor:pointer;text-align:left;text-decoration:underline;text-underline-offset:2px;text-decoration-color:transparent;transition:text-decoration-color .15s}.library-detail-name-btn:hover{text-decoration-color:var(--accent-dim)}.library-detail-date{font-size:.75rem;color:var(--text-dim)}.library-detail-source{font-size:.7rem;color:var(--accent);text-decoration:none;transition:opacity .15s}.library-detail-source:hover{opacity:.7}.library-detail-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-dim);font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;border-radius:6px;transition:color .15s,background .15s}.library-detail-close:hover{color:var(--text);background:var(--border)}.library-detail-body{overflow-y:auto;padding:1rem 1.25rem;flex:1}.library-detail-desc{font-size:.9rem;color:var(--text-dim);line-height:1.45;margin:0 0 1rem}.library-detail-name-readonly{color:var(--text)}.library-detail-meta-readonly{font-size:.85rem;color:var(--text-dim);margin:0}.library-edit-mode-btn{padding:.4rem .75rem;font-size:.85rem;font-family:Montserrat,sans-serif;background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:6px;cursor:pointer;transition:border-color .15s,color .15s}.library-edit-mode-btn:hover{border-color:var(--amber-dim);color:var(--amber-dim)}.library-edit-desc{margin-top:.25rem}.library-edit-meta{margin-bottom:.75rem}.library-meta-fields{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.35rem}.library-meta-label{display:flex;flex-direction:column;gap:.2rem;font-size:.8rem;color:var(--text-dim)}.library-meta-input{width:5rem;padding:.35rem .5rem;font-size:.85rem;font-family:Montserrat,sans-serif;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px}.library-meta-input:focus{border-color:var(--amber);outline:none}.library-edit-list{display:flex;flex-direction:column;gap:.4rem;margin-top:.35rem}.library-edit-row{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.library-ingredient-row .library-edit-amount{width:4.5rem;flex-shrink:0}.library-ingredient-row .library-edit-item{flex:1;min-width:6rem}.library-ingredient-row .library-edit-prep{width:7rem;flex-shrink:0}.library-step-row{align-items:flex-start}.library-step-row .library-step-num{font-size:.8rem;color:var(--amber-dim);flex-shrink:0;padding-top:.5rem}.library-step-row .library-edit-step-text{flex:1;min-width:0;resize:vertical}.library-step-timer-label{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--text-dim);flex-shrink:0}.library-step-timer-input{width:4rem}.library-edit-input{padding:.35rem .5rem;font-size:.85rem;font-family:Montserrat,sans-serif;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px}.library-edit-input:focus{border-color:var(--amber);outline:none}.library-edit-input::placeholder{color:var(--text-dim)}.library-edit-remove{flex-shrink:0;width:1.75rem;height:1.75rem;padding:0;font-size:1rem;line-height:1;background:var(--border);border:none;color:var(--text-dim);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.library-edit-remove:hover{background:var(--red);color:var(--bg)}.library-edit-add{margin-top:.25rem;padding:.35rem .5rem;font-size:.8rem;background:none;border:1px dashed var(--border);color:var(--text-dim);border-radius:6px;cursor:pointer;font-family:Montserrat,sans-serif;transition:border-color .15s,color .15s}.library-edit-add:hover{border-color:var(--amber-dim);color:var(--amber-dim)}.library-save-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.library-cancel-btn{padding:.4rem .75rem;font-size:.85rem;font-family:Montserrat,sans-serif;background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:6px;cursor:pointer;transition:border-color .15s,color .15s}.library-cancel-btn:hover{border-color:var(--text-dim);color:var(--text)}.library-save-recipe{background:var(--amber);color:var(--bg)}.library-detail-actions{padding:1rem 1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.library-detail-secondary{display:flex;justify-content:center}.library-delete-btn{background:none;border:none;color:var(--text-dim);font-size:.85rem;cursor:pointer;padding:.35rem .5rem;font-family:Montserrat,sans-serif;transition:color .15s}.library-delete-btn:hover{color:var(--red)}.library-name-input-modal{width:100%;font-size:1.1rem}.library-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;padding:.875rem 1rem;cursor:pointer;text-align:left;width:100%}.library-card-header:focus{outline:none}.library-card-header:focus-visible{outline:2px solid var(--amber);outline-offset:2px}.library-card-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.library-card-name{font-family:Montserrat,sans-serif;font-size:1rem;font-weight:600;color:var(--text);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-card-date{font-size:.75rem;color:var(--text-dim)}.library-card-badges{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.25rem}.library-badge{font-size:.7rem;color:var(--text-dim);background:var(--border);padding:.2rem .5rem;border-radius:4px}.library-badge-draft{background:var(--accent);color:var(--bg)}.library-card-draft .library-card-name{font-style:italic}.library-expand{font-size:.7rem;color:var(--text-dim);flex-shrink:0;padding-top:.15rem}.library-card-desc{font-size:.85rem;color:var(--text-dim);line-height:1.4;padding:0 1rem .75rem;margin:0;border-bottom:1px solid var(--border)}.library-card-body{padding:1rem;border-top:1px solid var(--border)}.library-section{margin-bottom:1rem}.library-section:last-of-type{margin-bottom:0}.library-section-title{font-size:.7rem;font-weight:600;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:0 0 .5rem}.library-ingredients,.library-steps{list-style:none;margin:0;padding:0;font-size:.875rem;color:var(--text-dim);line-height:1.5}.library-ingredients li,.library-steps li{padding:.2rem 0;padding-left:0}.library-steps{counter-reset:step}.library-steps li{counter-increment:step;padding-left:1.5rem;position:relative}.library-steps li:before{content:counter(step) ".";position:absolute;left:0;color:var(--accent-dim);font-size:.8rem}.ingredient-amount{color:var(--text-dim);margin-right:.25rem}.ingredient-name{color:var(--text)}.ingredient-prep{color:var(--text-dim);font-size:.85em}.step-timer{font-size:.8rem;color:var(--amber-dim);margin-left:.25rem}.library-notes{width:100%;min-height:4rem;padding:.5rem .625rem;font-size:.85rem;font-family:Montserrat,sans-serif;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;resize:vertical;margin-top:.25rem}.library-notes:focus{border-color:var(--accent);outline:none}.library-notes::placeholder{color:var(--text-dim)}.library-save-notes{margin-top:.5rem;padding:.4rem .75rem;font-size:.85rem;background:var(--accent);color:var(--bg);border:none;border-radius:6px;cursor:pointer;font-family:Montserrat,sans-serif;font-weight:600;transition:opacity .15s}.library-save-notes:hover{opacity:.9}.library-photos-section{margin-top:.75rem}.library-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem;margin-top:.35rem}.library-hero-images{margin-bottom:1rem}.library-photo-wrap{margin:0;border-radius:8px;overflow:hidden;background:var(--border);border:1px solid var(--border)}.library-photo{width:100%;aspect-ratio:1;object-fit:cover;display:block}.library-photo-caption{font-size:.65rem;color:var(--text-dim);padding:.25rem .35rem;text-align:center;background:#0000004d;margin:0}.library-photos-hint{font-size:.8rem;color:var(--text-dim);margin-top:.35rem;margin-bottom:0;line-height:1.4}.library-card-actions{padding:.75rem 1rem;border-top:1px solid var(--border);background:#00000026}.library-cook-btn{width:100%;padding:.6rem 1rem;font-size:.9rem;font-family:Montserrat,sans-serif;font-weight:500;background:var(--amber);color:var(--bg);border:none;border-radius:8px;cursor:pointer;transition:opacity .15s,transform .05s}.library-cook-btn:hover{opacity:.95}.library-cook-btn:active{transform:scale(.98)}.library-name-input{width:100%;padding:.25rem 0;font-size:1rem;font-family:Montserrat,sans-serif;font-weight:600;color:var(--text);background:transparent;border:none;border-bottom:1px solid var(--border);border-radius:0}.library-name-input:focus{outline:none;border-bottom-color:var(--amber)}.recipe-panel{background:var(--surface);border:1px solid var(--border);border-top:2px solid var(--gold);border-radius:6px;padding:1rem 1.125rem;box-shadow:0 1px 3px #3a2e260f}.recipe-header-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.recipe-header-row .recipe-name-group{flex:1;min-width:0}.recipe-header-row .recipe-name{margin:0}.recipe-source-link{font-size:.7rem;color:var(--text-dim);text-decoration:none;opacity:.7;transition:opacity .15s}.recipe-source-link:hover{opacity:1;color:var(--accent)}.about-recipe-btn{font-family:Montserrat,sans-serif;font-size:.75rem;font-weight:500;color:var(--text-dim);background:transparent;border:1px solid var(--border-dark);border-radius:999px;padding:.3rem .875rem;cursor:pointer;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;transition:border-color .15s,color .15s}.about-recipe-btn:hover{border-color:var(--accent);color:var(--accent)}.recipe-edit-section{margin-bottom:.75rem;display:flex;flex-direction:column;gap:.5rem}.about-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#3a2e2680;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem}.about-popup{background:var(--surface);border:1px solid var(--border-dark);border-radius:8px;max-width:420px;width:100%;max-height:80vh;overflow-y:auto;padding:1.25rem;box-shadow:0 8px 32px #3a2e2640,0 1px #ffffff4d inset}.about-popup-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.about-popup-header h3{font-family:Montserrat,sans-serif;font-size:1.15rem;font-weight:600;color:var(--text);margin:0}.about-popup-close{background:none;border:none;color:var(--text-dim);font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;border-radius:6px;flex-shrink:0;transition:color .15s}.about-popup-close:hover{color:var(--text)}.about-popup-source{display:inline-block;font-size:.8rem;color:var(--accent);text-decoration:none;margin-bottom:.75rem;transition:opacity .15s}.about-popup-source:hover{opacity:.7}.about-popup-images{display:flex;gap:.5rem;margin-bottom:.75rem;overflow-x:auto}.about-popup-img{width:100%;max-width:280px;border-radius:6px;object-fit:cover;border:1px solid var(--border);flex-shrink:0}.about-popup-desc{font-size:.9rem;color:var(--text-dim);line-height:1.5;margin:0 0 .75rem}.about-popup-meta{font-size:.85rem;color:var(--text-dim);margin:0 0 .75rem}.about-popup-tips h4{font-size:.7rem;font-weight:600;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:0 0 .5rem}.about-popup-tips ul{list-style:none;padding:0;margin:0;font-size:.85rem;color:var(--text-dim);line-height:1.5}.about-popup-tips li{padding:.2rem 0}.about-popup-notes{margin-top:1rem}.about-popup-notes h4{font-size:.7rem;font-weight:600;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:0 0 .35rem}.about-popup-notes .about-popup-desc{margin-bottom:0}.recipe-header{margin-bottom:.75rem}.recipe-name{font-family:Montserrat,sans-serif;font-size:1.15rem;font-weight:600;color:var(--text);margin-bottom:.25rem}.recipe-description{font-size:.85rem;color:var(--text-dim);line-height:1.45;margin:.25rem 0 0}.recipe-ingredients{margin-bottom:.875rem}.recipe-tips{margin-top:.75rem}.recipe-edit-name{width:100%;font-family:Montserrat,sans-serif;font-size:1.1rem;font-weight:600;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:.35rem .5rem;margin-bottom:.35rem}.recipe-edit-name:focus{outline:none;border-color:var(--amber)}.recipe-edit-meta-label{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-dim)}.recipe-edit-meta-input{width:4rem;padding:.2rem .4rem;font-size:.8rem;font-family:Montserrat,sans-serif;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:4px}.recipe-edit-meta-input:focus{outline:none;border-color:var(--amber)}.recipe-edit-btn{margin-left:auto;background:none;border:1px solid var(--border);color:var(--text-dim);font-size:.95rem;padding:.15rem .5rem;border-radius:5px;cursor:pointer;line-height:1;transition:border-color .15s,color .15s}.recipe-edit-btn:hover{border-color:var(--amber-dim);color:var(--amber-dim)}.recipe-edit-done-btn{margin-left:auto;background:var(--amber);color:var(--bg);border:none;font-size:.8rem;font-family:Montserrat,sans-serif;font-weight:500;padding:.25rem .7rem;border-radius:5px;cursor:pointer;transition:opacity .15s}.recipe-edit-done-btn:hover{opacity:.88}.recipe-edit-row{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.transcript-label{font-size:.7rem;font-weight:500;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem;flex-shrink:0}.auth-loading,.auth-screen{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;background:linear-gradient(135deg,#e8745f,#d95b43 40%,#c04a34);color:var(--text)}.auth-screen .logo{font-family:Brush Script MT,Brush Script Std,Dancing Script,cursive;font-size:3.5rem;color:#f5ebd7;text-shadow:0 2px 6px rgba(58,46,38,.35)}.auth-screen .tagline{color:#fbf4e9cc}.auth-google-btn{margin-top:.5rem;padding:.75rem 2rem;font-size:1rem;background:var(--bg);color:var(--accent);border:2px solid var(--gold);box-shadow:0 2px 12px #3a2e2633}.auth-guest-btn{margin-top:.5rem;padding:.5rem 1.25rem;font-size:.9rem;background:transparent;color:#fbf4e9bf;border:1px solid rgba(251,244,233,.35);border-radius:6px;cursor:pointer;transition:color .15s,border-color .15s}.auth-guest-btn:hover{color:#fbf4e9;border-color:#fbf4e9b3}.auth-guest-group{display:flex;flex-direction:column;align-items:center;gap:.35rem}.auth-guest-note{font-size:.78rem;color:#fbf4e980;text-align:center;margin:0}
