:root{--primary-50: #FFF7ED;--primary-100: #FFEDD5;--primary-200: #FED7AA;--primary-300: #FDBA74;--primary-400: #FB923C;--primary-500: #F97316;--primary-600: #EA580C;--primary-700: #C2410C;--primary-800: #9A3412;--primary-900: #7C2D12;--secondary-50: #ECFDF5;--secondary-100: #D1FAE5;--secondary-200: #A7F3D0;--secondary-300: #6EE7B7;--secondary-400: #34D399;--secondary-500: #10B981;--secondary-600: #059669;--secondary-700: #047857;--secondary-800: #065F46;--secondary-900: #064E3B;--accent-50: #FEF2F2;--accent-100: #FEE2E2;--accent-500: #EF4444;--accent-600: #DC2626;--accent-700: #B91C1C;--gray-50: #F9FAFB;--gray-100: #F3F4F6;--gray-200: #E5E7EB;--gray-300: #D1D5DB;--gray-400: #9CA3AF;--gray-500: #6B7280;--gray-600: #4B5563;--gray-700: #374151;--gray-800: #1F2937;--gray-900: #111827;--font-primary: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-secondary: "Inter", -apple-system, BlinkMacSystemFont, 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;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-0: 0;--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: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-card: 0 4px 20px rgba(0, 0, 0, .08);--shadow-card-hover: 0 8px 30px rgba(0, 0, 0, .12);--shadow-primary: 0 4px 12px rgba(249, 115, 22, .3);--shadow-primary-hover: 0 6px 16px rgba(249, 115, 22, .4);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--transition-bounce: .3s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-toast: 400;--z-tooltip: 500;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--container-2xl: 1440px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-primary);font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-normal);color:var(--gray-800);background-color:var(--gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--gray-900)}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{margin-bottom:var(--space-4)}a{color:var(--primary-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-700)}strong,b{font-weight:var(--font-semibold)}small{font-size:var(--text-sm)}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:none;border:none}input:focus,button:focus,textarea:focus,select:focus{outline:none}ul,ol{list-style:none}.container{width:100%;max-width:var(--container-xl);margin-left:auto;margin-right:auto;padding-left:var(--space-4);padding-right:var(--space-4)}@media(min-width:768px){.container{padding-left:var(--space-6);padding-right:var(--space-6)}}@media(min-width:1024px){.container{padding-left:var(--space-8);padding-right:var(--space-8)}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--primary-600)}.text-secondary{color:var(--secondary-600)}.text-muted{color:var(--gray-500)}.text-white{color:#fff}.bg-white{background-color:#fff}.bg-primary{background-color:var(--primary-500)}.bg-secondary{background-color:var(--secondary-500)}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.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)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.top-0{top:0}.left-0{left:0}.right-0{right:0}.bottom-0{bottom:0}.inset-0{top:0;right:0;bottom:0;left:0}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.transition{transition:all var(--transition-base)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}.m-0{margin:0}.m-auto{margin:auto}.mx-auto{margin-left:auto;margin-right:auto}.my-4{margin-top:var(--space-4);margin-bottom:var(--space-4)}.my-8{margin-top:var(--space-8);margin-bottom:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.mt-4{margin-top:var(--space-4)}.mt-8{margin-top:var(--space-8)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.py-8{padding-top:var(--space-8);padding-bottom:var(--space-8)}.py-12{padding-top:var(--space-12);padding-bottom:var(--space-12)}.py-16{padding-top:var(--space-16);padding-bottom:var(--space-16)}.py-20{padding-top:var(--space-20);padding-bottom:var(--space-20)}@media(max-width:767px){.hide-mobile{display:none!important}}@media(min-width:768px){.hide-tablet,.show-mobile-only{display:none!important}}@media(min-width:1024px){.hide-desktop{display:none!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-base);font-weight:var(--font-semibold);line-height:1;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-slow);white-space:nowrap;text-decoration:none}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-lg)}.btn-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-primary-hover)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:linear-gradient(135deg,var(--secondary-500),var(--secondary-600));color:#fff;box-shadow:0 4px 12px #10b9814d}.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.btn-outline{background:transparent;color:var(--primary-600);border:2px solid var(--primary-600)}.btn-outline:hover{background:var(--primary-50)}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover{background:var(--gray-100);color:var(--gray-900)}.btn-icon{padding:var(--space-3);border-radius:var(--radius-full)}.card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);overflow:hidden;transition:all var(--transition-slow)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}.card-body{padding:var(--space-4)}@media(min-width:768px){.card-body{padding:var(--space-6)}}.recipe-card{position:relative;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);overflow:hidden;transition:all var(--transition-slow);cursor:pointer}.recipe-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card-hover)}.recipe-card__image{position:relative;width:100%;aspect-ratio:4 / 3;overflow:hidden}.recipe-card__image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.recipe-card:hover .recipe-card__image img{transform:scale(1.05)}.recipe-card__badge{position:absolute;top:var(--space-3);left:var(--space-3);display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:#fff;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);box-shadow:var(--shadow-md)}.recipe-card__badge--success{background:var(--secondary-500);color:#fff}.recipe-card__badge--warning{background:var(--primary-500);color:#fff}.recipe-card__save{position:absolute;top:var(--space-3);right:var(--space-3);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:var(--radius-full);box-shadow:var(--shadow-md);transition:all var(--transition-fast)}.recipe-card__save:hover{background:var(--accent-50);transform:scale(1.1)}.recipe-card__save.active{background:var(--accent-500);color:#fff}.recipe-card__content{padding:var(--space-4)}.recipe-card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--gray-900);margin-bottom:var(--space-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recipe-card__meta{display:flex;align-items:center;gap:var(--space-4);font-size:var(--text-sm);color:var(--gray-500)}.recipe-card__meta-item{display:flex;align-items:center;gap:var(--space-1)}.recipe-card__tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}.tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--gray-100);color:var(--gray-700);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-full);transition:all var(--transition-fast)}.tag:hover{background:var(--gray-200)}.tag--primary{background:var(--primary-100);color:var(--primary-700)}.tag--secondary{background:var(--secondary-100);color:var(--secondary-700)}.tag--small{padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}.ingredient-tag{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--primary-100);color:var(--primary-800);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-lg);animation:tagPop .3s var(--transition-bounce) forwards}.ingredient-tag__remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;background:var(--primary-200);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--primary-700);cursor:pointer;transition:all var(--transition-fast)}.ingredient-tag__remove:hover{background:var(--primary-300);color:var(--primary-900)}@keyframes tagPop{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.input-group{position:relative;width:100%}.input-field{width:100%;padding:var(--space-4);font-size:var(--text-base);color:var(--gray-900);background:#fff;border:2px solid var(--gray-200);border-radius:var(--radius-xl);transition:all var(--transition-base)}.input-field::placeholder{color:var(--gray-400)}.input-field:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #f973161a}.input-field--lg{padding:var(--space-5) var(--space-6);font-size:var(--text-lg);border-radius:var(--radius-2xl)}.search-input{display:flex;align-items:center;background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);overflow:hidden;transition:all var(--transition-base)}.search-input:focus-within{box-shadow:var(--shadow-xl),0 0 0 3px #f9731626}.search-input__icon{display:flex;align-items:center;justify-content:center;padding-left:var(--space-5);color:var(--gray-400)}.search-input__field{flex:1;padding:var(--space-5) var(--space-4);font-size:var(--text-lg);border:none;background:transparent}.search-input__field::placeholder{color:var(--gray-400)}.search-input__field:focus{outline:none}.search-input__actions{display:flex;align-items:center;gap:var(--space-2);padding-right:var(--space-3)}.search-input__btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--primary-100);border-radius:var(--radius-xl);color:var(--primary-600);transition:all var(--transition-fast)}.search-input__btn:hover{background:var(--primary-200)}.match-meter{width:100%}.match-meter__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.match-meter__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--gray-600)}.match-meter__value{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--secondary-600)}.match-meter__bar{height:12px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.match-meter__fill{height:100%;background:linear-gradient(90deg,var(--secondary-500),var(--secondary-400));border-radius:var(--radius-full);transition:width .8s cubic-bezier(.34,1.56,.64,1)}.match-meter__details{display:flex;gap:var(--space-4);margin-top:var(--space-2);font-size:var(--text-sm);color:var(--gray-500)}.navbar{position:sticky;top:0;z-index:var(--z-sticky);background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--gray-100)}.navbar__container{display:flex;align-items:center;justify-content:space-between;height:64px}@media(min-width:768px){.navbar__container{height:72px}}.navbar__logo{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--gray-900)}.navbar__logo-icon{font-size:var(--text-2xl)}.navbar__logo-text{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar__menu{display:none;align-items:center;gap:var(--space-8)}@media(min-width:768px){.navbar__menu{display:flex}}.navbar__link{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--gray-600);transition:color var(--transition-fast)}.navbar__link:hover,.navbar__link.active{color:var(--primary-600)}.navbar__mobile-toggle{display:flex;padding:var(--space-2);color:var(--gray-700)}@media(min-width:768px){.navbar__mobile-toggle{display:none}}.mobile-menu{position:fixed;top:64px;left:0;right:0;bottom:0;background:#fff;padding:var(--space-4);transform:translate(100%);transition:transform var(--transition-slow);z-index:var(--z-modal)}.mobile-menu.active{transform:translate(0)}.mobile-menu__link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--gray-700);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.mobile-menu__link:hover,.mobile-menu__link.active{background:var(--primary-50);color:var(--primary-600)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background:#fff;border-top:1px solid var(--gray-100);box-shadow:0 -4px 20px #00000014;z-index:var(--z-sticky)}@media(min-width:768px){.bottom-nav{display:none}}.bottom-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--gray-500);transition:all var(--transition-fast)}.bottom-nav__item:hover,.bottom-nav__item.active{color:var(--primary-600)}.bottom-nav__icon{font-size:20px}.feature-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-6);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);transition:all var(--transition-slow)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.feature-card__icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--primary-100);border-radius:var(--radius-xl);font-size:28px;margin-bottom:var(--space-4)}.feature-card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--gray-900);margin-bottom:var(--space-2)}.feature-card__desc{font-size:var(--text-sm);color:var(--gray-500);line-height:var(--leading-relaxed)}.tooltip{position:relative}.tooltip__content{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);padding:var(--space-2) var(--space-3);background:var(--gray-900);color:#fff;font-size:var(--text-sm);border-radius:var(--radius-md);white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:var(--z-tooltip)}.tooltip:hover .tooltip__content{opacity:1;visibility:visible;transform:translate(-50%) translateY(-4px)}.toast-container{position:fixed;bottom:100px;right:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);z-index:var(--z-toast)}@media(min-width:768px){.toast-container{bottom:var(--space-6);right:var(--space-6)}}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);animation:slideInRight .4s var(--transition-bounce)}.toast--success{border-left:4px solid var(--secondary-500)}.toast--error{border-left:4px solid var(--accent-500)}.toast--info{border-left:4px solid var(--primary-500)}.toast__icon{font-size:20px}.toast--success .toast__icon{color:var(--secondary-500)}.toast--error .toast__icon{color:var(--accent-500)}.toast--info .toast__icon{color:var(--primary-500)}.toast__message{font-size:var(--text-sm);color:var(--gray-700)}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.dropdown{position:absolute;top:100%;left:0;right:0;margin-top:var(--space-2);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all var(--transition-base);z-index:var(--z-dropdown)}.dropdown.active{opacity:1;visibility:visible;transform:translateY(0)}.dropdown__item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition-fast)}.dropdown__item:hover{background:var(--gray-50)}.dropdown__item.selected{background:var(--primary-50)}.dropdown__emoji{font-size:var(--text-2xl)}.dropdown__text{flex:1}.dropdown__name{font-weight:var(--font-medium);color:var(--gray-900)}.dropdown__hint{font-size:var(--text-sm);color:var(--gray-500)}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-lg)}.skeleton--text{height:16px;margin-bottom:var(--space-2)}.skeleton--title{height:24px;width:70%;margin-bottom:var(--space-3)}.skeleton--image{aspect-ratio:4 / 3}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{width:24px;height:24px;border:3px solid var(--gray-200);border-top-color:var(--primary-500);border-radius:var(--radius-full);animation:spin 1s linear infinite}.spinner--lg{width:40px;height:40px;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes cookingPot{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-2px) rotate(-2deg)}50%{transform:translateY(-4px) rotate(0)}75%{transform:translateY(-2px) rotate(2deg)}}@keyframes steam{0%{opacity:0;transform:translateY(0) scale(1)}50%{opacity:.8}to{opacity:0;transform:translateY(-30px) scale(1.3)}}.animate-fadeIn{animation:fadeIn .5s ease forwards}.animate-fadeInUp{animation:fadeInUp .5s ease forwards}.animate-fadeInDown{animation:fadeInDown .5s ease forwards}.animate-slideUp{animation:slideUp .6s cubic-bezier(.34,1.56,.64,1) forwards}.animate-slideInLeft{animation:slideInLeft .5s ease forwards}.animate-slideInRight{animation:slideInRight .5s ease forwards}.animate-scaleIn{animation:scaleIn .4s ease forwards}.animate-pop{animation:pop .3s ease}.animate-bounce{animation:bounce 1s ease infinite}.animate-pulse{animation:pulse 2s ease infinite}.animate-wiggle{animation:wiggle .5s ease}.animate-float{animation:float 3s ease-in-out infinite}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.stagger-6{animation-delay:.6s}[class*=stagger-]{opacity:0}.hover-lift{transition:transform var(--transition-slow),box-shadow var(--transition-slow)}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.hover-scale{transition:transform var(--transition-fast)}.hover-scale:hover{transform:scale(1.05)}.hover-glow{transition:box-shadow var(--transition-base)}.hover-glow:hover{box-shadow:0 0 20px #f973164d}.hover-rotate{transition:transform var(--transition-fast)}.hover-rotate:hover{transform:rotate(15deg)}.page-enter{animation:fadeInUp .4s ease forwards}.page-exit{animation:fadeIn .3s ease reverse forwards}.hero-text{overflow:hidden}.hero-text span{display:inline-block;animation:slideUp .8s cubic-bezier(.34,1.56,.64,1) forwards;animation-delay:calc(var(--char-index, 0) * .05s)}.recipe-card-enter{opacity:0;transform:translateY(30px)}.recipe-card-visible{animation:fadeInUp .5s ease forwards}.ingredient-tag-enter{animation:tagPop .3s cubic-bezier(.34,1.56,.64,1) forwards}.ingredient-tag-exit{animation:scaleIn .2s ease reverse forwards}.match-meter-animate{animation:meterFill 1s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes meterFill{0%{width:0%}}@keyframes confetti{0%{opacity:1;transform:translateY(0) rotate(0)}to{opacity:0;transform:translateY(-100px) rotate(720deg)}}.confetti-piece{position:absolute;width:10px;height:10px;animation:confetti 1s ease-out forwards}.cooking-loader{display:flex;align-items:flex-end;gap:var(--space-2);height:60px}.cooking-loader__pot{font-size:40px;animation:cookingPot .8s ease infinite}.cooking-loader__steam{display:flex;gap:var(--space-1)}.cooking-loader__steam span{width:8px;height:8px;background:var(--gray-300);border-radius:var(--radius-full);animation:steam 1.5s ease infinite}.cooking-loader__steam span:nth-child(1){animation-delay:0s}.cooking-loader__steam span:nth-child(2){animation-delay:.3s}.cooking-loader__steam span:nth-child(3){animation-delay:.6s}.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-left{opacity:0;transform:translate(-30px);transition:opacity .6s ease,transform .6s ease}.reveal-left.visible{opacity:1;transform:translate(0)}.reveal-right{opacity:0;transform:translate(30px);transition:opacity .6s ease,transform .6s ease}.reveal-right.visible{opacity:1;transform:translate(0)}.focus-ring{transition:box-shadow var(--transition-fast)}.focus-ring:focus{outline:none;box-shadow:0 0 0 3px #f973164d}.btn-press:active{transform:scale(.98)}.ripple{position:relative;overflow:hidden}.ripple:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#ffffff4d;border-radius:var(--radius-full);transform:translate(-50%,-50%);opacity:0}.ripple:active:after{width:200px;height:200px;opacity:1;transition:width .3s ease,height .3s ease,opacity .3s ease}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
