:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--primary: #4CAF50;--primary-dark: #45a049;--primary-light: #81C784;--secondary: #FF9800;--surface: #ffffff;--surface-hover: #f5f5f5;--background: #fafafa;--border: #e0e0e0;--text-primary: #212121;--text-secondary: #666666;--text-tertiary: #999999;--white: #ffffff;--error: #f44336;--success: #4CAF50;--warning: #FF9800;--info: #2196F3;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 8px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .15);--shadow-xl: 0 12px 24px rgba(0, 0, 0, .18);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark]{--primary: #66BB6A;--primary-dark: #5cb860;--primary-light: #81C784;--secondary: #FFB74D;--surface: #1e1e1e;--surface-hover: #2a2a2a;--background: #121212;--border: #333333;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-tertiary: #808080;--white: #ffffff;--error: #ef5350;--success: #66BB6A;--warning: #FFB74D;--info: #42A5F5;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .5);--shadow-xl: 0 12px 24px rgba(0, 0, 0, .6)}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--background);color:var(--text-primary);overflow-x:hidden;transition:background-color .2s ease,color .2s ease}#root{width:100%;min-height:100vh}h1{font-size:2rem;line-height:1.2;font-weight:700;color:var(--text-primary)}h2{font-size:1.5rem;line-height:1.3;font-weight:600;color:var(--text-primary)}h3{font-size:1.25rem;line-height:1.4;font-weight:600;color:var(--text-primary)}p{color:var(--text-secondary);line-height:1.6}a{color:var(--primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--primary-dark)}button{font-family:inherit;font-size:1rem;cursor:pointer;border:none;background:transparent;color:var(--text-primary);transition:all .2s ease}button:disabled{cursor:not-allowed;opacity:.6}input,textarea,select{font-family:inherit;font-size:1rem;color:var(--text-primary);background-color:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;transition:border-color .2s ease,box-shadow .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4caf501a}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}*:focus-visible{outline:2px solid var(--primary);outline-offset:2px}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}::selection{background-color:var(--primary);color:var(--white)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){h1{font-size:1.75rem}h2{font-size:1.35rem}h3{font-size:1.15rem}}@media(min-width:1024px){h1{font-size:2.25rem}h2{font-size:1.75rem}}@media print{body{background:#fff;color:#000}button,.no-print{display:none!important}}@keyframes fadeIn{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 scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.app-container{min-height:100vh;animation:fadeIn .3s ease-out}.header{position:sticky;top:0;z-index:100;border-bottom:1px solid var(--border);box-shadow:0 2px 8px #0000000d;animation:fadeInDown .4s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;transition:all .3s ease}[data-theme=dark] .header{background:#1e1e1ef2}.header-content{max-width:1400px;margin:0 auto;padding:1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.header-logo{display:flex;align-items:center;gap:.75rem;flex-shrink:0;animation:slideInRight .5s ease-out}.logo-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:24px;border-radius:8px;transition:transform .6s cubic-bezier(.68,-.55,.265,1.55)}.logo-icon:hover{transform:rotate(360deg) scale(1.1)}.header-title{margin:0;font-size:1.5rem;white-space:nowrap;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-nav{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:flex-end}.mobile-menu-toggle{display:none;width:44px;height:44px;border-radius:8px;border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:20px;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.mobile-menu-toggle:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(var(--primary-rgb, 76, 175, 80),.1);transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.mobile-menu-toggle:hover:before{width:100px;height:100px}.mobile-menu-toggle:hover{background:var(--surface-hover);transform:scale(1.05);border-color:var(--primary)}.mobile-menu-toggle:active{transform:scale(.95)}.nav-links{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.nav-button{padding:.5rem 1rem;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:.5rem;white-space:nowrap;border:none;text-decoration:none;position:relative;overflow:hidden}.nav-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.nav-button:hover:before{left:100%}.nav-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.nav-button:active{transform:translateY(0)}.user-info{display:flex;align-items:center;gap:.5rem;padding:.25rem 1rem;border-radius:8px;animation:fadeIn .5s ease-out .2s both}.search-section{margin-bottom:2rem;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000000d;animation:scaleIn .4s ease-out .1s both;transition:all .3s ease}.search-section:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.search-grid{display:grid;grid-template-columns:1fr;gap:1rem;align-items:end;width:100%}.search-input-group{width:100%;min-width:0;animation:fadeIn .4s ease-out}.search-input-group label{display:block;margin-bottom:.5rem;font-size:14px;font-weight:500;transition:color .3s ease}.search-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:15px;outline:none;transition:all .3s ease;box-sizing:border-box;max-width:100%}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb, 76, 175, 80),.1);transform:translateY(-1px)}.search-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;width:100%}.search-button,.clear-button{padding:.75rem 1.5rem;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;width:100%;box-sizing:border-box;position:relative;overflow:hidden}.search-button:after,.clear-button:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease}.search-button:active:after,.clear-button:active:after{width:300px;height:300px}.main-content{max-width:1400px;margin:0 auto;padding:0 1rem 3rem;animation:fadeIn .5s ease-out .2s both}.content-layout{display:grid;grid-template-columns:1fr;gap:2rem;align-items:start}.recipes-section{width:100%;animation:slideInLeft .5s ease-out .3s both}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;transition:opacity .2s ease}.recipes-grid>*{animation:scaleIn .4s ease-out both}.recipes-grid>*:nth-child(1){animation-delay:.05s}.recipes-grid>*:nth-child(2){animation-delay:.1s}.recipes-grid>*:nth-child(3){animation-delay:.15s}.recipes-grid>*:nth-child(4){animation-delay:.2s}.recipes-grid>*:nth-child(5){animation-delay:.25s}.recipes-grid>*:nth-child(6){animation-delay:.3s}.recipes-grid>*:nth-child(7){animation-delay:.35s}.recipes-grid>*:nth-child(8){animation-delay:.4s}.sidebar-section{display:flex;flex-direction:column;gap:2rem;width:100%;animation:slideInRight .5s ease-out .4s both}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:1.5rem;margin-bottom:1.5rem;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000000d;flex-wrap:wrap;animation:fadeIn .4s ease-out}.pagination-button{padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:40px;text-align:center;border:1px solid var(--border);position:relative;overflow:hidden}.pagination-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:rgba(var(--primary-rgb, 76, 175, 80),.2);transform:translate(-50%,-50%);transition:width .4s ease,height .4s ease}.pagination-button:hover:before{width:100px;height:100px}.pagination-button:disabled{cursor:not-allowed;opacity:.5}.pagination-info{margin-left:1rem;font-size:14px;white-space:nowrap;animation:fadeIn .5s ease-out .2s both}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;animation:fadeIn .3s ease-out}.loading-spinner{width:48px;height:48px;border:4px solid var(--border);border-top:4px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;animation:fadeIn .5s ease-out}.login-card{max-width:500px;width:100%;border-radius:16px;padding:2rem;box-shadow:0 8px 32px #0000001a;text-align:center;animation:scaleIn .6s cubic-bezier(.4,0,.2,1);transition:all .3s ease}.login-card:hover{box-shadow:0 12px 48px #00000026;transform:translateY(-4px)}.login-logo{width:80px;height:80px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:48px;margin:0 auto;margin-bottom:2rem;animation:pulse 2s ease-in-out infinite}.login-title{margin-bottom:1rem;animation:fadeInDown .5s ease-out .2s both}.login-description{font-size:18px;margin-bottom:2rem;line-height:1.6;animation:fadeIn .5s ease-out .3s both}.features-grid{display:grid;gap:1rem;margin-bottom:2rem;text-align:left}.feature-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:8px;animation:slideInLeft .5s ease-out both;transition:all .3s ease}.feature-item:nth-child(1){animation-delay:.4s}.feature-item:nth-child(2){animation-delay:.5s}.feature-item:nth-child(3){animation-delay:.6s}.feature-item:nth-child(4){animation-delay:.7s}.feature-item:hover{transform:translate(8px)}.feature-icon{font-size:24px;flex-shrink:0;animation:pulse 2s ease-in-out infinite}.login-button{width:100%;padding:1rem 2rem;border-radius:8px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;box-shadow:0 4px 16px #0000001a;animation:fadeIn .5s ease-out .8s both;position:relative;overflow:hidden}.login-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.login-button:hover:before{left:100%}.theme-toggle{position:fixed;top:1.5rem;right:1.5rem;width:50px;height:50px;border-radius:50%;cursor:pointer;font-size:24px;display:flex;align-items:center;justify-content:center;transition:all .4s cubic-bezier(.4,0,.2,1);z-index:1000;animation:fadeIn .5s ease-out .3s both}.theme-toggle:hover{transform:scale(1.1) rotate(180deg)}.theme-toggle:active{transform:scale(.9) rotate(180deg)}@media(max-width:480px){.header-content{padding:.75rem}.header-title{font-size:1.25rem}.logo-icon{width:36px;height:36px;font-size:20px}.mobile-menu-toggle{display:flex}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;padding:1rem;box-shadow:0 4px 12px #0000001a;z-index:99;animation:fadeInDown .3s ease-out}.nav-links.mobile-menu-open{display:flex}.nav-button{width:100%;justify-content:center;padding:.75rem 1rem}.recipes-grid{grid-template-columns:1fr;gap:1rem}.search-section{padding:1rem}.search-buttons{grid-template-columns:1fr}.pagination{padding:1rem;gap:.25rem}.pagination-button{padding:.5rem .75rem;min-width:36px;font-size:13px}.pagination-info{margin-left:0;width:100%;text-align:center;margin-top:.5rem}.login-card{padding:1.5rem}.login-logo{width:64px;height:64px;font-size:36px}.login-description{font-size:16px}.theme-toggle{top:1rem;right:1rem;width:44px;height:44px;font-size:20px}}@media(min-width:481px)and (max-width:768px){.recipes-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.search-grid{grid-template-columns:1fr;gap:1rem}.search-buttons{grid-template-columns:1fr 1fr}.nav-links{gap:.5rem}.nav-button{padding:.5rem .75rem;font-size:13px}.header-nav{width:100%;justify-content:center}.mobile-menu-toggle{display:flex}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;padding:1rem;box-shadow:0 4px 12px #0000001a;z-index:99;animation:fadeInDown .3s ease-out}.nav-links.mobile-menu-open{display:flex}}@media(min-width:769px)and (max-width:900px){.search-grid{grid-template-columns:1fr;gap:1rem}.search-buttons{grid-column:1;grid-template-columns:1fr 1fr}.recipes-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.mobile-menu-toggle{display:flex}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;padding:1rem;box-shadow:0 4px 12px #0000001a;z-index:99;animation:fadeInDown .3s ease-out}.nav-links.mobile-menu-open{display:flex}}@media(min-width:901px)and (max-width:1200px){.search-grid{grid-template-columns:1fr 160px;gap:1rem}.search-buttons{grid-column:1 / -1;grid-template-columns:1fr 1fr}.content-layout{grid-template-columns:1fr}.sidebar-section{position:static;max-height:none}}@media(min-width:1201px){.search-grid{grid-template-columns:1fr 180px;gap:1rem}.search-buttons{grid-column:1 / -1;grid-template-columns:200px 120px;justify-self:start}.content-layout{grid-template-columns:1fr 1fr}.sidebar-section{position:sticky;top:80px;max-height:calc(100vh - 100px);overflow:auto}.recipes-grid{grid-template-columns:repeat(2,1fr)}}@media(hover:hover){.nav-button:hover{transform:translateY(-1px)}.search-button:hover,.clear-button:hover,.login-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.theme-toggle:hover{transform:scale(1.1) rotate(180deg)}.pagination-button:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}}html{scroll-behavior:smooth}@media(max-width:768px){button,a{min-height:44px;min-width:44px}}body{overflow-x:hidden}button:focus-visible,input:focus-visible,a:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
