:root{font-family:Poppins,Inter,Segoe UI,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-bg-main: #0f172a;--color-bg-card: #1e293b;--color-bg-input: #334155;--color-text-primary: #f1f5f9;--color-text-secondary: #cbd5e1;--color-text-tertiary: #94a3b8;--color-text: var(--color-text-primary);--color-primary: #f97316;--color-accent: #ef4444;--color-accent-hover: #dc2626;--color-bg-light: rgba(30, 41, 59, .85);--color-border-light: rgba(148, 163, 184, .25);--color-border: rgba(255, 255, 255, .1);--bg-primary: var(--color-bg-main);--text-primary: var(--color-text-primary);--text-secondary: var(--color-text-secondary);--text-tertiary: var(--color-text-tertiary);--bg-input: var(--color-bg-input);--border-color: var(--color-border);--radius-xl: 24px;--shadow-elevated: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);color:var(--color-text-primary);background-color:var(--color-bg-main)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:var(--color-bg-main);color:var(--color-text-primary)}button{font:inherit}:root{--bg-primary: #343541;--bg-secondary: #444654;--bg-sidebar: #202123;--bg-hover: #2A2B32;--bg-input: #40414F;--bg-elevated: #202123;--text-primary: #ECECF1;--text-secondary: #C5C5D2;--text-tertiary: #8E8EA0;--text-disabled: #6E6E80;--color-primary: #10A37F;--color-primary-hover: #1A7F64;--color-danger: #EF4444;--color-warning: #F59E0B;--color-info: #3B82F6;--border-color: #40414F;--border-color-light: #565869;--border-color-focus: #10A37F;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--sidebar-width: 260px;--sidebar-collapsed-width: 0px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Fira Code", "Courier New", monospace}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-color-light)}.app-container{min-height:100vh;display:flex;flex-direction:column;position:relative;background-color:var(--bg-primary)}.main-content{flex:1;display:flex;flex-direction:column;width:100%;transition:margin-left var(--transition-base)}.main-content.with-sidebar{margin-left:0}.content-container{max-width:800px;width:100%;margin:0 auto;padding:var(--spacing-xl) var(--spacing-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans);white-space:nowrap}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:var(--bg-hover)}.btn-ghost{background-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{background-color:var(--bg-hover);color:var(--text-primary)}.btn-danger{background-color:var(--color-danger);color:#fff}.btn-danger:hover{background-color:#dc2626}.input{width:100%;padding:var(--spacing-md);background-color:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-family:var(--font-sans);transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--border-color-focus);box-shadow:0 0 0 1px var(--border-color-focus)}.input::placeholder{color:var(--text-tertiary)}.card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--border-color-light)}.divider{height:1px;background-color:var(--border-color);margin:var(--spacing-md) 0}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}@media (max-width: 768px){:root{--sidebar-width: 0px}.main-content.with-sidebar{margin-left:0}.content-container{padding:var(--spacing-md)}}@media (max-width: 560px){.content-container{padding:var(--spacing-sm)}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(40px,6vw,96px) 16px;position:relative;background:radial-gradient(circle at 20% 20%,rgba(16,163,127,.12),transparent 32%),radial-gradient(circle at 80% 10%,rgba(59,130,246,.12),transparent 28%),var(--bg-primary)}.auth-container:before,.auth-container:after{content:"";position:absolute;border-radius:999px;filter:blur(60px);opacity:.6;z-index:-1}.auth-container:before{width:320px;height:320px;background:#10a37f47;top:8%;left:12%}.auth-container:after{width:360px;height:360px;background:#3b82f647;bottom:8%;right:10%}.auth-card{width:min(1080px,100%);display:grid;grid-template-columns:1fr;border-radius:var(--radius-xl);background:linear-gradient(145deg,#202123eb,#2c2e38e6);box-shadow:var(--shadow-elevated);overflow:hidden;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(86,88,105,.55)}.auth-showcase{position:relative;min-height:320px;display:flex;align-items:flex-end;justify-content:center;padding:clamp(28px,6vw,48px);background:linear-gradient(135deg,#10a37f47,#3b82f659);overflow:hidden}.auth-showcase-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 20%,rgba(255,255,255,.55),transparent 60%);mix-blend-mode:screen}.auth-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.45;transform:scale(1.05);filter:saturate(1.2)}.auth-content{padding:clamp(32px,6vw,56px);display:flex;flex-direction:column;gap:24px;background:linear-gradient(145deg,#202123e6,#343541d9)}.auth-header{display:flex;flex-direction:column;gap:12px}.auth-pill{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;background:linear-gradient(135deg,#10a37f2e,#3b82f640);color:var(--color-primary);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:.78rem}.auth-header h1{margin:0;font-size:clamp(1.8rem,2.8vw,2.6rem);line-height:1.2;color:var(--text-primary)}.auth-desc{margin:0;font-size:1rem;line-height:1.7;color:var(--text-secondary)}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-input{padding:14px 18px;border-radius:14px;border:1px solid var(--border-color);background:var(--bg-input);font-size:1rem;color:var(--text-primary);transition:border-color .2s,box-shadow .2s,transform .2s}.auth-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #10a37f40;outline:none;transform:translateY(-1px)}.auth-btn{width:100%;padding:15px 18px;border-radius:16px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-position .2s,background-color .2s ease}.auth-btn:disabled{opacity:.7;cursor:not-allowed}.primary-btn{background-image:linear-gradient(135deg,#10a37f,#0d9b76,#1a7f64);color:#fff;box-shadow:0 18px 32px #10a37f59;background-size:200% 200%}.primary-btn:hover{transform:translateY(-2px);background-position:100% 0;box-shadow:0 24px 40px #8b5cf640}.secondary-btn{background:#ffffff0f;color:var(--text-primary);border:1px solid var(--border-color)}.secondary-btn:hover{background:#ffffff1a;transform:translateY(-2px)}.auth-divider{position:relative;display:flex;align-items:center;gap:12px;color:var(--text-tertiary);font-size:.9rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,#10a37f00,#10a37fa6,#10a37f00)}.auth-socials{display:flex;gap:12px;flex-wrap:wrap}.social-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 16px;background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);border-radius:14px;transition:transform .2s ease,box-shadow .2s ease}.social-btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px #0f172a1f}.auth-error{color:#ef4444;font-size:.9rem;text-align:center}@media (min-width: 960px){.auth-card{grid-template-columns:1.1fr 1fr}.auth-showcase{min-height:100%}.auth-content{padding:clamp(40px,5vw,64px)}}@media (max-width: 640px){.auth-card{border-radius:24px}.auth-socials{flex-direction:column}.social-btn{width:100%}}.flm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0f172a66;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;padding:24px}.flm-modal{position:relative;width:min(440px,100%);border-radius:28px;background:#fffffff2;border:1px solid rgba(255,255,255,.75);padding:clamp(28px,6vw,40px);box-shadow:0 28px 60px #0f172a33;overflow:hidden}.flm-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top right,rgba(236,72,153,.28),transparent 55%);opacity:.9}.flm-header{position:relative;display:flex;gap:18px;align-items:center;margin-bottom:18px}.flm-logo{width:64px;height:64px;border-radius:20px;box-shadow:0 18px 38px #ef444438}.flm-header h2{margin:0;font-size:1.6rem;color:#0f172a}.flm-description{margin:8px 0 0;color:#475467;line-height:1.6}.flm-hint{position:relative;margin:0 0 24px;padding:14px 16px;border-radius:16px;background:#f9731614;color:#f97316;font-weight:600;border:1px solid rgba(249,115,22,.22)}.flm-actions{position:relative;display:flex;gap:12px;flex-wrap:wrap}.flm-primary,.flm-secondary{flex:1 1 160px;text-align:center;padding:14px 18px;border-radius:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.flm-primary{background:linear-gradient(135deg,#f97316,#ef4444,#8b5cf6);color:#fff;text-decoration:none;box-shadow:0 18px 34px #ef444440}.flm-primary:hover{transform:translateY(-2px)}.flm-secondary{border:none;background:#f8fafce6;border:1px solid rgba(148,163,184,.25);color:#475467}.flm-secondary:hover{transform:translateY(-2px);box-shadow:0 14px 24px #0f172a1f}@media (max-width: 480px){.flm-modal{border-radius:22px}.flm-header{flex-direction:column;text-align:center}.flm-hint{text-align:center}}.home-wrapper{display:flex;flex-direction:column;gap:clamp(32px,5vw,48px);margin:0 auto;width:min(1160px,94%);color:var(--text-primary)}.home-hero{position:relative;overflow:hidden;border-radius:var(--radius-xl);padding:clamp(36px,7vw,72px);background:var(--bg-secondary);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-xl)}.home-hero-ornament{position:absolute;top:-20%;right:40%;bottom:40%;left:-10%;background:var(--bg-hover);filter:blur(80px);opacity:.3}.home-hero-content{position:relative;display:flex;flex-direction:column;gap:clamp(18px,4vw,28px);max-width:640px;color:var(--text-primary)}.home-hero-badge{align-self:flex-start;padding:8px 18px;border-radius:999px;background:var(--bg-input);border:1px solid var(--border-color);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;color:var(--text-secondary)}.home-hero-title{margin:0;font-size:clamp(2.2rem,4vw,3.2rem);line-height:1.2;color:var(--text-primary)}.home-hero-subtitle{margin:0;font-size:1.05rem;line-height:1.7;color:var(--text-secondary)}.home-hero-actions{display:flex;flex-wrap:wrap;gap:16px}.home-hero-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 22px;border-radius:16px;font-weight:600;text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.home-hero-btn.primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-md)}.home-hero-btn.primary:hover{transform:translateY(-2px);background:var(--color-primary-hover)}.home-hero-btn.ghost{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.home-hero-btn.ghost:hover{transform:translateY(-2px);background:var(--bg-hover);box-shadow:0 12px 24px #0000004d}.home-stats{display:flex;flex-wrap:wrap;gap:24px}.home-stat{display:flex;flex-direction:column;gap:4px;padding:12px 0;min-width:140px}.home-stat-value{font-size:1.8rem;font-weight:700;color:var(--text-primary)}.home-stat-label{color:var(--text-secondary);font-size:.95rem}.home-pricing{display:flex;flex-direction:column;gap:28px;padding:clamp(28px,5vw,36px);border-radius:28px;background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:0 16px 40px #00000059}.pricing-header{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap}.pricing-header h2{margin:0;font-size:clamp(1.6rem,3vw,2.2rem);color:var(--text-primary)}.pricing-header p{margin:8px 0 0;color:var(--text-secondary);font-size:1rem;max-width:520px}.pricing-usage{display:flex;gap:16px}.pricing-usage-card{display:flex;flex-direction:column;gap:4px;padding:16px 20px;border-radius:16px;background:var(--bg-hover);border:1px solid var(--border-color);min-width:140px}.pricing-usage-label{font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.pricing-usage-value{font-size:1.6rem;font-weight:700;color:var(--text-primary)}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}.pricing-card{position:relative;display:flex;flex-direction:column;gap:20px;padding:28px 24px;border-radius:22px;background:var(--bg-hover);border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.pricing-card.selected{border-color:var(--color-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.pricing-card.recommended{border-color:var(--color-primary)}.pricing-card-badge{position:absolute;top:18px;right:18px;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;background:var(--color-primary);color:#fff;padding:6px 12px;border-radius:var(--radius-full)}.pricing-card-header h3{margin:0 0 8px;font-size:1.35rem;color:var(--text-primary);font-weight:700}.pricing-card-chip{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);background:var(--bg-input);border-radius:var(--radius-full);padding:4px 10px;margin-bottom:10px}.pricing-card-header p{margin:0;color:var(--text-secondary);line-height:1.6;font-size:.95rem}.pricing-card-price{display:flex;align-items:baseline;gap:8px}.pricing-card-amount{font-size:clamp(1.8rem,4vw,2.4rem);font-weight:700;color:var(--text-primary)}.pricing-card-frequency{font-size:.9rem;color:var(--text-secondary)}.pricing-card-estimate{padding:10px 14px;border-radius:var(--radius-md);background:var(--bg-input);color:var(--text-primary);font-size:.9rem;font-weight:500}.pricing-card-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;color:var(--text-primary);font-size:.95rem}.pricing-card-features li:before{content:"✔";margin-right:8px;color:var(--color-primary)}.pricing-card-select{margin-top:auto;align-self:flex-start;padding:10px 18px;border-radius:var(--radius-full);border:1px solid var(--border-color);background:transparent;color:var(--text-primary);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.pricing-card-select:hover,.pricing-card.selected .pricing-card-select{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.pricing-actions{display:flex;flex-direction:column;gap:16px}.pricing-promo{display:flex;flex-wrap:wrap;gap:12px}.pricing-promo-input{flex:1 1 220px;border-radius:var(--radius-md);border:1px solid var(--border-color);padding:12px 16px;font-size:.95rem;background:var(--bg-input);color:var(--text-primary);font-family:var(--font-sans)}.pricing-promo-input::placeholder{color:var(--text-tertiary)}.pricing-promo-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.pricing-promo-apply{padding:12px 20px;border-radius:var(--radius-md);border:none;background:var(--color-primary);color:#fff;font-weight:600;cursor:pointer;transition:background var(--transition-fast);font-family:var(--font-sans)}.pricing-promo-apply:hover{background:var(--color-primary-hover)}.pricing-promo-apply:disabled{opacity:.6;cursor:not-allowed}.pricing-status{padding:12px 16px;border-radius:var(--radius-md);font-size:.9rem}.pricing-status-info{background:var(--bg-input);color:var(--color-info);border:1px solid var(--border-color)}.pricing-status-success{background:var(--bg-input);color:var(--color-primary);border:1px solid var(--color-primary)}.pricing-status-error{background:#ef44441a;color:var(--color-danger);border:1px solid var(--color-danger)}.pricing-summary{display:grid;gap:12px;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;background:var(--bg-primary)}.pricing-summary-row{display:flex;justify-content:space-between;align-items:center;color:var(--text-secondary);font-size:.95rem}.pricing-summary-row strong{color:var(--text-primary);font-size:1.2rem}.pricing-summary-row.promo strong{color:var(--text-primary)}.pricing-cta{margin-top:8px;width:100%;padding:14px 20px;border-radius:var(--radius-md);border:none;background:var(--color-primary);color:#fff;font-weight:700;font-size:1rem;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans)}.pricing-cta:disabled{opacity:.6;cursor:not-allowed}.pricing-cta:not(:disabled):hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md)}.pricing-loading,.pricing-error{padding:16px 20px;border-radius:var(--radius-md);background:var(--bg-input);color:var(--text-primary);font-size:.95rem;border:1px solid var(--border-color)}.pricing-error{border-color:var(--color-danger);background:#ef44441a}.pricing-error-details{font-size:.85rem;color:var(--color-danger)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.home-empty-state{padding:var(--spacing-xl);text-align:center;color:var(--text-secondary)}.home-empty-state span{font-size:2rem;display:block;margin-bottom:12px}@media (max-width: 768px){.home-stats{gap:16px}.home-stat{min-width:120px}.home-pricing{border-radius:22px}.pricing-header{flex-direction:column;align-items:flex-start}.pricing-usage{width:100%;flex-wrap:wrap}.pricing-usage-card{flex:1 1 150px}}@media (max-width: 560px){.home-hero{border-radius:24px}.home-hero-actions{flex-direction:column}.home-hero-btn{width:100%}.pricing-grid{grid-template-columns:1fr}.pricing-card{padding:24px 20px}.pricing-promo{flex-direction:column}.pricing-promo-apply{width:100%}}.landing{position:relative;min-height:100vh;display:flex;flex-direction:column;gap:clamp(48px,8vw,80px);color:var(--text-primary);background:var(--bg-primary);overflow-x:hidden}.landing header,.landing main,.landing section,.landing nav{position:relative;z-index:2}.landing-hero{position:relative;z-index:1;padding:clamp(80px,10vw,120px) 0 clamp(60px,10vw,120px)}.landing-nav{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(16px,4vw,32px);padding:16px clamp(24px,5vw,40px);margin:0 auto;max-width:1200px;width:100%;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.landing-logo{display:inline-flex;align-items:center;gap:12px;font-weight:700;font-size:1.25rem;text-decoration:none;color:var(--text-primary);transition:opacity var(--transition-fast)}.landing-logo:hover{opacity:.8}.landing-logo img{height:42px;width:42px;border-radius:var(--radius-md)}.landing-nav-links{display:flex;justify-content:center;gap:clamp(16px,4vw,42px);align-items:center;font-weight:600;color:var(--text-secondary)}.landing-nav-links a{position:relative;text-decoration:none;color:inherit;padding:8px 12px;border-radius:var(--radius-md);transition:all var(--transition-fast)}.landing-nav-links a:hover{background-color:var(--bg-hover);color:var(--text-primary)}.landing-nav-cta{padding:10px 20px;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;text-decoration:none;font-weight:600;transition:background var(--transition-fast)}.landing-nav-cta:hover,.landing-nav-cta:focus-visible{background:var(--color-primary-hover)}.landing-hero-cta:hover,.landing-hero-cta:focus-visible{background:var(--color-primary-hover)}.landing-hero-content{position:relative;display:grid;grid-template-columns:minmax(300px,1.2fr) minmax(280px,1fr);gap:clamp(40px,8vw,80px);align-items:center;max-width:1200px;margin:0 auto;padding:0 clamp(24px,5vw,40px)}.landing-hero-copy{position:relative;z-index:1;display:flex;flex-direction:column;gap:clamp(16px,4vw,28px)}.landing-hero-badge{align-self:flex-start;padding:6px 14px;border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--color-primary);font-weight:600;letter-spacing:.05em;text-transform:uppercase;font-size:.75rem}.landing-hero-copy h1{margin:0;font-size:clamp(2.5rem,6vw,4rem);line-height:1.1;color:var(--text-primary);font-weight:800;letter-spacing:-.02em}.landing-hero-copy p{margin:0;font-size:clamp(1.05rem,2.2vw,1.2rem);line-height:1.75;color:var(--text-secondary)}.landing-hero-actions{display:flex;flex-wrap:wrap;gap:16px}.landing-hero-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-md);font-weight:600;text-decoration:none;transition:all var(--transition-fast)}.landing-hero-btn.primary{color:#fff;background:var(--color-primary)}.landing-hero-btn.primary:after{content:"→";font-size:1.1rem;transition:transform var(--transition-fast)}.landing-hero-btn.primary:hover:after,.landing-hero-btn.primary:focus-visible:after{transform:translate(4px)}.landing-hero-btn.primary:hover,.landing-hero-btn.primary:focus-visible{background:var(--color-primary-hover)}.landing-hero-btn.ghost{color:var(--text-primary);background:transparent;border:1px solid var(--border-color)}.landing-hero-btn.ghost:hover,.landing-hero-btn.ghost:focus-visible{background:var(--bg-secondary);border-color:var(--border-color-light)}.landing-hero-showcase{position:relative;display:grid;gap:16px}.landing-hero-orb{display:none}.landing-hero-card{position:relative;padding:24px;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-secondary);box-shadow:var(--shadow-md);transition:all var(--transition-base)}.landing-hero-card:hover{border-color:var(--border-color-light);box-shadow:var(--shadow-lg)}.landing-hero-card.primary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color-light)}.landing-hero-card.secondary{background:var(--bg-secondary);color:var(--text-primary)}.landing-hero-card-title{font-weight:700;font-size:1.1rem;display:flex;align-items:center;gap:8px;color:var(--text-primary)}.landing-hero-card-body{margin:10px 0 0;line-height:1.6;color:var(--text-secondary)}.landing-hero-stats{padding:20px;border-radius:var(--radius-lg);border:1px solid var(--border-color);background:var(--bg-secondary);box-shadow:var(--shadow-md);display:grid;gap:14px}.landing-hero-stat{display:flex;align-items:baseline;gap:12px}.landing-hero-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.landing-hero-stat-label{font-weight:500;color:var(--text-secondary);font-size:.9rem}.landing-hero-progress{position:relative;height:8px;border-radius:var(--radius-full);background:var(--border-color);overflow:hidden}.landing-hero-progress-fill{display:block;height:100%;width:var(--progress, 80%);background:var(--color-primary);border-radius:inherit;transition:width .3s ease}.landing-main{display:flex;flex-direction:column;gap:clamp(80px,12vw,140px)}.landing-section{max-width:1200px;margin:0 auto;padding:0 clamp(20px,5vw,48px);display:flex;flex-direction:column;gap:clamp(28px,5vw,44px);scroll-margin-top:120px}.landing-section-header{display:flex;flex-direction:column;gap:16px;max-width:640px}.landing-section-header h2{margin:0;font-size:clamp(1.9rem,4vw,2.6rem);color:var(--text-primary);font-weight:700}.landing-section-header p{margin:0;color:var(--text-secondary);line-height:1.65}.landing-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(20px,4vw,28px)}.landing-feature-card{padding:28px;border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.landing-feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--border-color-light)}.landing-feature-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-md);background:var(--bg-input);font-size:1.5rem}.landing-feature-card h3{margin:0;font-size:1.25rem;color:var(--text-primary);font-weight:700}.landing-feature-card p{margin:0;color:var(--text-secondary);line-height:1.6}.landing-step-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(20px,4vw,28px);padding:0;margin:0;list-style:none}.landing-step-item{padding:24px;border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);display:flex;gap:16px;transition:all var(--transition-base)}.landing-step-item:hover{box-shadow:var(--shadow-md);border-color:var(--border-color-light)}.landing-step-number{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;border-radius:var(--radius-md);background:var(--bg-input);border:1px solid var(--border-color);font-size:1.1rem;font-weight:700;color:var(--color-primary)}.landing-step-content{position:relative;z-index:1;display:flex;flex-direction:column;gap:10px}.landing-step-content h3{margin:0;font-size:1.25rem;color:var(--text-primary);font-weight:700}.landing-step-content p{margin:0;color:var(--text-secondary);line-height:1.65}.landing-pricing{width:100%}.landing-cta{position:relative;z-index:3;padding:0 clamp(24px,5vw,40px) clamp(60px,10vw,100px)}.landing-cta-card{max-width:1200px;margin:0 auto;padding:clamp(40px,8vw,60px);border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);display:flex;align-items:center;justify-content:space-between;gap:clamp(24px,4vw,40px);flex-wrap:wrap;box-shadow:var(--shadow-lg)}.landing-cta-card>div{max-width:600px;display:flex;flex-direction:column;gap:14px}.landing-cta-card h2{margin:0;font-size:clamp(1.8rem,5vw,2.5rem);font-weight:700;color:var(--text-primary)}.landing-cta-card p{margin:0;font-size:clamp(1rem,2vw,1.1rem);line-height:1.6;color:var(--text-secondary)}.landing-cta-button{align-self:flex-start;padding:12px 28px;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;font-weight:600;text-decoration:none;transition:background var(--transition-fast)}.landing-cta-button:hover,.landing-cta-button:focus-visible{background:var(--color-primary-hover)}.landing-testimonials{position:relative}.landing-testimonial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:clamp(24px,4vw,32px);margin-top:clamp(32px,6vw,48px)}.landing-testimonial-card{padding:28px;border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.landing-testimonial-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-color-light)}.landing-testimonial-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.landing-testimonial-avatar{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--bg-input);border:1px solid var(--border-color);font-size:1.5rem}.landing-testimonial-info{flex:1}.landing-testimonial-info h4{margin:0 0 4px;font-size:1.2rem;font-weight:700;color:var(--text-primary)}.landing-testimonial-info p{margin:0 0 8px;color:var(--text-secondary);font-size:.9rem;font-weight:500}.landing-testimonial-rating{display:flex;gap:2px;font-size:.85rem}.landing-testimonial-quote{margin:0;font-size:clamp(.95rem,2vw,1.05rem);line-height:1.6;color:var(--text-secondary)}@media (max-width: 1024px){.landing-nav{grid-template-columns:1fr;justify-items:stretch;row-gap:18px}.landing-nav-links{justify-content:space-between}.landing-hero-content{grid-template-columns:1fr}.landing-hero-showcase{order:-1}.landing-hero-copy{text-align:left}}@media (max-width: 768px){.landing{gap:clamp(40px,6vw,60px)}.landing-hero{padding:clamp(140px,18vw,160px) 0 clamp(40px,8vw,80px)}.landing-hero-content{grid-template-columns:1fr;gap:32px}.landing-hero-showcase{order:-1}.landing-testimonial-grid{grid-template-columns:1fr;gap:20px}.landing-feature-grid,.landing-step-list{grid-template-columns:1fr}}@media (max-width: 640px){.landing-nav{grid-template-columns:1fr;gap:12px}.landing-nav-links{justify-content:space-between;gap:16px;font-size:.9rem}.landing-nav-cta{width:100%;text-align:center}.landing-hero-copy h1{font-size:clamp(2rem,8vw,2.5rem)}.landing-hero-actions{flex-direction:column}.landing-hero-btn{width:100%;justify-content:center}.landing-cta-card{padding:32px 24px}.landing-cta-button{width:100%;text-align:center}}.profile-container{width:100%;max-width:800px;margin:0 auto;padding:var(--spacing-xl);background:transparent}.profile-header{display:flex;align-items:center;margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:var(--spacing-md)}.profile-header h1{flex:1;font-size:2rem;color:var(--text-primary);margin:0;font-weight:700}.profile-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid var(--border-color)}.profile-user-info{flex:1;min-width:200px}.profile-user-info h2{margin:0 0 var(--spacing-xs);font-size:1.25rem;color:var(--text-primary);font-weight:700}.profile-user-info p{margin:0;color:var(--text-secondary);font-size:.95rem}.profile-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.1rem;color:var(--text-secondary)}.profile-error{background-color:#ef44441a;color:var(--color-danger);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border:1px solid var(--color-danger)}.profile-success{background-color:#10a37f1a;color:var(--color-primary);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border:1px solid var(--color-primary)}.profile-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-section{background:var(--bg-secondary);padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.form-section h3{font-size:1.15rem;margin:0 0 var(--spacing-lg);color:var(--text-primary);font-weight:700}.checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-sm)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:.95rem;color:var(--text-secondary);padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.checkbox-label:hover{background-color:var(--bg-hover);color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.profile-input{width:100%;max-width:300px;padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--border-color);font-size:1rem;color:var(--text-primary);background-color:var(--bg-input);transition:all var(--transition-fast);font-family:var(--font-sans)}.profile-input::placeholder{color:var(--text-tertiary)}.profile-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.profile-select{width:100%;max-width:320px;padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--border-color);font-size:1rem;color:var(--text-primary);background-color:var(--bg-input);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;font-family:var(--font-sans)}.profile-select:hover{background-color:var(--bg-hover);border-color:var(--border-color-light)}.profile-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.profile-select:disabled{cursor:not-allowed;opacity:.5}.profile-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg);flex-wrap:wrap}.profile-save-btn,.profile-logout-btn{padding:12px 24px;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:none;font-family:var(--font-sans)}.profile-save-btn{background-color:var(--color-primary);color:#fff;box-shadow:var(--shadow-md)}.profile-save-btn:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:var(--shadow-lg)}.profile-save-btn:disabled{opacity:.5;cursor:not-allowed}.profile-logout-btn{background-color:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.profile-logout-btn:hover{background-color:var(--bg-hover);border-color:var(--border-color-light)}@media (max-width: 768px){.profile-container{padding:var(--spacing-md)}}@media (max-width: 640px){.profile-container{padding:var(--spacing-sm)}.profile-header{flex-direction:column;align-items:center;text-align:center}.profile-avatar{margin:0 auto var(--spacing-md)}.profile-user-info{width:100%;text-align:center}.checkbox-group{grid-template-columns:1fr}.profile-actions{flex-direction:column}.profile-save-btn,.profile-logout-btn{width:100%}.profile-select,.profile-input{max-width:100%}}.ingredient-text-input{max-width:800px;margin:0 auto;padding:20px;background-color:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-md);color:var(--text-primary)}.ingredient-text-input h2{color:var(--text-primary);margin-bottom:10px;font-size:1.8rem}.ingredient-text-input-description{color:var(--text-secondary);margin-bottom:20px;font-size:1rem}.ingredient-text-area-container{margin-bottom:15px}.ingredient-text-area{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;resize:vertical;font-family:inherit;background-color:var(--bg-input);color:var(--text-primary);transition:border-color var(--transition-base),box-shadow var(--transition-base),background-color var(--transition-base)}.ingredient-text-area::placeholder{color:var(--text-tertiary)}.ingredient-text-area:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #10a37f26;background-color:var(--bg-input)}.ingredient-text-actions{display:flex;gap:10px;margin-bottom:20px}.ingredient-extract-btn,.ingredient-reset-btn,.ingredient-add-btn,.ingredient-delete-btn{padding:10px 15px;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s;border:1px solid transparent}.ingredient-extract-btn{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff;flex:1}.ingredient-extract-btn:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.ingredient-extract-btn:disabled{background-color:#10a37f59;border-color:#10a37f59;cursor:not-allowed}.ingredient-reset-btn{background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--border-color)}.ingredient-reset-btn:hover{background-color:var(--bg-input);border-color:var(--border-color-light)}.ingredient-reset-btn:disabled{background-color:var(--bg-secondary);color:var(--text-disabled);border-color:var(--border-color);cursor:not-allowed}.ingredient-error{color:#ef4444;margin:10px 0;font-size:.9rem}.ingredient-results{margin-top:30px}.ingredient-results h3{color:var(--text-primary);margin-bottom:15px;font-size:1.4rem;border-bottom:1px solid var(--border-color);padding-bottom:8px}.ingredient-table th{text-align:left;padding:10px;background-color:var(--bg-hover);border-bottom:1px solid var(--border-color);color:var(--text-primary);font-weight:600}.ingredient-table td{padding:8px 10px;border-bottom:1px solid var(--border-color)}.ingredient-table input{width:100%;padding:8px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;background-color:var(--bg-input);color:var(--text-primary);transition:border-color var(--transition-base),box-shadow var(--transition-base),background-color var(--transition-base)}.ingredient-table input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #10a37f1f;background-color:var(--bg-input)}.ingredient-delete-btn{background-color:#ef444414;color:var(--color-danger);border-color:#ef444433;padding:6px 10px;font-size:.85rem}.ingredient-delete-btn:hover{background-color:#ef444426;border-color:#ef444459}.ingredient-add-btn{background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--border-color);display:block;margin:15px 0}.ingredient-add-btn:hover{background-color:var(--bg-input);border-color:var(--border-color-light)}@media (max-width: 768px){.ingredient-text-input{padding:15px}.ingredient-table{display:block;overflow-x:auto}.ingredient-text-actions{flex-direction:column}.ingredient-extract-btn,.ingredient-reset-btn{width:100%}}.voice-recipe-generator-integrated{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin:1rem 0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;box-shadow:var(--shadow-md)}.voice-header{text-align:center;margin-bottom:1.5rem}.voice-header h2{color:var(--color-text-primary);margin-bottom:.5rem;font-size:1.5rem}.voice-header p{color:var(--color-text-tertiary);font-size:1rem;margin:0}.progress-container{margin-bottom:1.5rem}.progress-bar{width:100%;height:6px;background:#94a3b838;border-radius:3px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#f97316,#fb7185);transition:width .5s ease;border-radius:3px}.progress-text{text-align:center;color:#374151;font-weight:500;margin:0;font-size:.875rem}.voice-controls{display:flex;justify-content:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.record-btn,.reset-btn{padding:.75rem 1.5rem;border:none;border-radius:2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:150px}.start-recording{background:linear-gradient(135deg,#f97316,#fb923c);color:#fff;box-shadow:0 2px 12px #f9731659}.start-recording:hover{transform:translateY(-1px);box-shadow:0 4px 15px #f9731673}.stop-recording{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 10px #ef44444d;animation:pulse 2s infinite}.stop-recording:hover{transform:translateY(-1px);box-shadow:0 4px 15px #ef444466}.processing{background:#9ca3af;color:#fff;cursor:not-allowed}.reset-btn{background:#475569;color:var(--color-text-primary)}.reset-btn:hover{background:#334155}@keyframes pulse{0%{box-shadow:0 2px 10px #ef44444d}50%{box-shadow:0 2px 15px #ef444499}to{box-shadow:0 2px 10px #ef44444d}}.audio-playback{background:#0f172a99;padding:1rem;border-radius:.5rem;margin-bottom:1rem;text-align:center;border:1px solid rgba(148,163,184,.16)}.audio-playback h4{margin-top:0;margin-bottom:.75rem;color:var(--color-text-secondary);font-size:.875rem}.transcript-display{background:#3b82f614;border:1px solid rgba(59,130,246,.2);padding:1rem;border-radius:.5rem;margin-bottom:1rem}.transcript-display h4{margin-top:0;margin-bottom:.75rem;color:#bfdbfe;font-size:.875rem}.transcript-text{background:#0f172ab3;padding:.75rem;border-radius:.375rem;border:1px solid rgba(59,130,246,.2);font-style:italic;color:var(--color-text-secondary);font-size:.875rem}.error-display{background:#fef2f2;border:1px solid #fecaca;padding:1rem;border-radius:.5rem;margin-bottom:1rem;text-align:center}.error-display p{color:#dc2626;margin-bottom:.75rem;font-weight:500;font-size:.875rem}.retry-btn{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-weight:500;font-size:.875rem}.retry-btn:hover{background:#dc2626}.voice-tips{background:#7c3aed14;border:1px solid rgba(124,58,237,.18);padding:1rem;border-radius:.5rem;margin-top:1rem}.voice-tips h4{margin-top:0;margin-bottom:.75rem;color:#c4b5fd;font-size:.875rem}.voice-tips ul{margin:0;padding-left:1.25rem;color:#e0e7ff}.voice-tips li{margin-bottom:.25rem;font-size:.875rem}.extracted-ingredients{background:#3b82f614;border:1px solid rgba(148,163,184,.18);padding:1rem;border-radius:.5rem;margin-bottom:1rem}.extracted-ingredients h4{margin-top:0;margin-bottom:.75rem;color:var(--color-text-primary);font-size:1.4rem;border-bottom:1px solid rgba(148,163,184,.18);padding-bottom:8px}.ingredient-table{width:100%;border-collapse:collapse;margin-bottom:20px}.ingredient-table th{text-align:left;padding:10px;background-color:#94a3b814;border-bottom:1px solid rgba(148,163,184,.18);color:var(--color-text-secondary);font-weight:600}.ingredient-table td{padding:8px 10px;border-bottom:1px solid rgba(148,163,184,.12)}.ingredient-table input{width:100%;padding:8px;border:1px solid rgba(148,163,184,.32);border-radius:4px;font-size:.9rem;background:#0f172a99;color:var(--color-text-primary)}.ingredient-table input:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 2px #93c5fd1a}.ingredient-delete-btn{background-color:#fee2e2;color:#ef4444;padding:6px 10px;font-size:.85rem;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.ingredient-delete-btn:hover{background-color:#fecaca}.ingredient-add-btn{background:linear-gradient(135deg,#7c3aed,#38bdf8);color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:background-color .2s;margin-bottom:.75rem}.ingredient-add-btn:hover{background:linear-gradient(135deg,#6d28d9,#0ea5e9)}.ingredients-note{color:var(--color-text-secondary);font-size:.875rem;font-style:italic;margin:0;background:#7c3aed14;padding:.5rem;border-radius:.25rem;border:1px solid rgba(124,58,237,.18)}@media (max-width: 768px){.voice-recipe-generator-integrated{padding:1rem}.voice-controls{flex-direction:column;align-items:center}.record-btn,.reset-btn{min-width:140px;padding:.625rem 1.25rem}}@media (max-width: 768px){.ingredient-table{font-size:.8rem}.ingredient-table th,.ingredient-table td,.ingredient-table input{padding:5px}.ingredient-delete-btn{padding:4px 8px;font-size:.7rem}}.photo-ingredient-input{margin-top:1em}.hidden-file-input{display:none}.photo-actions{display:flex;flex-wrap:wrap;gap:.75em;margin:.75em 0}.upload-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5em 1em;border:1px solid #d1d5db;border-radius:8px;background-color:#f9fafb;color:#111827;cursor:pointer;font-weight:600;transition:background-color .2s ease,border-color .2s ease}.upload-btn:hover{background-color:#f3f4f6;border-color:#9ca3af}.camera-btn,.capture-btn,.detect-btn{padding:.5em 1em;border-radius:8px;border:none;font-weight:600;cursor:pointer;background-color:#2563eb;color:#fff;transition:background-color .2s ease}.camera-btn:hover,.capture-btn:hover,.detect-btn:hover{background-color:#1d4ed8}.camera-btn:disabled,.capture-btn:disabled,.detect-btn:disabled{background-color:#9ca3af;cursor:not-allowed}.camera-preview{display:flex;flex-direction:column;align-items:flex-start;gap:.75em;margin-bottom:1em}.camera-preview video{width:100%;max-width:320px;border-radius:12px;background:#000}.photo-preview-container{margin:1em 0;display:flex;flex-wrap:wrap;gap:.75em}.photo-preview{max-width:150px;border-radius:12px;box-shadow:0 4px 12px #0000001a}.detect-btn{margin-top:.5em}.photo-error{color:#b91c1c;margin-top:.5em}.photo-ingredients-list{margin-top:1em;list-style:disc inside}.ingredients-page{width:100%;max-width:800px;margin:0 auto;padding:var(--spacing-lg);min-height:calc(100vh - 100px);display:flex;flex-direction:column}.ingredients-header{text-align:center;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.ingredients-header h1{color:var(--text-primary);font-size:2rem;margin-bottom:10px;font-weight:700}.ingredients-header p{color:var(--text-secondary);font-size:1rem}.input-method-selector{display:flex;justify-content:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-xl);padding:4px;background:var(--bg-input);border-radius:var(--radius-lg);width:fit-content;margin-left:auto;margin-right:auto}.method-btn{padding:10px 20px;border:none;border-radius:var(--radius-md);background-color:transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans)}.method-btn:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.method-btn.active{background-color:var(--bg-secondary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.method-btn:disabled{opacity:.5;cursor:not-allowed}.ingredients-input-container{margin-bottom:var(--spacing-lg)}.placeholder-container{text-align:center;padding:var(--spacing-2xl);background-color:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.placeholder-container p{color:var(--text-secondary);font-size:1rem}.generate-recipe-container{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.generate-recipe-btn{padding:12px 24px;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans);width:100%;max-width:200px;display:block;margin:0 auto}.generate-recipe-btn:hover{background-color:var(--color-primary-hover)}.generate-recipe-btn:disabled{opacity:.5;cursor:not-allowed}.recipe-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md);flex-wrap:wrap;justify-content:center}.save-recipe-btn,.generate-another-recipe-btn,.generate-image-btn,.publish-recipe-btn{background-color:transparent;color:var(--text-primary);border:1px solid var(--border-color);padding:10px 18px;border-radius:var(--radius-md);cursor:pointer;font-size:.9rem;font-weight:500;transition:all var(--transition-fast);font-family:var(--font-sans)}.save-recipe-btn:hover:not(:disabled),.generate-another-recipe-btn:hover:not(:disabled),.generate-image-btn:hover:not(:disabled),.publish-recipe-btn:hover:not(:disabled){background-color:var(--bg-hover);border-color:var(--border-color-light)}.save-recipe-btn:disabled,.generate-another-recipe-btn:disabled,.generate-image-btn:disabled,.publish-recipe-btn:disabled{opacity:.5;cursor:not-allowed}.save-recipe-btn.primary{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.save-recipe-btn.primary:hover:not(:disabled){background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.success-message{color:var(--color-primary);font-weight:500;margin-top:var(--spacing-sm);padding:var(--spacing-md);background-color:#10a37f1a;border:1px solid var(--color-primary);border-radius:var(--radius-md);text-align:center}.error-message{color:var(--color-danger);font-weight:500;margin-top:var(--spacing-sm);padding:var(--spacing-md);background-color:#ef44441a;border:1px solid var(--color-danger);border-radius:var(--radius-md);text-align:center}.saved-recipes-container{margin-top:var(--spacing-xl);padding:var(--spacing-lg);background-color:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.saved-recipes-container h2{color:var(--text-primary);margin-bottom:var(--spacing-md);font-size:1.25rem;font-weight:700}.saved-recipes-container ul{list-style:none;padding:0;margin:0}.saved-recipes-container li{padding:var(--spacing-md);margin-bottom:var(--spacing-sm);background-color:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-color);font-weight:500;color:var(--text-primary);transition:all var(--transition-fast);cursor:pointer}.saved-recipes-container li:hover{background-color:var(--bg-hover);border-color:var(--border-color-light)}.generation-options{margin-bottom:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.image-option{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.9rem;color:var(--text-secondary);cursor:pointer}.image-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary);cursor:pointer}.image-option:hover{color:var(--text-primary)}.selectors-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-lg);width:100%;max-width:900px;margin-left:auto;margin-right:auto}.meal-type-selector,.recipe-type-selector,.cooking-method-selector{font-size:.95rem;color:var(--text-primary)}.meal-type-selector label,.recipe-type-selector label,.cooking-method-selector label{display:flex;flex-direction:column;gap:var(--spacing-sm);font-weight:600;color:var(--text-primary)}.meal-type-selector select,.recipe-type-selector select,.cooking-method-selector select{width:100%;padding:14px 44px 14px 16px;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:1rem;background-color:var(--bg-input);color:var(--text-primary);transition:border-color var(--transition-base),box-shadow var(--transition-base),background-color var(--transition-base),transform var(--transition-fast);cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;font-family:inherit;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23ECECF1' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 14px center;background-repeat:no-repeat;background-size:18px;box-shadow:0 1px 3px #0000001a}.meal-type-selector select:hover,.recipe-type-selector select:hover,.cooking-method-selector select:hover{background-color:var(--bg-input);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.meal-type-selector select:focus,.recipe-type-selector select:focus,.cooking-method-selector select:focus{outline:2px solid var(--color-primary);outline-offset:2px;border-color:var(--color-primary);box-shadow:0 4px 8px #00000026;background-color:var(--bg-input);transform:translateY(-1px)}.meal-type-selector select:disabled,.recipe-type-selector select:disabled,.cooking-method-selector select:disabled{cursor:not-allowed;opacity:.5}.recipe-image-container{text-align:center;margin-bottom:var(--spacing-lg)}.recipe-image{max-width:100%;width:100%;height:auto;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.recipe-history{margin-top:var(--spacing-xl);padding:var(--spacing-lg);background-color:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.recipe-history h3{margin:0 0 var(--spacing-md);color:var(--text-primary);font-size:1.1rem;font-weight:700}.recipe-history-buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.recipe-history-btn{padding:8px 16px;border-radius:var(--radius-full);border:1px solid var(--border-color);background-color:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;font-weight:500;font-family:var(--font-sans)}.recipe-history-btn:hover{border-color:var(--color-primary);color:var(--text-primary);background-color:var(--bg-hover)}.recipe-history-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.recipe-display{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--border-color);margin:var(--spacing-lg) 0}.recipe-display h2,.recipe-display h3{color:var(--text-primary);margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm)}.recipe-display p,.recipe-display li{color:var(--text-secondary);line-height:1.6}.recipe-display ul,.recipe-display ol{padding-left:var(--spacing-lg)}.loading-spinner{display:flex;justify-content:center;align-items:center;padding:var(--spacing-xl);color:var(--text-secondary)}@media (max-width: 768px){.ingredients-page{padding:var(--spacing-md)}.ingredients-header h1{font-size:1.5rem}.input-method-selector{flex-direction:column;width:100%}.method-btn{width:100%}.selectors-row{grid-template-columns:1fr;gap:var(--spacing-md)}.meal-type-selector select,.recipe-type-selector select,.cooking-method-selector select{max-width:100%}.recipe-actions{flex-direction:column}.save-recipe-btn,.generate-another-recipe-btn,.generate-image-btn,.publish-recipe-btn{width:100%}}@media (max-width: 560px){.ingredients-page{padding:var(--spacing-sm)}.recipe-history-buttons{flex-direction:column}.recipe-history-btn{width:100%;text-align:center}}.generated-recipe-container{margin-top:var(--spacing-xl);padding:var(--spacing-lg);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-md)}.generated-recipe-container h2{color:var(--text-primary);margin-bottom:var(--spacing-md);font-size:1.5rem;font-weight:600}.generated-recipe-text{background:var(--bg-input);padding:1.5rem;border-radius:var(--radius-md);border:1px solid var(--border-color);color:var(--text-primary);line-height:1.7;font-size:1rem}.generated-recipe-text p{margin-bottom:1rem}.generated-recipe-text p:last-child{margin-bottom:0}.generated-recipe-text h1,.generated-recipe-text h2,.generated-recipe-text h3{color:var(--text-primary);margin-top:1.5rem;margin-bottom:.75rem}.generated-recipe-text ul,.generated-recipe-text ol{margin:1rem 0;padding-left:1.5rem}.generated-recipe-text li{margin-bottom:.5rem;color:var(--text-primary)}.navbar{width:min(1160px,94%);margin:24px auto 40px;padding:16px clamp(20px,4vw,32px);border-radius:24px;background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;justify-content:space-between;align-items:center;position:sticky;top:20px;z-index:100}.navbar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;border:1px solid var(--border-color-light)}.navbar-brand{display:flex;align-items:center;gap:14px}.brand-link{display:inline-flex;align-items:center;gap:16px;text-decoration:none;color:var(--text-primary)}.brand-logo-wrap{display:inline-flex;width:52px;height:52px;border-radius:18px;padding:4px;background:var(--bg-input);box-shadow:var(--shadow-md)}.brand-logo{width:100%;height:100%;border-radius:14px}.brand-copy{display:flex;flex-direction:column;gap:4px}.brand-name{font-size:1.4rem;font-weight:700;letter-spacing:.01em;color:var(--text-primary)}.brand-tagline{font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);font-weight:600}.navbar-links{display:flex;align-items:center;gap:clamp(16px,3vw,28px)}.navbar-link{position:relative;color:var(--text-secondary);text-decoration:none;font-weight:600;font-size:.98rem;padding:10px 14px;border-radius:12px;transition:color .2s ease}.navbar-link:after{content:"";position:absolute;inset:auto 14px -10px;height:3px;border-radius:999px;background:var(--color-primary);transform:scaleX(0);transform-origin:left;transition:transform .2s ease}.navbar-link:hover{color:var(--text-primary)}.navbar-link:hover:after,.navbar-link.active:after{transform:scaleX(1)}.navbar-link.active{color:var(--color-primary);background:var(--bg-input)}.logout-btn{padding:10px 18px;border-radius:16px;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.logout-btn:hover{transform:translateY(-2px);background:var(--color-primary);border-color:var(--color-primary);box-shadow:var(--shadow-lg);color:#fff}.language-switcher{display:inline-flex;align-items:center;gap:10px;padding:6px;border-radius:999px;background:var(--bg-input);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.lang-btn{border:none;background:transparent;padding:6px 12px;border-radius:999px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background .2s ease,color .2s ease}.lang-btn:hover{background:var(--bg-hover);color:var(--text-primary)}@media (max-width: 900px){.navbar{flex-direction:column;align-items:flex-start;gap:16px}.navbar-links{flex-wrap:wrap;gap:12px;width:100%}.language-switcher{margin-left:auto}}@media (max-width: 640px){.navbar{position:static;top:auto;width:calc(100% - 32px);margin:12px auto 24px;padding:14px 16px;border-radius:18px}.brand-logo-wrap{width:46px;height:46px}.brand-name{font-size:1.2rem}.brand-tagline{font-size:.72rem}.navbar-links{flex-direction:column;align-items:stretch}.navbar-link{width:100%}.language-switcher{width:100%;justify-content:center}}
