@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=M+PLUS+Rounded+1c:wght@300;400;500;700&display=swap");:root{--color-primary:#E8736E;--color-primary-light:#F4A9A6;--color-primary-dark:#C0504C;--color-primary-50:#FEF2F1;--color-primary-100:#FDE5E4;--color-secondary:#7ECEC1;--color-secondary-light:#B2E4DC;--color-secondary-dark:#5AAFA2;--color-accent:#F5C842;--color-accent-light:#FAEAB3;--color-safe:#4CAF50;--color-safe-bg:#E8F5E9;--color-warning:#FF9800;--color-warning-bg:#FFF3E0;--color-danger:#F44336;--color-danger-bg:#FFEBEE;--color-info:#2196F3;--color-info-bg:#E3F2FD;--color-bg:#FDFBF9;--color-bg-secondary:#F7F3EF;--color-bg-card:#FFFFFF;--color-text:#2C2420;--color-text-secondary:#6B5E57;--color-text-muted:#9E9490;--color-border:#E8E0DA;--color-border-light:#F0EBE7;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 1px 3px rgba(44,36,32,0.06);--shadow-md:0 4px 12px rgba(44,36,32,0.08);--shadow-lg:0 8px 24px rgba(44,36,32,0.12);--shadow-xl:0 16px 40px rgba(44,36,32,0.16);--shadow-glow:0 0 20px rgba(232,115,110,0.2);--font-ja:"M PLUS Rounded 1c","Hiragino Maru Gothic ProN",sans-serif;--font-en:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-normal:250ms cubic-bezier(0.4,0,0.2,1);--transition-slow:400ms cubic-bezier(0.4,0,0.2,1);--z-sticky:100;--z-modal:200;--z-toast:300}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{color:var(--color-text);background-color:var(--color-bg);line-height:1.7;min-height:100dvh}body,h1,h2,h3,h4,h5,h6{font-family:var(--font-ja)}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3;letter-spacing:-.01em}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}img{max-width:100%;height:auto;display:block}button{cursor:pointer;border:none;background:none}button,input,select,textarea{font-family:var(--font-ja)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-md)}.container-narrow{max-width:800px}.text-center{text-align:center}.text-left{text-align:left}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px 24px;font-size:.95rem;font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-normal);text-decoration:none;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:white;box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow);color:white}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-bg-card);color:var(--color-text);border:1.5px solid var(--color-border)}.btn-secondary:hover{border-color:var(--color-primary-light);background:var(--color-primary-50);color:var(--color-primary-dark)}.btn-cta{background:linear-gradient(135deg,var(--color-primary),#E85D57);color:white;padding:16px 32px;font-size:1.1rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),0 0 30px rgba(232,115,110,.3);letter-spacing:.02em}.btn-cta:hover{transform:translateY(-3px) scale(1.02);box-shadow:var(--shadow-xl),0 0 40px rgba(232,115,110,.4);color:white}.btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outline:hover{background:var(--color-primary);color:white}.btn-sm{padding:8px 16px;font-size:.85rem}.btn-lg{padding:16px 36px;font-size:1.1rem}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);overflow:hidden;transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-body{padding:var(--space-lg)}.input-group{display:flex;flex-direction:column;gap:var(--space-xs)}.input-label{font-size:.85rem;font-weight:600;color:var(--color-text-secondary)}.input-field{padding:12px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:.95rem;background:var(--color-bg-card);transition:all var(--transition-fast);color:var(--color-text)}.input-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-100)}.input-field::placeholder{color:var(--color-text-muted)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:600;border-radius:var(--radius-full);white-space:nowrap}.badge-safe{background:var(--color-safe-bg);color:var(--color-safe)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-primary{background:var(--color-primary-50);color:var(--color-primary-dark)}.allergen-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-bg-secondary);font-size:1.2rem;border:2px solid var(--color-border-light);transition:all var(--transition-fast)}.allergen-icon.free{background:var(--color-safe-bg);border-color:var(--color-safe)}.allergen-icon.contains{background:var(--color-danger-bg);border-color:var(--color-danger);opacity:.6}.navbar{position:sticky;top:0;z-index:var(--z-sticky);background:rgba(253,251,249,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border-light);padding:var(--space-md) 0}.navbar-inner{justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 var(--space-md)}.navbar-inner,.navbar-logo{display:flex;align-items:center}.navbar-logo{gap:var(--space-sm);font-size:1.15rem;font-weight:700;color:var(--color-text);text-decoration:none}.navbar-logo-emoji{font-size:1.4rem}.navbar-links{display:flex;align-items:center;gap:var(--space-md)}.navbar-link{font-size:.9rem;color:var(--color-text-secondary);font-weight:500;transition:color var(--transition-fast)}.navbar-link:hover{color:var(--color-primary)}.footer{background:var(--color-bg-secondary);border-top:1px solid var(--color-border-light);padding:var(--space-2xl) 0 var(--space-lg);margin-top:var(--space-3xl)}.footer-inner{max-width:1200px;margin:0 auto;padding:0 var(--space-md);text-align:center}.footer-links{display:flex;justify-content:center;gap:var(--space-lg);flex-wrap:wrap;margin-bottom:var(--space-lg)}.footer-link{font-size:.85rem;color:var(--color-text-secondary)}.footer-copy{font-size:.8rem;color:var(--color-text-muted)}.section{padding:var(--space-3xl) 0}.section-title{font-size:1.6rem;margin-bottom:var(--space-sm);color:var(--color-text)}.section-subtitle{font-size:.95rem;color:var(--color-text-secondary);margin-bottom:var(--space-2xl)}.hero{position:relative;padding:var(--space-3xl) 0;background:linear-gradient(135deg,var(--color-primary-50) 0,#FFF5F0 50%,#F0FBF8 100%);overflow:hidden}.hero:before{top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(232,115,110,.08) 0,transparent 70%)}.hero:after,.hero:before{content:"";position:absolute;border-radius:50%;pointer-events:none}.hero:after{bottom:-30%;left:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(126,206,193,.08) 0,transparent 70%)}.hero-content{position:relative;z-index:1;max-width:800px;margin:0 auto;padding:0 var(--space-md);text-align:center}.hero-title{font-size:2rem;margin-bottom:var(--space-md);background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.05rem;color:var(--color-text-secondary);margin-bottom:var(--space-xl);line-height:1.8}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.animate-fadeIn{animation:fadeIn .5s ease-out forwards}.animate-fadeInUp{animation:fadeInUp .6s ease-out forwards}.animate-slideInRight{animation:slideInRight .5s ease-out forwards}.stagger-1{animation-delay:.1s;opacity:0}.stagger-2{animation-delay:.2s;opacity:0}.stagger-3{animation-delay:.3s;opacity:0}.stagger-4{animation-delay:.4s;opacity:0}.stagger-5{animation-delay:.5s;opacity:0}.allergen-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-sm)}.allergen-chip{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-sm) var(--space-xs);border-radius:var(--radius-md);border:2px solid var(--color-border);background:var(--color-bg-card);cursor:pointer;transition:all var(--transition-fast);text-align:center;font-size:.75rem;color:var(--color-text-secondary);user-select:none}.allergen-chip:hover{border-color:var(--color-primary-light);background:var(--color-primary-50)}.allergen-chip.selected{border-color:var(--color-primary);background:var(--color-primary-50);color:var(--color-primary-dark);box-shadow:0 0 0 2px var(--color-primary-100)}.allergen-chip-icon{font-size:1.5rem}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-lg)}.product-card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);overflow:hidden;transition:all var(--transition-normal);text-decoration:none;color:var(--color-text);display:block}.product-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);color:var(--color-text)}.product-card-image{position:relative;width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--color-primary-50),var(--color-bg-secondary));display:flex;align-items:center;justify-content:center;overflow:hidden}.product-card-placeholder{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);color:var(--color-text-muted);font-size:.85rem}.product-card-placeholder-icon{font-size:2.5rem;opacity:.5}.product-card-body{padding:var(--space-md)}.product-card-name{font-size:1rem;font-weight:700;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-card-store{font-size:.8rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.product-card-summary{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:var(--space-sm);line-height:1.5}.product-card-allergens{display:flex;flex-wrap:wrap;gap:4px}.no-image{width:100%;aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);background:linear-gradient(135deg,var(--color-bg-secondary),var(--color-border-light));color:var(--color-text-muted);font-size:.85rem}.no-image-icon{font-size:3rem;opacity:.4}.teaser{flex-direction:column;height:100dvh;max-height:100dvh;background:var(--color-bg)}.teaser,.teaser-image{display:flex;overflow:hidden}.teaser-image{position:relative;flex:0 0 38%;background:linear-gradient(135deg,var(--color-primary-50),#FFF5F0);align-items:center;justify-content:center}.teaser-image img{width:100%;height:100%;object-fit:cover}.teaser-back{position:absolute;top:var(--space-md);left:var(--space-md);width:36px;height:36px;border-radius:var(--radius-full);background:rgba(255,255,255,.9);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-size:1.2rem;box-shadow:var(--shadow-sm);z-index:2;color:var(--color-text)}.teaser-content{flex:1;display:flex;flex-direction:column;justify-content:space-between;padding:var(--space-lg) var(--space-md);overflow:hidden}.teaser-header{margin-bottom:var(--space-md)}.teaser-product-name{font-size:1.3rem;font-weight:700;margin-bottom:4px;line-height:1.3}.teaser-store-name{font-size:.85rem;color:var(--color-text-muted)}.teaser-allergens{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--space-md)}.teaser-summary{font-size:.95rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-md);font-style:italic}.teaser-summary:before{content:"✨ "}.teaser-freshness{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--space-md)}.teaser-cta{margin-top:auto}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-md)}.stat-card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm)}.stat-card-label{font-size:.8rem;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.stat-card-value{font-size:2rem;font-weight:700;color:var(--color-text)}.stat-card-unit{font-size:.85rem;font-weight:400;color:var(--color-text-secondary);margin-left:4px}.checkbox-wrapper{display:flex;align-items:flex-start;gap:var(--space-sm);cursor:pointer}.checkbox{width:20px;height:20px;border:2px solid var(--color-border);border-radius:4px;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);background:var(--color-bg-card)}.checkbox.checked{background:var(--color-primary);border-color:var(--color-primary);color:white}.checkbox-label{font-size:.9rem;line-height:1.5;color:var(--color-text)}.lp-hero{position:relative;padding:var(--space-3xl) 0;background:linear-gradient(135deg,#1A1F36,#2D1B4E 50%,#1A1F36);color:white;overflow:hidden;text-align:center}.lp-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 40%,rgba(232,115,110,.15) 0,transparent 50%),radial-gradient(circle at 70% 60%,rgba(126,206,193,.1) 0,transparent 50%);pointer-events:none}.lp-hero-title{font-size:2.2rem;margin-bottom:var(--space-md);position:relative}.lp-hero-subtitle{font-size:1.1rem;opacity:.85;margin-bottom:var(--space-xl);position:relative}.lp-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-xl);padding:var(--space-3xl) var(--space-md);max-width:1200px;margin:0 auto}.lp-feature-card{text-align:center;padding:var(--space-xl);border-radius:var(--radius-xl);background:var(--color-bg-card);box-shadow:var(--shadow-md);border:1px solid var(--color-border-light);transition:all var(--transition-normal)}.lp-feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.lp-feature-icon{font-size:3rem;margin-bottom:var(--space-md)}.lp-feature-title{font-size:1.2rem;font-weight:700;margin-bottom:var(--space-sm)}.lp-feature-desc{font-size:.9rem;color:var(--color-text-secondary);line-height:1.7}.steps{display:flex;flex-direction:column;gap:var(--space-xl);max-width:600px;margin:0 auto}.step{display:flex;gap:var(--space-md);align-items:flex-start}.step-number{flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:white;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.step-content h3{font-size:1.05rem;margin-bottom:4px}.step-content p{font-size:.9rem;color:var(--color-text-secondary)}.legal-page{max-width:800px;margin:0 auto;padding:var(--space-2xl) var(--space-md)}.legal-page h1{font-size:1.6rem;margin-bottom:var(--space-xl)}.legal-page h2{font-size:1.2rem;margin-top:var(--space-xl);margin-bottom:var(--space-md);color:var(--color-primary-dark)}.legal-page li,.legal-page p{font-size:.9rem;color:var(--color-text-secondary);line-height:1.8;margin-bottom:var(--space-sm)}.legal-page ol,.legal-page ul{padding-left:var(--space-lg)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl) var(--space-md);text-align:center}.empty-state-icon{font-size:4rem;margin-bottom:var(--space-lg);opacity:.7}.empty-state-title{font-size:1.2rem;font-weight:700;margin-bottom:var(--space-sm)}.empty-state-desc{font-size:.95rem;color:var(--color-text-secondary);margin-bottom:var(--space-xl);max-width:400px;line-height:1.7}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:var(--z-sticky);background:rgba(253,251,249,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--color-border-light);padding:6px 0 env(safe-area-inset-bottom,8px);box-shadow:0 -2px 12px rgba(0,0,0,.06)}.mobile-bottom-nav-inner{display:flex;justify-content:space-around;align-items:center;max-width:500px;margin:0 auto}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 8px;font-size:.65rem;color:var(--color-text-muted);text-decoration:none;transition:color var(--transition-fast);min-width:56px;-webkit-tap-highlight-color:transparent}.mobile-nav-item.active,.mobile-nav-item:hover{color:var(--color-primary)}.mobile-nav-icon{font-size:1.3rem;line-height:1}@media (max-width:768px){.hero-title{font-size:1.5rem}.hero-description{font-size:.95rem}.product-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.allergen-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.lp-hero-title{font-size:1.6rem}.section-title{font-size:1.3rem}.dashboard-grid{grid-template-columns:1fr}}@media (max-width:640px){.mobile-bottom-nav{display:block}.navbar-links{display:none!important}body{padding-bottom:72px}.navbar{padding:var(--space-sm) 0}.navbar-logo{font-size:1rem}.navbar-logo-emoji{font-size:1.2rem}.hero{padding:var(--space-xl) 0}.hero-title{font-size:1.3rem}.hero-description{font-size:.85rem}.product-grid{grid-template-columns:1fr;gap:var(--space-md)}.allergen-chip{min-height:44px;padding:var(--space-sm) var(--space-sm);font-size:.7rem}.allergen-chip-icon{font-size:1.3rem}.allergen-grid{grid-template-columns:repeat(4,1fr);gap:6px}.btn-cta{padding:14px 24px;font-size:1rem;width:100%}.card-body{padding:var(--space-md)}.product-card-body{padding:var(--space-sm) var(--space-md)}.form-row{grid-template-columns:1fr}.footer-links{flex-direction:column;gap:var(--space-md)}.lp-features{grid-template-columns:1fr;padding:var(--space-xl) var(--space-md)}.lp-hero-title{font-size:1.4rem}.toast{left:var(--space-md);right:var(--space-md);transform:none;bottom:80px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background:var(--color-primary-100);color:var(--color-primary-dark)}.glass{background:rgba(255,255,255,.75);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.3)}.toast{position:fixed;bottom:var(--space-xl);left:50%;transform:translateX(-50%);background:var(--color-text);color:white;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-lg);font-size:.9rem;box-shadow:var(--shadow-xl);z-index:var(--z-toast);animation:fadeInUp .3s ease-out}.consent-box{background:var(--color-warning-bg);border:2px solid var(--color-warning);border-radius:var(--radius-lg);padding:var(--space-lg);margin:var(--space-lg) 0}.consent-box-title{font-size:1rem;font-weight:700;color:var(--color-warning);margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-sm)}.consent-box-text{font-size:.85rem;color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--space-md)}.form-section{margin-bottom:var(--space-xl)}.form-section-title{font-size:1rem;font-weight:700;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:2px solid var(--color-border-light)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}@media (max-width:640px){.form-row{grid-template-columns:1fr}}.skeleton{position:relative;overflow:hidden;background:var(--color-bg-secondary);border-radius:var(--radius-md)}.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:shimmer 1.5s infinite}