:root {
  --primary-color: #9C1C66;
  --secondary-color: #72104A;
  --accent-color: #C0E0B1;
  --light-color: #F8EDF4;
  --dark-color: #280A1A;
  --gradient-primary: linear-gradient(135deg, #C03080 0%, #9C1C66 100%);
  --hover-color: #560D34;
  --background-color: #FDFBFC;
  --text-color: #280A1A;
  --border-color: rgba(156,28,102,0.13);
  --divider-color: rgba(156,28,102,0.07);
  --shadow-color: rgba(40,10,26,0.08);
  --highlight-color: #4A9E3A;
  --main-font: 'Oswald', sans-serif;
  --alt-font: 'Open Sans', sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--alt-font);font-size:clamp(14px,4vw,16px);color:var(--text-color);background-color:var(--background-color);min-height:100dvh;display:flex;flex-direction:column;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}

.pattern-bg{
  background-color:var(--background-color);
  background-image:
    radial-gradient(circle,rgba(156,28,102,0.06) 1.2px,transparent 1.2px),
    radial-gradient(circle,rgba(156,28,102,0.06) 1.2px,transparent 1.2px);
  background-size:24px 24px;
  background-position:0 0,12px 12px;
}

/* HEADER small */
.site-header{padding:.9rem 0;background:var(--background-color);border-bottom:1px solid var(--border-color)}
.header-inner{max-width:1180px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center}
.logo{display:flex;align-items:center;gap:.6rem;text-decoration:none}
.logo-icon{width:36px;height:36px;flex-shrink:0}
.logo-text{font-family:var(--main-font);font-weight:700;font-size:clamp(18px,4vw,24px);color:var(--dark-color);letter-spacing:.08em;text-transform:uppercase}
.logo-text em{font-style:normal;color:var(--primary-color)}

main{flex:1}

/* ══ BANNER: centered product + surrounding text ══ */
.banner-section{background:var(--dark-color);position:relative;overflow:hidden;padding:2rem 0 0}
.banner-deco{position:absolute;inset:0;pointer-events:none}
.banner-deco::before{content:'';position:absolute;top:-60px;left:-60px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(156,28,102,0.12) 0%,transparent 70%)}
.banner-deco::after{content:'';position:absolute;bottom:-80px;right:-40px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(192,224,177,0.07) 0%,transparent 70%)}

.banner-inner{max-width:1180px;margin:0 auto;padding:0 1.5rem 50px;position:relative;z-index:1}

