*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--primary:#832479;--primary-light:#a44d99;--primary-dark:#5e1a57;--cta:#FFCE12;--cta-hover:#e6b800;--bg-light:#EFE6EB;--bg-white:#fff;--text-dark:#1a1a1a;--text-body:#333;--text-muted:#666;--radius:8px;--shadow:0 2px 12px rgba(131,36,121,.1);--max-width:1140px;--header-h:70px}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:calc(var(--header-h) + 16px)}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;font-size:16px;line-height:1.6;color:var(--text-body);background:var(--bg-white)}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover,a:focus-visible{text-decoration:underline}
ul,ol{list-style:none}
h1,h2,h3,h4{color:var(--primary-dark);line-height:1.25}
h1{font-size:clamp(1.6rem,4vw,2.5rem)}
h2{font-size:clamp(1.3rem,3vw,2rem);margin-bottom:.75rem}
h3{font-size:clamp(1.1rem,2.5vw,1.5rem)}

/* HEADER */
.site-header{position:fixed;top:0;left:0;width:100%;height:var(--header-h);background:var(--bg-white);box-shadow:0 2px 8px rgba(0,0,0,.08);z-index:1000;display:flex;align-items:center}
.header-container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.logo-img{width:auto;height:40px}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamburger-line{display:block;width:24px;height:3px;background:var(--primary);border-radius:2px;transition:transform .3s}
.main-nav .nav-list{display:flex;gap:1.25rem;align-items:center}
.main-nav .nav-list a{font-size:.9rem;font-weight:500;color:var(--text-dark);white-space:nowrap;padding:4px 0}
.main-nav .nav-list a:hover,.main-nav .nav-list a:focus-visible{color:var(--primary)}
.btn-header-cta{display:inline-flex;align-items:center;justify-content:center;background:var(--cta);color:var(--text-dark);font-weight:700;font-size:.95rem;padding:10px 22px;border-radius:var(--radius);white-space:nowrap;text-decoration:none;transition:background .2s,transform .15s;box-shadow:0 2px 6px rgba(0,0,0,.1)}
.btn-header-cta:hover,.btn-header-cta:focus-visible{background:var(--cta-hover);text-decoration:none;transform:translateY(-1px)}

/* MOBILE NAV */
@media(max-width:768px){
.menu-toggle{display:flex}
.main-nav{position:absolute;top:var(--header-h);left:0;width:100%;background:var(--bg-white);box-shadow:0 4px 12px rgba(0,0,0,.1);max-height:0;overflow:hidden;transition:max-height .35s ease}
.main-nav.open{max-height:400px}
.main-nav .nav-list{flex-direction:column;padding:1rem;gap:0}
.main-nav .nav-list li{width:100%}
.main-nav .nav-list a{display:block;padding:.75rem 0;border-bottom:1px solid #eee;font-size:1rem}
}

/* SPACER */
.header-spacer{height:var(--header-h)}

/* HERO */
.hero{background:var(--bg-light);padding:3rem 1rem 2.5rem}
.hero-container{max-width:var(--max-width);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.hero-text{order:1}
.hero-image{order:2;text-align:center}
.hero-image img{margin:0 auto;max-height:420px;width:auto}
.hero h1{margin-bottom:1rem}
.hero-subtitle{font-size:1.1rem;color:var(--text-body);margin-bottom:1.5rem}
.hero-benefits{margin-bottom:1.5rem}
.hero-benefits li{position:relative;padding-left:1.75rem;margin-bottom:.5rem;font-size:.95rem}
.hero-benefits li::before{content:"✓";position:absolute;left:0;color:var(--primary);font-weight:700}
.hero-social-proof{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.9rem;color:var(--text-muted)}
.stars{color:var(--cta);font-size:1.1rem;letter-spacing:2px}
@media(max-width:768px){
.hero-container{grid-template-columns:1fr;text-align:center}
.hero-text{order:2}
.hero-image{order:1}
.hero-image img{max-height:300px}
.hero-benefits{text-align:left;display:inline-block}
.hero-social-proof{justify-content:center}
}

/* CTA BUTTON */
.btn-cta{display:inline-flex;align-items:center;justify-content:center;background:var(--cta);color:var(--text-dark);font-weight:700;font-size:1.15rem;padding:16px 40px;border-radius:var(--radius);border:none;cursor:pointer;text-decoration:none;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 14px rgba(255,206,18,.35);min-width:220px;min-height:56px}
.btn-cta:hover,.btn-cta:focus-visible{background:var(--cta-hover);transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,206,18,.5);text-decoration:none}
.cta-subtitle{display:block;margin-top:.5rem;font-size:.85rem;color:var(--text-muted);text-align:center}
.cta-wrapper{text-align:center;margin:2rem 0}

/* SECTIONS */
section{padding:3rem 1rem}
.section-container{max-width:var(--max-width);margin:0 auto}
.section-alt{background:var(--bg-light)}
.section-white{background:var(--bg-white)}
.text-center{text-align:center}

/* A COSA SERVE */
.featured-snippet{font-size:1.05rem;line-height:1.7;margin-bottom:1.5rem;color:var(--text-body)}

/* BENEFITS */
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}
.benefit-card{background:var(--bg-white);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);text-align:center;transition:transform .2s}
.benefit-card:hover{transform:translateY(-3px)}
.benefit-icon{font-size:2.5rem;margin-bottom:.75rem}
.benefit-card h3{margin-bottom:.5rem}
.benefit-card p{font-size:.9rem;color:var(--text-muted)}

