@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--color-primary: #FF6B35;--color-accent: #FF9A6B;--color-secondary: #2D1B12;--color-bg: #0A0A0D;--color-bg-elevated: #12121A;--color-bg-card: rgba(255, 255, 255, .03);--color-text: #F5F5F5;--color-text-muted: #9CA3AF;--color-text-dim: #6B7280;--color-border: rgba(255, 255, 255, .08);--color-border-hover: rgba(255, 255, 255, .15);--color-success: #10B981;--color-error: #EF4444;--color-warning: #F59E0B;--font-display: "Outfit", sans-serif;--font-body: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--shadow-glow: 0 0 40px rgba(255, 107, 53, .3);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 32px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--color-text);background:var(--color-bg);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}img,video{max-width:100%;height:auto}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}::selection{background:#ff6b354d;color:#fff}#root{min-height:100vh}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:#0f0f14d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.05)}.navbar-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.navbar-logo{display:flex;align-items:center;gap:.5rem;text-decoration:none;font-size:1.5rem;font-weight:700}.logo-image{width:40px;height:40px;object-fit:contain}.logo-text{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-family:var(--font-display)}.navbar-links{display:flex;align-items:center;gap:1rem}.user-greeting{color:var(--color-text-muted);font-size:.9rem}.nav-button{padding:.6rem 1.4rem;border-radius:8px;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s ease;cursor:pointer;border:none;font-family:inherit}.login-button{background:transparent;color:var(--color-text);border:1px solid rgba(255,255,255,.15)}.login-button:hover{background:#ffffff0d;border-color:#ffffff40}.register-button{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff}.register-button:hover{transform:translateY(-2px);box-shadow:0 4px 20px #ff6b3566}.logout-button{background:#ffffff1a;color:var(--color-text)}.logout-button:hover{background:#ff6b3533;color:var(--color-primary)}.home-page{min-height:100vh;overflow-x:hidden}.hero-section{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;padding:8rem 4rem 4rem;max-width:1400px;margin:0 auto;position:relative}.hero-background{position:absolute;inset:0;overflow:hidden;z-index:-1}.gradient-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.4}.orb-1{width:600px;height:600px;background:radial-gradient(circle,var(--color-primary) 0%,transparent 70%);top:-200px;right:-100px}.orb-2{width:400px;height:400px;background:radial-gradient(circle,var(--color-accent) 0%,transparent 70%);bottom:100px;left:-100px}.orb-3{width:300px;height:300px;background:radial-gradient(circle,#ff9f6b 0%,transparent 70%);top:50%;left:40%}.hero-content{z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ff6b3526;border:1px solid rgba(255,107,53,.3);border-radius:50px;font-size:.9rem;color:var(--color-primary);margin-bottom:1.5rem}.badge-logo{width:24px;height:24px;object-fit:contain}.hero-title{font-family:var(--font-display);font-size:clamp(2.5rem,5vw,4rem);font-weight:800;line-height:1.1;margin-bottom:1.5rem;color:var(--color-text)}.title-highlight{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.2rem;color:var(--color-text-muted);line-height:1.7;margin-bottom:2rem;max-width:500px}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}.cta-button{display:inline-flex;align-items:center;justify-content:center;padding:1rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s ease;cursor:pointer;border:none;font-family:inherit}.cta-button.primary{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;box-shadow:0 4px 20px #ff6b354d}.cta-button.primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px #ff6b3566}.cta-button.secondary{background:#ffffff0d;color:var(--color-text);border:1px solid rgba(255,255,255,.15)}.cta-button.secondary:hover{background:#ffffff1a;border-color:#ffffff40}.cta-button.large{padding:1.2rem 2.5rem;font-size:1.1rem}.hero-visual{display:flex;justify-content:center;align-items:center}.visual-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:2rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 4px 60px #0000004d,inset 0 1px #ffffff1a}.recipe-preview{width:320px}.recipe-image-placeholder{width:100%;height:200px;background:linear-gradient(135deg,#ff6b3533,#ff9a6b1a);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:5rem;margin-bottom:1.5rem}.recipe-info h4{font-family:var(--font-display);font-size:1.4rem;margin-bottom:.5rem;color:var(--color-text)}.recipe-info p{color:var(--color-text-muted);font-size:.95rem;margin-bottom:1rem}.recipe-meta{display:flex;gap:1.5rem;color:var(--color-text-muted);font-size:.9rem}.features-section{padding:6rem 4rem;max-width:1400px;margin:0 auto}.section-header{text-align:center;margin-bottom:4rem}.section-header h2{font-family:var(--font-display);font-size:clamp(2rem,3vw,2.5rem);font-weight:700;margin-bottom:1rem;color:var(--color-text)}.section-header p{color:var(--color-text-muted);font-size:1.1rem;max-width:600px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem}.feature-card{background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:20px;padding:2rem;transition:all .3s ease}.feature-card:hover{background:#ffffff0a;border-color:#ff6b354d;transform:translateY(-5px)}.feature-icon{display:inline-block;font-size:2.5rem;margin-bottom:1rem}.feature-card h3{font-family:var(--font-display);font-size:1.3rem;font-weight:600;margin-bottom:.75rem;color:var(--color-text)}.feature-card p{color:var(--color-text-muted);font-size:.95rem;line-height:1.6}.cta-section{padding:6rem 4rem;text-align:center}.cta-content{max-width:700px;margin:0 auto;padding:4rem;background:linear-gradient(135deg,#ff6b351a,#ff9a6b0d);border:1px solid rgba(255,107,53,.2);border-radius:32px}.cta-content h2{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.2rem);font-weight:700;margin-bottom:1rem;color:var(--color-text)}.cta-content p{color:var(--color-text-muted);font-size:1.1rem;margin-bottom:2rem}.footer{padding:3rem 4rem;border-top:1px solid rgba(255,255,255,.05)}.footer-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-brand{display:flex;align-items:center;gap:.5rem;font-size:1.3rem;font-weight:700}.footer-logo{width:36px;height:36px;object-fit:contain}.footer-brand .logo-text{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-family:var(--font-display)}.footer-text{color:var(--color-text-muted);font-size:.9rem}@media(max-width:1024px){.hero-section{grid-template-columns:1fr;text-align:center;padding:6rem 2rem 4rem;gap:3rem}.hero-description{max-width:100%;margin:0 auto 2rem}.hero-cta{justify-content:center}.hero-visual{order:-1}.visual-card{max-width:100%}.recipe-preview{width:100%;max-width:320px}}@media(max-width:640px){.hero-section{padding:5rem 1.5rem 3rem}.features-section,.cta-section,.footer{padding-left:1.5rem;padding-right:1.5rem}.cta-content{padding:2rem}.footer-content{flex-direction:column;text-align:center}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative}.auth-background{position:fixed;inset:0;overflow:hidden;z-index:-1}.auth-background .gradient-orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:.3}.auth-background .orb-1{width:500px;height:500px;background:radial-gradient(circle,var(--color-primary) 0%,transparent 70%);top:-150px;right:-100px}.auth-background .orb-2{width:400px;height:400px;background:radial-gradient(circle,var(--color-accent) 0%,transparent 70%);bottom:-100px;left:-100px}.auth-container{width:100%;max-width:440px}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;font-size:1.6rem;font-weight:700}.auth-logo-image{width:48px;height:48px;object-fit:contain}.auth-logo .logo-text{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-family:var(--font-display)}.auth-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:2.5rem;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.auth-title{font-family:var(--font-display);font-size:1.8rem;font-weight:700;margin-bottom:.5rem;text-align:center;color:var(--color-text)}.auth-subtitle{color:var(--color-text-muted);text-align:center;margin-bottom:2rem}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:500;color:var(--color-text)}.form-group input{padding:.9rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;font-size:1rem;color:var(--color-text);transition:all .2s ease;font-family:inherit}.form-group input::placeholder{color:var(--color-text-muted);opacity:.6}.form-group input:focus{outline:none;border-color:var(--color-primary);background:#ff6b350d}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171;padding:.75rem 1rem;border-radius:10px;font-size:.9rem;text-align:center}.auth-submit{margin-top:.5rem;padding:1rem;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));border:none;border-radius:12px;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all .3s ease;font-family:inherit;display:flex;align-items:center;justify-content:center;min-height:52px}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 20px #ff6b3566}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:var(--color-text-muted);font-size:.85rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.oauth-button{width:100%;padding:.9rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;font-size:.95rem;font-weight:500;color:var(--color-text);cursor:pointer;transition:all .2s ease;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:.75rem}.oauth-button:hover{background:#ffffff14;border-color:#fff3}.oauth-icon{width:20px;height:20px}.auth-footer{text-align:center;margin-top:1.5rem;color:var(--color-text-muted);font-size:.9rem}.auth-footer a{color:var(--color-primary);text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}@media(max-width:480px){.auth-page{padding:1rem}.auth-card{padding:1.5rem}.auth-title{font-size:1.5rem}}.app,.main-content{min-height:100vh}
