/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:#1a1a2e;line-height:1.6;background:#fff;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:#082587;text-decoration:none}
a:hover{text-decoration:underline}
ul{list-style:none}
h1,h2,h3,h4{line-height:1.25}

/* === HEADER === */
.site-header{position:sticky;top:0;z-index:1000;background:#082587;color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.header-container{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem}
.header-logo{display:flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none}
.header-logo-img{width:28px;height:auto;border-radius:4px}
.header-brand{font-size:1.15rem;font-weight:700;letter-spacing:.5px}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;flex-direction:column;gap:5px}
.menu-bar{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:transform .3s}
.nav-list{display:flex;align-items:center;gap:1.5rem}
.nav-link{color:#fff;font-size:.95rem;font-weight:500;transition:opacity .2s}
.nav-link:hover{opacity:.8;text-decoration:none}
.cta-header-link{display:none}
.cta-header-btn{background:#FFCE12;color:#1a1a2e;font-weight:700;padding:.5rem 1.2rem;border-radius:6px;font-size:.95rem;transition:transform .2s,box-shadow .2s;white-space:nowrap}
.cta-header-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(255,206,18,.4);text-decoration:none}

/* === HERO === */
.hero{background:linear-gradient(135deg,#082587 0%,#0a3cbf 100%);color:#fff;padding:2rem 1rem;overflow:hidden}
.hero-container{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:2rem}
.hero-content{flex:1;min-width:0}
.hero h1{font-size:2.2rem;margin-bottom:.75rem;line-height:1.2}
.hero-subtitle{font-size:1.15rem;margin-bottom:1rem;opacity:.95;line-height:1.5}
.hero-benefits{margin-bottom:1.5rem}
.hero-benefits li{padding:.35rem 0;padding-left:1.5rem;position:relative;font-size:1rem}
.hero-benefits li::before{content:"✓";position:absolute;left:0;color:#FFCE12;font-weight:700}
.hero-social-proof{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}
.hero-stars{color:#FFCE12;font-size:1.2rem;letter-spacing:2px}
.hero-rating-text{font-size:.9rem;opacity:.9}
.hero-image{flex:0 0 320px;text-align:center}
.hero-image img{max-width:100%;height:auto;filter:drop-shadow(0 8px 24px rgba(0,0,0,.3))}
.hero-cta-wrap{display:flex;flex-direction:column;gap:.5rem;align-items:flex-start}
.hero-price{font-size:1.5rem;font-weight:700;color:#FFCE12}

/* === CTA BUTTON === */
.btn-cta{display:inline-block;background:#FFCE12;color:#1a1a2e;font-weight:700;font-size:1.15rem;padding:1rem 2.5rem;border-radius:8px;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s;text-align:center;min-width:220px;text-decoration:none}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,206,18,.45);text-decoration:none}
.btn-cta:active{transform:translateY(0)}
.cta-subtext{font-size:.85rem;opacity:.85;margin-top:.25rem}

/* === SECTIONS === */
.section{padding:3rem 1rem}
.section-alt{background:#f4f6fb}
.section-container{max-width:1000px;margin:0 auto}
.section-title{font-size:1.75rem;color:#082587;text-align:center;margin-bottom:1.5rem;position:relative}
.section-title::after{content:"";display:block;width:60px;height:3px;background:#FFCE12;margin:.75rem auto 0}
.section-intro{text-align:center;max-width:700px;margin:0 auto 2rem;color:#444;font-size:1.05rem;line-height:1.7}

/* === ORDER FORM === */
.order-section{background:#082587;padding:2.5rem 1rem}
.order-section .section-title{color:#fff}
.order-section .section-title::after{background:#FFCE12}
.order-intro{color:#fff;text-align:center;max-width:650px;margin:0 auto 1.5rem;font-size:1.05rem;line-height:1.6}
.order-form-card{background:#fff;border-radius:12px;padding:2rem;max-width:480px;margin:0 auto;box-shadow:0 8px 32px rgba(0,0,0,.15)}
.order-form-card label{display:block;font-weight:600;margin-bottom:.35rem;color:#1a1a2e;font-size:.95rem}
.order-form-card input[type="text"],
.order-form-card input[type="tel"]{width:100%;padding:.85rem 1rem;border:2px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .2s;margin-bottom:1rem}
.order-form-card input:focus{outline:none;border-color:#082587;box-shadow:0 0 0 3px rgba(8,37,135,.1)}
.order-form-card .btn-cta{width:100%;font-size:1.2rem;padding:1.1rem}
.form-privacy{font-size:.78rem;color:#666;text-align:center;margin-top:.75rem;line-height:1.4}
.form-privacy a{color:#082587}
.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:#555}
.trust-badge svg{width:18px;height:18px;color:#082587;flex-shrink:0}
.form-error{background:#ffe0e0;color:#c00;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem;text-align:center}

/* === BENEFITS === */
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.benefit-card{background:#fff;border-radius:10px;padding:1.5rem;box-shadow:0 2px 12px rgba(0,0,0,.06);border-left:4px solid #082587;transition:transform .2s}
.benefit-card:hover{transform:translateY(-2px)}
.benefit-card h3{color:#082587;margin-bottom:.5rem;font-size:1.1rem}
.benefit-card p{color:#555;font-size:.95rem;line-height:1.6}

/* === INGREDIENTS === */
.ingredients-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.ingredient-card{background:#fff;border-radius:10px;padding:1.5rem;text-align:center;box-shadow:0 2px 12px rgba(0,0,0,.06);transition:transform .2s}
.ingredient-card:hover{transform:translateY(-2px)}
.ingredient-card img{width:100px;height:100px;object-fit:contain;margin:0 auto .75rem;border-radius:8px}
.ingredient-card h3{color:#082587;margin-bottom:.5rem;font-size:1.05rem}
.ingredient-card p{color:#555;font-size:.9rem;line-height:1.5}
.ingredient-study{font-size:.8rem;margin-top:.5rem}
.ingredient-study a{color:#082587;font-weight:600}

/* === REVIEWS === */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.review-card{background:#fff;border-radius:10px;padding:1.5rem;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.review-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}
.review-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;background:#e0e5f0;border:2px solid #082587;flex-shrink:0;filter:blur(3px)}
.review-meta{flex:1}
.review-name{font-weight:700;color:#1a1a2e;font-size:.95rem}
.review-city{font-size:.8rem;color:#888}
.review-stars{color:#FFCE12;font-size:.95rem;letter-spacing:1px;margin-bottom:.5rem}
.review-text{color:#555;font-size:.9rem;line-height:1.6}

/* === HOW TO USE === */
.usage-steps{display:flex;flex-direction:column;gap:1.5rem}
.usage-step{display:flex;align-items:center;gap:1.25rem;background:#fff;border-radius:10px;padding:1.25rem;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.usage-step-icon{flex-shrink:0;width:60px;height:60px;display:flex;align-items:center;justify-content:center}
.usage-step-icon img{max-width:48px;max-height:48px;object-fit:contain}
.usage-step h3{color:#082587;font-size:1rem;margin-bottom:.25rem}
.usage-step p{color:#555;font-size:.9rem}

/* === WHERE TO BUY === */
.where-buy-content{display:flex;align-items:center;gap:2rem}
.where-buy-text{flex:1}
.where-buy-text p{margin-bottom:.75rem;color:#555;line-height:1.7}
.where-buy-img{flex:0 0 200px;text-align:center}
.where-buy-img img{max-width:180px;height:auto;filter:drop-shadow(0 4px 12px rgba(0,0,0,.1))}

/* === HOW TO ORDER === */
.order-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}
.order-step{text-align:center;padding:1.5rem;background:#fff;border-radius:10px;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.order-step-number{width:48px;height:48px;background:#082587;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;margin:0 auto .75rem}
.order-step h3{color:#082587;margin-bottom:.35rem;font-size:1rem}
.order-step p{color:#555;font-size:.9rem}

/* === FAQ === */
.faq-list{max-width:750px;margin:0 auto}
.faq-item{border-bottom:1px solid #e0e5f0;padding:1rem 0}
.faq-question{display:flex;justify-content:space-between;align-items:center;cursor:pointer;background:none;border:none;width:100%;text-align:left;font-size:1.05rem;font-weight:600;color:#1a1a2e;padding:.5rem 0;line-height:1.4}
.faq-question::after{content:"+";font-size:1.4rem;color:#082587;transition:transform .3s;flex-shrink:0;margin-left:1rem}
.faq-item.active .faq-question::after{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease;color:#555;line-height:1.7;font-size:.95rem}
.faq-item.active .faq-answer{max-height:500px;padding:.5rem 0 .75rem}

/* === CONTRAINDICATIONS === */
.contra-list{max-width:750px;margin:0 auto}
.contra-list li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#555;line-height:1.6}
.contra-list li::before{content:"⚠";position:absolute;left:0}

/* === AGGREGATE RATING DISPLAY === */
.rating-display{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}
.rating-display .stars{color:#FFCE12;font-size:1.3rem;letter-spacing:2px}
.rating-display .rating-text{font-size:1rem;color:#555}

/* === CTA SECTION === */
.cta-section{background:#082587;padding:2.5rem 1rem;text-align:center;color:#fff}
.cta-section h2{color:#fff;margin-bottom:.75rem;font-size:1.5rem}
.cta-section p{margin-bottom:1.25rem;opacity:.9}
.cta-section .btn-cta{font-size:1.2rem;padding:1.1rem 3rem}
.cta-section .cta-subtext{color:#fff}

/* === FOOTER === */
.site-footer{background:#0a1628;color:#ccc;padding:2.5rem 1rem 1rem}
.footer-container{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}
.footer-brand{display:flex;align-items:center;gap:.75rem}
.footer-logo-img{width:40px;height:auto;border-radius:4px}
.footer-brand-name{font-size:1.1rem;font-weight:700;color:#fff}
.footer-nav h3,.footer-legal h3{font-size:.95rem;color:#fff;margin-bottom:.75rem}
.footer-nav ul,.footer-legal ul{display:flex;flex-direction:column;gap:.4rem}
.footer-nav a,.footer-legal a{color:#aab;font-size:.85rem;transition:color .2s}
.footer-nav a:hover,.footer-legal a:hover{color:#FFCE12}
.footer-bottom{border-top:1px solid #1d2a44;padding-top:1.25rem;text-align:center;max-width:900px;margin:0 auto}
.footer-bottom p{font-size:.78rem;color:#888;margin-bottom:.5rem;line-height:1.5}
.footer-disclaimer{font-style:italic}
.footer-update{font-size:.75rem !important;color:#666 !important}
.footer-copy{font-size:.8rem !important;color:#fff !important;margin-top:.5rem !important}

/* === SPINNER === */
.spinner{display:none;width:22px;height:22px;border:3px solid rgba(26,26,46,.2);border-top-color:#1a1a2e;border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}
.btn-cta.loading{pointer-events:none;opacity:.7}
.btn-cta.loading .spinner{display:inline-block;vertical-align:middle;margin-left:.5rem}
.btn-cta.loading .btn-text{opacity:.5}
@keyframes spin{to{transform:rotate(360deg)}}

/* === LEGAL PAGES === */
.legal-page{padding:2rem 1rem;max-width:800px;margin:0 auto}
.legal-page h1{font-size:1.75rem;color:#082587;margin-bottom:1.5rem}
.legal-page h2{font-size:1.3rem;color:#082587;margin:1.5rem 0 .75rem}
.legal-page h3{font-size:1.1rem;color:#333;margin:1rem 0 .5rem}
.legal-page p{color:#555;margin-bottom:.75rem;line-height:1.7}
.legal-page ul{margin:.5rem 0 1rem 1.5rem;list-style:disc}
.legal-page ul li{color:#555;margin-bottom:.35rem;line-height:1.6}
.legal-page table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.8rem}
.legal-page th,.legal-page td{border:1px solid #ddd;padding:.5rem;text-align:left;vertical-align:top}
.legal-page th{background:#f4f6fb;color:#082587;font-weight:600}

/* === CONTACT PAGE === */
.contact-form{max-width:550px;margin:0 auto}
.contact-form label{display:block;font-weight:600;margin-bottom:.35rem;color:#1a1a2e;font-size:.95rem}
.contact-form input[type="text"],
.contact-form input[type="tel"],
.contact-form input[type="email"],
.contact-form textarea{width:100%;padding:.85rem 1rem;border:2px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .2s;margin-bottom:1rem;font-family:inherit}
.contact-form textarea{min-height:120px;resize:vertical}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#082587;box-shadow:0 0 0 3px rgba(8,37,135,.1)}
.contact-form .checkbox-group{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:1rem}
.contact-form .checkbox-group input[type="checkbox"]{margin-top:.3rem;flex-shrink:0}
.contact-form .checkbox-group label{font-weight:400;font-size:.85rem;color:#555}
.contact-form .btn-cta{width:100%}
.contact-success{background:#e0f5e0;color:#2a7a2a;padding:1rem;border-radius:8px;text-align:center;margin-bottom:1rem}
.field-error{color:#c00;font-size:.8rem;margin-top:-.75rem;margin-bottom:.75rem;display:none}

/* === THANK YOU === */
.thankyou{text-align:center;padding:4rem 1rem;max-width:600px;margin:0 auto}
.thankyou h1{color:#082587;margin-bottom:1rem}
.thankyou p{color:#555;line-height:1.7;margin-bottom:1rem}
.thankyou .btn-cta{margin-top:1.5rem}

/* === RESPONSIVE === */
@media(max-width:768px){
    .menu-toggle{display:flex}
    .main-nav{position:absolute;top:100%;left:0;right:0;background:#082587;max-height:0;overflow:hidden;transition:max-height .3s ease}
    .main-nav.open{max-height:400px}
    .nav-list{flex-direction:column;padding:1rem;gap:.75rem}
    .cta-header-link{display:block}
    .hero-container{flex-direction:column;text-align:center}
    .hero-content{display:contents}
    .hero h1{font-size:1.6rem;order:1}
    .hero-image{flex:none;max-width:250px;margin:0 auto;order:2}
    .hero-cta-wrap{align-items:center;order:3}
    .hero-subtitle{order:4}
    .hero-benefits{order:5}
    .hero-social-proof{justify-content:center;order:6}
    .hero-benefits li{text-align:left}
    .where-buy-content{flex-direction:column;text-align:center}
    .where-buy-img{flex:none}
    .section-title{font-size:1.4rem}
    .reviews-grid{grid-template-columns:1fr}
    .order-steps{grid-template-columns:1fr}
    .footer-container{grid-template-columns:1fr;text-align:center}
}
@media(min-width:769px){
    .hero{padding:3rem 1rem}
    .hero h1{font-size:2.6rem}
    .section{padding:4rem 1rem}
}