/* INGREDIENTS */
.ingredients-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}
.ingredient-card{background:var(--bg-white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .2s}
.ingredient-card:hover{transform:translateY(-3px)}
.ingredient-card img{width:100%;height:200px;object-fit:cover}
.ingredient-card .ingredient-body{padding:1.25rem}
.ingredient-card h3{margin-bottom:.5rem}
.ingredient-card p{font-size:.9rem;color:var(--text-muted)}

/* HOW TO USE */
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}
.step-card{text-align:center;padding:1.5rem}
.step-number{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;font-size:1.5rem;font-weight:700;margin-bottom:1rem}
.step-card h3{margin-bottom:.5rem}
.step-card p{font-size:.9rem;color:var(--text-muted)}

/* HOW TO ORDER */
.order-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:2rem}
.order-step{background:var(--bg-white);border-radius:var(--radius);padding:1.5rem;text-align:center;box-shadow:var(--shadow)}
.order-step-num{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--cta);color:var(--text-dark);font-weight:700;font-size:1.25rem;margin-bottom:.75rem}

/* REVIEWS / TESTIMONIALS */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}
.review-card{background:var(--bg-white);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}
.review-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.review-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover}
.review-author{font-weight:600;color:var(--text-dark)}
.review-location{font-size:.85rem;color:var(--text-muted)}
.review-stars{color:var(--cta);font-size:1rem;letter-spacing:2px;margin-bottom:.5rem}
.review-text{font-size:.95rem;color:var(--text-body);line-height:1.6}
.rating-summary{display:flex;align-items:center;gap:.75rem;margin:1.5rem 0;justify-content:center;flex-wrap:wrap}
.rating-score{font-size:2rem;font-weight:700;color:var(--primary)}
.rating-label{font-size:.9rem;color:var(--text-muted)}

/* WHERE TO BUY */
.where-buy-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center;margin-top:2rem}
.where-buy-content img{border-radius:var(--radius)}
@media(max-width:768px){
.where-buy-content{grid-template-columns:1fr}
}

