@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap";
@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.0-dom-5bn10r2.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.1y4-pdgsjb-pw.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.3lvt2whj97whp.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.2uwcyprjm3xu3.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.0k62hbripvv8p.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.3-6t-g6q0vh0a.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.2bn3s6zvc0dyp.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_ed4bac32-module__-2Pd1W__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_ed4bac32-module__-2Pd1W__variable{--font-body:"Inter", "Inter Fallback"}
@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.1spbknb88wd48.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.1gsd1jahc5dg_.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit Fallback;src:local(Arial);ascent-override:100.18%;descent-override:26.05%;line-gap-override:0.0%;size-adjust:99.82%}.outfit_38930724-module__T9SkzW__className{font-family:Outfit,Outfit Fallback;font-style:normal}.outfit_38930724-module__T9SkzW__variable{--font-display:"Outfit", "Outfit Fallback"}
*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#0f0f1a;--color-bg-gradient:linear-gradient(135deg, #0f0f1a 0%, #1a1a2e 50%, #16213e 100%);--color-surface:#1a1a2e;--color-surface-hover:#1e1e36;--color-surface-elevated:#0f3460;--color-surface-glass:#1a1a2eb3;--color-border:#ffffff14;--color-border-hover:#ffffff26;--color-primary:#e94560;--color-primary-hover:#ff5a76;--color-primary-subtle:#e945601f;--color-secondary:#f5a623;--color-secondary-hover:#ffb940;--color-secondary-subtle:#f5a6231f;--color-accent:#53d8fb;--color-accent-hover:#72e1fc;--color-accent-subtle:#53d8fb1f;--color-success:#2ecc71;--color-success-subtle:#2ecc711f;--color-warning:#f5a623;--color-warning-subtle:#f5a6231f;--color-error:#e94560;--color-error-subtle:#e945601f;--color-info:#53d8fb;--color-info-subtle:#53d8fb1f;--color-text:#f8f8f2;--color-text-secondary:#a0a0b8;--color-text-muted:#6b6b80;--color-text-inverse:#0f0f1a;--note-yellow:#fff3cd;--note-pink:#ffd6e0;--note-blue:#d0e8ff;--note-green:#d4edda;--note-text:#2d2d3a;--font-display:"Outfit", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--leading-tight:1.1;--leading-snug:1.3;--leading-normal:1.5;--leading-relaxed:1.7;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:.375rem;--radius-md:.625rem;--radius-lg:1rem;--radius-xl:1.25rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-xl:0 16px 48px #0009;--shadow-glow-primary:0 0 20px #e945604d;--shadow-glow-secondary:0 0 20px #f5a6234d;--shadow-glow-accent:0 0 20px #53d8fb4d;--glass-bg:#1a1a2e99;--glass-border:#ffffff14;--glass-blur:blur(20px);--glass-saturate:saturate(180%);--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--z-base:0;--z-above:10;--z-dropdown:100;--z-sticky:200;--z-overlay:300;--z-modal:400;--z-toast:500;--sidebar-width:280px;--sidebar-width-collapsed:72px;--header-height:64px;--mobile-nav-height:64px}[data-theme=light]{--color-bg:#f5f3ef;--color-bg-gradient:linear-gradient(135deg, #f5f3ef 0%, #fff8f0 50%, #fbf4ec 100%);--color-surface:#fff;--color-surface-hover:#f8f6f2;--color-surface-elevated:#fff;--color-surface-glass:#ffffffb3;--color-border:#00000014;--color-border-hover:#00000026;--color-text:#1a1a2e;--color-text-secondary:#555568;--color-text-muted:#8888a0;--color-text-inverse:#f8f8f2;--glass-bg:#fff9;--glass-border:#0000000f;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 32px #0000001f;--shadow-xl:0 16px 48px #00000026}[data-choo-mode=true]{--color-primary:#d63384;--color-primary-hover:#fd7e14;--color-primary-subtle:#d633841f;--color-accent:#b197fc;--color-accent-hover:#d0bfff;--color-accent-subtle:#b197fc1f;--color-secondary:#e5a93b;--color-secondary-hover:#f0b85d;--color-secondary-subtle:#e5a93b1f;--color-error:#d63384;--color-error-subtle:#d633841f;--color-bg:#120e1e;--color-bg-gradient:linear-gradient(135deg, #120e1e 0%, #201026 50%, #150a26 100%);--color-surface:#1e172e;--color-surface-hover:#261d3a;--color-surface-elevated:#2d2245;--color-surface-glass:#1e172ebf;--color-border:#d6338433;--color-border-hover:#d6338459;--shadow-glow-primary:0 0 20px #d6338459}[data-theme=light][data-choo-mode=true]{--color-bg:#fff3f6;--color-bg-gradient:linear-gradient(135deg, #fff3f6 0%, #fff0f5 50%, #f5e3ec 100%);--color-surface:#fff;--color-surface-hover:#fff8fa;--color-surface-elevated:#fff;--color-surface-glass:#ffffffd9;--color-border:#d6338426;--color-border-hover:#d6338447;--color-text:#3d082a;--color-text-secondary:#7a4f6a;--color-text-muted:#a37f96;--color-primary:#d63384;--color-primary-hover:#fd7e14;--color-primary-subtle:#d633841f}@keyframes heartPulse{0%{transform:scale(1)}50%{transform:scale(1.12)}to{transform:scale(1)}}.choo-pulse{animation:1.2s ease-in-out infinite heartPulse;display:inline-block}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);font-weight:400;line-height:var(--leading-normal);color:var(--color-text);background:var(--color-bg);min-height:100vh;overflow-x:hidden}[dir=rtl] body{text-align:right}.bg-gradient{background:var(--color-bg-gradient);min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:var(--leading-tight);color:var(--color-text)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{color:var(--color-text-secondary);line-height:var(--leading-relaxed)}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}.glass{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur) var(--glass-saturate);border:1px solid var(--glass-border);border-radius:var(--radius-xl)}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur) var(--glass-saturate);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-6);transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base)}.glass-card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-border-hover);transform:translateY(-2px)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-body);font-size:var(--text-sm);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;font-weight:600;line-height:1;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:before{content:"";opacity:0;transition:opacity var(--transition-fast);background:linear-gradient(135deg,#ffffff26,#0000);position:absolute;inset:0}.btn:hover:before{opacity:1}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #e945604d}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-glow-primary)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover)}.btn-ghost{color:var(--color-text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--color-surface);color:var(--color-text)}.btn-danger{background:var(--color-error);color:#fff;box-shadow:0 2px 8px #e945604d}.btn-danger:hover{box-shadow:var(--shadow-glow-primary);background:#ff5a76}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs);border-radius:var(--radius-md)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base);border-radius:var(--radius-xl)}.btn-icon{padding:var(--space-3);aspect-ratio:1;border-radius:var(--radius-lg)}.input-group{gap:var(--space-2);flex-direction:column;display:flex;position:relative}.input-label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:500}.input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base);outline:none}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.input::placeholder{color:var(--color-text-muted)}.input-error{border-color:var(--color-error)}.input-error:focus{box-shadow:0 0 0 3px var(--color-error-subtle)}.textarea{resize:vertical;min-height:100px}.select{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='%23A0A0B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:40px}[dir=rtl] .select{padding-right:var(--space-4);background-position:12px;padding-left:40px}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-full);white-space:nowrap;font-weight:600;display:inline-flex}.badge-primary{background:var(--color-primary-subtle);color:var(--color-primary)}.badge-secondary{background:var(--color-secondary-subtle);color:var(--color-secondary)}.badge-success{background:var(--color-success-subtle);color:var(--color-success)}.badge-warning{background:var(--color-warning-subtle);color:var(--color-warning)}.badge-error{background:var(--color-error-subtle);color:var(--color-error)}.badge-info{background:var(--color-info-subtle);color:var(--color-info)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:var(--z-modal);padding:var(--space-4);background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);padding:var(--space-8);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-xl);animation:.3s cubic-bezier(.34,1.56,.64,1) slideUp;overflow-y:auto}.modal-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.modal-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700}.modal-footer{gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border);justify-content:flex-end;display:flex}[dir=rtl] .modal-footer{justify-content:flex-start}.sticky-note{padding:var(--space-5);border-radius:var(--radius-sm);min-height:120px;transition:transform var(--transition-base), box-shadow var(--transition-base);color:var(--note-text);font-size:var(--text-sm);line-height:var(--leading-relaxed);position:relative;overflow:hidden;box-shadow:2px 3px 12px #00000026,inset 0 -2px 4px #0000000d}.sticky-note:before{content:"";top:0;background:#0000000f;width:100%;height:4px;position:absolute;inset-inline-start:0}.sticky-note:hover{z-index:2;box-shadow:4px 6px 20px #0003;transform:scale(1.03)rotate(0)!important}.sticky-note-actions{top:var(--space-2);gap:var(--space-1);opacity:0;transition:opacity var(--transition-fast);display:flex;position:absolute;inset-inline-end:var(--space-2)}.sticky-note:hover .sticky-note-actions{opacity:1}.sticky-note-btn{border-radius:var(--radius-sm);padding:var(--space-1);cursor:pointer;color:var(--note-text);transition:background var(--transition-fast);background:#00000014;border:none;justify-content:center;align-items:center;display:flex}.sticky-note-btn:hover{background:#00000026}.recipe-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);cursor:pointer;transition:transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);overflow:hidden}.recipe-card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-border-hover);transform:translateY(-4px)}.recipe-card-image{aspect-ratio:16/10;object-fit:cover;background:var(--color-surface);width:100%}.recipe-card-image-placeholder{aspect-ratio:16/10;width:100%;font-size:var(--text-4xl);background:linear-gradient(135deg, var(--color-surface), var(--color-surface-elevated));justify-content:center;align-items:center;display:flex}.recipe-card-body{padding:var(--space-4)}.recipe-card-title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-weight:600;display:-webkit-box;overflow:hidden}.recipe-card-meta{align-items:center;gap:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-3);display:flex}.recipe-card-meta-item{align-items:center;gap:var(--space-1);display:flex}.recipe-card-favorite{top:var(--space-3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);padding:var(--space-2);cursor:pointer;color:#fff;transition:all var(--transition-fast);z-index:2;background:#0006;border:none;justify-content:center;align-items:center;display:flex;position:absolute;inset-inline-end:var(--space-3)}.recipe-card-favorite:hover{background:#0009;transform:scale(1.1)}.recipe-card-favorite.active{color:var(--color-primary)}.category-card{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:start;background:0 0;border:1px solid #0000;width:100%;font-family:inherit;display:flex;position:relative}.category-card:hover{background:var(--color-surface-hover)}.category-card.active{background:var(--color-primary-subtle);border-color:var(--color-primary)}.category-card-icon{border-radius:var(--radius-md);width:36px;height:36px;font-size:var(--text-lg);flex-shrink:0;justify-content:center;align-items:center;display:flex}.category-card-name{font-size:var(--text-sm);color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.category-card-count{font-size:var(--text-xs);color:var(--color-text-muted);background:var(--color-surface);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);text-align:center;min-width:24px}.dashboard-layout{background:var(--color-bg-gradient);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-inline-end:1px solid var(--color-border);top:0;bottom:0;z-index:var(--z-sticky);transition:transform var(--transition-base);flex-direction:column;display:flex;position:fixed;inset-inline-start:0;overflow-y:auto}.sidebar-header{padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--color-border);align-items:center;gap:var(--space-3);display:flex}.sidebar-logo{font-family:var(--font-display);font-size:var(--text-xl);background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.sidebar-section{padding:var(--space-4) var(--space-3)}.sidebar-section-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);padding:0 var(--space-3) var(--space-2);font-weight:600}.sidebar-nav{gap:var(--space-1);flex-direction:column;list-style:none;display:flex}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid var(--color-border);margin-top:auto}.main-content{flex:1;min-height:100vh;margin-inline-start:var(--sidebar-width)}.dashboard-header{z-index:var(--z-sticky);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--color-border);padding:0 var(--space-6);height:var(--header-height);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex;position:sticky;top:0}.dashboard-body{padding:var(--space-6)}.search-bar{flex:1;max-width:480px;position:relative}.search-bar-icon{top:50%;color:var(--color-text-muted);pointer-events:none;position:absolute;inset-inline-start:var(--space-4);transform:translateY(-50%)}.search-bar .input{padding-inline-start:var(--space-10)}.recipe-grid{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.note-board{gap:var(--space-4);margin-top:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.color-picker-grid{gap:var(--space-2);grid-template-columns:repeat(5,1fr);display:grid}.color-swatch{border-radius:var(--radius-md);cursor:pointer;width:36px;height:36px;transition:all var(--transition-fast);border:2px solid #0000}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{border-color:var(--color-text);box-shadow:0 0 0 2px var(--color-bg), 0 0 0 4px var(--color-text)}.emoji-picker-grid{gap:var(--space-1);grid-template-columns:repeat(9,1fr);display:grid}.emoji-btn{padding:var(--space-2);font-size:var(--text-xl);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:2px solid #0000;justify-content:center;align-items:center;display:flex}.emoji-btn:hover{background:var(--color-surface-hover)}.emoji-btn.active{background:var(--color-primary-subtle);border-color:var(--color-primary)}.recipe-detail-hero{aspect-ratio:21/9;object-fit:cover;border-radius:var(--radius-xl);width:100%;margin-bottom:var(--space-6)}.recipe-detail-hero-placeholder{aspect-ratio:21/9;border-radius:var(--radius-xl);width:100%;margin-bottom:var(--space-6);background:linear-gradient(135deg, var(--color-surface), var(--color-surface-elevated));justify-content:center;align-items:center;font-size:5rem;display:flex}.recipe-meta-strip{gap:var(--space-6);padding:var(--space-5) 0;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.recipe-meta-item{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);display:flex}.recipe-meta-item svg{color:var(--color-primary)}.recipe-sections{gap:var(--space-8);margin-bottom:var(--space-8);grid-template-columns:1fr 1fr;display:grid}.recipe-section-title{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-4);align-items:center;gap:var(--space-2);font-weight:700;display:flex}.ingredient-list{gap:var(--space-2);flex-direction:column;list-style:none;display:flex}.ingredient-item{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer;display:flex}.ingredient-item:hover{background:var(--color-surface-hover)}.ingredient-checkbox{border:2px solid var(--color-border-hover);border-radius:var(--radius-sm);width:20px;height:20px;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.ingredient-item.checked .ingredient-checkbox{background:var(--color-primary);border-color:var(--color-primary)}.ingredient-item.checked span{color:var(--color-text-muted);text-decoration:line-through}.instruction-list{gap:var(--space-4);flex-direction:column;list-style:none;display:flex}.instruction-item{gap:var(--space-4);display:flex}.instruction-number{border-radius:var(--radius-full);background:var(--color-primary);color:#fff;width:32px;height:32px;font-size:var(--text-sm);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.instruction-text{font-size:var(--text-base);color:var(--color-text-secondary);line-height:var(--leading-relaxed);padding-top:var(--space-1)}.auth-page{background:var(--color-bg-gradient);min-height:100vh;padding:var(--space-4);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-page:before{content:"";background:radial-gradient(circle, var(--color-primary-subtle), transparent 70%);top:-200px;border-radius:50%;width:600px;height:600px;animation:8s ease-in-out infinite float;position:absolute;inset-inline-end:-200px}.auth-page:after{content:"";background:radial-gradient(circle, var(--color-accent-subtle), transparent 70%);bottom:-100px;border-radius:50%;width:400px;height:400px;animation:10s ease-in-out infinite reverse float;position:absolute;inset-inline-start:-100px}.auth-card{z-index:1;width:100%;max-width:440px}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-logo{font-family:var(--font-display);font-size:var(--text-3xl);background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));-webkit-text-fill-color:transparent;margin-bottom:var(--space-3);-webkit-background-clip:text;background-clip:text;font-weight:800}.auth-title{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.auth-subtitle{color:var(--color-text-secondary);font-size:var(--text-sm)}.auth-form{gap:var(--space-5);flex-direction:column;display:flex}.auth-divider{align-items:center;gap:var(--space-4);color:var(--color-text-muted);font-size:var(--text-sm);display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.google-btn{justify-content:center;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-6);color:#333;border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-base);background:#fff;font-weight:600;display:flex}.google-btn:hover{box-shadow:var(--shadow-md);background:#f8f8f8}.auth-footer{text-align:center;margin-top:var(--space-6);font-size:var(--text-sm);color:var(--color-text-secondary)}.auth-link{color:var(--color-primary);cursor:pointer;font-weight:600}.toast-container{top:var(--space-4);z-index:var(--z-toast);gap:var(--space-2);pointer-events:none;flex-direction:column;display:flex;position:fixed;inset-inline-end:var(--space-4)}.toast{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);pointer-events:auto;min-width:300px;max-width:420px;animation:.3s cubic-bezier(.34,1.56,.64,1) slideInRight;display:flex}.toast-success{border-inline-start:3px solid var(--color-success)}.toast-error{border-inline-start:3px solid var(--color-error)}.toast-warning{border-inline-start:3px solid var(--color-warning)}.toast-info{border-inline-start:3px solid var(--color-info)}.toast-message{font-size:var(--text-sm);color:var(--color-text);flex:1}.toast-close{color:var(--color-text-muted);cursor:pointer;padding:var(--space-1);background:0 0;border:none;display:flex}.empty-state{text-align:center;padding:var(--space-16) var(--space-4);justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;display:flex}.empty-state-icon{opacity:.5;font-size:4rem;animation:4s ease-in-out infinite float}.empty-state-title{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-text);font-weight:600}.empty-state-text{font-size:var(--text-sm);color:var(--color-text-muted);max-width:300px}.skeleton{background:linear-gradient(90deg, var(--color-surface) 25%, var(--color-surface-hover) 50%, var(--color-surface) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite skeleton-shimmer}.skeleton-text{width:80%;height:1em}.skeleton-title{width:60%;height:1.5em}.skeleton-card{border-radius:var(--radius-xl);height:260px}.skeleton-avatar{border-radius:var(--radius-full);width:40px;height:40px}.landing-hero{text-align:center;min-height:100vh;padding:var(--space-8);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.landing-hero:before{content:"";background:radial-gradient(circle,#e9456014,#0000 70%);border-radius:50%;width:800px;height:800px;animation:12s ease-in-out infinite float;position:absolute;top:-300px;right:-300px}.landing-hero:after{content:"";background:radial-gradient(circle,#53d8fb0f,#0000 70%);border-radius:50%;width:600px;height:600px;animation:15s ease-in-out infinite reverse float;position:absolute;bottom:-200px;left:-200px}.landing-hero-title{font-size:clamp(var(--text-4xl), 5vw, var(--text-6xl));font-weight:800;line-height:var(--leading-tight);margin-bottom:var(--space-6);z-index:1;max-width:700px}.landing-hero-title .gradient-text{background:linear-gradient(135deg, var(--color-primary), var(--color-secondary), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-hero-subtitle{font-size:var(--text-xl);color:var(--color-text-secondary);max-width:500px;margin-bottom:var(--space-10);z-index:1}.landing-features{gap:var(--space-6);max-width:900px;margin-top:var(--space-16);z-index:1;grid-template-columns:repeat(3,1fr);display:grid}.landing-feature-card{text-align:center;padding:var(--space-8)}.landing-feature-icon{margin-bottom:var(--space-4);font-size:2.5rem}.landing-feature-title{font-size:var(--text-lg);margin-bottom:var(--space-2);font-weight:600}.landing-feature-desc{font-size:var(--text-sm);color:var(--color-text-secondary)}.landing-nav{z-index:var(--z-sticky);padding:var(--space-4) var(--space-6);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.landing-nav-logo{font-family:var(--font-display);font-size:var(--text-xl);background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.landing-nav-actions{align-items:center;gap:var(--space-3);display:flex}.avatar{border-radius:var(--radius-full);width:36px;height:36px;font-size:var(--text-sm);color:#fff;background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.user-menu{position:relative}.user-menu-dropdown{top:calc(100% + var(--space-2));background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:200px;padding:var(--space-2);z-index:var(--z-dropdown);animation:.2s slideUp;position:absolute;inset-inline-end:0}.user-menu-item{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast);text-align:inherit;font-family:var(--font-body);background:0 0;border:none;display:flex}.user-menu-item:hover{background:var(--color-surface-hover)}.user-menu-divider{background:var(--color-border);height:1px;margin:var(--space-2) 0}.form-section{margin-bottom:var(--space-6)}.form-section-title{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:var(--space-4);align-items:center;gap:var(--space-2);font-weight:700;display:flex}.form-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.dynamic-list{gap:var(--space-2);flex-direction:column;display:flex}.dynamic-list-item{align-items:center;gap:var(--space-2);display:flex}.dynamic-list-item .input{flex:1}.dynamic-list-remove{color:var(--color-text-muted);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);transition:all var(--transition-fast);background:0 0;border:none;display:flex}.dynamic-list-remove:hover{background:var(--color-error-subtle);color:var(--color-error)}.image-upload{border:2px dashed var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);justify-content:center;align-items:center;gap:var(--space-3);cursor:pointer;transition:all var(--transition-base);flex-direction:column;display:flex;position:relative;overflow:hidden}.image-upload:hover{border-color:var(--color-primary);background:var(--color-primary-subtle)}.image-upload-preview{aspect-ratio:16/10;object-fit:cover;border-radius:var(--radius-lg);width:100%}.image-upload-icon{color:var(--color-text-muted)}.image-upload-text{font-size:var(--text-sm);color:var(--color-text-muted)}.image-upload input[type=file]{opacity:0;cursor:pointer;position:absolute;inset:0}.mobile-nav{height:var(--mobile-nav-height);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-top:1px solid var(--color-border);z-index:var(--z-sticky);padding:0 var(--space-4);display:none;position:fixed;bottom:0;left:0;right:0}.mobile-nav-list{justify-content:space-around;align-items:center;height:100%;list-style:none;display:flex}.mobile-nav-item{padding:var(--space-2);color:var(--color-text-muted);font-size:var(--text-xs);transition:color var(--transition-fast);cursor:pointer;flex-direction:column;align-items:center;gap:2px;text-decoration:none;display:flex}.mobile-nav-item.active,.mobile-nav-item:hover{color:var(--color-primary)}.filter-bar{align-items:flex-end;gap:var(--space-4);padding:var(--space-4);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);margin-bottom:var(--space-5);flex-wrap:wrap;animation:.3s slideDown;display:flex}.filter-group{gap:var(--space-2);flex-direction:column;min-width:0;display:flex}.filter-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:var(--space-1);font-weight:600;display:flex}.filter-select{padding:var(--space-2) var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);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='%23A0A0B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;outline:none;padding-right:28px}[dir=rtl] .filter-select{padding-right:var(--space-3);background-position:8px;padding-left:28px}.filter-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-subtle)}.filter-chips{gap:var(--space-1);flex-wrap:wrap;display:flex}.filter-chip{padding:var(--space-1) var(--space-3);font-family:var(--font-body);font-size:var(--text-xs);color:var(--color-text-secondary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:var(--space-1);white-space:nowrap;font-weight:500;display:flex}.filter-chip:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover)}.filter-chip.active{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary);font-weight:600}.filter-clear{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);font-family:var(--font-body);font-size:var(--text-xs);color:var(--color-error);background:var(--color-error-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;align-self:flex-end;margin-inline-start:auto;font-weight:500;display:flex}.filter-clear:hover{background:var(--color-error);color:#fff}.ingredient-input-container{gap:var(--space-2);flex-direction:column;display:flex}.ingredient-input-header{gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;padding:0 0 var(--space-1);border-bottom:1px solid var(--color-border);grid-template-columns:80px 130px 1fr 1fr 36px;font-weight:600;display:grid}.ingredient-input-row{gap:var(--space-2);padding:var(--space-1) 0;border-bottom:1px solid #ffffff08;grid-template-columns:80px 130px 1fr 1fr 36px;align-items:center;animation:.2s fadeIn;display:grid}.ingredient-input-row:last-of-type{border-bottom:none}.ingredient-input-qty{text-align:center;font-variant-numeric:tabular-nums}.ingredient-input-unit{appearance:none;font-size:var(--text-sm)!important;background-size:10px 10px!important}[dir=rtl] .ingredient-input-unit{padding-left:var(--space-6)!important;padding-right:var(--space-2)!important;background-position:8px!important}[dir=ltr] .ingredient-input-unit{padding-right:var(--space-6)!important;padding-left:var(--space-2)!important;background-position:right 8px center!important}.ingredient-input-note{font-style:italic;font-size:var(--text-sm)!important;color:var(--color-text-muted)!important}.ingredient-input-col-qty,.ingredient-input-col-unit,.ingredient-input-col-name,.ingredient-input-col-note,.ingredient-input-col-action{min-width:0}.serving-scaler{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-base);flex-wrap:wrap;display:flex}.serving-scaler.active{background:var(--color-secondary-subtle);border-color:var(--color-secondary)}.scaling-toggle{background:var(--color-surface-hover);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;width:36px;height:36px;transition:all var(--transition-fast);color:var(--color-text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex}.scaling-toggle:hover{border-color:var(--color-secondary);color:var(--color-secondary)}.scaling-toggle.on{background:var(--color-secondary);border-color:var(--color-secondary);color:#fff;box-shadow:0 0 12px #f5a6234d}.serving-controls{align-items:center;gap:var(--space-2);display:flex}.serving-btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);color:var(--color-text);justify-content:center;align-items:center;display:flex}.serving-btn:hover:not(:disabled){background:var(--color-primary);border-color:var(--color-primary);color:#fff;transform:scale(1.1)}.serving-btn:disabled{opacity:.3;cursor:not-allowed}.serving-count{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-text);text-align:center;min-width:32px;transition:all var(--transition-fast);font-weight:700}.serving-count.adjusted{color:var(--color-secondary);text-shadow:0 0 8px #f5a6234d}.serving-reset{border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;width:28px;height:28px;color:var(--color-text-muted);transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.serving-reset:hover{color:var(--color-primary);border-color:var(--color-primary)}.serving-label{font-size:var(--text-xs);color:var(--color-secondary);background:var(--color-secondary-subtle);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-weight:600;animation:.3s fadeIn}.ingredient-scaled{position:relative}.ingredient-scaled:after{content:"";inset-inline-start:0;background:var(--color-secondary);border-radius:var(--radius-full);width:3px;animation:.3s fadeIn;position:absolute;top:0;bottom:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}[dir=rtl] .toast{animation-name:slideInLeft}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:.3s fadeIn}.animate-slide-up{animation:.4s cubic-bezier(.34,1.56,.64,1) slideUp}.animate-scale-in{animation:.3s cubic-bezier(.34,1.56,.64,1) scaleIn}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.flex-1{flex:1}.text-center{text-align:center}.w-full{width:100%}.relative{position:relative}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner-lg{border-width:3px;width:40px;height:40px}.loading-screen{justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;min-height:100vh;display:flex}@media (max-width:1024px){.recipe-grid{grid-template-columns:repeat(2,1fr)}.recipe-sections{grid-template-columns:1fr}.landing-features{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){:root{--sidebar-width:100%}.sidebar{transform:translate(-100%);z-index:500!important}[dir=rtl] .sidebar{transform:translate(100%)}.sidebar.open{transform:translate(0)}.main-content{padding-bottom:var(--mobile-nav-height);margin-inline-start:0}.mobile-nav{display:block}.recipe-grid,.note-board,.form-row{grid-template-columns:1fr}.recipe-detail-hero,.recipe-detail-hero-placeholder{aspect-ratio:16/9;border-radius:var(--radius-lg)}.landing-features{gap:var(--space-4);grid-template-columns:1fr}.landing-nav{padding:var(--space-3) var(--space-4)!important}.landing-nav-actions{gap:var(--space-2)!important}.landing-hero-title{font-size:var(--text-3xl)}.landing-hero-subtitle{font-size:var(--text-base)}.dashboard-body{padding:var(--space-4)}.modal-content{padding:var(--space-5);margin:var(--space-3)}.filter-bar{align-items:stretch;gap:var(--space-3);flex-direction:column}.filter-clear{justify-content:center;align-self:stretch;margin-inline-start:0}.ingredient-input-header,.ingredient-input-row{grid-template-columns:60px 100px 1fr 36px}.ingredient-input-col-note{display:none}.serving-scaler{flex-direction:column;align-items:flex-start}}@media (max-width:480px){.recipe-card-meta{gap:var(--space-2)}.recipe-meta-strip{gap:var(--space-3)}.emoji-picker-grid{grid-template-columns:repeat(7,1fr)}.landing-nav-logo{display:none!important}.landing-nav-actions{justify-content:flex-end;width:100%;gap:6px!important}.landing-nav-actions .btn{padding:var(--space-2) var(--space-3)!important;font-size:var(--text-xs)!important}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}::selection{background:var(--color-primary);color:#fff}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media print{.sidebar,.dashboard-header,.mobile-nav,.toast-container{display:none!important}.main-content{margin:0!important}}
