@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";*{box-sizing:border-box}body{margin:0;display:flex;justify-content:center;align-items:center;min-width:320px;min-height:100vh;background-color:#f2f4f6;font-family:-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Pretendard,Roboto,Helvetica Neue,Arial,sans-serif}#root{width:100%;max-width:480px;height:100vh;margin:0 auto;background-color:#fff;box-shadow:0 4px 20px #0000000d;display:flex;flex-direction:column;overflow-y:auto}:root{--primary: #1A1A1A;--primary-light: #333333;--accent: #2ecc71;--accent-soft: rgba(46, 204, 113, .1);--bg-white: #FFFFFF;--bg-gray: #F9F9F9;--text-dark: #111111;--text-muted: #666666;--border: #EEEEEE;--transition: all .3s cubic-bezier(.4, 0, .2, 1);--glass: rgba(255, 255, 255, .85)}*{box-sizing:border-box;-webkit-font-smoothing:antialiased}body{margin:0;font-family:Outfit,sans-serif;color:var(--text-dark);background-color:#f0f2f5;overflow-x:hidden;width:100%}.app-wrapper{position:relative;min-height:100vh;width:100%}.bg-blur-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;background-size:cover;background-position:center;filter:blur(40px) brightness(1.05);opacity:.25;transition:background-image 1s ease-in-out}.bg-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;background:radial-gradient(circle at center,transparent,rgba(0,0,0,.02))}.content-panel{width:100%;min-height:100vh;display:flex;flex-direction:column}.main-nav{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;position:sticky;top:0;background-color:var(--glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:100;border-bottom:1px solid rgba(0,0,0,.05);box-shadow:0 4px 12px #00000008}@media(max-width:768px){.main-nav{padding:14px 20px}}.nav-logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;letter-spacing:-1px;color:var(--text-dark);text-decoration:none}.nav-logo-img{height:36px;width:36px;object-fit:cover;border-radius:8px}.nav-links{display:flex;gap:28px}@media(max-width:640px){.nav-links{gap:16px}.nav-link{font-size:13px}}.nav-link{text-decoration:none;font-size:15px;font-weight:700;color:var(--text-muted);transition:var(--transition);cursor:pointer}.nav-link:hover,.nav-link.active{color:var(--text-dark)}.hero-banner{width:100%;padding:48px 40px 40px;background-size:cover;background-position:center;position:relative;overflow:hidden}.hero-banner:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,#ffffffbf,#ffffffeb)}.hero-banner .hero-content{position:relative;z-index:1;max-width:1200px;margin:0 auto}@media(max-width:768px){.hero-banner{padding:32px 20px 28px}}.main-container{padding:40px 24px 64px;max-width:1200px;margin:0 auto;width:100%;animation:slideUp .8s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.responsive-title{font-size:clamp(18px,3.2vw,30px);font-weight:800;margin-bottom:8px;letter-spacing:-1px;line-height:1.2;color:var(--text-dark);white-space:nowrap}.subtitle{font-size:clamp(14px,2.5vw,17px);color:var(--text-muted);margin-bottom:0;line-height:1.6}.gender-checkbox-group{display:flex;gap:24px;align-items:center}.gender-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:15px;font-weight:600;color:var(--text-muted);transition:var(--transition)}.gender-checkbox-label.selected{color:var(--text-dark)}.gender-checkbox{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;transition:var(--transition);flex-shrink:0}.gender-checkbox.checked{border-color:var(--accent);background-color:var(--accent)}.gender-checkbox.checked:after{content:"✓";color:#fff;font-size:12px;font-weight:800}.planner-form{display:grid;grid-template-columns:1fr;gap:24px;background:#fff;padding:40px;border-radius:20px;box-shadow:0 10px 40px #0000000a}@media(min-width:768px){.planner-form{grid-template-columns:repeat(2,1fr);gap:28px}.full-width{grid-column:span 2}}@media(max-width:640px){.planner-form{padding:24px}}.input-group{display:flex;flex-direction:column;gap:8px}.input-group label{font-size:12px;font-weight:800;text-transform:uppercase;color:var(--text-muted);letter-spacing:.8px}.input-group input,.input-group select,.input-group textarea{padding:14px 18px;font-size:15px;border:2px solid var(--border);border-radius:12px;font-family:inherit;transition:var(--transition);background-color:var(--bg-white);width:100%}.input-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #00000005}.cta-button{padding:18px;font-size:16px;font-weight:800;border-radius:14px;border:none;cursor:pointer;transition:var(--transition)}.primary-cta{background-color:var(--primary);color:#fff}.primary-cta:hover{background-color:#000;transform:translateY(-2px);box-shadow:0 10px 30px #00000026}.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;max-width:440px;margin:0 auto}.google-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:16px;margin-top:24px;background-color:#fff;border:1px solid var(--border);border-radius:12px;font-weight:700;cursor:pointer;transition:var(--transition);font-family:inherit;font-size:15px}.google-btn:hover{background-color:var(--bg-gray)}.google-icon{width:18px;height:18px}.premium-hero{text-align:left;margin-bottom:0}.premium-badge{display:inline-block;padding:5px 14px;background-color:var(--accent);color:#fff;border-radius:50px;font-size:11px;font-weight:800;margin-bottom:12px}.feature-grid.vertical-stack{display:flex;flex-direction:column;gap:28px;margin-bottom:64px}.feature-card{position:relative;border-radius:20px;overflow:hidden;min-height:220px;display:flex;flex-direction:column;justify-content:flex-end;padding:32px;transition:var(--transition)}.feature-card:hover{transform:translateY(-3px);box-shadow:0 15px 45px #0000001f}.feature-card .feature-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;filter:blur(3px);transform:scale(1.02)}.feature-card .feature-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,#000000bf,#00000040,#0000000d)}.feature-card .feature-info{position:relative;z-index:1;color:#fff}.feature-card .feature-info h3{font-size:22px;font-weight:800;margin:0 0 8px}.feature-card .feature-info p{font-size:15px;margin:0;opacity:.9;line-height:1.5}.pricing-card{background-color:var(--primary);color:#fff;padding:48px;border-radius:24px;text-align:center;max-width:560px;margin:0 auto}.price{font-size:40px;font-weight:800;margin:16px 0}.price span{font-size:18px;font-weight:400;opacity:.6}.result-header-img{width:100%;height:200px;border-radius:16px;object-fit:cover;margin-bottom:24px}.meal-grid{display:grid;gap:16px}@media(min-width:768px){.meal-grid{grid-template-columns:1fr 1fr}}.meal-card{background-color:#fff;padding:24px;border-radius:16px;box-shadow:0 2px 12px #00000008}.meal-time{font-size:12px;font-weight:800;color:var(--accent);margin-bottom:4px}.meal-title{font-size:17px;font-weight:800;margin-bottom:8px}.history-grid{display:grid;gap:16px}.history-item{padding:20px;border:1px solid var(--border);border-radius:16px;cursor:pointer;background:#fff;transition:var(--transition)}.history-item:hover{border-color:var(--text-dark)}.success-container{max-width:540px;margin:0 auto;background:#fff;padding:56px;border-radius:28px;box-shadow:0 20px 60px #0000000d;text-align:center;display:flex;flex-direction:column;align-items:center}.checkmark-circle{width:80px;height:80px;background-color:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:36px;box-shadow:0 10px 25px #2ecc714d;animation:scaleIn .5s cubic-bezier(.175,.885,.32,1.275);margin-bottom:24px}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.loading-dots:after{content:".";animation:dots 1.5s steps(5,end) infinite}@keyframes dots{0%,20%{content:"."}40%{content:".."}60%{content:"..."}80%,to{content:""}}.error-message{background-color:#fff5f5;border:1px solid #FFEBEB;color:#e53e3e;padding:14px;border-radius:12px;margin:20px 0;font-size:14px;font-weight:600;text-align:center}.cancel-alert{background-color:#fff5f5;border:1px solid #FFEBEB;color:#e53e3e;padding:16px;border-radius:12px;margin-bottom:24px;font-size:14px;font-weight:600;text-align:center}html,body{max-width:100vw;overflow-x:hidden}