/* ORDER FORM */
.form-section{padding:3rem 1rem}
.form-wrapper{max-width:560px;margin:0 auto;background:var(--bg-white);border-radius:12px;padding:2rem;box-shadow:0 4px 24px rgba(131,36,121,.12)}
.form-intro{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;justify-content:center;text-align:left}
.form-intro img{width:80px;height:auto;flex-shrink:0}
.form-intro p{font-size:.95rem;color:var(--text-body)}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:600;margin-bottom:.35rem;font-size:.9rem;color:var(--text-dark)}
.form-group input{width:100%;padding:12px 14px;border:2px solid #ddd;border-radius:var(--radius);font-size:1rem;transition:border-color .2s;background:#fff}
.form-group input:focus{outline:none;border-color:var(--primary)}
.form-group input.error{border-color:#e53935}
.form-error{color:#e53935;font-size:.8rem;margin-top:.25rem;display:none}
.form-group.has-error .form-error{display:block}
.btn-submit{width:100%;background:var(--cta);color:var(--text-dark);font-weight:700;font-size:1.15rem;padding:16px;border:none;border-radius:var(--radius);cursor:pointer;transition:background .2s,transform .15s;box-shadow:0 4px 14px rgba(255,206,18,.35);display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:56px}
.btn-submit:hover,.btn-submit:focus-visible{background:var(--cta-hover);transform:translateY(-2px)}
.btn-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}
.spinner{display:none;width:20px;height:20px;border:3px solid rgba(0,0,0,.15);border-top-color:var(--text-dark);border-radius:50%;animation:spin .6s linear infinite}
.btn-submit.loading .spinner{display:inline-block}
.btn-submit.loading .btn-text{display:none}
@keyframes spin{to{transform:rotate(360deg)}}
.form-privacy{font-size:.8rem;color:var(--text-muted);text-align:center;margin-top:.75rem}
.form-privacy a{color:var(--primary)}
.trust-badges{display:flex;justify-content:center;gap:1.5rem;margin-top:1.25rem;flex-wrap:wrap}
.trust-badge{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-muted)}
.trust-badge svg{width:20px;height:20px;fill:var(--primary)}

/* FAQ */
.faq-list{max-width:760px;margin:2rem auto 0}
.faq-item{border-bottom:1px solid #eee;padding:1rem 0}
.faq-question{width:100%;background:none;border:none;cursor:pointer;text-align:left;font-size:1rem;font-weight:600;color:var(--text-dark);display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;gap:1rem}
.faq-question::after{content:"+";font-size:1.5rem;transition:transform .3s;flex-shrink:0;color:var(--primary)}
.faq-item.open .faq-question::after{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease;font-size:.95rem;color:var(--text-muted);line-height:1.6}
.faq-item.open .faq-answer{max-height:500px;padding-bottom:.5rem}

/* CONTRAINDICATIONS */
.warning-box{background:#fff8e1;border-left:4px solid var(--cta);padding:1.25rem;border-radius:0 var(--radius) var(--radius) 0;margin-top:1.5rem}

/* PRICE SECTION */
.price-highlight{text-align:center;margin:2rem 0}
.price-tag{font-size:2.5rem;font-weight:700;color:var(--primary)}
.price-detail{font-size:1rem;color:var(--text-muted)}

/* LEGAL PAGES */
.legal-content{max-width:800px;margin:0 auto;padding:2rem 1rem}
.legal-content h1{margin-bottom:1.5rem}
.legal-content h2{margin-top:2rem;margin-bottom:.75rem;font-size:1.3rem}
.legal-content p,.legal-content li{margin-bottom:.75rem;font-size:.95rem;line-height:1.7;color:var(--text-body)}
.legal-content ul{margin-left:1.5rem}
.legal-content ul li{list-style:disc}

/* CONTACT PAGE */
.contact-form{max-width:560px;margin:2rem auto 0}
.contact-form .form-group label{margin-bottom:.35rem}
.contact-form textarea{width:100%;padding:12px 14px;border:2px solid #ddd;border-radius:var(--radius);font-size:1rem;font-family:inherit;resize:vertical;min-height:120px;transition:border-color .2s}
.contact-form textarea:focus{outline:none;border-color:var(--primary)}
.contact-form textarea.error{border-color:#e53935}
.checkbox-group{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:1.25rem}
.checkbox-group input[type="checkbox"]{margin-top:4px;accent-color:var(--primary)}
.checkbox-group label{font-size:.85rem;color:var(--text-muted);font-weight:400}

/* THANK YOU */
.thankyou-section{text-align:center;padding:4rem 1rem;min-height:60vh;display:flex;align-items:center;justify-content:center}
.thankyou-content{max-width:600px}
.thankyou-icon{font-size:4rem;margin-bottom:1rem}

/* FOOTER */
.site-footer{background:var(--primary-dark);color:rgba(255,255,255,.85);padding:2.5rem 1rem;font-size:.85rem}
.footer-container{max-width:var(--max-width);margin:0 auto;text-align:center}
.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 1.5rem;margin-bottom:1.5rem}
.footer-links a{color:rgba(255,255,255,.85);font-size:.85rem}
.footer-links a:hover{color:#fff}
.footer-disclaimer{margin-bottom:1rem;line-height:1.6;max-width:800px;margin-left:auto;margin-right:auto;margin-bottom:1.5rem}
.footer-disclaimer p{font-size:.8rem;color:rgba(255,255,255,.65)}
.footer-update{margin-bottom:.5rem}
.footer-copy p{color:rgba(255,255,255,.5)}

/* ALERT MSG */
.alert{padding:1rem;border-radius:var(--radius);margin-bottom:1.5rem;font-size:.9rem}
.alert-success{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}
.alert-error{background:#ffebee;color:#c62828;border:1px solid #ef9a9a}

/* UTILITIES */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.mb-1{margin-bottom:.5rem}
.mb-2{margin-bottom:1rem}
.mb-3{margin-bottom:1.5rem}
.mt-2{margin-top:1rem}
.mt-3{margin-top:1.5rem}

@media(max-width:480px){
section{padding:2rem .75rem}
.form-wrapper{padding:1.25rem}
.btn-cta{font-size:1rem;padding:14px 28px;min-width:unset;width:100%}
}
