@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Outfit:wght@400;600;700;800&display=swap";:root{--font-inter: "Inter", system-ui, -apple-system, sans-serif;--font-outfit: "Outfit", sans-serif;--color-primary: #f97316;--color-primary-hover: #ea580c;--color-primary-glow: rgba(249, 115, 22, .25);--color-bg-dark: #0a0f1e;--color-surface: #111827;--color-surface-2: #1a2236;--color-accent-blue: #38bdf8;--color-accent-purple: #a78bfa;--color-text-main: #f1f5f9;--color-text-dim: #64748b;--color-text-muted: #94a3b8;--color-border: rgba(255, 255, 255, .07);--color-danger: #ef4444;--color-success: #22c55e;--glass-bg: rgba(17, 24, 39, .75);--glass-border: rgba(255, 255, 255, .08);--glass-blur: 20px;--glass-shadow: 0 8px 40px rgba(0, 0, 0, .4);--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--ease-spring: cubic-bezier(.175, .885, .32, 1.275);--ease-out: cubic-bezier(.22, 1, .36, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-inter);background-color:var(--color-bg-dark);color:var(--color-text-main);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:var(--font-outfit);font-weight:700}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit}ul,ol{list-style:none}input{font-family:inherit;color:var(--color-text-main)}.bg-gradient-mesh{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:var(--color-bg-dark);background-image:radial-gradient(ellipse at 0% 0%,rgba(249,115,22,.12) 0,transparent 55%),radial-gradient(ellipse at 100% 0%,rgba(56,189,248,.09) 0,transparent 55%),radial-gradient(ellipse at 50% 100%,rgba(167,139,250,.08) 0,transparent 55%)}.glass-effect{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-lg)}.page-enter{animation:pageEnter .45s var(--ease-out) forwards;opacity:0}@keyframes pageEnter{0%{opacity:0;transform:translateY(16px) scale(.99)}to{opacity:1;transform:translateY(0) scale(1)}}.tokens-exhausted-modal{position:relative;width:100%;max-width:440px;padding:48px 40px;text-align:center;overflow:hidden;border-radius:var(--radius-xl)}.modal-glow-base{position:absolute;top:-60px;left:50%;transform:translate(-50%);width:320px;height:320px;background:radial-gradient(circle,var(--color-primary-glow) 0%,transparent 70%);z-index:0;pointer-events:none;opacity:.8}.modal-content-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}.token-icon-wrap{margin-bottom:24px}.token-icon-circle{display:inline-flex;align-items:center;justify-content:center;width:84px;height:84px;background:#f973161a;border:1px solid rgba(249,115,22,.2);border-radius:28px;transform:rotate(-3deg);box-shadow:0 12px 24px #0003;transition:transform .3s var(--ease-spring)}.token-icon-circle:hover{transform:rotate(2deg) scale(1.05)}.modal-title{font-size:1.85rem;font-weight:800;margin-bottom:12px;letter-spacing:-.03em;background:linear-gradient(to bottom,#fff,#cbd5e1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.edit-field{display:flex;flex-direction:column;gap:8px;width:100%}.edit-field label{font-size:.75rem;font-weight:700;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.06em;margin-left:2px}.edit-input{width:100%;background:#ffffff08;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:14px 18px;color:var(--color-text-main);font-size:.95rem;transition:all .3s var(--ease-out);outline:none}.edit-input:focus{background:#ffffff0f;border-color:var(--accent-color, var(--color-primary));box-shadow:0 0 0 4px #ffffff08,0 0 20px -5px var(--accent-color, var(--color-primary))}.edit-input::placeholder{color:var(--color-text-dim);opacity:.5}.edit-input:read-only{opacity:.7;cursor:not-allowed;background:#0003}.support-submit-btn{background:var(--accent-color, var(--color-primary));color:#fff;border:none;font-weight:800;padding:18px 30px;border-radius:var(--radius-lg);font-size:1rem;font-family:var(--font-outfit);display:flex;align-items:center;justify-content:center;gap:10px;width:100%;margin-top:12px;transition:all .3s var(--ease-spring);box-shadow:0 10px 30px -10px var(--accent-color, var(--color-primary))}.items-end{align-items:flex-end}.gap-10{gap:40px}.gap-12{gap:48px}.gap-16{gap:64px}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width: 640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:items-end{align-items:flex-end}.md\:flex-row{flex-direction:row}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:col-span-1{grid-column:span 1 / span 1}.lg\:col-span-2{grid-column:span 2 / span 2}}.w-24{width:96px}.h-24{height:96px}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.w-28{width:112px}.h-28{height:112px}.max-w-5xl{max-width:64rem}.p-10{padding:2.5rem}.p-12{padding:3rem}.px-8{padding:0 2rem}.py-16{padding:4rem 0}.py-20{padding:5rem 0}.mb-16{margin-bottom:4rem}.mt-16{margin-top:4rem}.text-5xl{font-size:3rem}@media (min-width: 768px){.md\:justify-center{justify-content:center}.md\:text-center{text-align:center}}.allergy-substitution-note{border-radius:var(--radius-xl);position:relative;overflow:hidden;border:1px solid rgba(245,158,11,.3);border-left:6px solid #f59e0b!important;background:linear-gradient(90deg,#f59e0b14,#f59e0b05)!important;box-shadow:0 10px 40px -10px #f59e0b33;animation:slideInBottom .6s var(--ease-out),pulseGlow 3s infinite ease-in-out;padding:24px!important}.allergy-substitution-note:before{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);animation:shimmer 4s infinite linear}@keyframes pulseGlow{0%,to{box-shadow:0 10px 40px -10px #f59e0b33}50%{box-shadow:0 10px 50px -5px #f59e0b4d}}@keyframes shimmer{0%{left:-100%}to{left:200%}}.allergy-substitution-note h4{color:#f59e0b!important;text-transform:uppercase;font-size:.75rem;font-weight:800;letter-spacing:.15em;margin-bottom:6px;display:flex;align-items:center;gap:8px}.duplicate-variation-note{border-radius:var(--radius-xl);position:relative;overflow:hidden;border:1px solid rgba(59,130,246,.3);border-left:6px solid #3b82f6!important;background:linear-gradient(90deg,#3b82f614,#3b82f605)!important;box-shadow:0 10px 40px -10px #3b82f633;animation:slideInBottom .6s var(--ease-out),bluePulse 4s infinite ease-in-out}.duplicate-variation-note:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);animation:shimmer 4s infinite linear}@keyframes bluePulse{0%,to{box-shadow:0 10px 40px -10px #3b82f633}50%{box-shadow:0 10px 50px -5px #3b82f666}}.duplicate-variation-note p{color:var(--color-text-main)!important;font-weight:500;text-shadow:0 0 20px rgba(59,130,246,.1)}.allergy-substitution-note p{color:var(--color-text-main)!important;font-weight:500;text-shadow:0 0 20px rgba(245,158,11,.1)}.visibility-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;line-height:none}.visibility-badge.public{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.visibility-badge.private{background:#ffffff08;color:var(--color-text-dim);border:1px solid rgba(255,255,255,.1)}.visibility-badge svg{flex-shrink:0}.new-chat-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;background:var(--color-primary)!important;border:none;border-radius:var(--radius-md);color:#fff!important;font-weight:800;font-size:.8rem;transition:all .3s var(--ease-out);margin-left:auto;text-transform:uppercase;letter-spacing:.08em;box-shadow:0 4px 15px -4px #f9731666}.new-chat-btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 8px 25px -5px #f9731680}.new-chat-btn:active{transform:translateY(0)}.new-chat-btn svg{transition:transform .5s var(--ease-spring)}.new-chat-btn:hover svg{transform:rotate(180deg)}@keyframes slideInBottom{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.p-8{padding:2rem}.p-6{padding:1.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.text-4xl{font-size:2.25rem}.font-extrabold{font-weight:800}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-8{margin-top:2rem}.mt-10{margin-top:2.5rem}.rounded-full{border-radius:9999px}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a}.z-10{z-index:10}.z-50{z-index:50}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-8>*+*{margin-top:2rem}.space-y-10>*+*{margin-top:2.5rem}.space-y-12>*+*{margin-top:3rem}.caution-note{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-md);color:#fbbf24;font-size:.85rem;line-height:1.5}.ing-info{display:flex;align-items:center;justify-content:space-between;width:100%}.ingredient-item--danger{background:#ef44440d!important;border-left:3px solid var(--color-danger);color:var(--color-danger)!important;border-radius:4px}.ingredient-item--danger .ing-name{font-weight:700;text-decoration:line-through}.info-trigger-wrap{position:relative;display:inline-flex}.onboarding-tooltip{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%) translateY(5px);width:max-content;max-width:200px;padding:12px 16px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:.8rem;font-weight:500;color:var(--color-text-main);box-shadow:0 15px 35px #00000080;opacity:0;visibility:hidden;transition:all .25s var(--ease-out);z-index:100;text-align:center;line-height:1.5;pointer-events:none}.info-trigger-wrap:hover .onboarding-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.onboarding-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:5px;border-style:solid;border-color:var(--color-border) transparent transparent transparent}.support-submit-btn:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.1);box-shadow:0 15px 40px -12px var(--accent-color, var(--color-primary))}.support-submit-btn:active:not(:disabled){transform:translateY(1px)}.support-submit-btn:disabled{opacity:.5;cursor:wait}.btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.modal-text{font-size:1rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:24px;max-width:320px;text-align:center}.token-request-box{background:#ffffff08;border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;width:100%;text-align:left;margin-bottom:20px}.token-request-box h4{font-size:.95rem;margin-bottom:4px;color:#fff}.request-fields{display:flex;flex-direction:column;gap:12px}.request-input,.request-textarea{width:100%;background:#0003;border:1px solid var(--color-border);border-radius:8px;color:#fff;padding:10px 14px;font-size:.85rem;outline:none;transition:border-color .2s}.request-input:focus,.request-textarea:focus{border-color:var(--color-primary)}.request-textarea{height:80px;resize:none}.modal-status-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:#ffffff0a;border:1px solid var(--color-border);border-radius:100px;font-size:.7rem;font-weight:800;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.1em;margin-bottom:32px}.modal-action-btn{width:100%;padding:14px;font-size:1rem!important}@keyframes fadeIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes spinSlow{to{transform:rotate(-360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes dotBounce{0%,80%,to{transform:scale(0);opacity:.3}40%{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.text-primary{color:var(--color-primary)}.text-dim{color:var(--color-text-dim)}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-outfit);font-weight:600;font-size:.9rem;transition:all .25s var(--ease-spring);white-space:nowrap}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-2px) scale(1.03);box-shadow:0 8px 24px var(--color-primary-glow)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-primary.btn-success{background:var(--color-success)}.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;background:#ffffff12;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-outfit);font-weight:600;font-size:.9rem;transition:all .2s;white-space:nowrap}.btn-secondary:hover{background:#ffffff1f;color:var(--color-text)}.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:.85rem;font-weight:500;transition:all .2s ease}.btn-ghost:hover{background:#ffffff0d;color:var(--color-text-main)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-dim);transition:all .2s ease}.icon-btn:hover{background:#ffffff0f;color:var(--color-text-main)}.icon-btn.danger:hover{background:#ef44441a;color:var(--color-danger);border-color:#ef44444d}.btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.modal-box{width:100%;max-width:540px;max-height:calc(100vh - 48px);overflow-y:auto;position:relative;padding:32px}.app-shell{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:32px 24px 64px}.navbar{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;margin:16px 24px;position:sticky;top:16px;z-index:100;gap:16px;height:64px}.navbar-brand{display:flex;align-items:center;gap:12px;flex:1;transition:transform .3s var(--ease-spring)}.navbar-brand:hover{transform:scale(1.02)}.brand-image{height:52px;width:auto;border-radius:12px;filter:drop-shadow(0 0 12px var(--color-primary-glow));transition:transform .3s var(--ease-spring)}.brand-image:hover{transform:scale(1.05) rotate(-2deg)}.brand-name{font-family:var(--font-outfit);font-size:1.5rem;font-weight:800;letter-spacing:-.04em;background:linear-gradient(135deg,#fff,#cbd5e1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:flex;align-items:center;gap:2px}.brand-name span{background:linear-gradient(135deg,var(--color-primary),#fb923c);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.landing-cta-logo{width:80px;height:80px;background:#f9731626;border:1px solid rgba(249,115,22,.3);border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;box-shadow:0 0 20px #0003,inset 0 0 10px #f973161a;transition:all .4s var(--ease-spring)}.landing-cta-logo:hover{transform:translateY(-8px) scale(1.05);box-shadow:0 12px 30px #f9731633,0 0 10px #f9731633}.cta-brand-image{width:54px;height:auto;border-radius:10px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:24px}.footer-brand-image{height:42px;width:auto;border-radius:10px;filter:drop-shadow(0 2px 4px rgba(249,115,22,.2))}.footer-brand-name{font-family:var(--font-outfit);font-size:1.5rem;font-weight:800;color:#fff;letter-spacing:-.02em}.footer-brand-name span{background:var(--color-primary);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.navbar-links{display:flex;gap:4px;padding:4px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:100px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-link{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:100px;color:var(--color-text-dim);font-size:.88rem;font-weight:500;transition:all .3s var(--ease-out)}.nav-link:hover{color:var(--color-text-main);background:#ffffff0d}.nav-link.active{color:#fff;background:var(--color-primary);box-shadow:0 4px 15px var(--color-primary-glow)}.navbar-auth{display:flex;align-items:center;gap:14px;flex:1;justify-content:flex-end}.user-pill{display:flex;align-items:center;gap:10px;padding:4px 14px 4px 4px;background:#ffffff08;border:1px solid var(--color-border);border-radius:100px;transition:all .2s ease}.user-pill:hover{background:#ffffff0f;border-color:#ffffff1f}.user-info-stack{display:flex;flex-direction:column;line-height:1.1}.user-name{font-size:.85rem;font-weight:600;color:var(--color-text-main)}.token-badge{display:flex;align-items:center;gap:4px;font-size:.7rem;font-weight:700;color:#fbbf24;margin-top:1px}.user-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary),#f9a8d4);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;box-shadow:0 2px 8px #f973164d}.nav-login{padding:10px 24px;font-size:.9rem;border-radius:100px}.generator-page{display:flex;flex-direction:column;gap:40px}.generator-hero{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;width:100%;padding-top:48px}.hero-header-row{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;width:100%;margin-bottom:8px}.hero-title{font-size:clamp(2.5rem,6vw,4.8rem);font-weight:800;letter-spacing:-.05em;line-height:1.05;text-align:center;width:100%}.hero-subtitle-line{font-size:clamp(1.3rem,2.5vw,1.8rem);color:var(--color-text-dim);text-align:center;width:100%;margin:12px 0 32px}.text-secondary-highlight{color:var(--color-accent-purple)}.hero-sub{font-size:1.1rem;color:var(--color-text-muted);max-width:560px;margin:0 auto 32px;line-height:1.7;font-weight:300;text-align:center}.search-bar{display:flex;align-items:center;gap:12px;width:100%;max-width:900px;margin:0 auto 20px;padding:8px 8px 8px 24px;transition:border-color .3s ease,box-shadow .3s ease}.search-bar:focus-within{border-color:#f9731666;box-shadow:0 0 0 3px var(--color-primary-glow),var(--glass-shadow)}.search-bar.wider-search{max-width:1000px;padding:10px 10px 10px 28px}.search-bar.pulsing{animation:pulse 1.5s ease infinite}.search-input{flex:1;background:transparent;border:none;outline:none;font-size:1rem;padding:10px 0;color:var(--color-text-main)}.search-input::placeholder{color:#ffffff40}.suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.suggestion-chip{padding:7px 16px;background:#ffffff0d;border:1px solid var(--color-border);border-radius:100px;font-size:.82rem;color:var(--color-text-muted);transition:all .2s ease;white-space:nowrap}.suggestion-chip:hover:not(:disabled){background:#f973161a;border-color:#f973164d;color:var(--color-primary);transform:translateY(-1px)}.gen-error{display:flex;align-items:center;gap:12px;padding:16px 20px;border-color:#ef44444d!important;color:#fca5a5;max-width:680px;margin:0 auto}.chef-thinking-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px}.thinking-card{text-align:center;padding:48px 64px;max-width:440px;width:100%}.chef-spinner{position:relative;width:100px;height:100px;margin:0 auto 28px}.spin-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:3px solid transparent}.ring-orange{border-top-color:var(--color-primary);animation:spin 1s linear infinite}.ring-blue{top:12px;right:12px;bottom:12px;left:12px;border-top-color:var(--color-accent-blue);animation:spinSlow 1.5s linear infinite}.spin-core{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:2rem;animation:pulse 2s ease infinite}.thinking-card h3{font-size:1.3rem;margin-bottom:8px}.thinking-card p{color:var(--color-text-dim);font-size:.9rem}.thinking-logo{width:54px;height:54px;border-radius:14px;box-shadow:0 0 20px #f9731626;border:2px solid rgba(255,255,255,.1)}.thinking-dots{display:flex;gap:6px;justify-content:center;margin-top:20px}.thinking-dots span{width:7px;height:7px;background:var(--color-primary);border-radius:50%;animation:dotBounce 1.3s ease infinite}.thinking-dots span:nth-child(2){animation-delay:.15s}.line-clamp-1{display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.save-progress-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:24px}.save-progress-card{text-align:center;padding:48px 40px;max-width:440px;width:100%}.save-progress-header{margin-bottom:28px}.save-loader-wrap{margin-bottom:24px}.recipe-progress-title{font-size:1.4rem;font-weight:700;margin-bottom:6px;color:var(--color-text-main);letter-spacing:-.02em}.recipe-progress-meta{font-size:.75rem;font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;opacity:.8}.recipe-progress-sub{font-size:.95rem;color:var(--color-text-dim);line-height:1.6}.save-progress-steps{display:flex;flex-direction:column;gap:12px;padding:20px;background:#ffffff08;border:1px solid var(--color-border);border-radius:16px;text-align:left}.recipe-result{display:flex;flex-direction:column;gap:20px}.result-header{padding:32px 36px;overflow:hidden}.result-image-wrap{margin:-32px -36px 28px;height:260px;overflow:hidden}.result-image{width:100%;height:100%;object-fit:cover;display:block}.result-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:#f973161f;border:1px solid rgba(249,115,22,.25);border-radius:100px;color:var(--color-primary);font-size:.75rem;font-weight:600;font-family:var(--font-outfit);letter-spacing:.05em;text-transform:uppercase;margin-bottom:16px}.result-title{font-size:clamp(1.6rem,4vw,2.4rem);margin-bottom:10px;letter-spacing:-.02em}.result-desc{color:var(--color-text-muted);line-height:1.7;margin-bottom:20px;max-width:680px}.result-stats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}.stat-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#ffffff0d;border:1px solid var(--color-border);border-radius:100px;font-size:.82rem;color:var(--color-text-muted)}.stat-icon{color:var(--color-accent-blue)}.stat-icon--meal{color:#a78bfa}.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.card-tag{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:100px;border:1px solid transparent;font-family:var(--font-outfit);letter-spacing:.02em}.card-tag--cuisine{background:#f973161f;border-color:#f973164d;color:var(--color-primary)}.card-tag--meal{background:#a78bfa1f;border-color:#a78bfa4d;color:#a78bfa}.stat-pill--cuisine{background:#f973161f;border-color:#f973164d}.stat-pill--cuisine .stat-icon{color:var(--color-primary)}.stat-pill--meal{background:#a78bfa1f;border-color:#a78bfa4d}.save-progress{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;padding:14px 18px;background:#ffffff08;border:1px solid var(--color-border);border-radius:12px}.save-step{display:flex;align-items:center;gap:10px;font-size:.83rem;color:var(--color-text-dim);transition:color .2s}.save-step--active{color:var(--color-text-muted)}.save-step--done{color:#4ade80}.save-step-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid var(--color-border);flex-shrink:0}.save-step--active .save-step-icon{border-color:var(--color-primary)}.save-step--done .save-step-icon{background:#4ade8026;border-color:#4ade80}.save-step-dot{width:6px;height:6px;border-radius:50%;background:var(--color-border)}.save-step-spinner{width:10px;height:10px;border:2px solid rgba(249,115,22,.3);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;display:block}.result-actions{display:flex;gap:10px;flex-wrap:wrap}.result-body{display:grid;grid-template-columns:1fr 1.4fr;gap:20px}@media (max-width: 700px){.result-body{grid-template-columns:1fr}}.result-panel{padding:24px 28px}.panel-title{font-size:1rem;margin-bottom:18px;color:var(--color-text-main)}.ingredient-list{display:flex;flex-direction:column;gap:8px}.ingredient-item{display:flex;align-items:baseline;gap:10px;padding:8px 0;border-bottom:1px solid var(--color-border);font-size:.9rem}.ingredient-item:last-child{border-bottom:none}.ing-amount{color:var(--color-primary);font-weight:600;min-width:70px;font-size:.82rem}.ing-name{color:var(--color-text-main)}.instruction-list{display:flex;flex-direction:column;gap:8px}.instruction-step{display:flex;align-items:flex-start;gap:14px;padding:12px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s ease;border:1px solid transparent}.instruction-step:hover{background:#ffffff0a}.instruction-step.expanded{background:#f973160a;border-color:#f973161f}.step-number{flex-shrink:0;width:26px;height:26px;background:#f9731626;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--color-primary);font-family:var(--font-outfit)}.step-content{flex:1}.step-content p{font-size:.88rem;color:var(--color-text-muted);line-height:1.6}.step-chevron{flex-shrink:0;color:var(--color-text-dim);margin-top:4px}.edit-form{padding:32px 36px;display:flex;flex-direction:column;gap:0}.edit-form-title{font-size:1.4rem;font-family:var(--font-outfit);font-weight:700;margin-bottom:28px;letter-spacing:-.02em}.edit-section{border-top:1px solid var(--color-border);padding:24px 0;display:flex;flex-direction:column;gap:16px}.edit-section:first-of-type{border-top:none;padding-top:0}.edit-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.edit-section-header h3{font-size:1rem;font-family:var(--font-outfit);font-weight:600}.edit-add-btn{font-size:.8rem;padding:6px 12px}.edit-row{display:flex;flex-wrap:wrap;gap:12px}.edit-field{display:flex;flex-direction:column;gap:6px;flex:1;min-width:140px}.edit-field--full{flex:1 1 100%}.edit-field label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.edit-input{background:#ffffff0a;border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-main);padding:9px 12px;font-size:.9rem;font-family:inherit;transition:border-color .2s;width:100%}.edit-input:focus{outline:none;border-color:var(--color-primary)}select.edit-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}select.edit-input option{background:#1a2236;color:var(--color-text-main)}.edit-textarea{background:#ffffff0a;border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-main);padding:9px 12px;font-size:.9rem;font-family:inherit;resize:vertical;line-height:1.5;width:100%;transition:border-color .2s}.edit-textarea:focus{outline:none;border-color:var(--color-primary)}.edit-ingredients{display:flex;flex-direction:column;gap:8px}.edit-ingredient-row{display:flex;align-items:center;gap:8px}.edit-ing-amount{flex:0 0 120px}.edit-ing-item{flex:1}.edit-instructions{display:flex;flex-direction:column;gap:10px}.edit-instruction-row{display:flex;align-items:flex-start;gap:10px}.edit-step-num{width:28px;height:28px;border-radius:50%;background:#ffffff0f;border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;margin-top:8px;color:var(--color-text-muted)}.edit-step-text{flex:1;min-height:48px;resize:none;overflow:hidden}.edit-remove-btn{margin-top:6px;flex-shrink:0}.edit-save-error{font-size:.82rem;color:#ef4444}.chef-notes{padding:20px 24px;border-color:#a78bfa33!important;background:#a78bfa0d!important;display:flex;flex-direction:column;gap:8px}.chef-notes-label{font-size:.72rem;font-weight:700;font-family:var(--font-outfit);letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent-purple)}.chef-notes p{font-size:.9rem;color:var(--color-text-muted);line-height:1.7;font-style:italic}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:420px;padding:40px 36px}.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:8px}.chef-icon{color:var(--color-primary)}.auth-logo h1{font-size:1.7rem;font-family:var(--font-outfit);font-weight:800;letter-spacing:-.02em}.auth-logo h1 span{color:var(--color-primary)}.auth-subtitle{color:var(--color-text-dim);font-size:.9rem;margin-bottom:28px}.auth-tabs{display:flex;background:#ffffff0a;border-radius:var(--radius-sm);padding:3px;margin-bottom:24px}.auth-tab{flex:1;padding:8px;border:none;background:transparent;color:var(--color-text-dim);border-radius:6px;font-size:.85rem;font-weight:500;transition:all .2s ease}.auth-tab.active{background:var(--color-surface-2);color:var(--color-text-main)}.auth-form{display:flex;flex-direction:column;gap:12px}.input-group{display:flex;align-items:center;gap:10px;padding:0 14px;background:#ffffff0a;border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color .2s ease}.input-group:focus-within{border-color:#f9731666}.input-icon{color:var(--color-text-dim);flex-shrink:0}.input-group input{flex:1;background:transparent;border:none;outline:none;padding:13px 0;font-size:.93rem}.input-group input::placeholder{color:#fff3}.auth-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-sm);color:#fca5a5;font-size:.83rem}.auth-submit{width:100%;justify-content:center;padding:13px;margin-top:4px}.auth-footer{text-align:center;color:var(--color-text-dim);font-size:.83rem;margin-top:20px}.auth-link{background:none;border:none;color:var(--color-primary);font-size:.83rem;cursor:pointer}.auth-link:hover{text-decoration:underline}.auth-divider{display:flex;align-items:center;gap:12px;margin:16px 0 12px;color:var(--color-text-dim);font-size:.78rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.auth-google{display:flex;justify-content:center;margin-bottom:4px}.vault-page{display:flex;flex-direction:column;gap:24px}.vault-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px}.vault-title{display:flex;align-items:center;gap:12px;font-size:2rem;letter-spacing:-.02em}.vault-title-icon{flex-shrink:0}.vault-sub{color:var(--color-text-dim);font-size:.9rem;margin-top:4px}.vault-search{display:flex;align-items:center;gap:10px;padding:10px 16px;max-width:480px}.vault-search input{flex:1;background:transparent;border:none;outline:none;font-size:.9rem}.vault-search input::placeholder{color:#fff3}.vault-grid{display:flex;gap:20px;align-items:flex-start}.vault-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;flex:1}.vault-detail{width:420px;flex-shrink:0;padding:28px 24px;position:sticky;top:100px;max-height:calc(100vh - 120px);overflow-y:auto}@media (max-width: 900px){.vault-grid{flex-direction:column}.vault-detail{width:100%;position:static;max-height:none}}.vault-card{padding:0;cursor:pointer;overflow:hidden;transition:all .3s var(--ease-spring);display:flex;flex-direction:column;gap:0}.vault-card:hover{transform:translateY(-5px);border-color:#f973164d}.vault-card.selected{border-color:var(--color-primary);background:#f973160f!important}.vault-card-image{width:100%;height:140px;overflow:hidden}.vault-card-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.vault-card:hover .vault-card-image img{transform:scale(1.05)}.source-image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f9731614,#a78bfa14);border-bottom:1px solid var(--color-border);gap:10px;padding:24px;text-align:center;position:relative;overflow:hidden}.source-image-placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(249,115,22,.05) 0%,transparent 70%)}.source-placeholder-icon{color:var(--color-primary);filter:drop-shadow(0 0 8px rgba(249,115,22,.3));margin-bottom:4px;position:relative;z-index:1}.source-placeholder-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-dim);opacity:.7;position:relative;z-index:1}.source-placeholder-url{font-size:.85rem;color:var(--color-text-main);font-family:var(--font-outfit);font-weight:600;word-break:break-all;max-width:100%;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;position:relative;z-index:1}.vault-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding:16px 16px 0}.vault-card-title,.vault-card .card-tags,.vault-card-stats{padding:0 16px}.vault-card-footer{padding:0 16px 16px}.vault-card-badge{font-size:.65rem;font-weight:700;font-family:var(--font-outfit);letter-spacing:.1em;text-transform:uppercase;color:var(--color-primary);background:#f973161a;padding:2px 8px;border-radius:100px}.vault-card-title{font-size:.98rem;margin-bottom:10px;line-height:1.3;font-family:var(--font-outfit);font-weight:700}.vault-card-stats{display:flex;gap:10px;font-size:.72rem;color:var(--color-text-dim);margin-bottom:14px;flex-wrap:wrap}.vault-card-stats span{display:flex;align-items:center;gap:4px}.cook-count-badge{color:var(--color-primary)!important;font-weight:600}.vault-card-footer{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--color-text-dim);border-top:1px solid var(--color-border);padding-top:12px;margin-top:auto}.detail-close{position:absolute;top:16px;right:16px;background:#ffffff0f;border:1px solid var(--color-border);border-radius:50%;width:28px;height:28px;font-size:.75rem;color:var(--color-text-dim);display:flex;align-items:center;justify-content:center;transition:all .2s ease}.detail-close:hover{background:#ffffff1a;color:var(--color-text-main)}.vault-detail{position:relative;overflow:hidden;padding:0}.vault-detail-image{width:100%;height:200px;overflow:hidden;flex-shrink:0}.vault-detail-image img{width:100%;height:100%;object-fit:cover;display:block}.vault-detail>:not(.vault-detail-image):not(.detail-close){padding-left:24px;padding-right:24px}.vault-detail>.result-badge{padding-top:20px}.vault-detail>.detail-stats{padding-bottom:4px}.vault-detail>.chef-notes{margin-left:24px;margin-right:24px}.vault-detail>a.btn-primary{margin-left:24px;margin-right:24px;margin-bottom:24px}.detail-close{position:absolute;top:12px;right:12px;z-index:2}.detail-title{font-size:1.35rem;margin-bottom:8px;letter-spacing:-.02em}.detail-desc{color:var(--color-text-dim);font-size:.85rem;line-height:1.6;margin-bottom:16px}.detail-stats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.detail-section-title{font-size:.85rem;color:var(--color-text-muted);margin:18px 0 10px;font-family:var(--font-outfit)}.vault-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:64px 40px;text-align:center;max-width:480px;margin:0 auto}.vault-empty h3{font-size:1.2rem;margin-top:8px}.vault-empty p{color:var(--color-text-dim);font-size:.9rem}.vault-loading{display:flex;flex-direction:column;gap:16px}.skeleton-card{height:280px;border-radius:12px;background:linear-gradient(90deg,var(--color-surface) 25%,var(--color-surface-2) 50%,var(--color-surface) 75%);background-size:200% 100%;animation:shimmer 1.4s ease infinite}@media (max-width: 768px){.navbar{margin:8px 12px;padding:8px 14px}.main-content{padding:20px 16px 48px}.vault-cards{grid-template-columns:1fr 1fr}.user-name{display:none}.detail-body{grid-template-columns:1fr}}@media (max-width: 480px){.vault-cards{grid-template-columns:1fr}.result-actions{flex-direction:column}.auth-card{padding:28px 20px}.detail-hero{padding:24px 20px}.detail-stats-row{gap:16px}}.recipe-detail{display:flex;flex-direction:column;gap:24px;max-width:1100px;margin:0 auto}.detail-nav{display:flex;align-items:center;justify-content:space-between;gap:12px}.detail-nav-actions{display:flex;gap:8px}.back-btn{font-size:.85rem}.danger-btn:hover{color:var(--color-danger)!important;border-color:#ef444466!important;background:#ef444412!important}.danger{color:var(--color-danger)!important}.text-success{color:var(--color-success)}.share-btn{color:var(--color-accent-blue)!important;border-color:#38bdf833!important;background:#38bdf80a!important}.share-btn:hover{background:#38bdf81a!important;border-color:#38bdf866!important}.print-btn{color:var(--color-accent-purple)!important;border-color:#a78bfa33!important;background:#a78bfa0a!important}.print-btn:hover{background:#a78bfa1a!important;border-color:#a78bfa66!important}.edit-btn{color:var(--color-primary)!important;border-color:#f9731633!important;background:#f973160a!important}.edit-btn:hover{background:#f973161a!important;border-color:#f9731666!important}.remix-btn{color:#fbbf24!important;border-color:#fbbf2433!important;background:#fbbf240a!important}.remix-btn:hover{background:#fbbf241a!important;border-color:#fbbf2466!important}.list-btn{color:var(--color-success)!important;border-color:#22c55e33!important;background:#22c55e0a!important}.list-btn:hover{background:#22c55e1a!important;border-color:#22c55e66!important}.gen-btn{color:var(--color-accent-blue)!important;border-color:#38bdf833!important;background:#38bdf80a!important}.gen-btn:hover{background:#38bdf81a!important;border-color:#38bdf866!important}.delete-btn{color:var(--color-danger)!important;border-color:#ef444433!important;background:#ef44440a!important}.delete-btn:hover{background:#ef44441a!important;border-color:#ef444466!important}.detail-hero{padding:36px 40px;overflow:hidden}.detail-hero-image{margin:-36px -40px 32px;height:320px;overflow:hidden;position:relative}.detail-hero-image:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent 40%,rgba(10,15,30,.85) 100%)}.detail-hero-img{width:100%;height:100%;object-fit:cover;display:block}.detail-hero-inner{max-width:860px}.detail-badges{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.difficulty-badge{font-size:.75rem;font-weight:700;font-family:var(--font-outfit);letter-spacing:.06em;text-transform:uppercase;padding:4px 12px;background:#ffffff0d;border:1px solid var(--color-border);border-radius:100px}.detail-title{font-size:clamp(1.7rem,4vw,2.6rem);letter-spacing:-.03em;margin-bottom:8px;line-height:1.15}.detail-author{color:var(--color-text-dim);font-size:.88rem;display:flex;align-items:center;gap:6px;margin-bottom:24px}.detail-author strong{color:var(--color-text-muted)}.detail-stats-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap}.detail-stat{display:flex;align-items:center;gap:10px}.detail-stat-icon{color:var(--color-primary)}.detail-stat div{display:flex;flex-direction:column}.stat-value{font-size:1.15rem;font-weight:700;font-family:var(--font-outfit);line-height:1}.stat-unit{font-size:.72rem;color:var(--color-text-dim);margin-top:2px;text-transform:uppercase;letter-spacing:.04em}.detail-stat-divider{width:1px;height:32px;background:var(--color-border)}.cooking-progress{margin-top:24px;max-width:480px}.progress-label{display:flex;justify-content:space-between;font-size:.8rem;color:var(--color-text-dim);margin-bottom:6px}.progress-track{height:6px;background:#ffffff12;border-radius:100px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent-blue));border-radius:100px;transition:width .4s var(--ease-out)}.detail-body{display:grid;grid-template-columns:1fr 1.5fr;gap:20px;align-items:start}.detail-panel{padding:28px 32px}.panel-hint{color:var(--color-text-dim);font-size:.78rem;margin-bottom:16px;margin-top:-12px}.ingredient-item.checkable{cursor:pointer;transition:opacity .2s ease;-webkit-user-select:none;user-select:none}.ingredient-item.checkable:hover{background:#ffffff08;border-radius:6px}.ingredient-item.checked{opacity:.4;text-decoration:line-through}.ing-check{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--color-border);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-success);transition:all .2s ease}.checked .ing-check{background:var(--color-success);border-color:var(--color-success);color:#fff}.ingredients-counter{margin-top:16px;font-size:.78rem;color:var(--color-text-dim);text-align:right;font-family:var(--font-outfit)}.detail-step{cursor:pointer;-webkit-user-select:none;user-select:none}.detail-step:hover{background:#ffffff0a!important;border-radius:8px}.step-done{opacity:.45}.step-done .step-content p{text-decoration:line-through}.step-num-done{background:#22c55e26!important;color:var(--color-success)!important}.completion-banner{margin-top:20px;padding:14px 18px;background:#22c55e1a;border:1px solid rgba(34,197,94,.25);border-radius:var(--radius-sm);color:#86efac;font-size:.9rem;text-align:center;animation:pageEnter .4s var(--ease-out) forwards}.ai-prompt-box{padding:20px 24px;border-color:#38bdf826!important;background:#38bdf80a!important;display:flex;flex-direction:column;gap:10px}.ai-prompt-label{font-size:.72rem;font-weight:700;font-family:var(--font-outfit);letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent-blue)}.ai-prompt-text{font-size:.9rem;color:var(--color-text-muted);font-style:italic;line-height:1.5}.detail-loading{display:flex;flex-direction:column;gap:20px}.detail-skeleton{padding:36px 40px}.skel{background:linear-gradient(90deg,var(--color-surface) 25%,var(--color-surface-2) 50%,var(--color-surface) 75%);background-size:200% 100%;animation:shimmer 1.6s ease infinite;border-radius:8px}.skel-title{height:48px;width:65%;margin-bottom:12px}.skel-sub{height:20px;width:30%;margin-bottom:24px}.skel-stats{height:32px;width:50%}.detail-skeleton-body{display:grid;grid-template-columns:1fr 1.5fr;gap:20px}.skel-panel{height:340px}.detail-error{display:flex;justify-content:center;padding-top:60px}.detail-error-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:56px 48px;text-align:center;max-width:440px}.detail-error-card h2{font-size:1.4rem}.cooking-mode-page{display:flex;flex-direction:column;min-height:calc(100vh - 120px);gap:20px}.cooking-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.icon-btn-ghost{display:inline-flex;align-items:center;justify-content:center;padding:8px;background:transparent;border:none;border-radius:50%;color:var(--color-text-main);transition:all .2s}.icon-btn-ghost:hover{background:#ffffff1a}.mise-container{max-width:800px;margin:0 auto;width:100%}.mise-subtitle{text-align:center;color:var(--color-text-dim);margin-bottom:24px}.mise-servings-bar{display:flex;align-items:center;gap:12px;padding:12px 20px;border-radius:16px;margin-bottom:28px;border:1px solid rgba(255,255,255,.07)}.mise-servings-icon{color:var(--color-primary);flex-shrink:0}.mise-servings-label{font-size:.85rem;color:var(--color-text-dim);font-weight:500;flex:1}.mise-servings-control{display:flex;align-items:center;background:#ffffff0d;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.mise-servings-control .servings-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--color-text-main);background:transparent;border:none;cursor:pointer;transition:background .15s}.mise-servings-control .servings-btn:hover:not(:disabled){background:#ffffff14}.mise-servings-control .servings-btn:disabled{opacity:.3;cursor:default}.mise-servings-value{min-width:32px;text-align:center;font-size:1rem;font-weight:700;color:var(--color-primary);padding:0 4px}.mise-servings-reset{font-size:.75rem;color:var(--color-text-dim);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:4px 10px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.mise-servings-reset:hover{background:#ffffff1a;color:var(--color-text-main)}.mise-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:40px}.mise-item{display:flex;align-items:center;padding:16px 20px;gap:16px;cursor:pointer;transition:all .3s;border:1px solid rgba(255,255,255,.05)}.mise-item:hover{background:#ffffff08}.mise-item.checked{border-color:#22c55e4d;background:#22c55e0d;opacity:.7}.mise-check{width:24px;height:24px;border-radius:50%;border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;color:transparent;transition:all .2s}.checked .mise-check{border-color:var(--color-success);background:var(--color-success);color:#fff}.mise-text{display:flex;flex-direction:column}.mise-amount{color:var(--color-primary);font-weight:600;font-size:.85rem}.mise-name{font-size:1.05rem}.checked .mise-name{text-decoration:line-through;color:var(--color-text-dim)}.start-cooking-btn{display:flex;margin:0 auto;padding:16px 40px;font-size:1.2rem}.steps-phase{display:flex;flex-direction:column;min-height:calc(100vh - 80px);gap:0}.cook-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-bottom:20px;border-bottom:1px solid var(--color-border);margin-bottom:0}.cook-topbar-center{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}.step-counter{font-family:var(--font-outfit);font-weight:700;font-size:.85rem;color:var(--color-primary);letter-spacing:.12em;text-transform:uppercase}.step-progress-inline{width:100%;max-width:280px;height:3px;background:#ffffff12;border-radius:99px;overflow:hidden}.step-progress-inline-fill{height:100%;background:var(--color-primary);border-radius:99px;transition:width .4s var(--ease-out)}.cook-topbar-actions{display:flex;gap:4px;align-items:center}.cook-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 0 20px;gap:28px}.step-text-block{display:flex;flex-direction:column;align-items:center;gap:16px;max-width:860px;width:100%}.step-text{font-size:clamp(1.45rem,4vw,2.4rem);line-height:1.55;font-weight:300}.repeat-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:100px;border:1px solid rgba(56,189,248,.3);background:#38bdf80f;color:var(--color-accent-blue);font-size:.8rem;cursor:pointer;transition:all .2s}.repeat-btn:hover{background:#38bdf824}.cook-nav{display:flex;align-items:center;justify-content:center;gap:20px;padding:20px 0 0}.cook-nav-prev{padding:14px;border-radius:50%;border:1px solid var(--color-border);background:#ffffff05;color:var(--color-text-main);transition:all .2s}.cook-nav-prev:hover:not(:disabled){background:#ffffff14}.cook-nav-prev:disabled{opacity:.25;cursor:not-allowed}.cook-nav-next{padding:14px 40px;font-size:1.15rem;border-radius:100px}.voice-panel{border-bottom:1px solid var(--color-border);padding:16px 0 20px;display:flex;flex-direction:column;gap:14px;animation:fadeInUp .25s var(--ease-out)}.voice-panel-header{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.8rem;color:var(--color-danger);font-weight:500;letter-spacing:.04em;text-transform:uppercase}.voice-listening-dot{width:8px;height:8px;border-radius:50%;background:var(--color-danger);animation:pulse 1.4s ease-in-out infinite}.voice-commands-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}.voice-cmd-chip{display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 18px;border-radius:var(--radius-md);background:#ffffff0a;border:1px solid var(--color-border);min-width:120px}.voice-cmd-say{font-family:var(--font-outfit);font-size:.9rem;font-weight:600;color:var(--color-text-main)}.voice-cmd-desc{font-size:.72rem;color:var(--color-text-dim);text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.timers-container{position:fixed;bottom:40px;right:40px;display:flex;flex-direction:column;gap:12px;z-index:1000}.timer-widget{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;gap:24px;border-radius:var(--radius-md);border-left:4px solid var(--color-accent-blue);background:#1e293be6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);min-width:250px}.timer-widget.timer-done{border-left-color:var(--color-danger);background:#ef44441a;border-color:#ef444480}.timer-info{display:flex;flex-direction:column}.timer-label{font-size:.75rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em}.timer-time{font-size:1.5rem;font-weight:700;font-family:var(--font-outfit)}.timer-done .timer-time{color:var(--color-danger)}.timer-actions{display:flex;gap:8px}.timer-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);background:#ffffff0d;color:var(--color-text-main);transition:all .2s}.timer-btn:hover{background:#ffffff26}.timer-btn.close:hover{background:#ef444433;color:var(--color-danger)}.step-tip-area{max-width:700px;width:100%;display:flex;justify-content:center}.step-tip-trigger{display:inline-flex;align-items:center;gap:6px;padding:7px 18px;border-radius:100px;border:1px dashed rgba(34,197,94,.4);background:transparent;color:var(--color-success);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.step-tip-trigger:hover:not(:disabled){background:#22c55e14;border-color:#22c55eb3}.step-tip-trigger:disabled{opacity:.55;cursor:not-allowed}.step-tip-callout{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;border-left:3px solid var(--color-success);background:#22c55e12;border-radius:0 var(--radius-md) var(--radius-md) 0;text-align:left;width:100%}.step-tip-callout p{font-size:1rem;line-height:1.6;color:var(--color-text-muted)}.step-tip-icon{color:var(--color-success);flex-shrink:0;margin-top:3px}.step-tip-error{font-size:.82rem;color:var(--color-text-dim);align-self:center}.timer-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.timer-dialog{padding:24px;border-radius:var(--radius-lg);width:320px;max-width:90vw}.timer-dialog-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:1rem;margin-bottom:20px}.timer-dialog-form{display:flex;flex-direction:column;gap:16px}.timer-dialog-field{display:flex;flex-direction:column;gap:6px}.timer-dialog-field label{font-size:.8rem;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.04em}.tts-btn{color:var(--color-text-dim)}.tts-btn.tts-active{color:var(--color-accent-blue);background:#38bdf81f}.voice-btn{color:var(--color-text-dim)}.voice-btn.voice-active{color:var(--color-danger);background:#ef44441a}.complete-phase{justify-content:center;align-items:center}.complete-card{display:flex;flex-direction:column;align-items:center;padding:60px 80px;text-align:center}.complete-card h1{font-size:3rem;margin-bottom:12px}.community-page{display:flex;flex-direction:column;gap:24px}.community-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px}.community-title{display:flex;align-items:center;gap:12px;font-size:2rem;letter-spacing:-.02em}.community-title-icon{flex-shrink:0}.community-sub{color:var(--color-text-dim);font-size:.9rem;margin-top:4px}.community-search,.vault-search{display:flex;align-items:center;gap:10px;padding:10px 16px;flex:1;min-width:320px}.community-search input,.vault-search input{flex:1;background:transparent;border:none;outline:none;font-size:.95rem;color:var(--color-text-main);padding:4px 0}.community-search input::placeholder,.vault-search input::placeholder{color:#ffffff40}.filters-container{display:flex;align-items:center;gap:20px;margin-bottom:40px;flex-wrap:wrap}.filters-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.filter-item{display:flex;align-items:center;gap:10px}.filter-select-wrap{position:relative;display:flex;align-items:center;gap:8px;background:#ffffff08;border:1px solid var(--color-border);border-radius:100px;padding:6px 30px 6px 14px;transition:all .3s ease;min-width:120px}.filter-select-wrap:hover{background:#ffffff0f;border-color:#fff3}.filter-select-wrap:focus-within{border-color:var(--color-primary);box-shadow:0 0 15px var(--color-primary-glow)}.filter-select-wrap svg{color:var(--color-text-dim);flex-shrink:0}.filter-select{background:transparent;border:none;color:var(--color-text-main);font-size:.85rem;font-weight:600;cursor:pointer;outline:none;width:100%;padding-right:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.filter-select option{background-color:var(--color-surface-2);color:var(--color-text-main);padding:10px}.filter-label{display:none}.filter-select-wrap:after{content:"";position:absolute;right:14px;width:6px;height:6px;border-right:2px solid var(--color-text-dim);border-bottom:2px solid var(--color-text-dim);transform:rotate(45deg);pointer-events:none}.filter-label{font-size:.75rem;font-weight:700;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.community-feed{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.community-card{display:flex;flex-direction:column;padding:0;overflow:hidden;cursor:pointer;transition:all .3s var(--ease-spring)}.community-card-image{width:100%;height:180px;overflow:hidden;flex-shrink:0}.community-card-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.community-card:hover .community-card-image img{transform:scale(1.05)}.community-card:hover{transform:translateY(-5px);border-color:#38bdf866}.community-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding:16px 16px 0}.community-card-body{padding:0 16px}.community-card-author{display:flex;align-items:center;gap:10px}.community-avatar{width:36px;height:36px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--color-text-main);font-family:var(--font-outfit)}.community-author-info{display:flex;flex-direction:column}.community-author-name{font-size:.9rem;font-weight:600;color:var(--color-text-main)}.community-author-date{font-size:.75rem;color:var(--color-text-dim)}.community-card-badge{display:flex;align-items:center;gap:4px;font-size:.65rem;font-weight:700;font-family:var(--font-outfit);letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent-blue);background:#38bdf81a;padding:4px 8px;border-radius:100px}.community-card-body{flex:1;display:flex;flex-direction:column}.community-card-title{font-size:1.15rem;margin-bottom:8px;line-height:1.3}.community-card-desc{font-size:.85rem;color:var(--color-text-muted);margin-bottom:16px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.community-card-stats{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.community-card-footer{display:flex;align-items:center;gap:16px;padding:16px;border-top:1px solid var(--color-border)}.action-btn{display:flex;align-items:center;gap:6px;background:transparent;border:none;color:var(--color-text-dim);font-size:.85rem;font-weight:500;transition:color .2s}.action-btn:hover{color:var(--color-primary)}.action-count{font-family:var(--font-inter)}.community-loading{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.community-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:64px 40px;text-align:center;max-width:480px;margin:0 auto}.community-empty h3{font-size:1.2rem;margin-top:8px}.community-empty p{color:var(--color-text-dim);font-size:.9rem;margin-bottom:16px}.comments-section{padding:24px 28px;margin-top:12px;display:flex;flex-direction:column;gap:20px}.comment-form{display:flex;gap:12px;align-items:center}.comment-input{flex:1;background:#ffffff0a;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:12px 16px;color:var(--color-text-main);outline:none;transition:all .2s ease}.comment-input:focus{border-color:#f9731666}.comments-list{display:flex;flex-direction:column;gap:16px}.comment-card{padding:16px;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-sm)}.comment-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.comment-avatar{width:32px;height:32px;background:var(--color-surface-2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:var(--color-text-main)}.comment-author{display:flex;flex-direction:column;flex:1}.comment-name{font-weight:600;font-size:.9rem}.verified-badge{display:flex;align-items:center;gap:4px;font-size:.65rem;color:var(--color-success);text-transform:uppercase;font-weight:700;margin-top:2px}.comment-date{font-size:.75rem;color:var(--color-text-dim)}.comment-text{font-size:.9rem;color:var(--color-text-muted);line-height:1.5}.hero-header-row{display:flex;justify-content:space-between;align-items:flex-end;max-width:860px;margin:0 auto 16px;text-align:left}.new-chat-btn{margin-bottom:8px;opacity:.8;transform:scale(.9);flex-shrink:0}.new-chat-btn:hover{opacity:1;transform:scale(1)}.search-actions{display:flex;align-items:center;gap:8px}.clear-btn{border:none!important;background:transparent!important;width:28px!important;height:28px!important;opacity:.4;display:flex;align-items:center;justify-content:center}.clear-btn:hover{opacity:1}.suggestions-container{display:flex;flex-direction:column;gap:24px;margin-top:32px}.suggestions-group{display:flex;flex-direction:column;gap:12px;align-items:center}.group-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;color:var(--color-text-dim);font-family:var(--font-outfit)}.tab-container{display:flex;background:#0003;padding:6px;border-radius:24px}.inactive-tab{color:var(--color-text-dim);background:transparent}.inactive-tab:hover{color:var(--color-text-main);background:#ffffff08}.active-dot{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;margin-bottom:4px;box-shadow:0 0 10px currentColor}.preference-chip{padding:8px 20px;background:#a78bfa14;border:1px solid rgba(167,139,250,.2);border-radius:100px;font-size:.85rem;color:#c4b5fd;transition:all .25s var(--ease-spring);font-weight:500;display:flex;align-items:center;gap:6px;cursor:pointer}.preference-chip:hover:not(:disabled){background:#a78bfa2e;border-color:var(--color-accent-purple);color:#fff;transform:translateY(-2px) scale(1.05);box-shadow:0 4px 15px #a78bfa40}.preferences-bar{display:flex;align-items:flex-end;justify-content:center;max-width:1000px;margin:0 auto 32px;padding:20px 28px;gap:20px;flex-wrap:nowrap}.pref-item{display:flex;flex-direction:column;gap:8px;align-items:flex-start;min-width:120px}.pref-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim);font-family:var(--font-outfit);margin-left:4px}.pref-select{background:#ffffff0d;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:0 12px;color:var(--color-text-main);font-size:.85rem;outline:none;cursor:pointer;transition:all .2s ease;height:38px;width:100%}.pref-select:hover{background:#ffffff14;border-color:#fff3}.pref-select option{background-color:#111827;color:#f1f5f9}.servings-control{display:flex;align-items:center;gap:12px;background:#ffffff0d;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:0 10px;height:38px}.servings-btn{background:transparent;border:none;color:var(--color-text-dim);font-size:1.2rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}@media (max-width: 600px){.preferences-bar{flex-direction:column;align-items:stretch;gap:16px}.pref-item{align-items:stretch}}.result-reference{display:flex;flex-wrap:wrap;gap:24px;padding:14px 20px;margin-top:16px;margin-bottom:24px;background:#ffffff08!important;border-color:#ffffff0f!important}.ref-item{display:flex;align-items:center;gap:8px}.ref-icon{color:var(--color-primary)}.ref-label{font-size:.75rem;font-weight:700;color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.05em}.ref-value{font-size:.88rem;font-weight:600;color:var(--color-text-main)}.text-green{color:#4ade80!important}@media print{.no-print,.detail-nav,.cooking-progress,.panel-hint,.ingredients-counter,.completion-banner,.btn-primary,.ai-prompt-box,.private-note-section,.comments-section,.bg-gradient-mesh,nav,header,footer{display:none!important}*,*:before,*:after{background:#fff!important;color:#1a1a1a!important;box-shadow:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;border-color:#e2e2e2!important;print-color-adjust:exact;-webkit-print-color-adjust:exact}body{font-family:Georgia,serif;font-size:11pt;line-height:1.5;margin:0;padding:0}h1,h2,h3,h4{font-family:Georgia,serif;color:#1a1a1a!important}.recipe-detail{max-width:100%;padding:0;margin:0}.detail-hero{border:1.5px solid #d97706!important;border-radius:8px!important;padding:6pt 12pt!important;margin-bottom:8pt;page-break-inside:avoid}.detail-hero-image{float:right;margin:0 0 4pt 10pt;width:60pt;border-radius:4px;overflow:hidden}.detail-hero-img{width:100%;height:auto;border-radius:4px;display:block}.detail-hero-inner{display:flex;flex-direction:column;gap:0}.detail-badges{display:inline;margin:0}.detail-title{font-size:12pt!important;font-weight:800;color:#92400e!important;margin:0 0 1pt!important;line-height:1.1}.card-tags{display:inline-flex!important;flex-wrap:wrap;align-items:center;gap:3pt;margin:0 0 1pt!important}.detail-author{font-size:7.5pt;color:#6b7280!important;margin:0 0 1pt!important;display:flex;align-items:center;gap:3pt;line-height:1.2}.detail-author svg{display:none}.difficulty-badge{font-size:6.5pt!important;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border:1px solid #d97706!important;padding:0 4pt!important;border-radius:20pt!important;color:#d97706!important;background:transparent!important;line-height:1.4}.card-tag{font-size:6.5pt!important;padding:0 4pt!important;border-radius:20pt!important;border:1px solid #d1d5db!important;margin-right:2pt;color:#374151!important;background:transparent!important;line-height:1.4}.detail-stats-row{display:flex;gap:0;margin-top:4pt;border-top:1px solid #e5e7eb!important;padding-top:4pt}.detail-stat{display:flex;flex-direction:row;align-items:center;justify-content:center;flex:1;gap:3pt}.detail-stat-icon{display:none}.stat-value{font-size:9.5pt!important;font-weight:700;color:#92400e!important}.stat-unit{font-size:7.5pt!important;color:#6b7280!important;text-transform:uppercase;letter-spacing:.05em}.detail-stat-divider{width:1px;background:#e5e7eb!important;align-self:stretch}.detail-body{display:flex;flex-direction:column;gap:14pt;margin-bottom:14pt}.ingredients-panel{order:1}.instructions-panel{order:2}.detail-panel{border:1.5px solid #e5e7eb!important;border-radius:8px!important;padding:14pt 18pt!important;page-break-inside:avoid}.panel-title{font-size:13pt!important;font-weight:700;color:#92400e!important;border-bottom:2px solid #fed7aa!important;padding-bottom:6pt;margin-bottom:10pt}.ingredient-list{list-style:none;padding:0;display:grid;grid-template-columns:1fr 1fr;column-gap:20pt}.ingredient-item{display:flex;gap:6pt;padding:4pt 0;border-bottom:1px dotted #e5e7eb!important;font-size:10pt;cursor:default}.ingredient-item:last-child{border-bottom:none!important}.ing-check{display:none}.ing-amount{font-weight:700;color:#92400e!important;min-width:44pt;flex-shrink:0}.ing-name{color:#374151!important}.instruction-list{list-style:none;padding:0}.instruction-step{display:flex;gap:10pt;margin-bottom:10pt;page-break-inside:avoid}.step-number{flex-shrink:0;width:20pt;height:20pt;border-radius:50%;background:#d97706!important;color:#fff!important;display:flex;align-items:center;justify-content:center;font-size:9pt;font-weight:700;margin-top:1pt}.step-content p{font-size:10pt;line-height:1.55;color:#1a1a1a!important;margin:0}.chef-notes{border:1.5px solid #e5e7eb!important;border-left:4px solid #d97706!important;border-radius:8px!important;padding:14pt 18pt!important;margin-bottom:14pt;page-break-inside:avoid}.chef-notes-label{font-size:9pt;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#d97706!important;display:block;margin-bottom:4pt}.chef-notes p{font-size:10pt;font-style:italic;color:#374151!important}.recipe-detail:after{content:"Generated by RevipeAI — " attr(data-url);display:block;text-align:center;font-size:8pt;color:#9ca3af!important;border-top:1px solid #e5e7eb!important;margin-top:20pt;padding-top:8pt}.detail-hero{page-break-after:avoid}.detail-body{page-break-before:avoid}}.text-purple{color:#a78bfa!important}.generator-alt-actions{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-top:1.25rem;flex-wrap:wrap}.generator-alt-actions .group-label{margin-right:.2rem}.alt-action-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 18px;border-radius:100px;font-size:.82rem;font-weight:600;font-family:var(--font-outfit);letter-spacing:.01em;border:1px solid transparent;transition:all .2s ease;white-space:nowrap}.alt-action-btn:hover{transform:translateY(-2px);filter:brightness(1.12);box-shadow:0 6px 20px #0000004d}.alt-action-btn--import{background:linear-gradient(135deg,#0ea5e9,#2563eb);color:#fff;border-color:#63b3ed4d;box-shadow:0 2px 10px #0ea5e940}.alt-action-btn--create{background:linear-gradient(135deg,#8b5cf6,#a855f7);color:#fff;border-color:#a78bfa4d;box-shadow:0 2px 10px #8b5cf640}.recipe-source-badge{position:absolute;top:12px;right:12px;z-index:10;display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#0006;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:100px;color:#fff;font-size:.7rem;font-weight:600;font-family:var(--font-outfit);text-decoration:none;letter-spacing:.02em;transition:all .3s var(--ease-out);box-shadow:0 4px 12px #0003}.recipe-source-badge:hover{background:var(--color-primary);border-color:var(--color-primary);transform:translateY(-2px) scale(1.02);box-shadow:0 6px 16px var(--color-primary-glow)}.recipe-source-badge svg{color:#fff;opacity:.9}.detail-source{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--color-text-dim);margin-bottom:12px;flex-wrap:wrap}.detail-source em{font-style:normal;color:var(--color-text-muted);max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-source-link{color:var(--color-primary);text-decoration:none;max-width:340px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block;vertical-align:bottom}.detail-source-link:hover{text-decoration:underline}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-box{width:100%;max-width:520px;border-radius:20px;padding:1.75rem;animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.modal-header h2{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;color:var(--color-text)}.import-url-row{display:flex;gap:.6rem}.import-url-input{flex:1;background:#ffffff0f;border:1px solid var(--color-border);border-radius:10px;padding:.6rem .9rem;font-size:.9rem;color:var(--color-text);outline:none;transition:border-color .2s}.import-url-input:focus{border-color:var(--color-primary)}.import-url-input::placeholder{color:var(--color-text-dim)}.import-error{margin-top:.75rem;font-size:.85rem;color:#f87171}.import-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem 0;color:var(--color-text-muted);font-size:.9rem}.import-preview-step h3{font-size:1.15rem;font-weight:700;margin-bottom:.4rem;color:var(--color-text)}.import-preview-stats{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.75rem;font-size:.82rem;color:var(--color-text-muted)}.import-preview-stats span{display:flex;align-items:center;gap:4px;background:#ffffff0d;border:1px solid var(--color-border);border-radius:100px;padding:3px 10px}.import-preview-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .9s linear infinite}.alt-action-btn--select{background:#ffffff12;color:var(--color-text-muted);border-color:var(--color-border)}.alt-action-btn--select-active{background:#f973161f;color:var(--color-primary);border-color:#f9731659}.alt-action-btn--grocery{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border-color:#22c55e4d;box-shadow:0 2px 10px #22c55e40}.vault-card-select-overlay{position:absolute;top:10px;left:10px;z-index:5}.vault-card-checkbox{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#0a0f1ebf;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-dim);transition:all .15s ease}.vault-card-checkbox--checked{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.grocery-modal{width:100%;max-width:560px;max-height:85vh;display:flex;flex-direction:column;border-radius:var(--radius-xl);padding:1.75rem;animation:modal-in .2s ease}.grocery-modal-subtitle{font-size:.82rem;color:var(--color-text-dim);margin-top:-.75rem;margin-bottom:1.25rem}.grocery-modal-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.grocery-section{display:flex;flex-direction:column;gap:.4rem}.grocery-section-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary);font-family:var(--font-outfit);margin-bottom:.25rem}.grocery-items{display:flex;flex-direction:column;gap:.2rem;list-style:none;padding:0;margin:0}.grocery-item{display:flex;align-items:center;gap:.6rem;padding:.45rem .6rem;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease;-webkit-user-select:none;user-select:none}.grocery-item:hover{background:#ffffff0d}.grocery-item--checked .grocery-item-text{opacity:.38;text-decoration:line-through}.grocery-item-check{color:var(--color-text-dim);flex-shrink:0}.grocery-item--checked .grocery-item-check{color:#22c55e}.grocery-item-text{font-size:.88rem;line-height:1.4}.grocery-item-amount{font-weight:600;color:var(--color-text-muted)}.grocery-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--color-border)}.grocery-page{display:flex;flex-direction:column;gap:32px;max-width:1200px;margin:0 auto}.grocery-header{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}.grocery-actions{display:flex;gap:12px}.grocery-grid{display:grid;grid-template-columns:320px 1fr;gap:32px;align-items:start}@media (max-width: 900px){.grocery-grid{grid-template-columns:1fr}.grocery-sidebar{order:2}.grocery-list-container{order:1}}.grocery-sidebar{display:flex;flex-direction:column;position:sticky;top:100px}.grocery-group{margin-bottom:24px}.grocery-group-header{display:flex;align-items:center;gap:10px;padding:14px 20px;background:#ffffff08;border-bottom:1px solid var(--color-border);font-family:var(--font-outfit);font-weight:600;font-size:.9rem;color:var(--color-text-muted)}.grocery-items-box{display:flex;flex-direction:column}.grocery-item{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--color-border);cursor:pointer;transition:all .2s ease}.grocery-item:last-child{border-bottom:none}.grocery-item:hover{background:#ffffff05}.item-main{display:flex;align-items:center;gap:14px;flex:1}.check-icon{flex-shrink:0;transition:transform .2s cubic-bezier(.175,.885,.32,1.275)}.grocery-item:hover .check-icon{transform:scale(1.1)}.item-text{display:flex;flex-direction:column;gap:2px}.item-name{font-size:1rem;font-weight:500;color:var(--color-text-main);transition:all .2s ease}.item-amount{font-size:.8rem;color:var(--color-primary);font-weight:600}.grocery-item.checked .item-name{text-decoration:line-through;opacity:.4}.grocery-item.checked .item-amount{opacity:.3}.item-delete{padding:8px;border-radius:8px;color:var(--color-text-dim);background:transparent;border:none;opacity:0;transition:all .2s ease}.grocery-item:hover .item-delete{opacity:1}.item-delete:hover{background:#ef44441a;color:var(--color-danger)}.save-progress-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px}.save-progress-card{max-width:440px;width:100%;padding:40px;text-align:center;border-color:#f9731633!important}.save-progress-header{margin-bottom:32px}.save-progress-header h3{font-size:1.5rem;margin-top:16px;margin-bottom:8px;letter-spacing:-.02em}.save-progress-header p{font-size:.95rem;color:var(--color-text-dim);line-height:1.6}.save-progress-steps{display:flex;flex-direction:column;gap:16px;text-align:left;background:#ffffff08;padding:20px 24px;border-radius:var(--radius-md);border:1px solid var(--color-border)}.save-error-text{font-size:.95rem;color:var(--color-text-muted);line-height:1.6;margin:16px 0 24px}.token-exhausted-icon{width:72px;height:72px;background:#f59e0b1a;border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 0 20px #f59e0b1a}.spin{animation:spin 1.2s linear infinite}.limit-reached-content{text-align:center;padding:24px 10px;display:flex;flex-direction:column;gap:12px;align-items:center}.limit-reached-content h3{font-size:1.5rem;letter-spacing:-.02em;color:var(--color-text-main)}.limit-reached-content p{font-size:.95rem;color:var(--color-text-dim);line-height:1.6;max-width:480px}.limit-actions{display:flex;gap:12px;margin-top:16px;width:100%;justify-content:center}@media (max-width: 480px){.limit-actions{flex-direction:column}.limit-actions a,.limit-actions button{width:100%;justify-content:center}}.fade-in{animation:fadeIn .4s var(--ease-out) forwards}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}.p-6{padding:24px}.p-12{padding:48px}.py-2{padding-top:8px;padding-bottom:8px}.py-20{padding-top:80px;padding-bottom:80px}.px-4{padding-left:16px;padding-right:16px}.m-0{margin:0}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}.mr-2{margin-right:8px}.ml-2{margin-left:8px}.ml-auto{margin-left:auto}.mx-auto{margin-left:auto;margin-right:auto}.w-full{width:100%}.h-full{height:100%}.text-center{text-align:center}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-xl{font-size:1.25rem}.font-bold{font-weight:700}.overflow-hidden{overflow:hidden}.inline{display:inline}.inline-flex{display:inline-flex}.relative{position:relative}.absolute{position:absolute}.inset-0{top:0;right:0;bottom:0;left:0}.opacity-20{opacity:.2}.opacity-50{opacity:.5}.chef-chat-section{padding:24px 28px;margin-top:24px;border-color:#f9731626;background:linear-gradient(135deg,#f973160d,#111827cc)}.chat-content{display:flex;flex-direction:column;gap:20px}.chat-header{display:flex;align-items:center;gap:16px}.chef-avatar-small{width:44px;height:44px;border-radius:12px;overflow:hidden;border:1px solid rgba(249,115,22,.3);box-shadow:0 4px 12px #f973161a}.chef-avatar-small img{width:100%;height:100%;object-fit:cover}.chat-meta h3{font-size:1.1rem;margin-bottom:2px;color:var(--color-text-main)}.chat-meta p{font-size:.85rem;color:var(--color-text-muted)}.chat-input-row{display:flex;gap:12px;background:#ffffff08;padding:6px;border-radius:var(--radius-md);border:1px solid var(--color-border);transition:all .3s ease}.chat-input-row:focus-within{border-color:#f9731666;box-shadow:0 0 0 2px var(--color-primary-glow)}.chat-refine-input{flex:1;background:transparent;border:none;outline:none;padding:8px 12px;color:var(--color-text-main);font-size:.95rem}.chat-refine-input::placeholder{color:#fff3}.chat-send-btn{padding:8px 18px;font-size:.85rem;border-radius:10px}.chef-chat-section--top{margin:0 0 10px;border-radius:var(--radius-lg);border-top-left-radius:0;border-top-right-radius:0;border-top:none}.chat-title-row{display:flex;align-items:center;gap:8px}.info-trigger-wrap{position:relative}.info-icon-btn{background:transparent;border:none;cursor:pointer;color:var(--color-primary);display:flex;align-items:center;opacity:.7;transition:opacity .2s;padding:4px}.info-icon-btn:hover{opacity:1}.chat-info-tooltip{position:absolute;top:calc(100% + 12px);left:0;width:520px;padding:20px;z-index:1000;background:#111827!important;border-color:#f973164d;box-shadow:0 12px 30px #0009;pointer-events:none}.chat-info-tooltip:before{content:"";position:absolute;top:-6px;left:8px;width:12px;height:12px;background:#111827;border-top:1px solid rgba(249,115,22,.3);border-left:1px solid rgba(249,115,22,.3);transform:rotate(45deg)}.tooltip-title{font-size:.9rem;font-family:var(--font-outfit);color:var(--color-primary);margin-bottom:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.tooltip-list{display:grid;grid-template-columns:1fr 1fr;gap:6px 16px}.tooltip-list li{font-size:.85rem;color:var(--color-text-main);line-height:1.4;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.05)}.tooltip-list li:last-child,.tooltip-list li:nth-last-child(2):nth-child(odd){border-bottom:none;padding-bottom:0}.chat-info-tooltip{z-index:9999!important}.chef-chat-section{position:relative;z-index:20}.clickable-example{cursor:pointer;transition:all .2s ease;pointer-events:auto!important}.clickable-example:hover{color:var(--color-primary);background:#f973160d;padding-left:6px}.chat-info-tooltip{pointer-events:auto!important}.main-info-trigger{margin-right:8px}.main-search-tooltip{top:auto;bottom:calc(100% + 16px);left:auto;right:-80px;width:780px}.main-search-tooltip .tooltip-list{grid-template-columns:1fr 1fr 1fr}.main-search-tooltip:before{top:auto;bottom:-6px;left:auto;right:86px;transform:rotate(225deg)}@media (max-width: 768px){.chat-info-tooltip{position:fixed!important;top:auto!important;bottom:0!important;left:0!important;right:0!important;width:100%!important;max-height:70vh;overflow-y:auto;border-radius:16px 16px 0 0;padding:20px 16px 32px}.chat-info-tooltip:before{display:none}.tooltip-list{grid-template-columns:1fr}.main-search-tooltip .tooltip-list{grid-template-columns:1fr 1fr}.tooltip-list li:nth-last-child(2):nth-child(odd){border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:6px}}@media (max-width: 480px){.main-search-tooltip .tooltip-list,.tooltip-list{grid-template-columns:1fr}}.floating-feedback-btn{position:fixed;bottom:24px;right:24px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;z-index:1000;border-radius:18px;color:var(--color-primary);background:var(--glass-bg);border:1px solid var(--color-primary-glow);box-shadow:0 10px 40px #00000080,0 0 20px var(--color-primary-glow);transition:all .3s var(--ease-spring);cursor:pointer;text-decoration:none}.floating-feedback-btn:hover{transform:translateY(-8px) scale(1.08) rotate(5deg);border-color:var(--color-primary);color:#fff;background:var(--color-primary);box-shadow:0 15px 50px var(--color-primary-glow)}.floating-feedback-btn:active{transform:translateY(-2px) scale(.95)}.floating-feedback-btn .tooltip{position:absolute;right:calc(100% + 12px);padding:6px 14px;background:var(--color-primary);color:#fff;border-radius:8px;font-size:.85rem;font-weight:600;opacity:0;transform:translate(10px);pointer-events:none;transition:all .2s ease;white-space:nowrap}.floating-feedback-btn:hover .tooltip{opacity:1;transform:translate(0)}.pulse-dot{position:absolute;top:-2px;right:-2px;width:12px;height:12px;background:#ef4444;border-radius:50%;border:2px solid var(--color-bg-dark);animation:feedbackPulse 2s infinite}@keyframes feedbackPulse{0%{transform:scale(1);box-shadow:0 0 #ef444466}70%{transform:scale(1.2);box-shadow:0 0 0 10px #ef444400}to{transform:scale(1);box-shadow:0 0 #ef444400}}@media (max-width: 600px){.floating-feedback-btn{bottom:20px;right:20px;width:48px;height:48px}}.auth-google-wrapper{display:flex;justify-content:center;width:100%;margin:1rem 0;overflow:hidden;border-radius:8px}.landing-container{max-width:1400px;margin:0 auto;padding:0 24px 80px}.landing-hero{text-align:center;padding:72px 0 64px}.hero-badges-row{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:32px}.ai-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:100px;background:#ffffff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:13px;font-weight:500;transition:all .3s var(--ease-spring)}.ai-badge:hover{transform:translateY(-2px);background:#ffffff14}.btn-landing-primary{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;border-radius:14px;background:var(--color-primary);color:#fff;font-weight:700;font-size:1.05rem;box-shadow:0 0 32px var(--color-primary-glow);transition:all .3s var(--ease-spring)}.btn-landing-primary:hover{box-shadow:0 0 48px #f9731666;transform:translateY(-2px) scale(1.02)}.btn-landing-secondary{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:14px;background:#ffffff0f;border:1px solid var(--color-border);color:#f1f5f9;font-weight:600;font-size:1rem;transition:all .25s ease}.btn-landing-secondary:hover{background:#ffffff1a;border-color:#fff3}.step-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}.landing-step-card{position:relative;padding:24px 20px;background:#11182799;border:1px solid var(--color-border);border-radius:20px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:all .3s ease}.landing-step-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px #0003}.step-num{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#000;flex-shrink:0}.model-card{padding:32px;border-radius:24px;display:flex;flex-direction:column;gap:16px;flex:1;border-width:1px;border-style:solid;transition:all .3s ease}.model-card:hover{transform:translateY(-4px) scale(1.01)}.feature-pill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.feature-pill{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffffff0a;border:1px solid var(--color-border);border-radius:12px;font-size:14px;color:var(--color-text-muted);transition:all .2s ease}@media (max-width: 1200px){.step-grid{grid-template-columns:repeat(3,1fr)!important}}.feature-pill:hover{background:#ffffff12;transform:translate(4px)}.cta-section{text-align:center;padding:64px 40px;background:linear-gradient(135deg,#f9731614,#a78bfa0f);border:1px solid rgba(249,115,22,.15);border-radius:var(--radius-xl);margin-top:40px}@media (max-width: 1024px){.main-content{padding:24px 20px 80px;max-width:100%}}@media (max-width: 768px){.navbar{margin:8px 12px;padding:8px 12px;gap:8px;height:auto;min-height:60px;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.navbar.glass-effect:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-radius:inherit;border:1px solid var(--glass-border)}.navbar-brand .brand-name{display:none}.navbar-links{position:fixed!important;bottom:20px!important;left:12px!important;right:12px!important;z-index:9999!important;margin:0;padding:8px;justify-content:flex-start;background:#0a0f1ef2!important;backdrop-filter:blur(28px)!important;-webkit-backdrop-filter:blur(28px)!important;border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 48px #000c;border-radius:20px;overflow-x:auto;scrollbar-width:none;gap:2px}.navbar-links::-webkit-scrollbar{display:none}.nav-link{flex:0 0 auto;flex-direction:column;gap:4px;padding:8px 12px;font-size:.65rem;color:var(--color-text-dim);min-width:58px}.nav-link svg{width:22px;height:22px}.nav-link span{display:block}.nav-link.active{background:transparent;color:var(--color-primary);box-shadow:none}.navbar-auth{flex:0 0 auto;justify-content:flex-end}.user-name{display:none}.user-pill{padding:4px;border-radius:50%}.hero-title{font-size:2.2rem!important;margin-bottom:20px!important}.hero-subtitle-line{font-size:1.25rem!important;margin-bottom:24px!important}.step-grid,.feature-pill-grid{grid-template-columns:1fr!important}.ai-model-card{flex-direction:column!important}.search-bar{flex-direction:column;padding:16px;gap:16px}.search-input{width:100%;text-align:center}.search-actions,.search-actions .btn-primary{width:100%;justify-content:center}.preferences-bar{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:16px;border-radius:var(--radius-md)}.pref-item{width:100%;min-width:0;align-items:stretch;border-bottom:none!important;padding-bottom:0!important}}@media (max-width: 480px){.navbar-brand .brand-name{display:none}.preferences-bar{grid-template-columns:1fr;gap:16px}.pref-item--privacy{width:100%;flex-direction:column!important;align-items:stretch!important;gap:8px!important}.result-actions{flex-direction:column}.result-actions .btn-primary,.result-actions .btn-ghost{width:100%;justify-content:center}.result-header{padding:24px 16px}.vault-cards{grid-template-columns:1fr!important}.hero-title{font-size:1.85rem!important;margin-bottom:16px!important}.hero-subtitle-line{font-size:1.15rem!important;margin-bottom:20px!important}.filter-item{width:100%}.filter-select-wrap{min-width:100%}}@media (max-width: 600px){.modal-box{width:95%;padding:24px 16px;max-height:90vh}.tokens-exhausted-modal{padding:32px 20px}}@media (max-width: 768px){.community-feed,.community-loading{grid-template-columns:1fr!important}.vault-header,.community-header{flex-direction:column;align-items:flex-start;gap:20px}.vault-header>div,.community-header>div{width:100%}.vault-header div:last-child{justify-content:flex-start}.vault-search,.community-search{max-width:100%}.detail-nav{flex-direction:column;gap:16px;align-items:flex-start}.detail-nav-actions{width:100%;flex-wrap:wrap;justify-content:flex-start;gap:8px}.detail-nav-actions .btn-ghost{flex:1;min-width:calc(50% - 8px);justify-content:center}.detail-hero{flex-direction:column;padding:0;overflow:hidden}.detail-hero-image{height:240px;width:100%}.detail-hero-inner{padding:24px 20px}.detail-stats-row{grid-template-columns:repeat(2,1fr)!important;display:grid!important;gap:16px;border:none}.detail-stat-divider{display:none}.detail-stat{border-right:none;padding:0}.detail-body{grid-template-columns:1fr!important;gap:20px}.chef-thinking-overlay .thinking-card{padding:32px 24px}.save-progress-overlay .save-progress-card{padding:32px 20px}.cook-topbar{padding:8px 12px}.cook-topbar-center .step-counter{font-size:.8rem}.cook-topbar-actions{gap:4px}.cook-nav{padding:0 16px;bottom:80px}.cook-nav-next{flex:1}.voice-commands-grid{grid-template-columns:1fr 1fr;display:grid}.floating-feedback-btn{bottom:90px;right:16px;width:44px;height:44px}.floating-feedback-btn .tooltip{display:none}}@media (max-width: 480px){.detail-nav-actions .btn-ghost{width:100%;min-width:100%}.detail-stats-row{grid-template-columns:1fr!important}.cook-main .step-text{font-size:1.25rem!important}.voice-commands-grid{grid-template-columns:1fr}}@media (max-width: 640px){.auth-card{padding:40px 24px;width:100%;border-radius:0;min-height:100vh;display:flex;flex-direction:column;justify-content:center}.auth-page{padding:0}.tab-container{width:100%;flex-direction:column;border-radius:24px;padding:12px}.tab-container button{width:100%;justify-content:flex-start}.support-page .grid{grid-template-columns:1fr!important}.blog-page>div:nth-child(2){grid-template-columns:1fr!important}.blog-page h1{font-size:2.2rem!important}.footer-bottom{flex-direction:column;gap:16px;text-align:center}.social-links{justify-content:center}.modal-box{width:100%;height:100%;border-radius:0;max-height:100%}}.privacy-toggle{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff0d;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;color:var(--color-text-main);transition:all .2s ease;cursor:pointer;height:38px}.privacy-toggle--public{background:#22c55e1a;border-color:#22c55e4d;color:#4ade80}.privacy-toggle--private{background:#f973161a;border-color:#f973164d;color:var(--color-primary)}.privacy-toggle:hover{transform:translateY(-1px);filter:brightness(1.1);box-shadow:0 4px 12px #0003}.pref-item--privacy{min-width:140px}@media (max-width: 768px){.pref-item--privacy{width:100%;justify-content:space-between;flex-direction:row;align-items:center}}.privacy-toggle-pill{display:flex;align-items:center;gap:8px;padding:6px 14px!important;border-radius:100px!important;font-size:.85rem!important;transition:all .3s var(--ease-spring);border-width:1.5px!important}.privacy-toggle-pill.public{background:#22c55e14!important;border-color:#22c55e40!important;color:#4ade80!important}.privacy-toggle-pill.private{background:#38bdf814!important;border-color:#38bdf840!important;color:#38bdf8!important}.privacy-toggle-pill:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #00000040;filter:brightness(1.1)}.privacy-badge-detail{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:100px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.privacy-badge-detail.public{background:#22c55e1a;border:1px solid rgba(34,197,94,.25);color:#4ade80}.privacy-badge-detail.private{background:#f973161a;border:1px solid rgba(249,115,22,.25);color:var(--color-primary)}.animate-spin{animation:spin 1s linear infinite}
