﻿/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   QNC MAROC â€” Design System v3
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Jost:wght@300;400;500;600;700&display=swap');

:root {
  --navy:    #1D6ED8;
  --blue:    #2B8DE8;
  --blu2:    #5BBCF5;
  --blu-lt:  #EEF7FD;
  --gold:    #C4973A;
  --gold-lt: #F5EDD6;
  --white:   #fff;
  --bg:      #F7F8FA;
  --g100:    #E8ECF0;
  --g300:    #9DAAB8;
  --g500:    #5A6472;
  --g700:    #2D3440;
  --g900:    #111418;
  --grn:     #10B981;
  --red:     #EF4444;
  --org:     #F59E0B;
  --wa:      #25D366;
  --f-disp: 'Cormorant Garamond', Georgia, serif;
  --f-body: 'Jost', system-ui, sans-serif;
  --nav-h: 70px;
  --sh-sm: 0 1px 4px rgba(0,0,0,.05), 0 4px 16px rgba(0,0,0,.04);
  --sh-md: 0 4px 12px rgba(0,0,0,.08), 0 16px 48px rgba(0,0,0,.06);
  --sh-lg: 0 8px 32px rgba(0,0,0,.12), 0 32px 80px rgba(0,0,0,.08);
  --r-sm: 8px; --r-md: 14px; --r-lg: 22px; --r-xl: 32px;
  --ease: 0.3s cubic-bezier(0.4,0,0.2,1);
}

/* â”€â”€ RESET â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:16px; scroll-behavior:smooth; scroll-padding-top:calc(var(--nav-h) + 24px); overflow-x:hidden; }
body { font-family:var(--f-body); color:var(--g900); overflow-x:hidden; line-height:1.65; -webkit-font-smoothing:antialiased; }
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
button { font-family:var(--f-body); cursor:pointer; border:none; outline:none; background:none; }
input,select,textarea { font-family:var(--f-body); }
ul { list-style:none; }

/* â”€â”€ CONTAINER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.container-sm { max-width:860px; margin:0 auto; padding:0 24px; }

/* â”€â”€ UTILITIES â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.w-full { width:100%; justify-content:center; }
.bg-light { background:var(--bg); }
.bg-navy  { background:var(--navy); }
.text-center { text-align:center; }
.pt-0 { padding-top:0 !important; }

/* Reveal animation */
[data-reveal] { opacity:0; transform:translateY(28px); transition:opacity .75s ease, transform .75s ease; }
[data-reveal].revealed { opacity:1; transform:translateY(0); }
[data-reveal="left"]  { transform:translateX(-28px); }
[data-reveal="left"].revealed  { transform:translateX(0); }
[data-reveal="right"] { transform:translateX(28px); }
[data-reveal="right"].revealed { transform:translateX(0); }

/* â”€â”€ KEYFRAMES â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@keyframes productFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-16px)} }
@keyframes scrollPulse  { 0%,100%{opacity:0;transform:scaleY(.5) translateY(-10px)} 50%{opacity:1;transform:scaleY(1) translateY(0)} }
@keyframes spin         { to{transform:rotate(360deg)} }
@keyframes pulse        { 0%,100%{box-shadow:0 0 0 0 rgba(18,120,184,.35)} 50%{box-shadow:0 0 0 10px rgba(18,120,184,0)} }
@keyframes slideUp      { from{transform:translateY(100%);opacity:0} to{transform:translateY(0);opacity:1} }
@keyframes blink        { 50%{border-color:transparent} }
@keyframes countUp      { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }

/* â”€â”€ BUTTONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 26px; border-radius:var(--r-sm); font-size:14px; font-weight:600;
  cursor:pointer; transition:all var(--ease); letter-spacing:.3px;
  border:2px solid transparent; white-space:nowrap; font-family:var(--f-body);
}
.btn-primary       { background:var(--navy); color:#fff; border-color:var(--navy); }
.btn-primary:hover { background:var(--blue); border-color:var(--blue); transform:translateY(-1px); box-shadow:var(--sh-sm); }
.btn-outline       { background:transparent; color:var(--navy); border-color:var(--navy); }
.btn-outline:hover { background:var(--navy); color:#fff; }
.btn-outline-light { background:transparent; color:#fff; border-color:rgba(255,255,255,.5); }
.btn-outline-light:hover { background:rgba(255,255,255,.12); border-color:#fff; }
.btn-ghost    { background:rgba(255,255,255,.1); color:#fff; border-color:rgba(255,255,255,.25); }
.btn-ghost:hover { background:rgba(255,255,255,.2); }
.btn-whatsapp { background:var(--wa); color:#fff; border-color:var(--wa); }
.btn-whatsapp:hover { background:#1DA851; border-color:#1DA851; transform:translateY(-1px); }
.btn-gold     { background:var(--gold); color:#fff; border-color:var(--gold); }
.btn-gold:hover { background:#b88428; transform:translateY(-1px); }
.btn-sm  { padding:8px 18px; font-size:13px; }
.btn-lg  { padding:15px 34px; font-size:15px; border-radius:var(--r-md); }
.btn-xl  { padding:17px 40px; font-size:16px; border-radius:var(--r-md); }

/* â”€â”€ SECTION LAYOUT â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.section { padding:88px 0; }

.section-header { text-align:center; margin-bottom:56px; }
.section-header.light .section-title,
.section-header.light .section-desc { color:#fff; }
.section-header.light .section-eyebrow { color:var(--blu2); border-color:rgba(74,174,224,.3); background:rgba(74,174,224,.1); }

.section-eyebrow {
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:2.5px;
  text-transform:uppercase; color:var(--blue); background:var(--blu-lt);
  padding:5px 14px; border-radius:20px; margin-bottom:14px;
  border:1px solid rgba(18,120,184,.15);
}
.section-title {
  font-family:var(--f-disp); font-size:clamp(2rem,4vw,2.8rem); font-weight:600;
  color:var(--navy); line-height:1.2; margin-bottom:14px;
}
.section-desc { font-size:16px; color:var(--g500); max-width:560px; margin:0 auto; line-height:1.75; }
.section-cta { text-align:center; margin-top:48px; }

/* Wave / clip dividers */
.section-wave { overflow:hidden; line-height:0; }
.section-wave svg { display:block; width:100%; }

/* â”€â”€ PROMO BAR â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.promo-bar {
  background:linear-gradient(135deg,var(--navy) 0%,#1a4a7a 100%);
  color:rgba(255,255,255,.88); text-align:center;
  padding:10px 48px; font-size:13px; letter-spacing:.4px; position:relative; z-index:201;
}
.promo-bar strong { color:#fff; }
.promo-close {
  position:absolute; right:16px; top:50%; transform:translateY(-50%);
  color:rgba(255,255,255,.4); font-size:18px; cursor:pointer; transition:color .2s;
  padding:4px 8px; line-height:1;
}
.promo-close:hover { color:#fff; }

/* â”€â”€ HEADER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* #site-header wrapper creates space for the fixed nav so promo bar renders below it */
#site-header { padding-top:var(--nav-h); }

.site-header {
  position:fixed; top:0; left:0; right:0; width:100%; z-index:200;
  background:#fff;
  border-bottom:1px solid transparent;
  transition:box-shadow var(--ease), border-color var(--ease), transform .35s cubic-bezier(.4,0,.2,1);
  transform:translateZ(0); /* promote to GPU layer for smooth scroll */
  will-change: transform;
}
.site-header.scrolled {
  box-shadow:0 2px 24px rgba(0,0,0,.1);
  border-color:var(--g100);
}
/* hide on scroll-down, reveal on scroll-up */
.site-header.hidden { transform:translateY(-110%); }

.hdr-inner {
  display:flex; align-items:center; justify-content:space-between; height:var(--nav-h);
}
.hdr-logo .logo-img { height:64px; width:auto; transition:transform .2s; }
.hdr-logo:hover .logo-img { transform:scale(1.04); }
.hdr-nav { display:flex; align-items:center; gap:30px; }
.nav-link {
  font-size:14px; font-weight:500; color:var(--g700); transition:color .2s;
  position:relative; white-space:nowrap; padding:4px 0;
}
.nav-link::after {
  content:''; position:absolute; bottom:-2px; left:0; width:0; height:2px;
  background:var(--gold); border-radius:2px; transition:width .3s ease;
}
.nav-link:hover,.nav-link.active { color:var(--navy); }
.nav-link:hover::after,.nav-link.active::after { width:100%; }
.hdr-actions { display:flex; align-items:center; gap:10px; }
.hdr-cart-btn {
  position:relative; padding:8px 10px; border-radius:var(--r-sm);
  transition:background .2s; color:var(--navy); display:flex; align-items:center;
}
.hdr-cart-btn:hover { background:var(--bg); }
.cart-badge {
  position:absolute; top:2px; right:2px; background:var(--gold); color:#fff;
  font-size:10px; font-weight:700; width:18px; height:18px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  animation:pulse 2s ease-in-out infinite;
}
.mob-menu-btn {
  display:none; flex-direction:column; gap:5px; padding:8px; cursor:pointer;
}
.mob-menu-btn span {
  width:22px; height:2px; background:var(--navy); border-radius:2px; display:block;
  transition:all .3s;
}
.mob-menu-btn.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.mob-menu-btn.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.mob-menu-btn.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile drawer */
.mob-drawer {
  display:none; position:fixed; top:0; right:0; bottom:0; width:300px;
  background:#fff; z-index:300; transform:translateX(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  box-shadow:var(--sh-lg); overflow-y:auto;
}
.mob-drawer.open { transform:translateX(0); }
.mob-drawer-inner { padding:80px 24px 100px; display:flex; flex-direction:column; gap:4px; }
.mob-nav-link {
  display:block; padding:13px 14px; border-radius:var(--r-sm);
  font-size:15px; font-weight:500; color:var(--g700); transition:all .2s;
}
.mob-nav-link:hover { background:var(--bg); color:var(--navy); }
.mob-nav-link.active { background:var(--blu-lt); color:var(--navy); font-weight:600; }
.mob-drawer-sep { height:1px; background:var(--g100); margin:12px 0; }
.mob-overlay {
  display:none; position:fixed; inset:0; background:rgba(10,36,64,.55);
  z-index:299; opacity:0; transition:opacity .3s; pointer-events:none;
}
.mob-overlay.open { opacity:1; pointer-events:all; }

