*{box-sizing:border-box;margin:0;padding:0}body{color:#e2e8f0;background:#0c0f1a;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}a{color:#fb923c;text-decoration:none}a:hover{text-decoration:underline}.loading{justify-content:center;align-items:center;height:100vh;display:flex}.loading-spinner{border:3px solid #2a2f45;border-top-color:#f97316;border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.spinner{animation:1.5s ease-in-out infinite pulse}button{cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;transition:all .2s}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:12px;padding:.85rem 2rem;font-size:1rem;font-weight:600;box-shadow:0 4px 16px #f973164d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px #f9731666}.btn-primary-sm{color:#fff;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:8px;padding:.5rem 1.2rem;font-weight:600}.btn-ghost{color:#94a3b8;background:0 0;border:1px solid #2a2f45;border-radius:12px;padding:.85rem 2rem;font-size:1rem}.btn-ghost:hover{color:#e2e8f0;background:#1a1f35}.btn-ghost-sm{color:#94a3b8;background:0 0;border:none;padding:.4rem .8rem;font-size:.85rem}.btn-secondary{color:#94a3b8;background:#1e2235;border:1px solid #2a2f45;padding:.45rem .9rem;font-size:.82rem}.btn-secondary:hover{color:#e2e8f0;background:#252a40}.btn-danger{color:#f87171;background:#ef44441a;border:1px solid #ef444433;padding:.35rem .7rem;font-size:.8rem}.btn-danger:hover{background:#ef444433}.error{color:#f87171;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;padding:.6rem .8rem;font-size:.85rem}.landing{background:#0c0f1a;min-height:100vh}.landing-nav{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;padding:1.25rem 2rem;display:flex}.landing-logo{background:linear-gradient(135deg,#f97316,#fb923c);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.4rem;font-weight:700}.hero{grid-template-columns:1fr 1fr;align-items:center;gap:3rem;max-width:1100px;margin:0 auto;padding:4rem 2rem 5rem;display:grid}.hero-content h1{letter-spacing:-1px;background:linear-gradient(135deg,#fff 30%,#94a3b8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.25rem;font-size:3rem;font-weight:800;line-height:1.15}.hero-sub{color:#64748b;max-width:440px;margin-bottom:2rem;font-size:1.1rem;line-height:1.7}.hero-actions{gap:1rem;display:flex}.hero-visual{justify-content:center;display:flex}.hero-card{background:linear-gradient(145deg,#1a1f35,#141827);border:1px solid #2a2f45;border-radius:20px;width:320px;padding:2rem;animation:.6s fadeIn;box-shadow:0 12px 48px #0006,0 0 120px #f973160f}.hero-card-img{text-align:center;filter:drop-shadow(0 4px 12px #0000004d);margin-bottom:1.25rem;font-size:5rem}.hero-card-text{flex-direction:column;gap:.3rem;display:flex}.hero-card-label{color:#22c55e;text-transform:uppercase;letter-spacing:1px;font-size:.75rem;font-weight:600}.hero-card-dish{color:#e2e8f0;font-size:1.2rem;font-weight:600}.hero-card-meta{color:#64748b;font-size:.85rem}.features{max-width:1100px;margin:0 auto;padding:3rem 2rem 5rem}.features h2{text-align:center;text-transform:uppercase;letter-spacing:2px;color:#64748b;margin-bottom:2.5rem;font-size:.85rem}.features-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem;display:grid}.feature-card{text-align:center;background:linear-gradient(145deg,#1a1f35,#141827);border:1px solid #2a2f45;border-radius:14px;padding:1.5rem;transition:border-color .2s}.feature-card:hover{border-color:#3a3f55}.feature-icon{margin-bottom:.75rem;font-size:2rem}.feature-card h3{color:#e2e8f0;margin-bottom:.4rem;font-size:1rem}.feature-card p{color:#64748b;font-size:.85rem;line-height:1.5}.landing-footer{text-align:center;color:#334155;border-top:1px solid #1a1e2e;padding:2rem;font-size:.82rem}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;background:#000000b3;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.auth-card{background:linear-gradient(145deg,#1a1f35,#141827);border:1px solid #2a2f45;border-radius:20px;width:100%;max-width:400px;padding:2.5rem;position:relative;box-shadow:0 8px 40px #00000080}.modal-close{color:#64748b;background:0 0;border:none;padding:.25rem .5rem;font-size:1.5rem;line-height:1;position:absolute;top:1rem;right:1rem}.modal-close:hover{color:#e2e8f0}.auth-card .logo-icon{text-align:center;margin-bottom:.5rem;font-size:2.5rem}.auth-card h1{background:linear-gradient(135deg,#f97316,#fb923c);-webkit-text-fill-color:transparent;text-align:center;-webkit-background-clip:text;background-clip:text;margin-bottom:.25rem;font-size:1.8rem;font-weight:700}.auth-card .subtitle{text-align:center;color:#64748b;margin-bottom:1.5rem;font-size:.9rem}.auth-card form{flex-direction:column;gap:.75rem;display:flex}.auth-card input{color:#e2e8f0;background:#0c0f1a;border:1px solid #2a2f45;border-radius:10px;padding:.8rem 1rem;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.auth-card input:focus{border-color:#f97316;outline:none;box-shadow:0 0 0 3px #f973161f}.auth-card input::placeholder{color:#475569}.auth-card button[type=submit]{color:#fff;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:10px;margin-top:.25rem;padding:.85rem;font-size:.95rem;font-weight:600;box-shadow:0 4px 16px #f9731640}.auth-card button[type=submit]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #f9731659}.toggle{text-align:center;color:#64748b;margin-top:1rem;font-size:.85rem}.dashboard{flex-direction:column;height:100vh;display:flex}.dashboard header{z-index:10;background:#111422;border-bottom:1px solid #1e2235;flex-shrink:0;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex}.dashboard header h1{background:linear-gradient(135deg,#f97316,#fb923c);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:700}.header-center{text-align:center;flex:1}.upload-btn-header{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:8px;align-items:center;gap:.4rem;padding:.5rem 1.2rem;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 2px 10px #f9731633}.upload-btn-header:hover{transform:translateY(-1px);box-shadow:0 4px 16px #f973164d}.header-right{align-items:center;gap:.75rem;display:flex}.username{color:#64748b;font-size:.82rem}.toast-error{color:#f87171;z-index:50;background:#ef444426;border:1px solid #ef44444d;border-radius:10px;align-items:center;gap:.75rem;padding:.6rem 1rem;font-size:.85rem;animation:.3s fadeIn;display:flex;position:fixed;top:4.5rem;left:50%;transform:translate(-50%)}.toast-error button{color:#f87171;cursor:pointer;background:0 0;border:none;padding:0;font-size:1.1rem}.upload-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:50;background:#000000bf;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.upload-overlay-inner{text-align:center}.upload-overlay-inner img{opacity:.6;border-radius:16px;max-width:280px;max-height:280px;margin-bottom:1.5rem}.upload-overlay-text{flex-direction:column;align-items:center;gap:.75rem;display:flex}.upload-overlay-text p{color:#94a3b8;font-size:.9rem}.workspace{flex:1;grid-template-columns:340px 1fr;display:grid;overflow:hidden}.history-panel{background:#111422;border-right:1px solid #1e2235;flex-direction:column;display:flex;overflow:hidden}.panel-header{border-bottom:1px solid #1a1e2e;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.panel-header h2{color:#94a3b8;text-transform:uppercase;letter-spacing:1.5px;font-size:.8rem;font-weight:600}.badge{color:#64748b;background:#1e2235;border-radius:10px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.history-list{flex:1;padding:.5rem 0;overflow-y:auto}.history-list::-webkit-scrollbar{width:4px}.history-list::-webkit-scrollbar-track{background:0 0}.history-list::-webkit-scrollbar-thumb{background:#2a2f45;border-radius:4px}.history-row{cursor:pointer;border-left:3px solid #0000;align-items:center;gap:.75rem;padding:.65rem 1.25rem;transition:background .15s;display:flex}.history-row:hover{background:#1a1e2e}.history-row.active{background:#1a1e2e;border-left-color:#f97316}.history-thumb{object-fit:cover;border-radius:8px;flex-shrink:0;width:44px;height:44px}.history-row-info{flex-direction:column;gap:.15rem;min-width:0;display:flex;overflow:hidden}.history-row-title{color:#cbd5e1;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:500;overflow:hidden}.history-row-date{color:#475569;font-size:.72rem}.empty-state{color:#475569;text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.empty-hint{color:#334155;margin-top:.25rem;font-size:.82rem}.recipe-panel{flex-direction:column;display:flex;overflow:hidden}.recipe-image-wrap{border-bottom:1px solid #1e2235;flex-shrink:0;max-height:300px;overflow:hidden}.recipe-image{object-fit:cover;width:100%;height:100%;max-height:300px;display:block}.recipe-content{flex:1;padding:1.5rem 2rem;overflow-y:auto}.recipe-content::-webkit-scrollbar{width:4px}.recipe-content::-webkit-scrollbar-track{background:0 0}.recipe-content::-webkit-scrollbar-thumb{background:#2a2f45;border-radius:4px}.recipe-text{white-space:pre-wrap;color:#b8c0d0;margin-bottom:1.5rem;font-family:inherit;font-size:.9rem;line-height:1.8}.recipe-footer{border-top:1px solid #1e2235;justify-content:space-between;align-items:center;padding-top:1rem;display:flex}.recipe-date{color:#475569;font-size:.78rem}.empty-recipe{color:#475569;text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.5rem;display:flex}.empty-recipe-icon{opacity:.4;margin-bottom:.5rem;font-size:3rem}.empty-recipe h3{color:#64748b;font-size:1.1rem}.empty-recipe p{color:#475569;font-size:.85rem}.mobile-detail{display:none}@media (width<=900px){.hero{text-align:center;grid-template-columns:1fr;padding:3rem 1.5rem}.hero-content h1{font-size:2.2rem}.hero-sub{margin:0 auto 1.5rem}.hero-actions{justify-content:center}.hero-visual{margin-top:1rem}.features-grid{grid-template-columns:repeat(2,1fr)}.workspace{grid-template-columns:260px 1fr}}@media (width<=640px){.hero-content h1{font-size:1.8rem}.hero-actions{flex-direction:column;align-items:center}.hero-card{width:260px;padding:1.5rem}.hero-card-img{font-size:3.5rem}.features-grid{grid-template-columns:1fr 1fr;gap:.75rem}.feature-card{padding:1.25rem 1rem}.feature-card h3{font-size:.9rem}.feature-card p{font-size:.8rem}.landing-nav{padding:1rem 1.25rem}.dashboard header{padding:.6rem 1rem}.dashboard header h1{font-size:1rem}.username{display:none}.upload-btn-header{padding:.4rem .9rem;font-size:.8rem}.workspace{grid-template-columns:1fr}.recipe-panel{display:none}.history-panel{border-right:none}.mobile-detail{z-index:40;background:#0c0f1a;flex-direction:column;animation:.2s fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.mobile-detail-header{z-index:1;background:#0c0f1a;border-bottom:1px solid #1e2235;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex;position:sticky;top:0}.mobile-detail-img{object-fit:cover;width:100%;max-height:280px}.mobile-detail-body{flex:1;padding:1.25rem}.mobile-detail-body .recipe-text{margin-bottom:1rem}.mobile-detail-body .recipe-date{border-top:1px solid #1e2235;padding-top:.75rem;display:block}}@media (width<=380px){.hero-content h1{font-size:1.5rem}.features-grid{grid-template-columns:1fr}.auth-card{padding:1.75rem 1.25rem}}
