@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/224e262ef877bfa4-s.753dfc0d.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:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/7f11d98043fdedc9-s.317fa95e.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/e6d00ff86ef9e699-s.51ae28b9.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:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/d8cb5ab3660140cd-s.3379eac0.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:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/07454f8ad8aaac57-s.p.fc65572f.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:Nunito Fallback;src:local(Arial);ascent-override:99.71%;descent-override:34.82%;line-gap-override:0.0%;size-adjust:101.39%}.nunito_22336911-module__FLPYxG__className{font-family:Nunito,Nunito Fallback;font-style:normal}.nunito_22336911-module__FLPYxG__variable{--font-nunito:"Nunito","Nunito Fallback"}
@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/65c558afe41e89d6-s.e2c8389a.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/14e23f9b59180572-s.9c448f3c.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:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/b49b0d9b851e4899-s.4f3fa681.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:Playfair Display;font-style:normal;font-weight:400 900;font-display:swap;src:url(../media/2a65768255d6b625-s.p.d19752fb.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:Playfair Display Fallback;src:local(Times New Roman);ascent-override:97.25%;descent-override:22.56%;line-gap-override:0.0%;size-adjust:111.26%}.playfair_display_fa003182-module__E_H7JW__className{font-family:Playfair Display,Playfair Display Fallback;font-style:normal}.playfair_display_fa003182-module__E_H7JW__variable{--font-playfair:"Playfair Display","Playfair Display Fallback"}
@font-face{font-family:Dancing Script;font-style:normal;font-weight:400 700;font-display:swap;src:url(../media/32fe63294b6cd18c-s.7f335ffb.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:Dancing Script;font-style:normal;font-weight:400 700;font-display:swap;src:url(../media/73091b67359a1d13-s.48aa4bab.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:Dancing Script;font-style:normal;font-weight:400 700;font-display:swap;src:url(../media/406d3fc8d5ec9f59-s.p.3f4cab70.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:Dancing Script Fallback;src:local(Arial);ascent-override:112.99%;descent-override:34.39%;line-gap-override:0.0%;size-adjust:81.43%}.dancing_script_f251a9e9-module__rJHZDa__className{font-family:Dancing Script,Dancing Script Fallback;font-style:normal}.dancing_script_f251a9e9-module__rJHZDa__variable{--font-dancing:"Dancing Script","Dancing Script Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--ease-in-out:cubic-bezier(.4,0,.2,1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-20{top:calc(var(--spacing)*20)}.isolate{isolation:isolate}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.\[file\:line\]{file:line}.\[hook\:advisory\]{hook:advisory}}:root{--color-primary:#f2b8c6;--color-primary-deep:#ce9ca8;--color-primary-light:var(--color-primary-light);--color-primary-soft:var(--color-primary-soft);--color-primary-shadow:242,184,198;--color-on-primary:#3a2a1a;--color-secondary:#a67b5b;--color-accent:#a8bfa0;--color-accent-soft:#c5d9be;--color-background:#fff8f0;--color-text:#4a3728;--color-surface:#fffdfb;--color-surface-warm:#fff9f5;--color-border:#ebd8c8;--color-border-soft:#f0e2d8;--shadow-soft:0 20px 40px #4a372814;--shadow-card:0 4px 20px #4a37280f,0 1px 3px rgba(var(--color-primary-shadow),.15);--shadow-card-hover:0 12px 32px #4a37281a,0 2px 8px rgba(var(--color-primary-shadow),.2);--transition-snappy:.22s ease-out;--transition-smooth:.3s ease-out}[data-theme=dark]{--color-on-primary:#fff;--color-secondary:#c4b0a0;--color-accent:#8a9e82;--color-accent-soft:#5a6e52;--color-background:#141420;--color-text:#e8e0d8;--color-surface:#1e1e30;--color-surface-warm:#242436;--color-border:#35354a;--color-border-soft:#2e2e42;--shadow-soft:0 20px 40px #0006;--shadow-card:0 4px 20px #0000004d,0 1px 3px #0003;--shadow-card-hover:0 12px 32px #0006,0 2px 8px rgba(var(--color-primary-shadow),.15)}[data-theme=dark] .main-column{background:var(--color-background)!important}[data-theme=dark] .sidebar{background:#191928}[data-theme=dark] .topbar{border-color:var(--color-border);background:#191928f5!important}[data-theme=dark] .mobile-tab-bar{border-color:var(--color-border)!important;background:linear-gradient(#191928fa 0%,#141420fc 100%)!important}[data-theme=dark] .mobile-tab{opacity:.85;color:#c4bab0!important}[data-theme=dark] .mobile-tab.active{background:rgba(var(--color-primary-shadow),.15);opacity:1;color:var(--color-primary)!important}[data-theme=dark] .recipe-card,[data-theme=dark] .category-card,[data-theme=dark] .stat-card,[data-theme=dark] .nutrition-card,[data-theme=dark] .love-letter{box-shadow:var(--shadow-card);background:var(--color-surface)!important;border-color:var(--color-border)!important}[data-theme=dark] .recipe-category-chip{background:var(--color-surface-warm)!important;border-color:var(--color-border)!important}[data-theme=dark] .empty-state{border-color:var(--color-border);background:var(--color-surface)!important}[data-theme=dark] .form-input,[data-theme=dark] .form-select,[data-theme=dark] .form-textarea,[data-theme=dark] .quiz-question input,[data-theme=dark] .topbar input,[data-theme=dark] .quiz-single-input,[data-theme=dark] .chat-input{background:var(--color-surface)!important;border-color:var(--color-border)!important;color:var(--color-text)!important}[data-theme=dark] .btn-secondary{border-color:var(--color-border);color:var(--color-text);background:var(--color-surface)!important}[data-theme=dark] .btn-secondary:hover{background:var(--color-surface-warm)!important}[data-theme=dark] .form-fieldset{background:var(--color-surface)!important;border-color:var(--color-border)!important}[data-theme=dark] .tag-filter-chip{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}[data-theme=dark] .tag-filter-chip:hover{background:var(--color-surface-warm)}[data-theme=dark] .tag-filter-chip.active{color:var(--color-on-primary)}[data-theme=dark] .chat-bubble-assistant{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}[data-theme=dark] .error-text{color:#f08080!important;background:#2a1a1a!important;border-color:#6b3030!important}[data-theme=dark] .loading-state{background:var(--color-background);color:var(--color-text)}[data-theme=dark] .mobile-search-overlay{background:#0a0a12e6}[data-theme=dark] .theme-card,[data-theme=dark] .color-swatch-btn{border-color:var(--color-border)}[data-theme=dark] .settings-page,[data-theme=dark] .dashboard-section,[data-theme=dark] .content{color:var(--color-text)}[data-theme=dark] .auth-screen{color:#4a3728;background:#f2b8c6}[data-theme=dark] .auth-screen .auth-card,[data-theme=dark] .auth-screen .quiz-card{color:#4a3728!important;background:#fffdfb!important;border-color:#ebd8c8!important}[data-theme=dark] .auth-screen input{color:#4a3728!important;background:#fff!important;border-color:#ebd8c8!important}[data-theme=dark] .birthday-scene,[data-theme=dark] .birthday-screen,[data-theme=dark] .love-letter-screen{color:#4a3728!important;background:#f2b8c6!important}[data-theme=dark] .love-letter{color:#5a4133!important;background:linear-gradient(168deg,#fffaf3,#fff5eb,#fef9f4)!important;border-color:#e2cdb8!important}*,:hover,:focus{box-sizing:border-box;cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath d='M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z' fill='%23e03c3c'/%3E%3C/svg%3E") 6 6,auto!important}body{background:var(--color-background);color:var(--color-text);font-family:var(--font-nunito),sans-serif;height:100vh;margin:0;transition:background .4s,color .4s;overflow:hidden}h1,h2,h3{font-family:var(--font-playfair),serif;margin:0}p{margin:0}.eyebrow{color:#000;letter-spacing:.08em;text-align:center;text-transform:uppercase;font-size:.76rem;font-weight:800}.auth-screen{background:var(--color-primary);justify-content:center;align-items:center;height:100vh;padding:1.5rem;display:flex;overflow:hidden}.auth-screen .quiz-card{transform:translateY(-15%)}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-soft);border-radius:1.25rem;flex-direction:column;gap:.75rem;width:100%;max-width:720px;padding:2rem;display:flex}.auth-card h1{font-size:clamp(1.85rem,2.6vw,2.75rem)}.subcopy{color:#745744}.quiz-form{gap:1rem;margin-top:.75rem;display:grid}.quiz-question{gap:.5rem;display:grid}.quiz-question span{font-weight:700}.quiz-question input,.topbar input{border:1px solid var(--color-border);color:var(--color-text);font:inherit;background:#fff;border-radius:.8rem;min-height:2.6rem;padding:.65rem .8rem}.quiz-question small{color:#6f563f;font-size:.8rem}.quiz-remember-me{cursor:pointer;color:var(--color-text);align-items:center;gap:.5rem;font-size:.9rem;display:flex}.quiz-remember-me input{accent-color:var(--color-primary);cursor:pointer;width:1rem;height:1rem}.quiz-form button{color:#fff;cursor:pointer;font:inherit;background:#e03c3c;border:none;border-radius:0;min-height:2.7rem;padding:.65rem .9rem;font-weight:700}.topbar button,.logout-button{background:linear-gradient(120deg,var(--color-primary),var(--color-primary-deep));border:1px solid var(--color-primary-deep);color:var(--color-on-primary);cursor:pointer;font:inherit;border-radius:.8rem;min-height:2.7rem;padding:.65rem .9rem;font-weight:700}@keyframes shake{0%,to{transform:translate(0)}15%{transform:translate(-7px)}30%{transform:translate(7px)}45%{transform:translate(-5px)}60%{transform:translate(5px)}75%{transform:translate(-3px)}90%{transform:translate(2px)}}@keyframes error-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.error-text{color:#e03c3c;background:#fff;border:1px solid #e03c3c;border-radius:0;padding:.75rem;font-size:.92rem;animation:.3s error-fade-in}.error-text.error-shake{animation:.5s ease-in-out shake}.quiz-card{box-shadow:none;text-align:center;background:0 0;border:none;gap:0;max-width:580px}.quiz-cat-photo{border-radius:1rem;width:100%;max-width:174px;margin:0 auto;display:block}.quiz-heart{color:#e03c3c;text-align:center;margin-top:-1rem;margin-bottom:.5rem;font-size:5rem;line-height:1}.quiz-progress{justify-content:center;gap:.5rem;margin-bottom:.25rem;display:flex}.quiz-dot{color:#000;opacity:.3;font-size:1rem;transition:color .3s,opacity .3s,transform .3s;display:inline-block}.quiz-dot-active{color:#e03c3c;opacity:1;transform:scale(1.35)}.quiz-dot-done{color:#e03c3c;opacity:1}.quiz-prompt{color:#000;letter-spacing:.08em;text-align:center;text-transform:uppercase;margin-top:10px;font-size:clamp(1rem,2vw,1.4rem);font-weight:800;line-height:1.25}.quiz-single-input{border:1px solid var(--color-border);color:var(--color-text);font:inherit;background:#fff;border-radius:0;width:100%;min-height:2.8rem;padding:.75rem .9rem;font-size:1.05rem}.quiz-hint{color:#6f563f;font-size:.82rem}@keyframes heart-center-pop{0%{opacity:1;transform:scale(.2)}55%{opacity:1;transform:scale(2.8)}to{opacity:0;transform:scale(5)}}@keyframes heart-particle-fly{0%{opacity:1;transform:translate(0)scale(1)}to{transform:translate(var(--tx),var(--ty))scale(.1);opacity:0}}.heart-splash-overlay{pointer-events:none;z-index:100;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.heart-splash-center{font-size:3.5rem;animation:.75s cubic-bezier(.22,.61,.36,1) forwards heart-center-pop;position:absolute}.heart-splash-particle{font-size:1.3rem;animation:.65s ease-out forwards heart-particle-fly;position:absolute}.loading-state{background:var(--color-background);color:var(--color-text);justify-content:center;align-items:center;min-height:100vh;display:flex}.app-shell{grid-template-columns:240px 1fr;gap:0;height:100vh;transition:grid-template-columns .25s;display:grid}.app-shell.sidebar-collapsed{grid-template-columns:56px 1fr}.sidebar{background:linear-gradient(180deg,var(--color-surface)0%,var(--color-surface-warm)100%);border-right:1px solid var(--color-border-soft);transition:padding var(--transition-smooth);flex-direction:column;justify-content:space-between;padding:1.25rem;display:flex;overflow:hidden;box-shadow:2px 0 16px #4a37280a}.sidebar-collapsed .sidebar{padding:1.25rem .6rem}.sidebar-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;display:flex}.sidebar-collapsed .sidebar-header{justify-content:center}.sidebar-top{min-width:0}.sidebar-label{color:var(--color-secondary);letter-spacing:.12em;text-transform:uppercase;font-size:.7rem;font-weight:800}.sidebar-title{white-space:nowrap;margin-top:.25rem;font-size:1.3rem}.sidebar-toggle{height:2rem;transition:background var(--transition-snappy),transform var(--transition-snappy);background:0 0;border:none;border-radius:.4rem;flex-shrink:0;justify-content:center;align-items:center;width:2rem;padding:0;display:flex}.sidebar-toggle:hover{background:linear-gradient(135deg,var(--color-primary-light)0%,var(--color-primary-soft)100%);transform:scale(1.05)}.hamburger-icon{background:#6f563f;width:14px;height:2px;display:block;position:relative}.hamburger-icon:before,.hamburger-icon:after{content:"";background:#6f563f;width:14px;height:2px;display:block;position:absolute;left:0}.hamburger-icon:before{top:-5px}.hamburger-icon:after{top:5px}.sidebar-nav{flex-direction:column;gap:.25rem;display:flex}.nav-link{color:#6f563f;text-overflow:ellipsis;transition:background var(--transition-snappy),color var(--transition-snappy),box-shadow var(--transition-snappy);white-space:nowrap;border-radius:.4rem;padding:.6rem .75rem;font-size:.92rem;font-weight:600;text-decoration:none;display:block;overflow:hidden}.sidebar-collapsed .nav-link{text-align:center;padding:.6rem;font-size:0}.nav-link.active{background:linear-gradient(135deg,var(--color-primary-soft)0%,var(--color-primary-soft)100%);box-shadow:inset 0 1px 2px rgba(var(--color-primary-shadow),.25);color:var(--color-text);font-weight:700}.nav-link:hover:not(.active){background:var(--color-primary-light);color:var(--color-text)}.nav-divider{border:none;border-top:1px solid var(--color-border);margin:.5rem 0}.logout-button{border:1px solid var(--color-border-soft);color:#6f563f;font:inherit;text-overflow:ellipsis;min-height:2.4rem;transition:background var(--transition-snappy),border-color var(--transition-snappy);white-space:nowrap;background:linear-gradient(#0000 0%,#fef0f380 100%);border-radius:.4rem;padding:.5rem .75rem;font-size:.85rem;font-weight:600;overflow:hidden}.logout-button:hover{background:linear-gradient(180deg,var(--color-primary-light)0%,var(--color-primary-soft)100%);border-color:var(--color-primary)}.main-column{background:linear-gradient(175deg,#fffbf8 0%,#fff8f2 50%,#fef6f0 100%);flex-direction:column;height:100vh;display:flex;position:relative;overflow:hidden}.topbar{background:linear-gradient(180deg,var(--color-surface)0%,var(--color-surface-warm)100%);border-bottom:1px solid var(--color-border-soft);align-items:center;gap:.75rem;padding:.65rem 1.25rem;display:flex;box-shadow:0 2px 12px #4a37280a}.topbar-brand{color:var(--color-text);text-decoration:none;display:none}.topbar-brand-line{font-family:var(--font-playfair),serif;font-size:1.05rem;font-weight:700;line-height:1;display:block}.app-shell-icon{width:100%;height:100%;display:block}.mobile-search-trigger{display:none}.mobile-search-overlay{z-index:1100;position:fixed;inset:0}.mobile-search-panel{background:var(--color-surface);border:1px solid var(--color-border-soft);box-shadow:var(--shadow-soft);border-radius:1rem;max-width:32rem;margin:0 auto;padding:1rem}.mobile-search-panel-header{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.85rem;display:flex}.mobile-search-title{font-size:1rem}.mobile-search-close{color:var(--color-secondary);cursor:pointer;font:inherit;background:0 0;border:none;font-size:.88rem;text-decoration:none}.mobile-search-close:hover{color:var(--color-text)}.mobile-search-wrapper .search-dropdown{margin-top:.5rem;position:static}.topbar input{background:var(--color-background);border:1px solid var(--color-border-soft);color:var(--color-text);font:inherit;min-height:2.2rem;transition:border-color var(--transition-snappy),box-shadow var(--transition-snappy);border-radius:.4rem;flex:1;padding:.45rem .75rem;font-size:.88rem}.topbar input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-shadow),.25);outline:none}.topbar button{background:linear-gradient(180deg,var(--color-primary)0%,var(--color-primary-deep)100%);box-shadow:0 2px 8px rgba(var(--color-primary-shadow),.35);color:var(--color-on-primary);font:inherit;min-height:2.2rem;transition:transform var(--transition-snappy),box-shadow var(--transition-snappy),opacity var(--transition-snappy);white-space:nowrap;border:none;border-radius:.4rem;padding:.45rem 1rem;font-size:.85rem;font-weight:700}.topbar button:hover{box-shadow:0 4px 14px rgba(var(--color-primary-shadow),.45);opacity:.95;transform:translateY(-1px)}.topbar .btn-primary.topbar-new-recipe{flex:none;justify-content:center;align-items:center;min-height:2.2rem;padding:.45rem 1rem;text-decoration:none;display:inline-flex}.content{flex-direction:column;flex:1;gap:1.5rem;min-height:0;padding:1.5rem;display:flex;position:relative;overflow:hidden auto}.hero-panel{background:linear-gradient(168deg,var(--color-surface)0%,var(--color-surface-warm)100%);border:1px solid var(--color-border-soft);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-snappy),transform var(--transition-snappy);border-radius:.5rem;padding:8px}.hero-panel:hover{box-shadow:var(--shadow-card-hover)}.hero-inner{border:2px solid var(--color-primary);box-shadow:inset 0 0 30px rgba(var(--color-primary-shadow),.12);border-radius:.35rem;justify-content:center;align-items:flex-start;min-height:233px;padding:.4rem 1.5rem 3rem;display:flex;position:relative}.hero-side{display:contents}.flower-scatter{position:absolute}.hero-center{text-align:center;z-index:1;flex-direction:column;align-items:center;gap:0;display:flex;position:relative}.hero-center svg{margin-bottom:-.2rem}.hero-title{font-family:var(--font-playfair),serif;white-space:nowrap;font-size:clamp(1.4rem,2.5vw,2rem);line-height:1.2}.dashboard-section{flex-direction:column;gap:.75rem;display:flex}.section-title{color:var(--color-text);font-size:1.1rem;font-weight:700;position:relative}.section-title:after{background:linear-gradient(90deg,var(--color-primary)0%,var(--color-accent-soft)100%);content:"";border-radius:2px;width:2.5rem;height:3px;margin-top:.35rem;display:block}.section-subtitle{color:var(--color-secondary);font-size:.9rem;line-height:1.5}.category-header-row{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.category-settings-panel{background:linear-gradient(180deg,var(--color-surface)0%,var(--color-surface-warm)100%);border:1px solid var(--color-border-soft);box-shadow:var(--shadow-card);border-radius:.6rem;flex-direction:column;gap:.5rem;margin-top:.25rem;padding:.75rem;display:flex}.category-settings-row{align-items:center;gap:.5rem;display:flex}.category-settings-delete{align-self:flex-start;margin-top:.25rem}.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;display:grid}.recipe-card{background:linear-gradient(180deg,var(--color-surface)0%,var(--color-surface-warm)100%);border:1px solid var(--color-border-soft);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-snappy),transform var(--transition-snappy),border-color var(--transition-snappy);border-radius:.5rem;justify-content:center;align-items:center;padding:1rem;display:flex}.recipe-card-vertical{flex-direction:column;justify-content:flex-start;align-items:stretch;padding:0;overflow:hidden}.recipe-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-card-hover);transform:translateY(-3px)}.recipe-info{text-align:center;flex-direction:column;gap:.2rem;display:flex}.recipe-info-card{text-align:left;align-items:flex-start;gap:.55rem;padding:1rem}.recipe-name{color:var(--color-text);font-size:.92rem;font-weight:700}.recipe-tag{color:var(--color-secondary);letter-spacing:.05em;text-transform:uppercase;font-size:.72rem;font-weight:600}.recipe-card-tags{flex-wrap:wrap;gap:.4rem;display:flex}.recipe-category-chip{border:1px solid var(--color-border-soft);color:var(--color-secondary);white-space:nowrap;background:#fff3f6;border-radius:999px;padding:.4rem .65rem;font-size:.72rem;font-weight:700;line-height:1;display:inline-flex}.favorites-row{gap:.75rem;padding-bottom:.25rem;display:flex;overflow-x:auto}.favorite-card{background:linear-gradient(180deg,var(--color-surface)0%,var(--color-surface-warm)100%);border:1px solid var(--color-border-soft);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-snappy),transform var(--transition-snappy),border-color var(--transition-snappy);border-radius:.5rem;flex-shrink:0;align-items:center;gap:.5rem;padding:.75rem 1.1rem;display:flex}.favorite-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.favorite-name{white-space:nowrap;font-size:.88rem;font-weight:700}.empty-state{background:linear-gradient(180deg,var(--color-surface-warm)0%,#fffdfbcc 100%);border:1px dashed var(--color-border);transition:border-color var(--transition-snappy),box-shadow var(--transition-snappy);border-radius:.5rem;justify-content:center;align-items:center;padding:2rem 1.5rem;display:flex}.empty-state:hover{border-color:var(--color-primary);box-shadow:inset 0 0 0 1px rgba(var(--color-primary-shadow),.2)}.empty-state-text{color:var(--color-secondary);text-align:center;font-size:.92rem}.category-grid{flex-wrap:wrap;gap:.75rem;display:flex}.category-card{background:linear-gradient(135deg,var(--color-surface)0%,var(--color-surface-warm)100%);border:1px solid var(--color-border-soft);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-snappy),transform var(--transition-snappy),border-color var(--transition-snappy);border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem 1.25rem;text-decoration:none;display:flex}.category-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-card-hover);transform:translateY(-3px)}.category-emoji{font-size:1.3rem}.category-label{color:var(--color-text);white-space:nowrap;font-size:.92rem;font-weight:700}.search-wrapper{flex:1;position:relative}.search-wrapper input{width:100%}.search-dropdown{background:linear-gradient(180deg,var(--color-surface)0%,var(--color-surface-warm)100%);border:1px solid var(--color-border-soft);box-shadow:var(--shadow-card-hover);z-index:50;border-radius:.4rem;max-height:280px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.search-result{color:var(--color-text);transition:background var(--transition-snappy);justify-content:space-between;align-items:center;gap:.5rem;padding:.6rem .75rem;font-size:.88rem;display:flex}.search-result:hover{background:linear-gradient(90deg,var(--color-primary-light)0%,var(--color-primary-soft)100%)}.search-no-results{color:var(--color-secondary);font-style:italic}.search-result-tag{color:var(--color-secondary);letter-spacing:.05em;text-transform:uppercase;font-size:.75rem;font-weight:600}@keyframes letter-fade-in{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.love-letter-screen{background:var(--color-primary);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.love-letter{background:linear-gradient(168deg,#fffaf3,#fff5eb,#fef9f4);border:1px solid #e2cdb8;border-radius:.25rem;flex-direction:column;gap:1.5rem;width:100%;max-width:560px;max-height:80vh;padding:2.5rem 2rem;animation:.8s ease-out both letter-fade-in;display:flex;overflow-y:auto;box-shadow:0 2px 12px #4a37281a,inset 0 0 40px #fff8f080}.love-letter-body{color:#5a4133;font-family:var(--font-dancing),cursive;text-align:center;white-space:pre-line;font-size:1.35rem;line-height:1.75}.love-letter-button{color:#fff;font-family:var(--font-nunito),sans-serif;background:#e03c3c;border:none;border-radius:0;width:100%;min-height:2.7rem;margin-top:.5rem;padding:.65rem .9rem;font-size:1rem;font-weight:700}.letter-link{color:#e03c3c;margin-top:.75rem;font-weight:700;text-decoration:none;display:inline-block}.letter-link:hover{text-decoration:underline}@media (max-width:960px){.app-shell{grid-template-columns:1fr}.sidebar{border-bottom:1px solid var(--color-border);border-right:none;flex-direction:row;padding:.75rem 1rem}.sidebar-top{margin-bottom:0}.sidebar-nav{flex-direction:row}.logout-button{margin-top:0}.main-column{height:auto}.hero-panel{flex-direction:column;gap:1rem}.hero-tip{max-width:100%}}@keyframes birthday-fade-in{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.birthday-scene{background:var(--color-primary);flex-direction:column;justify-content:center;align-items:center;height:100vh;display:flex;position:relative;overflow:hidden}.birthday-scene-inner{opacity:0;animation:1.2s cubic-bezier(.22,.61,.36,1) forwards birthday-fade-in}.birthday-video{object-fit:cover;border-radius:1.5rem;width:90vw;max-width:400px;max-height:70vh}@keyframes birthday-entrance{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.birthday-screen{background:var(--color-primary);justify-content:center;align-items:center;height:100vh;padding:1.5rem;display:flex;overflow:hidden}.birthday-screen-content{will-change:opacity,transform;transition:opacity .6s,transform .6s}.birthday-screen-content-fade-out{opacity:0;transform:scale(.98)}.birthday-title{color:var(--color-text);font-family:var(--font-playfair),serif;opacity:0;text-align:center;font-size:clamp(2rem,6vw,4rem);animation:.8s cubic-bezier(.22,.61,.36,1) forwards birthday-entrance}.section-title{color:var(--color-text);font-family:var(--font-playfair),serif;font-size:1.5rem}.dashboard-section{margin-bottom:1.5rem}.recipe-form-page{width:100%;max-width:720px}.recipe-form-nav{margin-bottom:.5rem}.recipe-form-back{color:var(--color-secondary);transition:color var(--transition-snappy),transform var(--transition-snappy);font-size:.88rem;text-decoration:none}.recipe-form-back:hover{color:var(--color-primary-deep);text-decoration:underline;transform:translate(-2px)}.recipe-form-subtitle{color:var(--color-secondary);margin:-.25rem 0 0;font-size:.9rem}.recipe-form{flex-direction:column;gap:1.25rem;margin-top:1rem;display:flex}.form-label{color:var(--color-text);flex-direction:column;gap:.35rem;font-size:.88rem;font-weight:700;display:flex}.form-input,.form-textarea,.form-select{background:var(--color-surface);border:1px solid var(--color-border-soft);color:var(--color-text);transition:border-color var(--transition-snappy),box-shadow var(--transition-snappy);border-radius:.4rem;padding:.6rem .75rem;font-family:inherit;font-size:.92rem}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-shadow),.2);outline:none}.form-textarea{resize:vertical}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:.75rem;display:grid}.form-actions{justify-content:flex-end;align-items:center;gap:.75rem;padding-top:.5rem;display:flex}.form-actions a{align-items:center;display:inline-flex}.btn-primary{background:linear-gradient(180deg,var(--color-primary)0%,var(--color-primary-deep)100%);box-shadow:0 2px 10px rgba(var(--color-primary-shadow),.3);color:var(--color-on-primary);cursor:pointer;transition:transform var(--transition-snappy),box-shadow var(--transition-snappy),opacity var(--transition-snappy);border:none;border-radius:.4rem;padding:.6rem 1.5rem;font-family:inherit;font-size:.88rem;font-weight:700;text-decoration:none}.btn-primary:hover{box-shadow:0 4px 16px rgba(var(--color-primary-shadow),.4);opacity:.95;transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-secondary{background:linear-gradient(180deg,#fff 0%,var(--color-surface-warm)100%);border:1px solid var(--color-border);color:var(--color-secondary);cursor:pointer;transition:background var(--transition-snappy),border-color var(--transition-snappy),box-shadow var(--transition-snappy),transform var(--transition-snappy);border-radius:.4rem;padding:.6rem 1.5rem;font-family:inherit;font-size:.88rem;font-weight:600;text-decoration:none}.btn-secondary:hover{background:linear-gradient(180deg,var(--color-primary-light)0%,var(--color-primary-soft)100%);border-color:var(--color-primary);box-shadow:0 2px 8px rgba(var(--color-primary-shadow),.15);transform:translateY(-1px)}.form-fieldset{border:1px solid var(--color-border-soft);transition:border-color var(--transition-snappy),box-shadow var(--transition-snappy);background:linear-gradient(#fffdfb99 0%,#fff9f566 100%);border-radius:.5rem;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.form-fieldset:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 1px rgba(var(--color-primary-shadow),.2)}.form-legend{color:var(--color-text);padding:0 .25rem;font-size:.88rem;font-weight:700}.ingredient-row,.instruction-row{align-items:center;gap:.5rem;display:flex}.ingredient-amount,.ingredient-unit{flex:0 0 84px}.ingredient-name{flex:220px;min-width:0}.instruction-text{flex:auto;min-width:0}.ingredient-row .form-input,.instruction-row .form-textarea{min-width:0}@media (max-width:480px){.ingredient-row,.instruction-row{flex-wrap:wrap}.ingredient-amount,.ingredient-unit{flex:7rem}.ingredient-name,.instruction-text{flex:100%}.ingredient-row .btn-icon-remove,.instruction-row .btn-icon-remove{margin-left:auto}}.btn-icon-remove{border:1px solid var(--color-border-soft);color:var(--color-secondary);cursor:pointer;width:28px;height:28px;transition:background var(--transition-snappy),border-color var(--transition-snappy),color var(--transition-snappy),transform var(--transition-snappy);background:0 0;border-radius:50%;font-size:1.1rem;line-height:1}.btn-icon-remove:hover{color:#c44;background:#fde8e8;border-color:#e8a0a0;transform:scale(1.08)}.btn-add-row{color:var(--color-secondary);cursor:pointer;transition:color var(--transition-snappy),transform var(--transition-snappy);background:0 0;border:none;align-self:flex-start;padding:.3rem 0;font-family:inherit;font-size:.85rem;font-weight:700}.btn-add-row:hover{color:#7a5a42;text-decoration:underline;transform:translate(2px)}.step-number{color:var(--color-secondary);min-width:24px;font-size:.88rem;font-weight:700}.macros-grid{grid-template-columns:repeat(4,1fr);gap:.75rem;display:grid}@media (max-width:600px){.macros-grid{grid-template-columns:1fr 1fr}}.category-select-row{gap:.5rem;display:flex}.category-select-row select{flex:1}.new-category-row{gap:.5rem;margin-top:.5rem;display:flex}.tag-input-row{gap:.5rem;display:flex}.tag-list{flex-wrap:wrap;gap:.4rem;margin-top:.4rem;display:flex}.tag-chip{background:linear-gradient(135deg,var(--color-primary-light)0%,var(--color-primary-soft)100%);border:1px solid var(--color-primary);box-shadow:0 1px 3px rgba(var(--color-primary-shadow),.2);color:var(--color-text);transition:transform var(--transition-snappy),box-shadow var(--transition-snappy);border-radius:1rem;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.8rem;text-decoration:none;display:inline-flex}.tag-chip:hover{box-shadow:0 2px 8px rgba(var(--color-primary-shadow),.3);transform:scale(1.02)}.tag-remove{color:var(--color-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:.9rem;line-height:1}.tag-remove:hover{color:#c44}.photo-upload-area{border:2px dashed var(--color-border-soft);transition:border-color var(--transition-snappy),background var(--transition-snappy),box-shadow var(--transition-snappy);border-radius:.5rem;overflow:hidden}.photo-upload-area:hover{border-color:var(--color-primary);box-shadow:inset 0 0 0 1px rgba(var(--color-primary-shadow),.15)}.photo-drop-label{cursor:pointer;min-height:160px;transition:background var(--transition-snappy);justify-content:center;align-items:center;padding:1.5rem;display:flex}.photo-drop-label:hover{background:linear-gradient(#fef9f7 0%,#fef5f2 100%)}.photo-drop-label span{color:var(--color-secondary);font-size:.88rem;font-weight:600}.photo-preview-wrap{position:relative}.photo-preview{object-fit:cover;width:100%;max-height:280px;display:block}.photo-remove{position:absolute;top:8px;right:8px}.import-section{margin-bottom:.5rem}.import-row{gap:.5rem;display:flex}.import-error,.form-error{color:#c44;margin-top:.3rem;font-size:.82rem}.import-divider{align-items:center;gap:1rem;margin-top:1.25rem;display:flex}.import-divider:before,.import-divider:after{background:var(--color-border);content:"";flex:1;height:1px}.import-divider span{color:var(--color-secondary);white-space:nowrap;font-size:.82rem}.new-recipe-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#4a372833;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:absolute;inset:0}.new-recipe-modal{background:linear-gradient(180deg,var(--color-surface)0%,var(--color-surface-warm)100%);border:1px solid var(--color-border-soft);box-shadow:var(--shadow-card-hover),0 0 0 1px rgba(var(--color-primary-shadow),.1);border-radius:.75rem;width:100%;max-width:420px;padding:1.5rem;position:relative}.new-recipe-modal-close{color:var(--color-secondary);cursor:pointer;z-index:1;min-width:2rem;min-height:2rem;transition:color var(--transition-snappy),transform var(--transition-snappy);background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;font-size:1.5rem;line-height:1;display:flex;position:absolute;top:.75rem;right:.75rem}.new-recipe-modal-close:hover{color:var(--color-text);transform:scale(1.1)}.new-recipe-modal-title{margin-bottom:.35rem;padding-right:2rem;font-size:1.25rem}.new-recipe-modal-subtitle{color:var(--color-secondary);margin-bottom:1.25rem;font-size:.9rem}.new-recipe-modal-actions{flex-direction:column;align-items:center;gap:.75rem;display:flex}.new-recipe-modal-option{background:linear-gradient(180deg,var(--color-background)0%,var(--color-surface-warm)100%);border:1px solid var(--color-border-soft);cursor:pointer;font:inherit;text-align:center;max-width:16rem;transition:background var(--transition-snappy),border-color var(--transition-snappy),box-shadow var(--transition-snappy),transform var(--transition-snappy);border-radius:.5rem;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:1rem 1.25rem;display:flex;box-shadow:0 1px 3px #4a37280f}.new-recipe-modal-option:hover{background:linear-gradient(180deg,var(--color-primary-light)0%,var(--color-primary-soft)100%);border-color:var(--color-primary);box-shadow:0 4px 14px rgba(var(--color-primary-shadow),.2);transform:translateY(-1px)}.new-recipe-modal-option-icon{font-size:1.25rem}.new-recipe-modal-url-row{gap:.5rem;margin-bottom:1rem;display:flex}.new-recipe-modal-url-row .form-input{flex:1}.new-recipe-modal-hearts{justify-content:center;gap:.5rem;margin-bottom:1rem;display:flex}.new-recipe-modal-hearts .heart{color:var(--color-primary);font-size:1.5rem;animation:.6s ease-in-out infinite heart-pulse}.new-recipe-modal-hearts .heart:nth-child(2){animation-delay:.2s}.new-recipe-modal-hearts .heart:nth-child(3){animation-delay:.4s}@keyframes heart-pulse{0%,to{opacity:.5;transform:scale(.9)}50%{opacity:1;transform:scale(1.2)}}.new-recipe-modal-back{color:var(--color-secondary);cursor:pointer;background:0 0;border:none;margin-top:.5rem;padding:.25rem 0;font-size:.88rem}.new-recipe-modal-back:hover{text-decoration:underline}.recipe-detail{max-width:720px}.recipe-detail-hero{object-fit:cover;border-radius:.25rem;width:100%;max-height:360px;display:block}.recipe-detail-header{justify-content:space-between;align-items:center;gap:.75rem;margin-top:1rem;display:flex}.recipe-detail-title{color:var(--color-text);font-family:var(--font-playfair),serif;font-size:1.8rem}.favorite-btn{color:var(--color-primary);cursor:pointer;background:0 0;border:none;font-size:1.8rem;line-height:1;transition:transform .2s}.favorite-btn:hover{transform:scale(1.15)}.favorite-btn.favorited{color:#e8457c}.recipe-detail-meta{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.meta-chip{color:var(--color-secondary);background:#fef0f3;border-radius:1rem;padding:.25rem .7rem;font-size:.82rem;font-weight:600}.recipe-detail-cats,.recipe-detail-tags{flex-wrap:wrap;gap:.4rem;margin-top:.5rem;display:flex}.nutrition-card{border:1px solid var(--color-border);background:linear-gradient(168deg,#fef8f0,#fff5eb);border-radius:.25rem;margin-top:1rem;padding:1rem}.nutrition-title{color:var(--color-text);margin-bottom:.5rem;font-size:.85rem;font-weight:700}.nutrition-grid{gap:1.5rem;display:flex}.nutrition-item{flex-direction:column;align-items:center;display:flex}.nutrition-value{color:var(--color-text);font-size:1.2rem;font-weight:700}.nutrition-label{color:var(--color-secondary);font-size:.75rem}.recipe-detail-section{margin-top:1.5rem}.recipe-detail-section-title{border-bottom:1px solid var(--color-border);color:var(--color-text);margin-bottom:.75rem;padding-bottom:.4rem;font-size:1.1rem;font-weight:700}.ingredient-checklist{flex-direction:column;gap:.4rem;padding:0;list-style:none;display:flex}.ingredient-check-item{cursor:pointer;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.92rem;display:flex}.ingredient-check-item.checked span{color:var(--color-secondary);text-decoration:line-through}.ingredient-checkbox{accent-color:var(--color-primary)}.instruction-list{flex-direction:column;gap:.75rem;padding-left:1.25rem;display:flex}.instruction-step{color:var(--color-text);font-size:.92rem;line-height:1.6}.recipe-notes-text{color:var(--color-text);white-space:pre-wrap;font-size:.92rem;line-height:1.6}.source-link{color:var(--color-primary);margin-top:1rem;font-size:.88rem;display:inline-block}.recipe-detail-actions{gap:.75rem;margin-top:1.5rem;display:flex}.btn-danger{color:#c44;cursor:pointer;background:0 0;border:1px solid #e8a0a0;border-radius:.25rem;padding:.6rem 1.5rem;font-family:inherit;font-size:.88rem;font-weight:600;transition:background .2s}.btn-danger:hover{background:#fde8e8}.tag-filter-row{flex-wrap:wrap;gap:.4rem;margin-bottom:1rem;display:flex}.tag-filter-chip{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;border-radius:1rem;align-items:center;padding:.3rem .8rem;font-family:inherit;font-size:.82rem;font-weight:600;transition:background .2s,border-color .2s,color .2s,box-shadow .2s;display:inline-flex}.tag-filter-chip:hover{background:#fef0f3}.tag-filter-chip:focus-visible{box-shadow:0 0 0 3px rgba(var(--color-primary-shadow),.25);outline:none}.tag-filter-chip.active{background:var(--color-primary);border-color:var(--color-primary);box-shadow:inset 0 1px 2px rgba(var(--color-primary-shadow),.28);color:var(--color-on-primary)}.tag-filter-add{min-width:2rem;padding:.3rem .6rem;font-size:1rem;font-weight:700}.filters-top-row{flex-wrap:wrap;gap:.5rem;margin:1rem 0 1.25rem;display:flex}.filters-trigger{gap:.55rem}.filters-count{background:rgba(var(--color-primary-shadow),.15);border:1px solid rgba(var(--color-primary-shadow),.18);color:inherit;border-radius:999px;justify-content:center;align-items:center;min-width:1.55rem;height:1.25rem;padding:0 .4rem;font-size:.75rem;font-weight:800;display:inline-flex}.tag-filter-chip.active .filters-count{background:#fff3;border-color:#ffffff38}.filters-clear{opacity:.92}.filters-sheet-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1100;background:#0a08084d;justify-content:center;align-items:flex-end;padding:1rem .75rem;display:flex;position:fixed;inset:0}.filters-sheet{border:1px solid var(--color-border-soft);box-shadow:var(--shadow-soft);background:linear-gradient(#fffdfbf2 0%,#fff9f5eb 100%);border-radius:1.1rem;width:100%;max-width:42rem;max-height:min(70vh,34rem);padding:1rem;overflow:auto}[data-theme=dark] .filters-sheet{background:linear-gradient(#1e1a18f5 0%,#181514f0 100%)}.filters-sheet-header{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.85rem;display:flex;position:sticky;top:0}.filters-sheet-title{font-size:1rem}.filters-done-button{color:var(--color-secondary);cursor:pointer;font:inherit;background:0 0;border:none;padding:.25rem .35rem;font-size:.9rem;font-weight:700}.filters-done-button:hover{color:var(--color-text)}.filters-section{flex-direction:column;gap:.65rem;display:flex}.filters-section-label{color:var(--color-secondary);letter-spacing:.02em;text-transform:uppercase;font-size:.8rem;font-weight:700}.filters-chips-row{flex-wrap:wrap;gap:.5rem;display:flex}.filters-new-category-row{gap:.65rem;margin-top:.75rem;display:flex}.new-tag-inline-row{gap:.5rem;margin-bottom:1rem;display:flex}.recipe-card-img{object-fit:cover;border-radius:.5rem .5rem 0 0;width:100%;height:140px;display:block}.recipe-card-img-placeholder{border-bottom:1px solid var(--color-border-soft);background:#f3efe9;flex-direction:column;justify-content:center;padding:.9rem 1rem;display:flex}.recipe-card-img-placeholder-bar{background:#e6ddd2;border-radius:999px;width:75%;height:.9rem;margin-bottom:.45rem}.recipe-card-img-placeholder-bar-secondary{width:52%}.settings-page{max-width:720px}.settings-section{margin-top:1.5rem}.settings-heading{margin-bottom:.5rem;font-size:1rem}.settings-description{color:var(--color-secondary);margin-bottom:.75rem;font-size:.85rem}.color-picker-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.color-swatch-btn{cursor:pointer;border:2px solid #0000;border-radius:50%;width:36px;height:36px;transition:transform .2s,border-color .2s}.color-swatch-btn:hover{transform:scale(1.15)}.color-swatch-active{border-color:var(--color-text)}.dark-mode-toggle-row{align-items:center;gap:.75rem;display:flex}.dark-mode-toggle{background:var(--color-border);cursor:pointer;border:none;border-radius:999px;width:54px;height:30px;padding:3px;transition:background .3s;position:relative}.dark-mode-toggle.dark-mode-on{background:var(--color-primary)}.dark-mode-toggle-thumb{background:#fff;border-radius:50%;width:24px;height:24px;transition:transform .3s;display:block}.dark-mode-on .dark-mode-toggle-thumb{transform:translate(24px)}.dark-mode-label{color:var(--color-text);font-size:.9rem;font-weight:600}.chat-container{flex-direction:column;flex:1;width:100%;max-width:720px;min-height:0;display:flex}.chat-messages{flex-direction:column;flex:1;gap:.75rem;padding-bottom:1rem;display:flex;overflow-y:auto}.chat-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.chat-empty-title{font-family:var(--font-playfair),serif;font-size:1.5rem}.chat-empty-sub{color:var(--color-secondary);margin-top:.25rem;font-size:.92rem}.chat-bubble{white-space:pre-wrap;border-radius:1rem;max-width:80%;padding:.75rem 1rem;font-size:.92rem;line-height:1.55}.chat-bubble-user{background:var(--color-primary);color:var(--color-on-primary);align-self:flex-end}.chat-bubble-assistant{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);align-self:flex-start}.chat-typing{align-items:center;gap:4px;padding:.75rem 1.25rem;display:flex}@keyframes typing-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.typing-dot{background:var(--color-secondary);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite typing-bounce;display:block}.typing-dot:nth-child(2){animation-delay:.15s}.typing-dot:nth-child(3){animation-delay:.3s}.chat-input-bar{border-top:1px solid var(--color-border);gap:.5rem;padding-top:.75rem;display:flex}.chat-input{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);font:inherit;border-radius:.5rem;flex:1;padding:.6rem .75rem;font-size:.92rem}.chat-input:focus{border-color:var(--color-primary);outline:none}.chat-send{border-radius:.5rem;min-width:70px}.modal-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem;width:90%;max-width:480px;max-height:80vh;padding:1.5rem;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.modal-title{font-size:1.1rem}.modal-close{color:var(--color-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.modal-close:hover{color:var(--color-text)}.share-page{background:var(--color-background);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.share-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.5rem;width:100%;max-width:640px;padding:2rem;box-shadow:0 8px 32px #4a37281a}.share-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.share-title{color:var(--color-text);font-family:var(--font-playfair),serif;font-size:1.8rem}.share-hero{object-fit:cover;border-radius:.25rem;width:100%;max-height:360px;display:block}.share-meta{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.share-ingredient-list{color:var(--color-text);flex-direction:column;gap:.3rem;padding-left:1.25rem;font-size:.92rem;line-height:1.5;display:flex}.share-footer{color:var(--color-secondary);font-family:var(--font-dancing),cursive;text-align:center;margin-top:2rem;font-size:.92rem}@keyframes heart-pop{0%{transform:scale(1)}30%{transform:scale(1.35)}60%{transform:scale(.95)}to{transform:scale(1)}}.favorite-btn.is-favorited{color:#e03c3c;animation:.4s cubic-bezier(.17,.67,.35,1.5) heart-pop}.btn-primary:active,.btn-secondary:active{transition:transform .1s;transform:scale(.96)}.recipe-card{transition:transform var(--transition-snappy),box-shadow var(--transition-snappy)}.recipe-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}.search-dropdown{animation:.2s ease-out dropdown-slide}@keyframes dropdown-slide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--color-border,#ebd8c8)25%,var(--color-surface,#fffdfb)50%,var(--color-border,#ebd8c8)75%);background-size:200% 100%;border-radius:8px;animation:1.5s ease-in-out infinite skeleton-shimmer}.skeleton-text{width:80%;height:1rem;margin-bottom:.5rem}.skeleton-text-short{width:50%;height:1rem}.skeleton-card{border-radius:16px;height:180px}.skeleton-avatar{border-radius:50%;width:48px;height:48px}@keyframes content-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.content{animation:.3s ease-out content-fade-in}.chat-bubble{animation:.25s ease-out content-fade-in}.mobile-tab-bar{display:none}@media (max-width:768px){.sidebar{display:none!important}.app-shell{grid-template-columns:1fr!important}.main-column{height:calc(100dvh - 72px - 6px - env(safe-area-inset-bottom))}.topbar{padding:calc(.65rem + env(safe-area-inset-top)).75rem .65rem;justify-content:space-between;align-items:center;gap:.6rem;display:flex;position:relative}.topbar-brand{text-align:center;flex-direction:column;align-items:center;margin-top:.15rem;display:flex;position:absolute;left:50%;transform:translate(-50%)}.topbar-brand-line{font-size:clamp(.98rem,4vw,1.15rem)}.mobile-search-trigger{background:linear-gradient(180deg,var(--color-surface)0%,var(--color-surface-warm)100%);border:1px solid var(--color-border-soft);color:var(--color-text);font:inherit;border-radius:999px;flex:none;justify-content:center;align-items:center;width:3.6rem;height:3.6rem;padding:0;display:inline-flex;box-shadow:0 2px 10px #4a372814}.mobile-search-trigger-icon{width:3.2rem;height:3.2rem;display:block}.desktop-search{display:none}.topbar .topbar-new-recipe,.mobile-search-trigger{z-index:1;position:relative}.topbar-new-recipe{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;height:3.6rem;padding:0 1.1rem;font-size:.8rem;display:inline-flex}.topbar-new-recipe .new-recipe-plus{font-size:1.8rem;font-weight:800;line-height:1}.topbar-new-recipe .new-recipe-label{line-height:1}.topbar-new-recipe{width:3.6rem;padding:0}.topbar-new-recipe .new-recipe-label{display:none}.mobile-search-overlay{padding:calc(env(safe-area-inset-top) + 1rem)1rem 1rem;background:#4a372838}.mobile-search-wrapper input{width:100%;font-size:.9rem}.mobile-tab-bar{bottom:calc(env(safe-area-inset-bottom) + 6px);border-top:1px solid var(--color-border,#ebd8c8);z-index:1000;background:linear-gradient(#fffdfbfa 0%,#fff9f5fa 100%);justify-content:space-around;align-items:center;min-height:72px;padding:.35rem .1rem;display:flex;position:fixed;left:0;right:0;box-shadow:0 -6px 20px #4a372814}.mobile-tab{color:var(--color-text,#4a3728);opacity:.72;min-width:0;min-height:44px;transition:background var(--transition-snappy),color var(--transition-snappy),opacity var(--transition-snappy);border-radius:.9rem;flex-direction:column;flex:1 1 0;justify-content:center;align-items:center;gap:.15rem;padding:.35rem .2rem;font-size:.65rem;text-decoration:none;display:flex}.mobile-tab.active{background:linear-gradient(135deg,var(--color-primary-soft)0%,var(--color-primary-light)100%);color:var(--color-text,#4a3728);opacity:1}.mobile-tab-icon{justify-content:center;align-items:center;width:1.25rem;height:1.25rem;line-height:1;display:flex}.mobile-tab-label{font-size:.58rem;font-weight:600;font-family:var(--font-nunito),sans-serif;text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.content{padding:1rem 1rem 2px}.recipe-grid,.favorites-row{grid-template-columns:1fr!important}.stat-cards{grid-template-columns:1fr 1fr!important}.section-title{font-size:1.3rem}.recipe-form-page{padding:0}.form-row-3{grid-template-columns:1fr!important}.ingredient-row{flex-wrap:wrap}.macros-grid{grid-template-columns:1fr 1fr!important}.chat-container{padding:0}.chat-input-bar{padding:.25rem 0}}@media (max-width:480px){.stat-cards{grid-template-columns:1fr!important}.topbar-brand-line{font-size:.95rem}.topbar-new-recipe{padding:.4rem .6rem;font-size:.75rem}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