/* â”€â”€ CART DRAWER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cart-overlay {
  position:fixed; inset:0; background:rgba(10,36,64,.5);
  z-index:400; opacity:0; pointer-events:none; transition:opacity .3s;
}
.cart-overlay.open { opacity:1; pointer-events:all; }
.cart-drawer {
  position:fixed; top:0; right:0; bottom:0; width:400px; max-width:100vw;
  background:#fff; z-index:401; transform:translateX(100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column; box-shadow:var(--sh-lg);
}
.cart-drawer.open { transform:translateX(0); }
.cart-drawer-header {
  padding:20px 24px; border-bottom:1px solid var(--g100);
  display:flex; align-items:center; justify-content:space-between; flex-shrink:0;
}
.cart-drawer-header h3 { font-size:18px; font-weight:700; color:var(--navy); }
.cart-close-btn {
  width:34px; height:34px; border-radius:50%; border:1.5px solid var(--g100);
  background:var(--bg); color:var(--g500); display:flex; align-items:center;
  justify-content:center; cursor:pointer; transition:all .2s;
}
.cart-close-btn:hover { background:#FEE2E2; color:var(--red); border-color:#FCA5A5; }
.cart-items { flex:1; overflow-y:auto; padding:0 24px; }
.cart-empty {
  text-align:center; padding:60px 20px; color:var(--g300);
  display:flex; flex-direction:column; align-items:center; gap:14px;
}
.cart-empty svg { width:52px; height:52px; opacity:.3; margin:0 auto; }
.cart-empty p { font-size:14px; color:var(--g500); }
.cart-item {
  display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--g100); align-items:center;
}
.cart-item:last-child { border-bottom:none; }
.cart-item-img { width:60px; height:60px; border-radius:var(--r-sm); background:var(--blu-lt); flex-shrink:0; overflow:hidden; object-fit:cover; }
.cart-item-info { flex:1; min-width:0; }
.cart-item-name { font-size:13.5px; font-weight:600; color:var(--navy); margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cart-item-label { font-size:12px; color:var(--g500); margin-bottom:4px; }
.cart-item-price { font-size:14px; font-weight:700; color:var(--navy); }
.cart-item-del { padding:8px; border-radius:8px; color:var(--g300); transition:all .2s; flex-shrink:0; min-width:38px; min-height:38px; display:flex; align-items:center; justify-content:center; }
.cart-item-del:hover { background:#FEE2E2; color:var(--red); }
.cart-footer {
  padding:20px 24px; border-top:1px solid var(--g100); background:var(--bg);
  flex-shrink:0; display:flex; flex-direction:column; gap:12px;
}
.cart-subtotal { display:flex; justify-content:space-between; align-items:center; font-size:16px; font-weight:700; color:var(--navy); }
.cart-cod-note { font-size:12.5px; color:var(--g500); text-align:center; }

/* â”€â”€ WA FAB â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.wa-fab {
  position:fixed; bottom:28px; left:24px; z-index:360;
  width:60px; height:60px; border-radius:50%; background:var(--wa);
  box-shadow:0 4px 20px rgba(37,211,102,.5); display:flex; align-items:center;
  justify-content:center; cursor:pointer; transition:transform .2s, box-shadow .2s;
}
.wa-fab:hover { transform:scale(1.12); box-shadow:0 8px 30px rgba(37,211,102,.6); }

/* â”€â”€ TOAST â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.toast {
  position:fixed; bottom:24px; right:24px; z-index:600;
  background:var(--navy); color:#fff; padding:13px 20px;
  border-radius:var(--r-md); font-size:14px; font-weight:500;
  box-shadow:var(--sh-lg); transform:translateY(16px); opacity:0;
  transition:all .3s; pointer-events:none; max-width:calc(100vw - 48px);
}
.toast.show { transform:translateY(0); opacity:1; }
.toast.toast-error { background:#991B1B; }

/* Mobile floating CTA */
.mob-float-cta {
  display:none; position:fixed; bottom:0; left:0; right:0; z-index:350;
  background:linear-gradient(135deg,#22c55e 0%,#16a34a 50%,#2B8DE8 100%);
  padding:12px 20px 16px;
  box-shadow:0 -4px 24px rgba(0,0,0,.18);
  animation:slideUp .4s ease;
}
.mob-float-cta.hidden { display:none; }
.mob-float-cta-inner { display:flex; align-items:center; gap:12px; max-width:500px; margin:0 auto; }
.mob-float-cta-text { flex:1; color:#fff; font-size:14px; font-weight:600; line-height:1.3; }
.mob-float-cta-text span { font-size:11px; color:rgba(255,255,255,.65); display:block; }
.mob-float-cta-btn { background:#fff; color:var(--navy); border:none; padding:11px 20px; border-radius:50px; font-size:14px; font-weight:700; white-space:nowrap; cursor:pointer; transition:all .2s; }
.mob-float-cta-btn:hover { background:var(--gold-lt); }

/* â”€â”€ HERO â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.hero {
  position:relative; display:flex; align-items:center;
  overflow:hidden; background:var(--navy);
}
.hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:.38; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(10,36,64,.78) 0%,rgba(18,120,184,.42) 100%); }
.hero-content { position:relative; z-index:2; color:#fff; padding:72px 24px; max-width:1200px; margin:0 auto; width:100%; text-align:center; display:flex; flex-direction:column; align-items:center; }
.hero-badge {
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:2.5px;
  text-transform:uppercase; color:#16a34a; background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.85); padding:8px 22px; border-radius:20px; margin-bottom:18px;
}
.hero-title {
  font-family:var(--f-disp); font-size:clamp(2.8rem,6vw,4.8rem); font-weight:700;
  line-height:1.08; margin-bottom:18px; max-width:800px;
}
.hero-title em { font-style:italic; color:var(--blu2); }
.hero-sub {
  font-size:clamp(15px,2vw,18px); color:rgba(255,255,255,.82);
  line-height:1.8; margin-bottom:28px; max-width:580px;
}
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:28px; justify-content:center; }
.hero-trust { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.hero-trust span {
  display:flex; align-items:center; gap:7px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.25);
  border-radius:40px;
  padding:7px 16px;
  font-size:12.5px;
  color:rgba(255,255,255,.95);
  font-weight:500;
  letter-spacing:.2px;
  white-space:nowrap;
  transition:background .2s, border-color .2s;
}
.hero-trust span:hover { background:rgba(255,255,255,.2); border-color:rgba(255,255,255,.38); }
.hero-scroll-indicator { position:absolute; bottom:32px; left:50%; transform:translateX(-50%); z-index:2; }
.hero-scroll-indicator span { display:block; width:2px; height:36px; background:linear-gradient(to bottom,rgba(255,255,255,.6),transparent); margin:0 auto; animation:scrollPulse 2s ease-in-out infinite; }

/* â”€â”€ ANIMATED STATS SECTION â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.stats-section {
  background:var(--navy);
  padding:56px 0; position:relative; overflow:hidden;
}
.stats-section::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 30% 50%,rgba(74,174,224,.15) 0%,transparent 60%),
             radial-gradient(ellipse at 70% 50%,rgba(196,151,58,.08) 0%,transparent 60%);
}
.stats-section .container { position:relative; z-index:1; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; text-align:center; }
.stat-item {
  padding:28px 20px; position:relative;
}
.stat-item::after {
  content:''; position:absolute; top:20%; right:0; bottom:20%;
  width:1px; background:rgba(255,255,255,.12);
}
.stat-item:last-child::after { display:none; }
.stat-num {
  display:block; font-family:var(--f-body); font-size:clamp(2rem,4vw,3rem); font-weight:800;
  color:#fff; line-height:1; margin-bottom:8px;
  animation:countUp .6s ease forwards;
}
.stat-suffix { font-size:1.4em; color:var(--blu2); font-weight:700; }
.stat-lbl { font-size:13px; color:rgba(255,255,255,.65); font-weight:500; letter-spacing:.5px; text-transform:uppercase; }

/* â”€â”€ PRODUCT CARDS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.products-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:28px; }
.home-products  { grid-template-columns:repeat(2,1fr); }
.boutique-grid  { grid-template-columns:repeat(2,1fr); gap:32px; }
.related-products { grid-template-columns:repeat(auto-fit,minmax(280px,400px)); }

.product-card {
  background:#fff; border-radius:var(--r-lg); border:1px solid var(--g100);
  overflow:hidden; transition:box-shadow var(--ease), transform var(--ease);
  display:flex; flex-direction:column;
}
.product-card:hover { box-shadow:var(--sh-md); transform:translateY(-5px); }
.product-card.featured { border:2px solid var(--g100); }

.pc-img-wrap {
  position:relative; aspect-ratio:4/3; background:var(--blu-lt);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.pc-img { width:100%; height:100%; object-fit:contain; padding:12px; transition:transform .5s ease; }
.product-card:hover .pc-img { transform:scale(1.06); }
.pc-badge {
  position:absolute; top:16px; left:16px; font-size:11px; font-weight:700;
  padding:4px 12px; border-radius:20px; letter-spacing:.4px;
}
.pc-badge-gold { background:var(--gold); color:#fff; }
.pc-badge-blue { background:var(--blue); color:#fff; }

.pc-body { padding:24px; display:flex; flex-direction:column; flex:1; gap:10px; }
.pc-name { font-family:var(--f-disp); font-size:clamp(21px,2.1vw,30px); font-weight:600; color:var(--navy); line-height:1.25; white-space:normal; }
.pc-name:hover { color:var(--blue); }
.pc-desc { font-size:15px; color:var(--g500); }
.pc-bullets { display:flex; flex-direction:column; gap:4px; }
.pc-bullets span { font-size:13px; color:var(--g700); }
.pc-price-row { display:flex; align-items:baseline; gap:10px; margin-top:4px; }
.pc-price { font-size:24px; font-weight:800; color:var(--navy); }
.pc-price-old { font-size:15px; color:var(--g300); text-decoration:line-through; }
.pc-discount { font-size:12px; font-weight:700; color:var(--grn); background:#D1FAE5; padding:2px 8px; border-radius:10px; }
.pc-stock { font-size:12.5px; color:var(--grn); font-weight:600; }
.pc-actions { margin-top:auto; display:flex; flex-direction:column; gap:8px; }

/* â”€â”€ BENEFITS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.benefits-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.benefit-card {
  text-align:center; padding:36px 20px; background:#fff;
  border-radius:var(--r-lg); border:1px solid var(--g100);
  transition:all var(--ease); box-shadow:var(--sh-sm);
}
.benefit-card:hover { transform:translateY(-6px); box-shadow:var(--sh-md); border-color:var(--blu2); }
.benefit-icon {
  width:64px; height:64px; border-radius:16px;
  background:linear-gradient(135deg,var(--blue),var(--navy));
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 22px;
  box-shadow:0 8px 24px rgba(29,110,216,.22);
  transition:transform var(--ease), box-shadow var(--ease);
}
.benefit-card:hover .benefit-icon { transform:translateY(-3px); box-shadow:0 12px 32px rgba(29,110,216,.32); }
.benefit-icon svg { width:28px; height:28px; stroke:#fff; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.benefit-card h3 { font-size:16px; font-weight:700; color:var(--navy); margin-bottom:8px; }
.benefit-card p { font-size:14px; color:var(--g500); line-height:1.65; }

/* â”€â”€ SPOTLIGHT â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.spotlight-grid { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }

/* Premium display card for product image */
.spotlight-img-wrap {
  display:flex; flex-direction:column; align-items:center;
  background:linear-gradient(150deg,#EBF5FF 0%,#F6FAFF 55%,#E4F1FD 100%);
  border-radius:28px;
  padding:36px 36px 24px;
  border:1.5px solid rgba(18,120,184,.13);
  box-shadow:0 20px 60px rgba(10,36,64,.08), 0 0 0 5px rgba(18,120,184,.04),
             inset 0 1px 0 rgba(255,255,255,.85);
  position:relative; overflow:hidden;
}
/* Radial glow behind product */
.spotlight-img-wrap::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse at 50% 25%, rgba(43,141,232,.10) 0%, transparent 68%);
}
/* Gold corner accent */
.spotlight-img-wrap::after {
  content:''; position:absolute; top:0; right:0;
  width:80px; height:80px; pointer-events:none;
  background:linear-gradient(225deg, rgba(218,165,32,.14) 0%, transparent 60%);
  border-radius:0 28px 0 80px;
}

.spotlight-img {
  width:100%; height:300px;
  object-fit:contain; background:transparent;
  border-radius:0; aspect-ratio:unset;
  position:relative; z-index:1;
  transition:transform .45s cubic-bezier(.25,.46,.45,.94);
  display:block;
}
.spotlight-img-wrap:hover .spotlight-img { transform:scale(1.04) translateY(-6px); }

/* Result badge â€” below the product, not overlapping */
.spotlight-badge-float {
  position:relative; bottom:auto; left:auto;
  margin-top:22px; z-index:2;
  display:inline-flex; align-items:center; gap:7px;
  background:linear-gradient(135deg,#9A7200,#C8960C 45%,#B8860B);
  color:#fff; font-size:12.5px; font-weight:700; letter-spacing:.3px;
  padding:9px 22px; border-radius:50px;
  box-shadow:0 4px 18px rgba(184,134,11,.28), inset 0 1px 0 rgba(255,255,255,.18);
}

/* Social proof mini-row on spotlight */
.spotlight-proof {
  display:flex; align-items:center; gap:6px;
  font-size:12.5px; color:var(--g500); margin-top:8px;
}
.spotlight-proof-stars { color:#F59E0B; letter-spacing:1px; font-size:13px; }

.spotlight-content { display:flex; flex-direction:column; gap:16px; }
.spotlight-content h2 { font-family:var(--f-disp); font-size:clamp(1.6rem,2.4vw,2.6rem); font-weight:600; color:var(--navy); line-height:1.2; white-space:nowrap; }
.spotlight-content h2 em { font-style:italic; color:var(--blue); }
.spotlight-content p { font-size:15px; color:var(--g700); line-height:1.75; }
.spotlight-list { display:flex; flex-direction:column; gap:8px; }
.spotlight-list li { font-size:14.5px; color:var(--g700); }

/* â”€â”€ TESTIMONIALS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testimonial-card {
  background:#fff; border:1px solid var(--g100); border-radius:var(--r-lg);
  padding:28px; box-shadow:var(--sh-sm); display:flex; flex-direction:column; gap:14px;
  transition:all var(--ease);
}
.testimonial-card:hover { transform:translateY(-4px); box-shadow:var(--sh-md); }
.tc-stars { color:var(--gold); font-size:16px; }
.tc-text { font-size:14.5px; color:var(--g700); line-height:1.72; font-style:italic; flex:1; }
.tc-author { display:flex; align-items:center; gap:12px; }
.tc-avatar {
  width:42px; height:42px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  color:#fff; font-size:15px; font-weight:700; display:flex; align-items:center; justify-content:center;
}
.tc-name { font-size:13.5px; font-weight:700; color:var(--navy); }
.tc-city { font-size:12px; color:var(--g300); }

/* â”€â”€ CERTIFICATIONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.certs-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.cert-card {
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-lg); padding:36px 28px; text-align:center;
  transition:all var(--ease);
}
.cert-card:hover { background:rgba(255,255,255,.12); transform:translateY(-4px); }
.cert-img { height:64px; object-fit:contain; margin:0 auto 16px; filter:brightness(0) invert(1); }
.cert-name { font-size:16px; font-weight:700; color:#fff; margin-bottom:8px; }
.cert-desc { font-size:13px; color:rgba(255,255,255,.6); line-height:1.6; }
.bg-light .cert-card { background:#fff; border-color:var(--g100); }
.bg-light .cert-img { filter:none; }
.bg-light .cert-name { color:var(--navy); }
.bg-light .cert-desc { color:var(--g500); }

/* â”€â”€ CTA SECTION â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cta-section { background:#0B3168; }
.cta-content { text-align:center; padding:80px 28px; color:#fff; }
.cta-content h2 { font-family:var(--f-disp); font-size:clamp(2rem,4vw,3rem); font-weight:600; margin-bottom:16px; line-height:1.2; }
.cta-content p { font-size:17px; color:rgba(255,255,255,.78); margin-bottom:36px; }
.cta-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-bottom:20px; }
.cta-reassure { font-size:13px; color:rgba(255,255,255,.5); }

/* â”€â”€ TRUST BAR â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.trust-bar { background:var(--bg); border-bottom:1px solid var(--g100); padding:14px 0; }
.trust-bar-inner { display:flex; align-items:center; justify-content:center; gap:32px; flex-wrap:wrap; font-size:13.5px; font-weight:500; color:var(--g700); }

/* â”€â”€ PAGE HEADER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.page-header {
  background:linear-gradient(135deg,var(--navy) 0%,#2B8DE8 100%);
  color:#fff; padding:56px 0 48px; text-align:center;
}
.page-header.small { padding:28px 0; text-align:left; }
.page-title { font-family:var(--f-disp); font-size:clamp(2rem,4.5vw,3rem); font-weight:600; margin-bottom:12px; }
.page-subtitle { font-size:16px; color:rgba(255,255,255,.75); max-width:520px; margin:0 auto; }
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:13px; color:rgba(255,255,255,.55); margin-bottom:16px; flex-wrap:wrap; }
.breadcrumb a { color:rgba(255,255,255,.55); transition:color .2s; }
.breadcrumb a:hover { color:#fff; }
.breadcrumb span:last-child { color:rgba(255,255,255,.9); }

/* â”€â”€ PRODUCT HERO (product pages) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.prod-hero {
  background:linear-gradient(135deg,var(--bg) 0%,#e8f4fd 100%);
  padding:48px 0 32px; position:relative; overflow:hidden;
}
.prod-hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.prod-hero-text { display:flex; flex-direction:column; gap:16px; }
.prod-hero-tag {
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:2px;
  text-transform:uppercase; padding:5px 14px; border-radius:20px;
}
.prod-hero-tag.gold { background:var(--gold-lt); color:var(--gold); }
.prod-hero-tag.blue { background:var(--blu-lt); color:var(--blue); }
.prod-hero-title {
  font-family:var(--f-body); font-size:clamp(1.55rem,3.4vw,2.6rem);
  font-weight:700; color:var(--navy); line-height:1.15;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  padding-bottom:10px; position:relative; display:inline-block;
}
.prod-hero-title::after {
  content:''; position:absolute; bottom:0; left:0;
  width:56px; height:3.5px; border-radius:2px;
  background:linear-gradient(90deg, var(--blue), var(--blu2));
}
.prod-hero-title em { font-style:italic; color:var(--blue); }

/* â”€â”€ ANIMATED WORD LINE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.hero-anim-line {
  font-size:1.08rem; font-weight:500; color:var(--g500);
  margin:14px 0 0; letter-spacing:.01em;
}
.anim-word {
  color:var(--grn); font-weight:700; display:inline-block;
  font-size:1.05em;
  transition:opacity .28s ease, transform .28s ease;
}
.anim-word.hide { opacity:0; transform:translateY(5px); }

.prod-hero-sub { font-size:16px; color:var(--g700); line-height:1.75; }
.prod-hero-bullets {
  background:#fff; border-left:4px solid var(--blue); padding:16px 20px;
  border-radius:0 var(--r-sm) var(--r-sm) 0; box-shadow:var(--sh-sm);
}
.prod-hero-bullets li {
  padding:5px 0 5px 24px; position:relative; color:var(--g700); font-size:14.5px;
}
.prod-hero-bullets li::before {
  content:''; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:10px; height:10px; background:var(--blue); border-radius:50%;
}
.prod-hero-img-wrap { display:flex; flex-direction:column; justify-content:center; align-items:center; position:relative; gap:0; }
.prod-hero-img {
  width:clamp(260px,40vw,480px); max-width:100%; height:auto;
  filter:none;
  animation:none;
}

/* â”€â”€ PRODUCT IMAGE SLIDER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.prod-img-slider {
  position:relative;
  width:clamp(260px,40vw,460px); max-width:100%;
  /* Premium display card */
  background:linear-gradient(150deg,#EBF5FF 0%,#F6FAFF 55%,#E4F1FD 100%);
  border-radius:26px;
  padding:0 0 16px;
  border:1.5px solid rgba(18,120,184,.13);
  box-shadow:0 24px 64px rgba(10,36,64,.10), 0 0 0 5px rgba(18,120,184,.04),
             inset 0 1px 0 rgba(255,255,255,.9);
}
/* No overlay on slider â€” keep images clean */
.prod-img-slider::before {
  display:none;
}
/* Gold accent corner */
.prod-img-slider::after {
  content:''; position:absolute; top:0; right:0;
  width:70px; height:70px; pointer-events:none;
  background:linear-gradient(225deg,rgba(218,165,32,.13) 0%,transparent 60%);
  border-radius:0 26px 0 70px;
}
.prod-img-slider .prod-hero-img {
  width:100%; height:100%; animation:none; position:relative; z-index:1;
  object-fit:contain; object-position:center center; background:transparent;
}
.prod-img-slider-inner { overflow:hidden; border-radius:26px 26px 0 0; position:relative; z-index:1; height:320px; aspect-ratio:unset; width:100%; }

/* Result badge below the slider */
.prod-hero-result-tag {
  display:inline-flex; align-items:center; gap:7px;
  margin-top:14px; margin-left:16px; margin-right:16px;
  background:linear-gradient(135deg,#9A7200,#C8960C 45%,#B8860B);
  color:#fff; font-size:12.5px; font-weight:700; letter-spacing:.3px;
  padding:9px 22px; border-radius:50px;
  box-shadow:0 4px 18px rgba(184,134,11,.28), inset 0 1px 0 rgba(255,255,255,.18);
}
/* Social proof below badge */
.prod-hero-proof {
  display:flex; align-items:center; gap:5px;
  font-size:12px; color:var(--g500); margin-top:6px; margin-bottom:0;
}
.prod-hero-proof-stars { color:#F59E0B; font-size:13px; letter-spacing:1px; }
.prod-img-slider-track {
  display:flex;
  width:100%;
  height:100%;
  transition:transform 0.42s cubic-bezier(0.25,0.46,0.45,0.94);
  will-change:transform;
}
.prod-img-slide { flex:0 0 100%; width:100%; height:100%; }
.prod-img-slide img { width:100%; height:100%; object-fit:contain; object-position:center center; display:block; }
.prod-img-controls {
  display:flex; align-items:center; justify-content:center; gap:14px; margin-top:12px;
}
.prod-img-nav {
  position:static; transform:none; flex-shrink:0;
  width:38px; height:38px; border-radius:50%;
  background:#fff; border:1.5px solid rgba(18,120,184,.25);
  display:flex; align-items:center; justify-content:center;
  font-size:18px; line-height:1; cursor:pointer; color:var(--navy);
  box-shadow:0 2px 10px rgba(10,36,64,.15); z-index:5; transition:all .15s;
  padding:0;
}
.prod-img-nav:hover { background:var(--blu-lt); border-color:var(--blue); box-shadow:0 4px 16px rgba(10,36,64,.22); }
.prod-img-prev { left:auto; }
.prod-img-next { right:auto; }
.prod-img-dots { display:flex; justify-content:center; gap:7px; }
.prod-img-dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(10,36,64,.18); border:none; cursor:pointer; padding:0;
  transition:all .2s;
}
.prod-img-dot.active { background:var(--blue); transform:scale(1.35); }

/* â”€â”€ INLINE ORDER FORM â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.order-section { background:#fff; }
.order-card {
  max-width:680px; margin:0 auto; background:#fff; border-radius:var(--r-xl);
  box-shadow:var(--sh-lg); overflow:hidden;
  border:1px solid var(--g100);
}
.order-card-header {
  background:linear-gradient(135deg,var(--navy),var(--blue));
  padding:28px 32px; color:#fff; text-align:center;
}
.order-card-header h2 { font-family:var(--f-disp); font-size:1.8rem; font-weight:600; margin-bottom:4px; }
.order-card-header p { font-size:14px; color:rgba(255,255,255,.78); }
.order-card-body { padding:32px; }

/* Offer radio cards */
.offer-label { font-size:13px; font-weight:700; color:var(--g700); margin-bottom:10px; display:block; }
.offer-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:20px; }
.offer-radio-card {
  position:relative; background:#fff; border:2px solid var(--g100);
  border-radius:var(--r-md); padding:14px 10px; cursor:pointer;
  transition:all .2s; box-shadow:var(--sh-sm); text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:6px;
}
.offer-radio-card:hover { border-color:var(--blue); transform:translateY(-2px); box-shadow:var(--sh-md); }
.offer-radio-card.active { border-color:var(--navy); background:var(--blu-lt); box-shadow:0 0 0 3px rgba(18,120,184,.15); }
.offer-radio-card input[type="radio"] { position:absolute; opacity:0; pointer-events:none; }
.offer-radio-img { width:64px; height:64px; object-fit:contain; }
.offer-radio-qty { font-size:13px; font-weight:700; color:var(--navy); line-height:1.2; }
.offer-radio-price { font-size:16px; font-weight:800; color:var(--navy); }
.offer-radio-old { font-size:11px; color:var(--g300); text-decoration:line-through; }
.offer-radio-save { font-size:10px; font-weight:700; color:var(--grn); }
.offer-radio-info { display:flex; flex-direction:column; gap:2px; align-items:center; }
.offer-badge {
  position:absolute; top:-1px; right:-1px;
  background:linear-gradient(135deg,var(--org),#e53e3e);
  color:#fff; font-size:9px; font-weight:800;
  padding:3px 9px; border-radius:0 var(--r-md) 0 var(--r-md);
  letter-spacing:.3px; white-space:nowrap;
}
.offer-badge.best { background:linear-gradient(135deg,var(--navy),var(--blue)); font-size:11px; padding:4px 11px; }

/* Order card header & action area */
.order-card-header {
  background:linear-gradient(135deg,var(--navy),var(--blue));
  padding:16px 24px; color:#fff;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
}
.order-card-header span:first-child { font-size:14px; font-weight:700; }
.order-card-cod { font-size:12px; color:rgba(255,255,255,.75); }
.order-btns { display:flex; flex-direction:column; gap:10px; margin:20px 0 14px; }
.order-trust { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; font-size:11.5px; color:var(--g500); }
.order-trust span { display:flex; align-items:center; gap:4px; }

/* Typing cursor */
.typing-cursor {
  display:inline-block; border-right:3px solid var(--blue);
  margin-left:2px; animation:blink .9s steps(1,end) infinite;
  vertical-align:bottom;
}

/* Product hero floating badge */
.prod-hero-float-badge {
  position:absolute; bottom:24px; right:24px;
  background:#fff; border-radius:var(--r-md); padding:10px 16px;
  box-shadow:var(--sh-md); text-align:center; line-height:1.2;
  border-left:4px solid var(--gold);
}
.prod-hero-float-badge strong { display:block; font-size:18px; font-weight:800; color:var(--navy); }
.prod-hero-float-badge span { font-size:11px; color:var(--g500); }

/* FAQ SVG arrow */
.faq-item.open .faq-q svg { transform:rotate(180deg); }
.faq-q svg { transition:transform .3s; flex-shrink:0; }

.offer-best-tag {
  position:absolute; top:-8px; left:50%; transform:translateX(-50%);
  background:var(--gold); color:#fff; font-size:9px; font-weight:800;
  padding:2px 10px; border-radius:10px; letter-spacing:.5px; white-space:nowrap;
}

.order-form-fields { display:flex; flex-direction:column; gap:14px; margin-bottom:20px; }
.order-field label { display:block; font-size:12.5px; font-weight:600; color:var(--g700); margin-bottom:5px; }
.order-field input, .order-field select {
  width:100%; padding:12px 16px; border:1.5px solid var(--g100);
  border-radius:var(--r-sm); font-size:14px; outline:none;
  transition:all .2s; background:var(--bg); color:var(--g900);
}
.order-field input:focus, .order-field select:focus {
  border-color:var(--navy); background:#fff; box-shadow:0 0 0 3px rgba(10,36,64,.07);
}
.order-cod-badge {
  display:flex; align-items:center; gap:12px; background:var(--blu-lt);
  border:1px solid rgba(18,120,184,.2); border-radius:var(--r-sm);
  padding:14px 18px; margin-bottom:16px;
}
.order-cod-badge svg { flex-shrink:0; stroke:var(--blue); fill:none; stroke-width:2; }
.order-cod-badge p { font-size:13px; color:var(--g700); line-height:1.5; }
.order-cod-badge strong { color:var(--navy); }
.order-btn-group { display:flex; flex-direction:column; gap:10px; }
.btn-order-now {
  width:100%; padding:16px; background:linear-gradient(135deg,var(--navy),var(--blue));
  color:#fff; border:none; border-radius:var(--r-md); font-size:16px; font-weight:700;
  cursor:pointer; transition:all .2s; box-shadow:0 4px 20px rgba(18,120,184,.35);
  font-family:var(--f-body);
}
.btn-order-now:hover { transform:translateY(-2px); box-shadow:0 8px 30px rgba(18,120,184,.45); }
.btn-order-now:disabled { opacity:.6; cursor:not-allowed; transform:none; }
.btn-add-cart {
  width:100%; padding:14px; background:#fff; color:#16a34a;
  border:2px solid #16a34a; border-radius:var(--r-md); font-size:14px; font-weight:600;
  cursor:pointer; transition:all .2s; font-family:var(--f-body);
  display:flex; align-items:center; justify-content:center; gap:8px;
}
.btn-add-cart:hover { background:#f0fdf4; border-color:#15803d; color:#15803d; }

/* "Choisir mon offre" — green outlined, cart-style (used on home product cards) */
.btn-choose-offer {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  background:transparent; color:#16a34a; border:2px solid #16a34a;
  border-radius:var(--r-sm); font-size:14px; font-weight:600;
  cursor:pointer; transition:all var(--ease); letter-spacing:.3px;
  white-space:nowrap; font-family:var(--f-body); padding:12px 26px;
}
.btn-choose-offer:hover { background:#f0fdf4; border-color:#15803d; color:#15803d; transform:translateY(-1px); }
.order-success-msg {
  display:none; background:#D1FAE5; border:1px solid #6EE7B7; border-radius:var(--r-md);
  padding:28px 24px; text-align:center; margin-top:16px;
}
.order-success-msg.show { display:block; }
.order-success-msg h3 { font-size:18px; font-weight:700; color:#065F46; margin-bottom:8px; }
.order-success-msg p { font-size:14px; color:#065F46; line-height:1.65; }

/* â”€â”€ PRODUCT BENEFITS SECTION (product pages) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.prod-benefits-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.prod-benefit {
  background:linear-gradient(135deg,#fff 0%,var(--bg) 100%);
  padding:28px 22px; border-radius:var(--r-lg); box-shadow:var(--sh-sm);
  transition:all var(--ease); border-top:3px solid transparent;
}
.prod-benefit:hover { transform:translateY(-6px); box-shadow:var(--sh-md); border-top-color:var(--blue); }
.prod-benefit-icon {
  width:52px; height:52px; background:linear-gradient(135deg,var(--blue),var(--navy));
  border-radius:var(--r-md); display:flex; align-items:center; justify-content:center;
  margin-bottom:16px; box-shadow:0 4px 12px rgba(29,110,216,.25);
}
.prod-benefit-icon svg { width:26px; height:26px; stroke:#fff; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.prod-benefit h3 { font-size:15px; font-weight:700; color:var(--navy); margin-bottom:8px; }
.prod-benefit p { font-size:13.5px; color:var(--g500); line-height:1.65; }

/* â”€â”€ EFFICACY CARDS (01â€“05) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.mag-eff-card {
  display:flex; gap:24px; align-items:flex-start;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.10);
  border-radius:var(--r-lg); padding:28px 28px;
  transition:background .25s, transform .25s;
}
.mag-eff-card:hover { background:rgba(255,255,255,.10); transform:translateX(6px); }
.mag-eff-num {
  font-family:var(--f-disp); font-size:2.8rem; font-weight:800; line-height:1;
  color:rgba(43,141,232,.25); letter-spacing:-2px; flex-shrink:0; width:60px;
  transition:color .25s;
}
.mag-eff-card:hover .mag-eff-num { color:var(--blu2); }
.mag-eff-body h3 { font-size:16px; font-weight:700; color:#fff; margin-bottom:8px; line-height:1.3; }
.mag-eff-body p { font-size:14px; color:rgba(255,255,255,.65); line-height:1.72; margin:0; }
@media(max-width:640px) {
  .mag-eff-card { padding:20px 18px; gap:16px; }
  .mag-eff-num { font-size:2.2rem; width:48px; }
  .mag-eff-body h3 { font-size:15px; }
}

/* â”€â”€ PRODUCT DETAILS SECTION (blue bg) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.prod-details-section {
  background:#0B3168;
  padding:72px 0; color:#fff;
}
.prod-details-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.prod-details-img { text-align:center; }
.prod-details-img img {
  max-width:340px; width:100%; height:auto; border-radius:var(--r-xl);
  filter:drop-shadow(0 20px 40px rgba(43,141,232,.18)) brightness(1.04);
}
.prod-details-content h2 { font-family:var(--f-disp); font-size:clamp(1.8rem,3vw,2.4rem); font-weight:600; margin-bottom:28px; color:#fff; }
.detail-item {
  background:rgba(255,255,255,.08); padding:20px; border-radius:var(--r-md);
  margin-bottom:14px; border-top:3px solid transparent; backdrop-filter:blur(10px);
  transition:all .3s;
}
.detail-item:hover { background:rgba(255,255,255,.14); transform:translateY(-4px); border-top-color:var(--blu2); }
.detail-head { display:flex; align-items:center; gap:14px; margin-bottom:10px; }
.detail-icon {
  width:48px; height:48px; background:linear-gradient(135deg,var(--blue),var(--blu2));
  border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.detail-icon svg { width:24px; height:24px; stroke:#fff; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.detail-item h4 { font-size:15px; font-weight:700; color:#fff; margin:0; }
.detail-item p { font-size:14px; color:rgba(255,255,255,.8); line-height:1.65; }

/* â”€â”€ PRODUCT TABS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.product-tabs { }
.tabs-nav {
  display:flex; border-bottom:2px solid var(--g100);
  margin-bottom:36px; overflow-x:auto; gap:0; -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.tabs-nav::-webkit-scrollbar { display:none; }
.tab-btn {
  padding:13px 26px; font-size:14px; font-weight:600; color:var(--g500);
  cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-2px;
  transition:all .2s; white-space:nowrap; flex-shrink:0;
}
.tab-btn:hover { color:var(--navy); }
.tab-btn.active { color:var(--navy); border-bottom-color:var(--navy); }
.tab-panel { display:none; }
.tab-panel.active { display:block; }
.tab-panel h3 { font-family:var(--f-disp); font-size:1.6rem; font-weight:600; color:var(--navy); margin-bottom:16px; }
.tab-panel h4 { font-size:16px; font-weight:700; color:var(--navy); margin:24px 0 10px; }
.tab-panel p { font-size:15px; color:var(--g700); line-height:1.75; margin-bottom:14px; }
.tab-panel ul { padding-left:20px; margin-bottom:16px; }
.tab-panel ul li { font-size:14.5px; color:var(--g700); line-height:1.7; margin-bottom:6px; list-style:disc; }

/* How-to steps */
.emploi-steps { display:flex; flex-direction:column; gap:18px; margin-bottom:24px; }
.emploi-step { display:flex; gap:16px; align-items:flex-start; }
.emploi-num {
  width:38px; height:38px; border-radius:50%; background:var(--navy); color:#fff;
  font-size:14px; font-weight:700; display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.emploi-step div strong { display:block; font-size:14.5px; color:var(--navy); margin-bottom:3px; }
.emploi-step div { font-size:14px; color:var(--g700); line-height:1.6; }
.emploi-tip { background:var(--blu-lt); border:1px solid rgba(18,120,184,.2); border-radius:var(--r-sm); padding:16px 18px; font-size:13.5px; color:var(--g700); line-height:1.65; margin-bottom:14px; }
.emploi-warning { background:#FFFBEB; border:1px solid #FDE68A; border-radius:var(--r-sm); padding:16px 18px; font-size:13.5px; color:var(--g700); line-height:1.65; }

/* Composition table */
.composition-table { width:100%; border-collapse:collapse; margin-bottom:16px; }
.composition-table th { text-align:left; padding:10px 14px; font-size:13px; font-weight:700; color:var(--navy); background:var(--bg); border-bottom:2px solid var(--g100); }
.composition-table td { padding:10px 14px; font-size:14px; color:var(--g700); border-bottom:1px solid var(--g100); }
.comp-note { font-size:12.5px; color:var(--g500); line-height:1.6; }

/* FAQ */
.faq-list { display:flex; flex-direction:column; }
.faq-item { border-bottom:1px solid var(--g100); }
.faq-q {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 0; cursor:pointer; font-size:15px; font-weight:600;
  color:var(--navy); gap:16px; width:100%; text-align:left;
}
.faq-q span { font-size:20px; color:var(--g300); flex-shrink:0; line-height:1; transition:transform .3s; }
.faq-item.open .faq-q span { transform:rotate(45deg); }
.faq-a { font-size:14.5px; color:var(--g700); line-height:1.72; padding-bottom:18px; display:none; }
.faq-item.open .faq-a { display:block; }

/* â”€â”€ ORDER FORM / CHECKOUT (commande.html) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.checkout-layout { display:grid; grid-template-columns:1fr 400px; gap:40px; align-items:start; padding:56px 0; }
.checkout-form-card { background:#fff; border:1px solid var(--g100); border-radius:var(--r-lg); padding:36px; box-shadow:var(--sh-sm); }
.checkout-form-card h2 { font-family:var(--f-disp); font-size:1.7rem; font-weight:600; color:var(--navy); margin-bottom:6px; }
.form-sub { font-size:13.5px; color:var(--g500); margin-bottom:28px; }
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-size:13px; font-weight:600; color:var(--g700); margin-bottom:7px; }
.form-group label .req { color:var(--red); }
.form-input, .form-select, .form-textarea {
  width:100%; padding:12px 16px; border:1.5px solid var(--g100);
  border-radius:var(--r-sm); font-size:14px; outline:none;
  transition:all .2s; background:var(--bg); color:var(--g900); appearance:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--navy); background:#fff; box-shadow:0 0 0 3px rgba(10,36,64,.07); }
.form-input.error, .form-select.error { border-color:var(--red); }
.form-textarea { resize:vertical; min-height:90px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field-error { font-size:12px; color:var(--red); margin-top:4px; display:none; }
.field-error.show { display:block; }
.cod-banner { background:var(--blu-lt); border:1px solid rgba(18,120,184,.2); border-radius:var(--r-sm); padding:16px 18px; margin-bottom:24px; font-size:13.5px; color:var(--g700); line-height:1.65; }
.cod-banner strong { color:var(--navy); }
.order-summary-card { background:#fff; border:1px solid var(--g100); border-radius:var(--r-lg); overflow:hidden; position:sticky; top:calc(var(--nav-h) + 24px); }
.osum-header { padding:18px 22px; background:var(--navy); color:#fff; }
.osum-header h3 { font-size:15px; font-weight:700; }
.osum-items { padding:8px 22px; }
.osum-item { display:flex; align-items:center; gap:14px; padding:14px 0; border-bottom:1px solid var(--g100); }
.osum-item:last-child { border-bottom:none; }
.osum-img { width:52px; height:52px; border-radius:var(--r-sm); background:var(--blu-lt); flex-shrink:0; overflow:hidden; }
.osum-img img { width:100%; height:100%; object-fit:cover; }
.osum-iname { font-size:13px; font-weight:600; color:var(--navy); margin-bottom:2px; }
.osum-ioffer { font-size:11.5px; color:var(--g500); }
.osum-iprice { font-size:14px; font-weight:700; color:var(--navy); margin-left:auto; flex-shrink:0; }
.osum-total { padding:16px 22px; border-top:2px solid var(--navy); display:flex; justify-content:space-between; align-items:center; }
.osum-total span:first-child { font-size:14px; font-weight:600; color:var(--g700); }
.osum-total-val { font-size:22px; font-weight:800; color:var(--navy); }
.osum-empty { padding:32px 22px; text-align:center; color:var(--g500); font-size:14px; }
.osum-cod { padding:12px 22px 18px; font-size:12.5px; color:var(--g500); line-height:1.6; text-align:center; border-top:1px solid var(--g100); }
/* â”€â”€ ORDER SUCCESS â€” Branded Thank-You â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.order-success {
  display:none; background:#fff; border-radius:var(--r-xl);
  box-shadow:var(--sh-lg); overflow:hidden; text-align:center;
  border:1px solid var(--g100);
}
.order-success.show { display:block; }

.os-brand-header {
  background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 100%);
  padding:22px 32px; display:flex; align-items:center; justify-content:center;
}
.os-logo { height:38px; filter:brightness(0) invert(1); }

.os-confetti-wrap { padding:36px 32px 0; }
.os-check-circle {
  width:84px; height:84px; border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  display:flex; align-items:center; justify-content:center;
  margin:0 auto;
  box-shadow:0 8px 32px rgba(29,110,216,.35);
  animation:osPopIn .5s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes osPopIn { from{transform:scale(0);opacity:0} to{transform:scale(1);opacity:1} }

.os-main-title {
  font-family:var(--f-disp); font-size:clamp(1.8rem,4vw,2.4rem); font-weight:600;
  color:var(--navy); margin:20px 32px 8px; line-height:1.2;
}
.os-client-name { color:var(--blue); }
.os-headline { font-size:16px; color:var(--g500); margin:0 32px 24px; }

.os-phone-alert {
  display:flex; align-items:flex-start; gap:14px; text-align:left;
  background:linear-gradient(135deg,var(--blu-lt),#f0f7ff);
  border:1.5px solid rgba(43,141,232,.25); border-radius:var(--r-md);
  padding:18px 22px; margin:0 32px 28px;
}
.os-phone-icon {
  flex-shrink:0; width:44px; height:44px; border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  color:#fff; display:flex; align-items:center; justify-content:center;
}
.os-phone-alert strong { display:block; font-size:14.5px; color:var(--navy); margin-bottom:3px; }
.os-phone-alert span { font-size:13px; color:var(--g700); line-height:1.5; }
.os-phone-alert span strong { display:inline; font-size:inherit; color:var(--blue); margin-bottom:0; }

/* Timeline */
.os-timeline {
  display:flex; align-items:flex-start; gap:0;
  padding:0 32px 28px; position:relative;
}
.os-step {
  display:flex; flex-direction:column; align-items:center; flex:1; position:relative;
}
.os-step-dot {
  width:38px; height:38px; border-radius:50%; background:var(--g100);
  border:2px solid var(--g100); display:flex; align-items:center; justify-content:center;
  color:var(--g300); flex-shrink:0; position:relative; z-index:2;
}
.os-step-dot--done { background:var(--grn); border-color:var(--grn); color:#fff; }
.os-step-dot--current {
  background:var(--blue); border-color:var(--blue); color:#fff;
  box-shadow:0 0 0 4px rgba(43,141,232,.2);
  animation:pulse 2s ease-in-out infinite;
}
.os-step-dot--gold { background:var(--gold); border-color:var(--gold); color:#fff; }
.os-step-body { margin-top:10px; text-align:center; padding:0 4px; }
.os-step-label { display:block; font-size:12px; font-weight:700; color:var(--navy); margin-bottom:2px; }
.os-step-desc { display:block; font-size:11px; color:var(--g500); line-height:1.4; }
.os-step-connector {
  flex:1; height:2px; background:var(--g100);
  margin-top:19px; position:relative; z-index:1;
}
.os-step--current ~ .os-step-connector { background:var(--g100); }
.os-step--done + .os-step-connector { background:var(--grn); }

.os-order-ref {
  display:flex; align-items:center; justify-content:center; gap:14px;
  background:var(--bg); border-top:1px solid var(--g100); border-bottom:1px solid var(--g100);
  padding:16px 32px;
}
.os-ref-label { font-size:12px; color:var(--g500); font-weight:600; letter-spacing:.5px; text-transform:uppercase; }
.os-ref-val {
  font-family:monospace; font-size:16px; font-weight:800; color:var(--navy);
  background:var(--blu-lt); padding:5px 14px; border-radius:var(--r-sm);
  border:1px solid rgba(43,141,232,.2);
}

.os-reassure-grid {
  display:flex; justify-content:center; gap:20px; flex-wrap:wrap;
  padding:16px 24px;
}
.os-reassure-item {
  display:flex; align-items:center; gap:6px;
  font-size:12.5px; color:var(--g700); font-weight:500;
  background:var(--bg); border:1px solid var(--g100); border-radius:40px;
  padding:6px 14px;
}
.os-reassure-icon { display:flex; align-items:center; justify-content:center; color:var(--navy); flex-shrink:0; }

.os-back-btn { margin:4px 32px 32px; width:calc(100% - 64px); }

/* â”€â”€ ABOUT PAGE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.about-intro { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center; }
.about-intro-img { border-radius:var(--r-xl); overflow:hidden; aspect-ratio:1; background:var(--blu-lt); }
.about-intro-img img { width:100%; height:100%; object-fit:cover; }
.about-intro-content { display:flex; flex-direction:column; gap:16px; }
.about-intro-content h2 { font-family:var(--f-disp); font-size:clamp(1.8rem,3vw,2.5rem); font-weight:600; color:var(--navy); line-height:1.2; }
.about-intro-content p { font-size:15px; color:var(--g700); line-height:1.8; }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.value-card { background:#fff; border:1px solid var(--g100); border-radius:var(--r-lg); padding:32px; text-align:center; box-shadow:var(--sh-sm); transition:all var(--ease); }
.value-card:hover { transform:translateY(-5px); box-shadow:var(--sh-md); }
.value-icon {
  width:64px; height:64px; border-radius:16px;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 22px;
  box-shadow:0 8px 24px rgba(29,110,216,.22);
  transition:transform var(--ease), box-shadow var(--ease);
}
.value-card:hover .value-icon { transform:translateY(-3px); box-shadow:0 12px 32px rgba(29,110,216,.32); }
.value-icon svg { width:28px; height:28px; stroke:#fff; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.value-card h3 { font-size:17px; font-weight:700; color:var(--navy); margin-bottom:10px; }
.value-card p { font-size:14px; color:var(--g500); line-height:1.7; }

/* â”€â”€ VALUES â€” PREMIUM DARK REDESIGN â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.values-dark-section {
  background:linear-gradient(150deg,#0A1628 0%,#0F2044 55%,#0D1A38 100%);
  position:relative; overflow:hidden;
}
.values-dark-section::before {
  content:''; position:absolute; top:-30%; right:-10%;
  width:700px; height:700px; border-radius:50%;
  background:radial-gradient(circle,rgba(196,151,58,.06) 0%,transparent 70%);
  pointer-events:none;
}
.values-dark-section::after {
  content:''; position:absolute; bottom:-20%; left:-5%;
  width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle,rgba(43,141,232,.07) 0%,transparent 70%);
  pointer-events:none;
}
.values-premium-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:rgba(255,255,255,.07);
  border-radius:var(--r-lg); overflow:hidden;
  position:relative; z-index:1;
}
.vpillar {
  background:rgba(255,255,255,.03);
  padding:44px 36px;
  transition:background var(--ease), border-top-color var(--ease);
  border-top:2px solid transparent;
  display:flex; flex-direction:column; gap:0;
}
.vpillar:hover { background:rgba(255,255,255,.07); border-top-color:var(--gold); }
.vpillar-num {
  font-family:var(--f-disp); font-size:3.5rem; font-weight:700; line-height:1;
  color:rgba(196,151,58,.18); letter-spacing:-3px; margin-bottom:18px;
  transition:color var(--ease);
}
.vpillar:hover .vpillar-num { color:rgba(196,151,58,.35); }
.vpillar-icon {
  width:46px; height:46px; border-radius:12px;
  border:1.5px solid rgba(196,151,58,.3);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); margin-bottom:22px;
  transition:all var(--ease);
}
.vpillar:hover .vpillar-icon { background:rgba(196,151,58,.1); border-color:var(--gold); }
.vpillar-title {
  font-family:var(--f-disp); font-size:1.3rem; font-weight:600; line-height:1.25;
  color:#fff; margin-bottom:14px;
}
.vpillar-desc {
  font-size:14px; color:rgba(255,255,255,.58); line-height:1.8; flex:1;
}
.vpillar-tag {
  display:inline-block; margin-top:24px;
  font-size:10.5px; font-weight:700; letter-spacing:.7px; text-transform:uppercase;
  color:var(--gold); opacity:.7;
}

.team-note { background:linear-gradient(135deg,var(--navy),var(--blue)); border-radius:var(--r-xl); padding:56px; color:#fff; text-align:center; }
.team-note h2 { font-family:var(--f-disp); font-size:2rem; font-weight:600; margin-bottom:14px; }
.team-note p { font-size:16px; color:rgba(255,255,255,.8); max-width:560px; margin:0 auto; line-height:1.7; }

/* â”€â”€ CONTACT PAGE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.contact-layout { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.contact-block { margin-bottom:36px; }
.contact-block h3 { font-size:16px; font-weight:700; color:var(--navy); margin-bottom:8px; }
.contact-block p, .contact-block a { font-size:15px; color:var(--g700); line-height:1.7; }
.contact-block a:hover { color:var(--blue); }
.contact-block a.wa-contact-btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 24px; background:var(--wa); color:#fff; border-radius:var(--r-md);
  font-size:15px; font-weight:700; margin-top:10px; transition:background .2s;
}
.contact-block a.wa-contact-btn:hover { background:#1DA851; color:#fff; }

/* â”€â”€ LEGAL PAGES â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.legal-content { max-width:780px; margin:0 auto; padding:64px 28px 96px; }
.legal-content h1 { font-family:var(--f-disp); font-size:2.4rem; color:var(--navy); margin-bottom:8px; }
.legal-date { font-size:13px; color:var(--g300); margin-bottom:48px; display:block; }
.legal-content h2 { font-size:18px; font-weight:700; color:var(--navy); margin:36px 0 12px; }
.legal-content p, .legal-content li { font-size:15px; color:var(--g700); line-height:1.82; margin-bottom:12px; }
.legal-content ul { padding-left:22px; margin-bottom:14px; }
.legal-content ul li { list-style:disc; }
.legal-content a { color:var(--blue); }
.legal-content a:hover { text-decoration:underline; }
.legal-content strong { color:var(--g900); }

/* â”€â”€ FOOTER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.site-footer { background:var(--navy); color:rgba(255,255,255,.65); padding:72px 0 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr 1.4fr; gap:48px; margin-bottom:56px; }
.footer-logo { height:68px; filter:brightness(0) invert(1); margin-bottom:16px; transition:opacity .2s; }
.footer-logo:hover { opacity:.8; }
.footer-tagline { font-family:var(--f-disp); font-size:16px; color:rgba(255,255,255,.85); margin-bottom:8px; }
.footer-desc { font-size:13px; line-height:1.7; color:rgba(255,255,255,.45); max-width:220px; margin-bottom:18px; }
.footer-social { display:flex; gap:10px; }
.social-link { width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.social-wa { background:rgba(37,211,102,.2); color:var(--wa); }
.social-wa:hover { background:var(--wa); color:#fff; transform:scale(1.1); }
.social-ig { background:rgba(255,255,255,.08); color:rgba(255,255,255,.55); }
.social-ig:hover { background:rgba(255,255,255,.15); color:#fff; }
.footer-col h4 { font-size:12px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.9); margin-bottom:18px; }
.footer-col a { display:block; font-size:13.5px; color:rgba(255,255,255,.5); margin-bottom:10px; transition:color .2s; }
.footer-col a:hover { color:#fff; }
.footer-certs { display:flex; flex-direction:column; gap:8px; margin-bottom:12px; }
.footer-certs img { height:28px; filter:brightness(0) invert(1); opacity:.45; object-fit:contain; }
.footer-cert-note { font-size:12px; color:rgba(255,255,255,.3); line-height:1.6; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.08); padding:24px 0; display:flex; align-items:center; justify-content:space-between; font-size:12.5px; color:rgba(255,255,255,.3); flex-wrap:wrap; gap:12px; }
.footer-bottom-links { display:flex; gap:20px; }
.footer-bottom-links a { color:rgba(255,255,255,.3); transition:color .2s; }
.footer-bottom-links a:hover { color:rgba(255,255,255,.7); }

/* â”€â”€ RESPONSIVE â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media(max-width:1100px) {
  .footer-grid { grid-template-columns:1.5fr 1fr 1fr 1fr; gap:36px; }
  .footer-grid > div:last-child { grid-column:1 / -1; }
  .prod-details-grid { gap:40px; }
  .checkout-layout { grid-template-columns:1fr 360px; gap:28px; }
}
@media(max-width:900px) {
  .hdr-nav { display:none; }
  .mob-menu-btn { display:flex; }
  .mob-drawer { display:block; }
  .mob-overlay { display:block; }
  .mob-float-cta { display:block; }

  .home-products { grid-template-columns:repeat(2,1fr); gap:16px; }
  .boutique-grid { grid-template-columns:repeat(2,1fr); gap:16px; }
  .benefits-grid { grid-template-columns:repeat(2,1fr); }
  .testimonials-grid { grid-template-columns:1fr 1fr; }
  .spotlight-grid { grid-template-columns:1fr; gap:40px; }
  .spotlight-grid.reverse .spotlight-img-wrap { order:-1; }
  .spotlight-content h2 { white-space:normal; font-size:clamp(1.4rem,5vw,2.2rem); }
  .spotlight-img-wrap { padding:24px 20px 18px; }
  .spotlight-img { height:240px; }
  .prod-img-slider-inner { height:260px; }
  .contact-layout { grid-template-columns:1fr; gap:40px; }
  .about-intro { grid-template-columns:1fr; gap:40px; }
  .values-grid { grid-template-columns:1fr 1fr; }
  .values-premium-grid { grid-template-columns:1fr; }
  .vpillar { padding:36px 28px; border-top:none; border-left:2px solid transparent; }
  .vpillar:hover { border-left-color:var(--gold); border-top-color:transparent; }
  .certs-grid { grid-template-columns:1fr; gap:16px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .footer-grid > div:nth-child(1) { grid-column:1 / -1; }
  .prod-hero-grid { grid-template-columns:1fr; gap:6px; }
  .prod-hero-img-wrap { order:-1; }
  .prod-hero-img { width:min(300px,80vw); }
  .prod-img-slider {
    width:calc(100% + 32px); margin-left:-16px; margin-right:-16px;
    background:none; border:none; box-shadow:none; border-radius:0; padding:0;
  }
  .prod-img-slider::before, .prod-img-slider::after { display:none; }
  .prod-img-slider-inner { border-radius:0; height:auto; aspect-ratio:4/3; }
  .prod-img-controls { margin-top:10px; }
  .prod-hero-result-tag { margin-left:0; margin-right:0; }
  .prod-details-grid { grid-template-columns:1fr; gap:40px; }
  .prod-details-img { display:none; }
  .prod-benefits-grid { grid-template-columns:1fr 1fr; }
  .offer-grid { grid-template-columns:1fr; }
  .checkout-layout { grid-template-columns:1fr; }
  .order-summary-card { position:static; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .stat-item::after { display:none; }
  /* Mobile bottom padding for floating CTA â€” on footer so no empty gap shows */
  body { padding-bottom:0; }
  .site-footer { padding-bottom:calc(96px + env(safe-area-inset-bottom,0px)); }
}
@media(max-width:640px) {
  .container { padding:0 16px; }
  .hero .hero-content { padding:64px 22px; }
  .section { padding:56px 0; }
  .hero-title { font-size:2.4rem; }
  .hero-actions { flex-direction:column; }
  .hero-actions .btn { width:100%; }
  .hero-trust { gap:8px; }
  .hero-trust span { font-size:12px; padding:6px 13px; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .home-products { grid-template-columns:repeat(2,1fr); gap:12px; }
  .boutique-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .products-grid { grid-template-columns:1fr; }
  .home-products .pc-body,
  .boutique-grid .pc-body { padding:12px 10px; gap:6px; }
  .home-products .pc-name,
  .boutique-grid .pc-name { font-size:18px; white-space:normal; }
  .home-products .pc-desc,
  .boutique-grid .pc-desc { font-size:13px; }
  .home-products .pc-bullets,
  .boutique-grid .pc-bullets { display:none; }
  .home-products .pc-price,
  .boutique-grid .pc-price { font-size:19px; }
  .home-products .btn-order-now,
  .boutique-grid .btn-order-now { padding:10px 8px; font-size:12px; gap:4px; }
  .home-products .btn-add-cart,
  .boutique-grid .btn-add-cart { padding:9px 8px; font-size:12px; gap:4px; }
  .home-products .cadeau-badge,
  .boutique-grid .cadeau-badge { font-size:11px; }
  .home-products .pc-badge,
  .boutique-grid .pc-badge { font-size:10px; padding:3px 8px; top:8px; left:8px; }
  .pc-name { white-space:normal; font-size:23px; }
  .benefits-grid { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .cta-actions { flex-direction:column; }
  .cta-actions .btn { width:100%; }
  .trust-bar-inner { flex-direction:column; gap:8px; align-items:flex-start; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; gap:12px; text-align:center; }
  .footer-bottom-links { justify-content:center; }
  .form-row { grid-template-columns:1fr; }
  .values-grid { grid-template-columns:1fr; }
  .vpillar { padding:28px 20px; }
  .team-note { padding:36px 24px; }
  .checkout-form-card { padding:24px 18px; }
  .prod-benefits-grid { grid-template-columns:1fr; }
  .tabs-nav { gap:0; }
  .tab-btn { padding:12px 16px; font-size:13px; }
  .order-card-body { padding:20px 16px; }
  .stats-section { padding:40px 0; }
  .stat-num { font-size:2.2rem; }
  .offer-radio-img { width:52px; height:52px; }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   QNC MAROC â€” Extended Styles v3.1
   Page Loader + Footer Redesign + Mobile Polish
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ PAGE LOADER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.qnc-loader {
  position:fixed; inset:0; z-index:99999;
  background:var(--navy);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; padding:20px;
  transition:opacity .7s cubic-bezier(.4,0,.2,1), visibility .7s;
  will-change:opacity;
  /* Ensure perfect centering on ALL screen sizes */
  left:0 !important; right:0 !important; top:0 !important; bottom:0 !important;
  width:100vw; height:100vh;
}
.qnc-loader.done { opacity:0; visibility:hidden; pointer-events:none; }
.qnc-loader-inner {
  text-align:center; width:100%; max-width:260px; margin:0 auto;
  animation:loaderIn .55s cubic-bezier(.34,1.4,.64,1) both;
}
@keyframes loaderIn {
  from { opacity:0; transform:translateY(20px) scale(.95); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
.qnc-loader-brand {
  margin-bottom:28px;
}
.qnc-loader-logo {
  height:56px; width:auto; display:block; margin:0 auto;
  filter:brightness(0) invert(1);
  animation:loaderFloat 2.2s ease-in-out infinite;
}
.qnc-loader-text-logo {
  font-family:var(--f-disp); font-size:3.5rem; font-weight:700;
  color:#fff; letter-spacing:6px; line-height:1;
  animation:loaderFloat 2.2s ease-in-out infinite;
}
@keyframes loaderFloat {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-7px); }
}
.qnc-loader-bar {
  width:180px; height:3px; background:rgba(255,255,255,.1);
  border-radius:100px; margin:0 auto 18px; overflow:hidden;
  position:relative;
}
.qnc-loader-fill {
  position:absolute; left:0; top:0; height:100%;
  background:linear-gradient(90deg, var(--blue) 0%, var(--blu2) 50%, var(--gold) 100%);
  background-size:200% 100%;
  border-radius:100px;
  animation:loaderBarFill 1.5s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes loaderBarFill {
  0%  { width:0%; }
  70% { width:85%; }
  100%{ width:100%; }
}
.qnc-loader-tagline {
  font-family:var(--f-disp); font-size:15px; font-style:italic;
  color:rgba(255,255,255,.4); letter-spacing:.5px; margin:0;
}

/* â”€â”€ FOOTER REDESIGN (overrides base footer styles) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.site-footer {
  background:var(--navy); color:rgba(255,255,255,.6); padding:0;
}

/* CTA Strip at top of footer */
.footer-cta-strip {
  background:#fff;
  border-bottom:1px solid #E2E8F0;
  padding:32px 0;
}
.footer-cta-inner {
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; flex-wrap:wrap;
}
.footer-cta-text h3 {
  font-family:var(--f-disp); font-size:1.5rem; font-weight:600;
  color:var(--navy); margin-bottom:5px; line-height:1.2;
}
.footer-cta-text p {
  font-size:13.5px; color:var(--mut);
}
.footer-cta-strip .btn-gold {
  background:var(--gold); color:#fff; border-color:var(--gold);
  white-space:nowrap; flex-shrink:0;
}
.footer-cta-strip .btn-gold:hover { background:#b88428; transform:translateY(-2px); box-shadow:0 8px 24px rgba(196,151,58,.45); }

/* Main footer content */
.footer-main { padding:60px 0 0; }
.footer-grid {
  display:grid;
  grid-template-columns:2.2fr 1fr 1fr 1.3fr;
  gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.06);
  margin-bottom:0 !important;
}

/* Brand column */
.footer-logo {
  height:68px; width:auto; display:block;
  filter:brightness(0) invert(1);
  margin-bottom:16px; transition:opacity .2s;
}
.footer-logo:hover { opacity:.75; }
.footer-tagline {
  font-family:var(--f-disp); font-size:17px; font-style:italic;
  color:rgba(255,255,255,.85); margin-bottom:10px;
}
.footer-desc {
  font-size:13.5px; line-height:1.78; color:rgba(255,255,255,.38);
  margin-bottom:20px; max-width:240px;
}
.footer-social { display:flex; gap:10px; margin-bottom:22px; }
.social-link {
  width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  transition:all .25s; flex-shrink:0;
}
.social-wa { background:rgba(37,211,102,.12); color:var(--wa); border:1px solid rgba(37,211,102,.2); }
.social-wa:hover { background:var(--wa); color:#fff; transform:scale(1.12); box-shadow:0 4px 16px rgba(37,211,102,.45); }
.social-ig { background:rgba(225,48,108,.18); color:#e1306c; border:1px solid rgba(225,48,108,.35); }
.social-ig:hover { background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); color:#fff; transform:scale(1.12); box-shadow:0 4px 16px rgba(225,48,108,.4); }

.footer-contact-links { display:flex; flex-direction:column; gap:9px; }
.footer-contact-links a {
  display:flex; align-items:center; gap:10px;
  font-size:13px; color:rgba(255,255,255,.42); transition:color .2s;
}
.footer-contact-links a:hover { color:#fff; }
.footer-contact-icon {
  width:28px; height:28px; border-radius:7px;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; flex-shrink:0;
}

/* Nav columns */
.footer-col-title {
  font-size:11px; font-weight:700; letter-spacing:2px;
  text-transform:uppercase; color:rgba(255,255,255,.88);
  margin-bottom:20px; display:flex; align-items:center;
  justify-content:space-between; cursor:default;
}
.footer-col-title .acc-icon { display:none; }

.footer-col-body-inner a {
  display:flex; align-items:center; gap:8px;
  font-size:13.5px; color:rgba(255,255,255,.42);
  margin-bottom:11px; transition:color .2s, padding-left .15s;
}
.footer-col-body-inner a::before {
  content:''; width:4px; height:4px; border-radius:50%;
  background:rgba(255,255,255,.18); flex-shrink:0; transition:background .2s;
}
.footer-col-body-inner a:hover { color:#fff; padding-left:4px; }
.footer-col-body-inner a:hover::before { background:var(--blu2); }

/* Certification cards */
.footer-certs-grid { display:flex; flex-direction:column; gap:8px; margin-bottom:14px; }
.footer-cert-item {
  display:flex; align-items:center; gap:10px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07);
  border-radius:9px; padding:9px 12px; transition:all .2s;
}
.footer-cert-item:hover { background:rgba(255,255,255,.09); border-color:rgba(255,255,255,.14); }
.footer-cert-item img {
  height:22px; width:auto; filter:brightness(0) invert(1);
  opacity:.55; object-fit:contain; flex-shrink:0;
}
.footer-cert-item span { font-size:12px; color:rgba(255,255,255,.5); font-weight:500; line-height:1.3; }
.footer-cert-note { font-size:11.5px; color:rgba(255,255,255,.28); line-height:1.65; }

/* Trust strip */
.footer-trust-strip {
  background:rgba(0,0,0,.18); border-top:1px solid rgba(255,255,255,.05); padding:15px 0;
}
.footer-trust-inner {
  display:flex; align-items:center; justify-content:center; gap:28px; flex-wrap:wrap;
}
.footer-trust-item {
  display:flex; align-items:center; gap:8px;
  font-size:12.5px; color:rgba(255,255,255,.48); font-weight:500;
}
.trust-icon { font-size:16px; }

/* Bottom bar */
.footer-bottom {
  padding:18px 0; display:flex; align-items:center;
  justify-content:space-between; font-size:12px;
  color:rgba(255,255,255,.22); flex-wrap:wrap; gap:12px;
}
.footer-bottom-links { display:flex; gap:20px; }
.footer-bottom-links a { color:rgba(255,255,255,.28); transition:color .2s; }
.footer-bottom-links a:hover { color:rgba(255,255,255,.7); }

/* â”€â”€ FOOTER MOBILE (new overrides) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width:1100px) {
  .footer-grid { grid-template-columns:1.8fr 1fr 1fr 1.2fr; gap:36px; }
}

@media (max-width:900px) {
  /* CTA strip */
  .footer-cta-strip { padding:24px 0; }
  .footer-cta-inner { flex-direction:column; text-align:center; gap:18px; }
  .footer-cta-text h3 { font-size:1.2rem; }
  .footer-cta-strip .btn { width:100%; max-width:340px; }

  /* Grid: single column stacked */
  .footer-main { padding-top:36px; }
  .footer-grid {
    grid-template-columns:1fr; gap:0;
    padding-bottom:0; border-bottom:none;
  }

  /* Brand: centered */
  .footer-brand {
    text-align:center; padding-bottom:28px;
    border-bottom:1px solid rgba(255,255,255,.06);
  }
  .footer-logo { margin:0 auto 14px; }
  .footer-desc { max-width:300px; margin:0 auto 18px; }
  .footer-social { justify-content:center; }
  .footer-contact-links { align-items:center; }

  /* Accordion nav columns */
  .footer-col { border-bottom:1px solid rgba(255,255,255,.06); }
  .footer-col-title {
    cursor:pointer; padding:16px 0; margin-bottom:0;
    user-select:none; -webkit-tap-highlight-color:transparent; transition:color .2s;
  }
  .footer-col-title .acc-icon {
    display:flex; align-items:center; justify-content:center;
    width:22px; height:22px; border-radius:50%;
    border:1.5px solid rgba(255,255,255,.2);
    font-size:15px; font-weight:700; line-height:1;
    color:rgba(255,255,255,.45); flex-shrink:0;
    transition:transform .3s, background .2s, color .2s;
  }
  .footer-col.acc-open .footer-col-title { color:#fff; }
  .footer-col.acc-open .footer-col-title .acc-icon {
    transform:rotate(45deg); background:rgba(255,255,255,.1); color:#fff;
  }
  .footer-col-body {
    max-height:0; overflow:hidden;
    transition:max-height .38s cubic-bezier(.4,0,.2,1);
  }
  .footer-col.acc-open .footer-col-body { max-height:320px; }
  .footer-col-body-inner { padding-bottom:16px; }

  /* Certs: always open on mobile, horizontal grid */
  .footer-certs-col .footer-col-title { cursor:default; }
  .footer-certs-col .footer-col-title .acc-icon { display:none !important; }
  .footer-certs-col .footer-col-body { max-height:none !important; overflow:visible; }
  .footer-certs-grid { flex-direction:row; flex-wrap:wrap; gap:8px; padding-bottom:16px; }
  .footer-cert-item { flex:1 0 calc(50% - 4px); }

  /* Trust */
  .footer-trust-inner { gap:14px; justify-content:flex-start; padding:0 2px; }

  /* Bottom */
  .footer-bottom { flex-direction:column; text-align:center; padding:18px 0 28px; gap:10px; }
  .footer-bottom-links { flex-wrap:wrap; justify-content:center; gap:14px; }
}

@media (max-width:480px) {
  .footer-cert-item { flex:1 0 100%; }
  .footer-trust-inner { flex-direction:column; gap:10px; align-items:flex-start; }
  .footer-trust-strip { padding:14px 0; }
  .footer-cta-text h3 { font-size:1.1rem; }
}

/* â”€â”€ PRODUCT IMAGE FULL-DISPLAY FIX (extra specificity) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.pc-img-wrap { background:linear-gradient(145deg,#EEF7FD 0%,#F7F8FA 100%); }
.product-card:hover .pc-img { transform:scale(1.05); }

/* â”€â”€ GLOBAL MOBILE POLISH â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width:640px) {
  .promo-bar { padding:10px 40px 10px 16px; font-size:12px; }
  .wa-fab { width:56px; height:56px; bottom:calc(84px + env(safe-area-inset-bottom,0px)); left:16px; }
  .mob-float-cta { padding-bottom:calc(16px + env(safe-area-inset-bottom,0px)); }
  .cart-drawer { width:100vw; }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   QNC MAROC â€” Fixes v3.3
   Z-Index Â· WA Icon Â· Cert Images Â· Waves Â· Cart Â· Mobile
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ MOBILE MENU: Sit above floating CTA (z-index 350) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.mob-drawer  { z-index:460 !important; }
.mob-overlay { z-index:459 !important; }
/* Ensure mob-menu-btn is visible on any breakpoint that needs it */
@media (max-width:900px) {
  .mob-menu-btn { display:flex !important; }
  .hdr-nav      { display:none !important; }
  .mob-drawer   { display:block !important; }
  .mob-overlay  { display:block !important; }
}

/* â”€â”€ WA FAB: Icon must be white â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.wa-fab { color:#fff !important; }
.wa-fab svg { width:26px; height:26px; fill:currentColor; display:block; }

/* ── BACK-TO-TOP FAB (bottom-right, site-wide) ──────────────────── */
.to-top {
  position:fixed; bottom:28px; right:24px; z-index:360;
  width:52px; height:52px; border-radius:50%;
  background:var(--navy); color:#fff; border:none; cursor:pointer; padding:0;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 18px rgba(29,110,216,.40);
  opacity:0; visibility:hidden; transform:translateY(12px);
  transition:opacity .25s ease, transform .25s ease, box-shadow .2s, background .2s;
}
.to-top.show { opacity:1; visibility:visible; transform:translateY(0); }
.to-top:hover { background:#1a5fbf; box-shadow:0 8px 26px rgba(29,110,216,.5); }
.to-top.show:hover { transform:translateY(-3px); }
.to-top svg { width:24px; height:24px; stroke:currentColor; fill:none; stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round; display:block; }
@media (max-width:640px) {
  /* Sit above the sticky order bar / safe area, mirror of .wa-fab on the left */
  .to-top { width:48px; height:48px; bottom:calc(84px + env(safe-area-inset-bottom,0px)); right:16px; }
}
@media (prefers-reduced-motion: reduce) {
  .to-top { transition:opacity .2s ease; transform:none; }
  .to-top.show { transform:none; }
  .to-top.show:hover { transform:none; }
}

/* â”€â”€ FOOTER CERT IMAGES: Natural colors, white bg pill â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.footer-cert-item img {
  filter:none !important;
  opacity:1 !important;
  height:24px !important;
  width:auto;
  object-fit:contain;
  background:#fff;
  padding:3px 6px;
  border-radius:5px;
  flex-shrink:0;
}

/* â”€â”€ PRODUCT PAGE CERT CARDS: Controlled image size â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* The <img> inside .cert-card has no class â€” target it directly */
.cert-card img {
  height:68px;
  width:auto;
  max-width:112px;
  object-fit:contain;
  display:block;
  margin:0 auto 16px;
  background:#fff;
  padding:8px 10px;
  border-radius:10px;
  transition:transform .3s ease;
}
.cert-card:hover img { transform:scale(1.06); }
/* Prevent the cert-img class rule from conflicting */
.cert-card .cert-img { height:68px; padding:8px; background:#fff; border-radius:10px; filter:none; }

/* â”€â”€ PREMIUM PROMO TICKER BAR â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.promo-bar {
  background:linear-gradient(90deg,#071c33 0%,#0F3165 30%,#2B8DE8 65%,#0F3165 85%,#071c33 100%);
  background-size:300% 100%;
  animation:promoGlow 8s ease infinite;
  padding:0 48px 0 0;
  position:relative; z-index:201;
  overflow:hidden;
  display:flex; align-items:center;
  height:38px;
}
@keyframes promoGlow {
  0%,100% { background-position:0% 50%; }
  50%     { background-position:100% 50%; }
}
.promo-ticker-wrap {
  flex:1; overflow:hidden; position:relative;
  mask-image:linear-gradient(90deg,transparent 0%,#000 6%,#000 94%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 6%,#000 94%,transparent 100%);
}
.promo-ticker-inner {
  display:flex; align-items:center; white-space:nowrap;
  animation:tickerScroll 28s linear infinite;
  will-change:transform;
}
.promo-ticker-inner:hover { animation-play-state:paused; }
@keyframes tickerScroll {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}
.promo-item {
  font-size:12.5px; font-weight:500; color:rgba(255,255,255,.88);
  padding:0 6px; letter-spacing:.3px;
  display:inline-flex; align-items:center;
}
.promo-item strong { color:#fff; font-weight:700; }
.promo-sep {
  color:var(--gold); font-size:10px; padding:0 14px;
  opacity:.7; flex-shrink:0;
}
.promo-close {
  position:absolute; right:14px; top:50%; transform:translateY(-50%);
  color:rgba(255,255,255,.38); font-size:16px; cursor:pointer; transition:color .2s;
  padding:4px 8px; line-height:1; background:none; border:none; z-index:1;
}
.promo-close:hover { color:#fff; }
/* Mobile promo bar */
@media (max-width:640px) {
  .promo-bar { height:34px; padding-right:38px; }
  .promo-item { font-size:11.5px; }
}

/* â”€â”€ ANIMATED WAVE SECTION DIVIDERS â€” PREMIUM â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@keyframes waveSlide {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}
@keyframes waveSlide2 {
  0%   { transform:translateX(-10%); }
  100% { transform:translateX(-60%); }
}

.qnc-wave {
  position:relative;
  overflow:hidden;
  clip-path:inset(0);
  line-height:0;
  height:72px;
  pointer-events:none;
  z-index:5;
  flex-shrink:0;
}
.qnc-wave svg {
  position:absolute;
  width:200%;
  height:100%;
  top:0; left:0;
  animation:waveSlide 14s linear infinite;
  transform:translateZ(0);
}
.qnc-wave.wave-slow svg  { animation-duration:22s; }
.qnc-wave.wave-fast svg  { animation-duration:9s; }
/* Second SVG layer (shimmer layer) */
.qnc-wave .wave-layer2 {
  animation:waveSlide2 18s linear infinite;
  opacity:.22;
}

/* Sections after a wave: flush join */
.qnc-wave + section,
.qnc-wave + .stats-section,
.qnc-wave + .cta-section,
.qnc-wave + .prod-details-section { margin-top:0; }

@media (max-width:640px) {
  .qnc-wave { height:44px; }
}

/* â”€â”€ PREMIUM RESULTS / BEFORE-AFTER SECTION â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.results-section { background:#fff; }
.results-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:20px; margin-top:48px;
}
.result-card {
  border-radius:var(--r-lg); overflow:hidden;
  box-shadow:0 8px 32px rgba(10,36,64,.10);
  transition:transform .3s, box-shadow .3s;
  background:#fff;
  border:2px solid var(--gold);
}
.result-card:hover { transform:translateY(-8px); box-shadow:0 20px 48px rgba(10,36,64,.18); }
.result-img-wrap { position:relative; overflow:hidden; aspect-ratio:1/1; }
.result-img { width:100%; height:100%; object-fit:cover; transition:transform .5s; display:block; }
.result-card:hover .result-img { transform:scale(1.06); }
.result-tag {
  position:absolute; top:12px; left:12px;
  background:var(--blue); color:#fff;
  font-size:9px; font-weight:800; letter-spacing:2px; text-transform:uppercase;
  padding:4px 10px; border-radius:20px;
}
.result-body {
  padding:18px 16px; display:flex; flex-direction:column; gap:4px;
  border-top:3px solid var(--gold);
}
.result-body h3 { font-size:14px; font-weight:700; color:var(--navy); }
.result-body p { font-size:12.5px; color:var(--g500); }

/* Before / After comparison */
.ba-section { margin-top:52px; }
.ba-title { text-align:center; margin-bottom:28px; }
.ba-title h3 { font-family:var(--f-disp); font-size:clamp(1.5rem,3vw,2rem); color:var(--navy); font-weight:600; }
.ba-title p { font-size:15px; color:var(--g500); margin-top:8px; }
.ba-compare {
  display:grid; grid-template-columns:1fr 1fr;
  gap:20px; max-width:720px; margin:0 auto;
}
.ba-panel { border-radius:var(--r-lg); overflow:hidden; position:relative; box-shadow:0 8px 32px rgba(10,36,64,.12); }
.ba-panel img { width:100%; height:320px; object-fit:cover; display:block; }
.ba-panel-label {
  position:absolute; bottom:0; left:0; right:0;
  padding:12px 16px;
  background:linear-gradient(to top, rgba(10,36,64,.85) 0%, transparent 100%);
  color:#fff; font-size:13px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
}
.ba-panel.after .ba-panel-label { background:linear-gradient(to top, rgba(18,120,184,.85) 0%, transparent 100%); }

@media (max-width:900px) {
  .results-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px) {
  .results-grid { grid-template-columns:1fr 1fr; gap:12px; }
  .ba-compare { grid-template-columns:1fr 1fr; gap:12px; }
  .ba-panel img { height:200px; }
}


/* Offer required shake */
@keyframes shakeOffer {
  0%,100%{transform:translateX(0)}
  20%,60%{transform:translateX(-6px)}
  40%,80%{transform:translateX(6px)}
}
.offer-grid.shake { animation:shakeOffer .4s ease; }
.offer-required-msg {
  display:none; background:#FEE2E2; color:#991B1B;
  border:1px solid #FCA5A5; border-radius:8px;
  padding:10px 14px; font-size:13px; font-weight:600;
  margin-top:10px; text-align:center;
}
.offer-required-msg.show { display:block; }

/* â”€â”€ CART DRAWER: Mobile improvements â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cart-item-name {
  /* Allow text to wrap on mobile instead of truncate */
  white-space:normal !important;
  line-height:1.35;
  font-size:13px;
}
.cart-item-label { font-size:11.5px; }

/* Cart footer buttons stacked clearly */
.cart-footer { gap:10px; }
.cart-footer .btn { font-size:14px; padding:13px; }

@media (max-width:640px) {
  /* Cart full-screen on mobile */
  .cart-drawer { width:100vw; max-width:none; border-radius:0; }

  /* Cart items: smaller image, more text space */
  .cart-item { gap:10px; padding:12px 0; }
  .cart-item-img {
    width:54px; height:54px; min-width:54px;
    border-radius:8px; background:var(--blu-lt);
  }
  .cart-item-info { min-width:0; flex:1; }
  .cart-item-name { font-size:13px; }
  .cart-item-price { font-size:14px; font-weight:800; }

  /* Cart items padding */
  .cart-items { padding:0 16px; }
  .cart-footer { padding:14px 16px; }

  /* Header */
  .cart-drawer-header { padding:16px 16px; }
  .cart-drawer-header h3 { font-size:16px; }
}

/* â”€â”€ FACEBOOK SOCIAL ICON â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.social-fb { background:#1877F2; color:#fff; border:1px solid #1877F2; }
.social-fb:hover { background:#1558c0; color:#fff; transform:scale(1.12); box-shadow:0 4px 16px rgba(24,119,242,.55); }

/* â”€â”€ MOBILE MENU DRAWER â€” BODY LEVEL FIX â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* When mob-drawer lives at body level (not inside header) */
body > .mob-drawer,
body > .mob-overlay { }

/* Mob drawer inner: tight top padding since drawer is body-level */
.mob-drawer-inner {
  padding:0 !important;
  display:flex;
  flex-direction:column;
}
.mob-drawer-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 20px 14px; border-bottom:1px solid var(--g100);
}
.mob-drawer-logo { height:32px; width:auto; }
.mob-drawer-close {
  width:34px; height:34px; border-radius:50%;
  background:var(--bg); border:1.5px solid var(--g100);
  display:flex; align-items:center; justify-content:center;
  color:var(--g500); cursor:pointer; transition:all .2s;
}
.mob-drawer-close:hover { background:#FEE2E2; color:#ef4444; }
.mob-nav-links-wrap { padding:10px 14px; display:flex; flex-direction:column; gap:2px; flex:1; }
.mob-sep { height:1px; background:var(--g100); margin:10px 0; }
.mob-cta-wrap { padding:0 14px 14px; display:flex; flex-direction:column; gap:8px; }
.mob-wa-link {
  display:flex; align-items:center; gap:10px;
  padding:13px 14px; border-radius:8px;
  background:rgba(37,211,102,.08); color:#25D366;
  font-size:14px; font-weight:600;
  transition:background .2s;
}
.mob-wa-link:hover { background:rgba(37,211,102,.15); }
.mob-wa-icon { display:flex; align-items:center; }
.mob-wa-icon svg { width:18px; height:18px; fill:currentColor; }
/* Hamburger lines on scrolled header stay visible */
.site-header.scrolled .mob-menu-btn span { background:#0F3165; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   QNC â€” COLLAGENE PAGE ADDITIONS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ RESULTS GRID: 5-column layout â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.results-grid-5 { grid-template-columns:repeat(5,1fr); }
@media(max-width:1100px) { .results-grid-5 { grid-template-columns:repeat(3,1fr); } }
@media(max-width:640px)  {
  .results-grid-5 { grid-template-columns:repeat(2,1fr); }
  .results-grid-5 .result-card-highlight { grid-column:span 2; }
  .results-grid-5 .result-card-highlight .result-img-wrap { aspect-ratio:16/9; }
}
.result-tag-gold {
  background:linear-gradient(135deg,var(--gold),#d4a843);
  color:#fff;
}
@media(max-width:1100px) { .results-grid-5 { grid-template-columns:repeat(3,1fr); } }
@media(max-width:640px)  { .results-grid-5 { grid-template-columns:repeat(2,1fr); } }

/* â”€â”€ CERTIFICATIONS â€” WHITE / LIGHT SECTION â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.certs-white-section { background:var(--bg); }
.certs-grid-light {
  display:grid; grid-template-columns:repeat(3,1fr); gap:28px;
  margin-top:0;
}
.cert-card-light {
  background:#fff; border:1.5px solid var(--g100);
  border-radius:var(--r-lg); padding:44px 32px; text-align:center;
  transition:all var(--ease); box-shadow:0 2px 16px rgba(10,36,64,.06);
  position:relative; overflow:hidden;
}
.cert-card-light::before {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--navy),var(--blue),var(--blu2));
  opacity:0; transition:opacity .3s;
}
.cert-card-light:hover { transform:translateY(-8px); box-shadow:0 16px 48px rgba(10,36,64,.14); border-color:var(--blu2); }
.cert-card-light:hover::before { opacity:1; }
.cert-logo-wrap {
  height:88px; display:flex; align-items:center; justify-content:center; margin-bottom:22px;
}
.cert-logo { max-height:80px; max-width:180px; object-fit:contain; transition:transform .3s; }
.cert-card-light:hover .cert-logo { transform:scale(1.06); }
.cert-light-name {
  font-family:var(--f-disp); font-size:20px; font-weight:700;
  color:var(--navy); margin-bottom:12px;
}
.cert-light-desc { font-size:14px; color:var(--g500); line-height:1.65; }
@media(max-width:768px) { .certs-grid-light { grid-template-columns:1fr; max-width:420px; margin:0 auto; } }

/* â”€â”€ PRODUCT PAGE â€” CTA SECTION (redesigned) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cta-product-section { position:relative; padding:0; }
.cta-product-section::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(91,188,245,.4),transparent);
}
.cta-product-inner {
  text-align:center; padding:88px 28px; max-width:700px; margin:0 auto;
}
.cta-start-badge {
  display:inline-block;
  background:rgba(196,151,58,.18); color:var(--gold);
  border:1px solid rgba(196,151,58,.38);
  font-size:11px; font-weight:800; letter-spacing:2.5px;
  text-transform:uppercase; padding:6px 18px; border-radius:20px;
  margin-bottom:20px;
}
.cta-product-title {
  font-family:var(--f-disp); font-size:clamp(2rem,4vw,3rem);
  font-weight:600; color:#fff; line-height:1.2; margin-bottom:18px;
}
.cta-product-title em { font-style:italic; color:var(--blu2); }
.cta-product-sub {
  font-size:clamp(15px,2vw,18px); color:rgba(255,255,255,.8);
  line-height:1.75; margin-bottom:40px;
}
.cta-product-sub strong { color:#fff; font-weight:700; }
.cta-product-actions {
  display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin-bottom:28px;
}
.btn-cta-main {
  display:inline-flex; align-items:center; gap:10px;
  padding:18px 40px; background:#fff; color:var(--navy);
  border:2px solid #fff; border-radius:var(--r-md);
  font-size:16px; font-weight:700; cursor:pointer;
  transition:all var(--ease); font-family:var(--f-body);
  box-shadow:0 4px 20px rgba(0,0,0,.2);
}
.btn-cta-main:hover { background:var(--gold-lt); border-color:var(--gold-lt); transform:translateY(-2px); box-shadow:0 8px 32px rgba(0,0,0,.28); }
.btn-cta-ghost {
  display:inline-flex; align-items:center; gap:10px;
  padding:18px 36px; background:transparent; color:#fff;
  border:2px solid rgba(255,255,255,.45); border-radius:var(--r-md);
  font-size:15px; font-weight:600; cursor:pointer;
  transition:all var(--ease); font-family:var(--f-body);
}
.btn-cta-ghost:hover { background:rgba(255,255,255,.14); border-color:#fff; transform:translateY(-2px); }
.cta-product-trust {
  display:flex; gap:20px; justify-content:center; flex-wrap:wrap;
}
.cta-product-trust span {
  font-size:13px; color:rgba(255,255,255,.65); font-weight:500;
  display:flex; align-items:center; gap:5px;
}
@media(max-width:640px) {
  .cta-product-actions { flex-direction:column; align-items:center; }
  .btn-cta-main, .btn-cta-ghost { width:100%; max-width:320px; justify-content:center; }
  .cta-product-trust { gap:12px; }
  .cta-product-trust span { font-size:12px; }
}

/* â”€â”€ QUANTITY CONTROLS IN CART â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cart-item-qty {
  display:flex; align-items:center; gap:8px; margin-top:4px;
}
.cart-qty-btn {
  width:22px; height:22px; border-radius:50%; border:1.5px solid var(--g100);
  background:var(--bg); color:var(--navy); font-size:14px; font-weight:700;
  display:flex; align-items:center; justify-content:center; cursor:pointer;
  transition:all .2s; line-height:1;
}
.cart-qty-btn:hover { background:var(--navy); color:#fff; border-color:var(--navy); }
.cart-qty-num { font-size:13px; font-weight:600; color:var(--navy); min-width:18px; text-align:center; }

/* â”€â”€ ADMIN SETUP BANNER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.admin-setup-banner {
  background:linear-gradient(135deg,#FEF3C7,#FDE68A);
  border:1.5px solid #FCD34D; border-radius:var(--r-sm);
  padding:14px 18px; margin-bottom:18px; font-size:13px; color:#92400E;
  display:flex; align-items:flex-start; gap:12px;
}
.admin-setup-banner strong { display:block; margin-bottom:4px; font-size:13.5px; }

/* â”€â”€ MOBILE OFFER CARDS: Row layout, edge-to-edge â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width:640px) {
  /* Offer grid: single column, full width */
  .offer-grid {
    grid-template-columns:1fr !important;
    gap:10px;
  }
  /* Offer card: horizontal row layout */
  .offer-radio-card {
    flex-direction:row;
    text-align:left !important;
    align-items:center;
    gap:14px;
    padding:14px 16px;
  }
  .offer-radio-img {
    width:58px; height:58px; flex-shrink:0;
  }
  .offer-radio-info {
    flex:1;
    align-items:flex-start !important;
    gap:3px;
  }
  .offer-radio-qty  { font-size:14px; font-weight:600; }
  .offer-radio-price{ font-size:20px; font-weight:800; }
  .offer-radio-old  { font-size:12px; }
  .offer-radio-save { font-size:12px; }

  /* Offer badge (Ã‰conomie / Meilleure) repositioned for row layout */
  .offer-badge {
    top:-1px; right:-1px;
    padding:3px 10px; font-size:9px;
    border-radius:0 var(--r-md) 0 var(--r-md);
  }

  /* Order card: full-bleed on small screens */
  .order-card {
    border-radius:var(--r-lg);
    margin:0;
  }
  .order-card-body { padding:16px; }

  /* Product hero text reduce gap */
  .prod-hero-text { gap:12px; }
  .prod-hero { padding:24px 0 20px; }

  /* "Choisissez votre offre" header */
  .order-card-header {
    padding:13px 16px;
    border-radius:var(--r-lg) var(--r-lg) 0 0;
  }
  .order-card-header span:first-child { font-size:13px; }
  .order-card-cod { font-size:11px; }

  /* Order buttons */
  .btn-order-now { padding:15px; font-size:15px; }
  .btn-add-cart  { padding:13px; font-size:13.5px; }
  .order-trust   { font-size:11px; gap:8px; }
}

/* â”€â”€ SECTION PADDING: Better mobile spacing â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width:640px) {
  .section { padding:44px 0; }
  .stats-section { padding:36px 0; }
  .cta-section .cta-content { padding:52px 20px; }

  /* Reduce container side padding slightly for content-richness */
  .container { padding:0 14px; }
  .prod-img-slider { width:calc(100% + 28px); margin-left:-14px; margin-right:-14px; }
  .hero .hero-content { padding:64px 22px; }

  /* Benefits grid on product pages: 2 columns on medium mobile */
  .prod-benefits-grid { grid-template-columns:1fr 1fr; gap:12px; }
}
@media (max-width:380px) {
  .prod-benefits-grid { grid-template-columns:1fr; }
  .offer-radio-img { width:48px; height:48px; }
}

/* â”€â”€ TESTIMONIAL CARDS: Proper styling on product pages â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.testi-card {
  background:#fff; border:1px solid var(--g100); border-radius:var(--r-lg);
  padding:24px; box-shadow:var(--sh-sm); transition:all var(--ease);
}
.testi-card:hover { transform:translateY(-4px); box-shadow:var(--sh-md); }
.testi-stars { color:var(--gold); font-size:16px; margin-bottom:10px; }
.testi-body {
  font-size:14.5px; color:var(--g700); line-height:1.72;
  font-style:italic; margin-bottom:16px;
}
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-avatar {
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  color:#fff; font-size:15px; font-weight:700;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.testi-author strong { display:block; font-size:13.5px; font-weight:700; color:var(--navy); }
.testi-author span   { display:block; font-size:12px; color:var(--g300); }
@media (max-width:640px) {
  .testimonials-grid { grid-template-columns:1fr; }
}

/* â”€â”€ OFFER ATTRACTION SIGNALS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* Popular indicator (offer 2) */
.offer-popular {
  display:inline-flex; align-items:center; gap:3px;
  font-size:10px; font-weight:800; letter-spacing:.4px; text-transform:uppercase;
  color:#ea580c; margin-top:4px; line-height:1;
}
/* Stock warning (offer 3 below save text) */
.offer-stock-warn {
  font-size:12px; font-weight:700; color:#dc2626; margin-top:3px;
  display:flex; align-items:center; gap:3px;
}
/* Offer 1 hint */
.offer-hint {
  font-size:10px; color:var(--grn); font-weight:700; margin-top:3px;
  letter-spacing:.2px;
}

/* Stock + urgency on one line */
.offer-bottom-row {
  display:flex; align-items:center; justify-content:space-between;
  gap:6px; margin-top:5px; width:100%;
}
.offer-urgency-wrap { margin-left:auto; }
.offer-urgency {
  display:inline-flex; align-items:center; gap:5px;
  background:linear-gradient(135deg,#f97316,#ef4444);
  color:#fff; font-size:8px; font-weight:800; letter-spacing:.5px;
  text-transform:uppercase; padding:4px 9px; border-radius:20px;
  white-space:nowrap; box-shadow:0 2px 10px rgba(249,115,22,.45);
  animation:urgencyGlow 1.8s ease-in-out infinite;
}
.offer-urgency svg { flex-shrink:0; }
@keyframes urgencyGlow {
  0%,100% { box-shadow:0 2px 10px rgba(249,115,22,.4); }
  50%      { box-shadow:0 2px 18px rgba(249,115,22,.7); transform:scale(1.04); }
}

/* Section gap: reduce certs bottom padding */
.certs-white-section { padding-bottom:52px; }

/* â”€â”€ MOBILE FIXES â€” Very small screens (<375px) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width:375px) {
  html { font-size:15px; }
  .container { padding:0 12px; }
  .prod-hero-title { font-size:1.4rem; white-space:normal; }
  .offer-radio-img { width:44px; height:44px; }
  .offer-radio-price { font-size:17px; }
  .offer-radio-qty { font-size:12px; }
  .btn-order-now { padding:13px; font-size:14px; }
  .btn-add-cart  { padding:11px; font-size:13px; }
  .section { padding:36px 0; }
  .cart-drawer { width:100vw; }
  .mob-drawer { width:85vw; }
  .prod-img-slider-inner { height:auto; aspect-ratio:4/3; }
  .results-grid-5 { grid-template-columns:repeat(2,1fr); gap:10px; }
  .prod-benefits-grid { grid-template-columns:1fr; gap:10px; }
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:0; }
  .stat-num { font-size:1.8rem; }
  .section-title { font-size:1.55rem; }
  .hdr-logo .logo-img { height:48px; }
  .os-reassure-grid { gap:8px; padding:12px 16px; flex-direction:column; align-items:center; }
  .os-timeline { padding:0 16px 20px; }
  .os-step-dot { width:30px; height:30px; }
  .os-step-dot svg { width:11px; height:11px; }
  .os-step-label { font-size:10px; }
  .os-step-desc { font-size:9.5px; }
  .checkout-form-card { padding:18px 14px; }
  .footer-grid { grid-template-columns:1fr; gap:20px; }
}

/* ── GENERAL SMALL SCREEN OVERFLOW FIX ─────────────────────────── */
html, body { overflow-x:hidden; }
img { max-width:100%; height:auto; }

/* â”€â”€ PROD HERO TITLE: prevent overflow on narrow screens â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width:480px) {
  .prod-hero-title {
    font-size:clamp(1.3rem, 5vw, 1.8rem);
    white-space:normal;
    overflow:visible;
    text-overflow:unset;
  }
  .spotlight-content h2 { font-size:clamp(1.3rem,5vw,1.8rem); white-space:normal; }
  .pc-name { white-space:normal; font-size:18px; }
  .order-card { margin:0 -2px; }
  .promo-bar { padding:8px 40px; font-size:12px; }
  .os-main-title { font-size:1.5rem; margin:16px 18px 6px; }
  .os-phone-alert { padding:14px 16px; margin:0 16px 20px; }
  .os-brand-header { padding:16px 20px; }
  .os-back-btn { width:calc(100% - 32px); margin:4px 16px 24px; }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   QNC MAROC â€” Additions v3.5
   Animated Footer Border Â· Green-Blue CTAs Â· Scroll Fix Â· Icons
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ ANIMATED FOOTER TOP BORDER â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@keyframes footerBorderAnim {
  0%,100% { background-position:0% 50%; }
  50%     { background-position:100% 50%; }
}
.site-footer::before {
  content:''; display:block; height:3px;
  background:linear-gradient(90deg,#1D6ED8,#2B8DE8,#5BBCF5,#C4973A,#2B8DE8,#1D6ED8);
  background-size:300% 100%;
  animation:footerBorderAnim 6s ease infinite;
}

/* â”€â”€ ANIMATED BORDERS ON PRE-FOOTER CTA SECTION â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cta-section { position:relative; }
.cta-section::before,
.cta-section::after {
  content:''; display:block; height:3px; width:100%;
  background:linear-gradient(90deg,#1D6ED8,#2B8DE8,#5BBCF5,#C4973A,#2B8DE8,#1D6ED8);
  background-size:300% 100%;
  animation:footerBorderAnim 6s ease infinite;
}
.cta-section::after { animation-delay:3s; }

/* â”€â”€ GREEN-BLUE HIGH-CONVERSION BUTTONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn-order-now {
  background:linear-gradient(135deg,#22c55e 0%,#16a34a 50%,#2B8DE8 100%) !important;
  color:#fff !important; border:none !important;
  box-shadow:0 4px 18px rgba(34,197,94,.28),0 2px 8px rgba(43,141,232,.15) !important;
  transition:all .25s ease !important;
}
.btn-order-now:hover:not(:disabled) {
  background:linear-gradient(135deg,#16a34a 0%,#15803d 50%,#1D6ED8 100%) !important;
  transform:translateY(-2px) !important;
  box-shadow:0 8px 28px rgba(34,197,94,.38),0 4px 12px rgba(43,141,232,.22) !important;
}
.btn-cta-main {
  background:linear-gradient(135deg,#22c55e 0%,#16a34a 50%,#2B8DE8 100%) !important;
  color:#fff !important; border-color:transparent !important;
  box-shadow:0 4px 18px rgba(34,197,94,.28),0 2px 8px rgba(43,141,232,.15) !important;
  transition:all .25s ease !important;
}
.btn-cta-main:hover {
  background:linear-gradient(135deg,#16a34a 0%,#15803d 50%,#1D6ED8 100%) !important;
  border-color:transparent !important; transform:translateY(-2px) !important;
  box-shadow:0 8px 28px rgba(34,197,94,.38),0 4px 12px rgba(43,141,232,.22) !important;
}

/* Inline green button — for spotlight "Decouvrir" links, keeps natural width */
.btn-green { background:linear-gradient(135deg,#22c55e 0%,#16a34a 50%,#2B8DE8 100%); color:#fff; border-color:transparent; box-shadow:0 4px 18px rgba(34,197,94,.28),0 2px 8px rgba(43,141,232,.15); }
.btn-green:hover { background:linear-gradient(135deg,#16a34a 0%,#15803d 50%,#1D6ED8 100%); transform:translateY(-2px); box-shadow:0 8px 28px rgba(34,197,94,.38),0 4px 12px rgba(43,141,232,.22); color:#fff; }

/* Nav CTA button */
.btn-nav-cta {
  background:linear-gradient(135deg,#22c55e 0%,#16a34a 50%,#2B8DE8 100%);
  color:#fff !important; border:none; padding:9px 20px; border-radius:var(--r-sm);
  font-size:13.5px; font-weight:700; cursor:pointer; white-space:nowrap;
  transition:all .25s ease; font-family:var(--f-body); display:inline-flex;
  align-items:center; gap:7px; text-decoration:none;
  box-shadow:0 2px 10px rgba(34,197,94,.22);
}
.btn-nav-cta:hover {
  background:linear-gradient(135deg,#16a34a 0%,#15803d 50%,#1D6ED8 100%);
  transform:translateY(-1px); box-shadow:0 4px 16px rgba(34,197,94,.34);
}

/* Mobile CTA drawer button */
.mob-cta-wrap .btn {
  background:linear-gradient(135deg,#22c55e 0%,#16a34a 50%,#2B8DE8 100%) !important;
  border-color:transparent !important; color:#fff !important;
}

/* Mobile floating scroller button */
.mob-float-cta-btn {
  background:linear-gradient(135deg,#22c55e 0%,#16a34a 50%,#2B8DE8 100%) !important;
  color:#fff !important; border:none !important;
  box-shadow:0 4px 18px rgba(34,197,94,.28),0 2px 8px rgba(43,141,232,.15) !important;
}

/* Desktop nav CTA button: hide on mobile */
@media (max-width:900px) { .hdr-cta-link { display:none !important; } }

/* â”€â”€ SCROLL MARGIN FIX â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
html { scroll-padding-top:calc(var(--nav-h) + 52px); }
.section, .stats-section, .prod-hero, .cta-section,
.certs-white-section, .hero, .results-section, .prod-details-section {
  scroll-margin-top:calc(var(--nav-h) + 52px);
}

/* â”€â”€ SECTION VISUAL SEPARATORS (prevent empty-looking blends) â”€â”€â”€â”€â”€ */
.bg-light + .section:not(.bg-light),
.section:not(.bg-light,.stats-section,.cta-section,.cta-product-section) + .bg-light {
  border-top:1px solid var(--g100);
}

/* â”€â”€ HOME PAGE SECTION ORDERING: CTA always last â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
[data-section-id="home-cta"] { order:999; }

/* â”€â”€ LOCATION ICON IN TRUST ITEMS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.loc-icon-svg { display:inline-flex; align-items:center; flex-shrink:0; vertical-align:middle; }

/* â”€â”€ HOME PAGE: Prevent empty-looking sections â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* Any section that is shown must have at least enough height to be visible */
[data-section-id]:not([style*="display:none"]):not([style*="display: none"]) {
  min-height:40px;
}
/* Sections with no visible content collapse via this rule */
.section:empty, .stats-section:empty { display:none !important; }

/* â”€â”€ CADEAU INCLUS BADGE BELOW COMMANDER BUTTONS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cadeau-badge {
  display:flex; align-items:center; justify-content:center; gap:5px;
  font-size:11.5px; font-weight:700; color:var(--grn);
  letter-spacing:.2px;
}
.cadeau-badge svg { flex-shrink:0; }

/* ── MOBILE SCROLL QUALITY ───────────────────────────────────────── */

/* 1. Eliminate 300ms tap delay on all interactive elements */
a, button, [role="button"], input, select, textarea, label {
  touch-action: manipulation;
}

/* 2. iOS momentum scrolling inside drawers */
.mob-drawer,
.cart-items {
  -webkit-overflow-scrolling: touch;
}

/* 3. Contain scroll within drawers — stop page from scrolling behind them */
.mob-drawer,
.cart-drawer {
  overscroll-behavior-y: contain;
}

/* 4. Prevent horizontal rubber-band / bounce */
html, body { overscroll-behavior-x: none; }

/* 5. Smooth scroll for all anchor navigation */
html { scroll-behavior: smooth; }

/* 6. Keep floating CTA from clipping last section content on small phones */
@media (max-width:640px) {
  .site-footer { padding-bottom:calc(104px + env(safe-area-inset-bottom,0px)); }
}