/* Banner top: title + eyebrow */
.banner-top{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem;padding-bottom:1.5rem}
.banner-eyebrow{font-family:var(--alt-font);font-size:10.5px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:rgba(192,224,177,0.7)}
.banner-title{font-family:var(--main-font);font-weight:700;font-size:clamp(48px,9vw,90px);color:#fff;line-height:.88;letter-spacing:.04em;text-transform:uppercase}
.banner-title em{font-style:normal;color:var(--accent-color)}

/* Banner middle: 3-col with image center */
.banner-mid{display:grid;grid-template-columns:1fr;gap:1rem;align-items:center}
@media(min-width:768px){.banner-mid{grid-template-columns:1fr auto 1fr;gap:2rem}}

.banner-left-text,.banner-right-text{display:flex;flex-direction:column;gap:.6rem}
.banner-desc{font-family:var(--alt-font);font-size:13.5px;color:rgba(255,255,255,.65);line-height:1.75}
.banner-stat{background:rgba(192,224,177,0.08);border:1px solid rgba(192,224,177,0.18);padding:.65rem .9rem}
.banner-stat strong{display:block;font-family:var(--main-font);font-weight:700;font-size:22px;color:var(--accent-color);letter-spacing:.04em}
.banner-stat span{font-family:var(--alt-font);font-size:11px;color:rgba(255,255,255,.45)}

.banner-image-col{display:flex;justify-content:center;align-items:flex-end}
.banner-image-frame{position:relative;text-align:center;padding:0 1rem}
.banner-image-frame picture,.banner-image-frame img{display:block;max-width:220px;height:auto;margin:0 auto;filter:drop-shadow(0 -10px 40px rgba(156,28,102,0.35))}

/* Price bar */
.price-bar{background:var(--primary-color);padding:.8rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.4rem}
@media(min-width:640px){.price-bar{flex-direction:row;justify-content:space-between}}
.price-left{display:flex;align-items:baseline;gap:.5rem}
.price-amount{font-family:var(--main-font);font-weight:700;font-size:clamp(22px,4vw,32px);color:#fff;letter-spacing:.04em}
.price-curr{font-family:var(--alt-font);font-size:12px;font-weight:600;color:rgba(255,255,255,.5)}
.price-label{font-family:var(--alt-font);font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.btn-cart{display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;padding:.7rem 1.75rem;background:var(--accent-color);color:var(--dark-color);font-family:var(--main-font);font-weight:700;font-size:14px;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border:none;transition:background .2s,transform .15s}
.btn-cart:hover{background:#9CD49F;transform:translateY(-1px)}
.btn-cart svg{width:16px;height:16px}

/* ══ BENTO FEATURES GRID ══ */
.features-section{padding:2rem 0;background:var(--background-color)}
.container{width:100%;max-width:1180px;margin:0 auto;padding:0 1.5rem}
.bento-grid{display:grid;grid-template-columns:1fr;gap:.85rem}
@media(min-width:580px){.bento-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.bento-grid{grid-template-columns:repeat(4,1fr);grid-template-rows:auto auto}}

.bento-card{background:#fff;border:1px solid var(--border-color);padding:1.25rem;display:flex;flex-direction:column;gap:.6rem}
.bento-card--wide{background:var(--primary-color)}
@media(min-width:900px){.bento-card--wide{grid-column:span 2}}
.bento-card--tall{background:var(--light-color)}
@media(min-width:900px){.bento-card--tall{grid-row:span 2}}

.bento-icon{width:48px;height:48px;border-radius:50%;background:var(--light-color);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center}
.bento-card--wide .bento-icon{background:rgba(192,224,177,0.15);border-color:rgba(192,224,177,0.25)}
.bento-card--tall .bento-icon{background:#fff;border-color:var(--border-color)}
.bento-icon svg{width:22px;height:22px;color:var(--primary-color)}
.bento-card--wide .bento-icon svg{color:var(--accent-color)}

.bento-card h3{font-family:var(--main-font);font-weight:700;font-size:14px;color:var(--dark-color);text-transform:uppercase;letter-spacing:.05em}
.bento-card--wide h3{color:#fff}
.bento-card p{font-family:var(--alt-font);font-size:12px;color:rgba(40,10,26,.6);line-height:1.6}
.bento-card--wide p{color:rgba(255,255,255,.6)}
.bento-cta{display:inline-flex;align-items:center;gap:.35rem;margin-top:.25rem;font-family:var(--main-font);font-weight:700;font-size:12px;color:#fff;text-decoration:none;text-transform:uppercase;letter-spacing:.06em}

/* guarantee card */
.guarantee-card{background:var(--dark-color);border:none;padding:1.25rem;display:flex;flex-direction:column;gap:.6rem}
.guarantee-card h3{font-family:var(--main-font);font-weight:700;font-size:13px;color:var(--accent-color);text-transform:uppercase;letter-spacing:.06em}
.guarantee-card p{font-family:var(--alt-font);font-size:12px;color:rgba(255,255,255,.55);line-height:1.6}

/* ══ CTA HIGHLIGHT ══ */
.cta-highlight{background:var(--accent-color);padding:1.25rem 1.5rem;text-align:center;border-top:3px solid var(--primary-color);border-bottom:3px solid var(--primary-color)}
.cta-highlight strong{font-family:var(--main-font);font-weight:700;font-size:clamp(16px,4vw,22px);color:var(--dark-color);letter-spacing:.04em;text-transform:uppercase}

/* ══ TESTIMONIALS — horizontal cards ══ */
.testimonials-section{background:var(--dark-color);padding:2.5rem 0}
.section-title{text-align:center;margin-bottom:1.5rem}
.section-title h2{font-family:var(--main-font);font-weight:700;font-size:clamp(17px,4vw,24px);color:#fff;text-transform:uppercase;letter-spacing:.06em}
.section-title-bar{width:36px;height:3px;background:var(--accent-color);margin:.5rem auto 0}
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:.85rem}
@media(min-width:640px){.testimonials-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.testimonials-grid{grid-template-columns:repeat(3,1fr)}}
.testimonial-card{background:rgba(255,255,255,.06);border:1px solid rgba(156,28,102,.2);border-left:3px solid var(--accent-color);padding:1.2rem;transition:background .2s}
.testimonial-card:hover{background:rgba(255,255,255,.09)}
.t-header{display:flex;align-items:center;gap:.65rem;margin-bottom:.5rem}
.t-avatar{width:38px;height:38px;border-radius:50%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--main-font);font-weight:700;font-size:12px;color:#fff;text-transform:uppercase;letter-spacing:.04em}
.t-name{font-family:var(--main-font);font-weight:700;font-size:13px;color:#fff;text-transform:uppercase;letter-spacing:.04em}
.t-loc{font-family:var(--alt-font);font-size:11px;color:rgba(192,224,177,.75)}
.t-stars{display:flex;gap:2px;margin-bottom:.45rem}
.t-stars svg{width:13px;height:13px;fill:var(--accent-color)}
.t-text{font-family:var(--alt-font);font-size:12.5px;color:rgba(255,255,255,.68);line-height:1.65;font-style:italic}

/* FOOTER */
.site-footer{background:var(--dark-color);border-top:3px solid var(--primary-color)}
.footer-inner{max-width:1180px;margin:0 auto;padding:1rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.8rem}
@media(min-width:768px){.footer-inner{flex-direction:row;justify-content:space-between}}
.footer-logo{display:flex;align-items:center;gap:.5rem;text-decoration:none}
.footer-logo-icon{width:26px;height:26px}
.footer-logo-text{font-family:var(--main-font);font-weight:700;font-size:17px;color:#fff;letter-spacing:.08em;text-transform:uppercase}
.footer-logo-text em{font-style:normal;color:var(--accent-color)}
.footer-nav{display:flex;flex-direction:column;align-items:center;gap:.4rem}
@media(min-width:768px){.footer-nav{flex-direction:row;gap:1.4rem}}
.footer-nav a{font-family:var(--alt-font);font-size:11.5px;color:rgba(255,255,255,.42);text-decoration:none;transition:color .2s}
.footer-nav a:hover{color:var(--accent-color)}
.footer-copyright{border-top:1px solid rgba(255,255,255,.07);padding:.55rem 1.5rem;text-align:center;font-family:var(--alt-font);font-size:11px;color:rgba(255,255,255,.22);max-width:1180px;margin:0 auto;width:100%}