/* ============ Tokens ============ */
:root{
  --white:#ffffff;
  --black:#0A0A0A;
  --blue:#1D6FF2;
  --blue-dark:#1860d6;
  --pink:#FF0066;
  --pink-dark:#d9004f;
  --pink-soft:#ffe5ee;
  --gray-50:#fafafa;
  --gray-100:#f5f5f5;
  --gray-200:#ececec;
  --gray-400:#bfbfbf;
  --gray-500:#8a8a8a;
  --gray-600:#6b6b6b;
  --shadow-sm:0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 8px 24px rgba(0,0,0,.08);
  --shadow-lg:0 20px 50px rgba(0,0,0,.12);
  --radius:12px;
  --radius-lg:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
html,body{margin:0;padding:0;overflow-x:clip}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:'Inter',system-ui,-apple-system,Arial,sans-serif;
  color:var(--black);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  font-size:15px;
  line-height:1.5;
  width:100%;max-width:100vw;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none;padding:0;margin:0}
h1,h2,h3,h4,h5{margin:0;letter-spacing:-.02em}

.container{max-width:1280px;margin:0 auto;padding:0 24px}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 26px;border-radius:8px;
  font-weight:700;font-size:13px;letter-spacing:.06em;
  transition:transform .15s ease, background .2s ease, color .2s ease;
  text-transform:uppercase;
}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dark)}
.btn-outline{background:transparent;color:#fff;border:1.5px solid #fff}
.btn-outline:hover{background:#fff;color:var(--black)}

.eyebrow{
  display:inline-block;color:var(--pink);
  font-weight:700;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:8px;
}
.eyebrow-light{color:#ff7aa6}

.link-arrow{
  font-size:11px;font-weight:700;letter-spacing:.16em;
  color:var(--black);white-space:nowrap;
}
.link-arrow:hover{color:var(--pink)}

/* ============ Announcement bar ============ */
.announce{
  background:var(--pink);color:#fff;
  font-size:11.5px;letter-spacing:.04em;
  overflow:hidden;
  position:relative;z-index:201;
}
.announce-track{
  display:flex;justify-content:space-around;align-items:center;
  gap:32px;padding:10px 0;white-space:nowrap;
  animation:scrollAnnounce 25s linear infinite;
  width:max-content;
}
@keyframes scrollAnnounce{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.announce-item{display:inline-flex;align-items:center;gap:8px;color:#fff}
.announce-item svg{opacity:1}

/* ============ Header ============ */
.header{
  position:sticky;top:0;z-index:200;
  background:transparent;border-bottom:1px solid transparent;
  transition:background .25s ease, border-color .25s ease, box-shadow .25s ease, color .25s ease;
}
.header.scrolled{
  background:#fff;border-bottom:1px solid var(--gray-100);
  box-shadow:var(--shadow-sm);
}
/* Transparante header — witte tekst over hero */
.header:not(.scrolled) .nav a,
.header:not(.scrolled) .icon-btn,
.header:not(.scrolled) .logo,
.header:not(.scrolled) .logo img{
  color:#fff !important;
}
.header:not(.scrolled) .icon-btn{
  background:rgba(255,255,255,.15) !important;
  border:1px solid rgba(255,255,255,.3) !important;
}
.header:not(.scrolled) .icon-btn:hover{
  background:rgba(255,255,255,.25) !important;
}
.header:not(.scrolled) .cart-badge{
  background:var(--pink) !important;
  color:#fff !important;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;gap:24px;max-width:1280px;margin:0 auto;padding:0 24px;overflow:visible;
}
.logo{
  display:inline-flex;align-items:center;
  font-weight:900;font-size:20px;letter-spacing:.02em;color:var(--black);
  flex-shrink:0;
}
.logo img{height:28px;width:auto;display:block}
.logo-footer img{height:24px}
.logo span{color:var(--blue)}
.nav{display:flex;gap:30px}
.nav a{
  font-size:13px;font-weight:600;color:var(--black);
  position:relative;padding:6px 0;
}
.nav a:hover{color:var(--pink)}

.header-icons{display:flex;align-items:center;gap:6px;flex-shrink:0;position:relative;z-index:51}
.icon-btn{
  width:40px;height:40px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--black);position:relative;flex-shrink:0;
}
.icon-btn:hover{background:var(--gray-100)}
.cart-badge{
  position:absolute;top:4px;right:4px;
  background:var(--pink);color:#fff;
  font-size:10px;font-weight:700;
  min-width:16px;height:16px;border-radius:8px;
  display:inline-flex;align-items:center;justify-content:center;padding:0 4px;
}
.menu-toggle{display:none}

/* ============ Hero ============ */
.hero{
  position:relative;width:100%;
  height:min(78vh,780px);min-height:520px;overflow:hidden;
  background:#000;
  margin-top:-112px; /* Achter header (72px) + announcement bar (40px) */
}
.hero-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  will-change:transform;transform:scale(1.15);
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(0,0,0,.45) 0%,rgba(0,0,0,.15) 45%,rgba(0,0,0,0) 70%);
}
.hero-content{
  position:relative;z-index:2;height:100%;
  display:flex;flex-direction:column;justify-content:center;
  color:#fff;
}
.hero-content h1{
  font-weight:900;font-size:clamp(48px,7vw,92px);
  line-height:.92;letter-spacing:-.03em;
  text-shadow:0 2px 30px rgba(0,0,0,.25);
}
.hero-content p{
  font-size:16px;margin:18px 0 28px;max-width:480px;
  font-weight:400;opacity:.95;
}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}

/* ============ Scroll cue ============ */
.scroll-cue{
  position:absolute;left:50%;bottom:26px;transform:translateX(-50%);
  z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;
  color:#fff;opacity:.85;transition:opacity .25s ease, transform .25s ease;
  animation:cueFloat 2.4s ease-in-out infinite;
}
.scroll-cue:hover{opacity:1}
.scroll-cue-text{
  font-size:10px;font-weight:800;letter-spacing:.32em;text-indent:.32em;
  text-shadow:0 1px 8px rgba(0,0,0,.4);
}
.scroll-cue-mouse{
  width:26px;height:42px;border-radius:14px;
  border:2px solid rgba(255,255,255,.8);
  display:flex;justify-content:center;padding-top:7px;
  box-shadow:0 2px 12px rgba(0,0,0,.25);
}
.scroll-cue-wheel{
  width:3px;height:8px;border-radius:3px;background:#fff;
  animation:cueWheel 1.8s ease-in-out infinite;
}
@keyframes cueFloat{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(6px)}
}
@keyframes cueWheel{
  0%{opacity:0;transform:translateY(0)}
  30%{opacity:1}
  60%{opacity:1;transform:translateY(12px)}
  100%{opacity:0;transform:translateY(12px)}
}
@media (prefers-reduced-motion:reduce){
  .scroll-cue,.scroll-cue-wheel{animation:none}
}

/* ============ USP bar ============ */
.usp-wrap{margin-top:-44px;position:relative;z-index:3}
.usp-bar{
  position:relative;
  background:#fff;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  display:grid;grid-template-columns:repeat(4,1fr);
  padding:26px 14px;overflow:hidden;
  border:1px solid var(--gray-100);
}
/* Pink branding accent bar on top */
.usp-bar::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--pink) 0%,var(--pink-dark) 60%,var(--blue) 100%);
}
.usp{
  display:flex;align-items:center;gap:15px;padding:8px 22px;
  border-right:1px solid var(--gray-100);
  transition:transform .25s ease;
}
.usp:last-child{border-right:0}
.usp:hover{transform:translateY(-3px)}
.usp-icon{
  width:46px;height:46px;border-radius:12px;
  background:var(--pink-soft);color:var(--pink);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .25s ease, color .25s ease, transform .25s ease;
}
.usp:hover .usp-icon{
  background:var(--pink);color:#fff;transform:scale(1.06);
  box-shadow:0 8px 18px rgba(255,0,102,.28);
}
.usp h4{
  font-size:13px;font-weight:800;margin-bottom:3px;letter-spacing:-.01em;
  text-transform:uppercase;
}
.usp p{margin:0;font-size:12px;color:var(--gray-600);line-height:1.4}
.usp .usp-stars{color:#FFB100;font-size:12px;letter-spacing:1px;margin-bottom:2px;display:block}

/* ============ Sections ============ */
.section{padding:80px 0}
.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;margin-bottom:32px;
}
.section-head h2{
  font-size:clamp(28px,3.4vw,40px);
  font-weight:900;letter-spacing:-.02em;
}
.section-sub{
  margin:10px 0 0;font-size:14px;color:var(--gray-600);max-width:460px;
}

/* ============ Drops carousel ============ */
.carousel{position:relative;overflow:hidden}
.drops-track{
  display:grid;grid-auto-flow:column;grid-auto-columns:minmax(220px,1fr);
  gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;
  scroll-behavior:smooth;padding-bottom:8px;
  scrollbar-width:none;
}
.drops-track::-webkit-scrollbar{display:none}
.drops-empty{grid-column:1/-1;text-align:center;color:var(--gray-500);padding:40px 0;font-size:14px}
@media (min-width:900px){
  .drops-track{grid-template-columns:repeat(4,1fr);grid-auto-columns:unset;grid-auto-flow:row;gap:24px;row-gap:36px}
}
.card{scroll-snap-align:start;display:block}
.card-img{
  position:relative;aspect-ratio:4/5;
  background:var(--gray-100) center/cover no-repeat;
  border-radius:var(--radius);overflow:hidden;margin-bottom:14px;
  transition:background-size .5s ease, box-shadow .3s ease, transform .3s ease;
}
.card-img::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(0,0,0,.32) 100%);
  opacity:0;transition:opacity .3s ease;
}
.card-img-2{
  position:absolute;inset:0;
  background:center/cover no-repeat;
  opacity:0;transition:opacity .45s ease;
}
.card:hover .card-img-2{opacity:1}
.card:hover .card-img{
  box-shadow:0 18px 40px rgba(0,0,0,.14);transform:translateY(-4px);background-size:108%;
}
.card:hover .card-img::after{opacity:1}
.badge{
  position:absolute;top:12px;left:12px;z-index:2;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  color:var(--black);
  font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  padding:6px 11px;border-radius:6px;
  box-shadow:0 2px 8px rgba(0,0,0,.08);
  display:inline-flex;align-items:center;gap:4px;line-height:1;
}
.badge-sale{background:var(--pink);color:#fff;box-shadow:0 4px 12px rgba(255,0,102,.35)}
.card-view{
  position:absolute;left:12px;right:12px;bottom:12px;z-index:2;
  background:#fff;color:var(--black);
  font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  text-align:center;padding:11px 12px;border-radius:8px;
  opacity:0;transform:translateY(10px);
  transition:opacity .3s ease, transform .3s ease;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
}
.card:hover .card-view{opacity:1;transform:translateY(0)}
.card-brand{
  display:block;color:var(--pink);
  font-size:11px;font-weight:700;letter-spacing:.12em;margin-bottom:5px;
}
.card-name{
  font-size:14px;font-weight:600;margin-bottom:7px;color:var(--black);
  transition:color .2s ease;
}
.card:hover .card-name{color:var(--pink)}
.card-price{font-size:14px;color:var(--black);font-weight:700;display:inline-flex;align-items:center;gap:8px}
.price-now{color:var(--pink)}
.price-old{color:var(--gray-500);font-weight:500;text-decoration:line-through;font-size:13px}

.carousel-arrow{
  position:absolute;top:38%;transform:translateY(-50%);
  width:42px;height:42px;border-radius:50%;
  background:#fff;box-shadow:var(--shadow-md);
  display:flex;align-items:center;justify-content:center;
  z-index:3;color:var(--black);
}
.carousel-arrow:hover{color:var(--pink)}
.carousel-arrow.left{left:8px}
.carousel-arrow.right{right:8px}
/* Drops is a grid on desktop and a swipe row on mobile — hide arrows */
.carousel-arrow{display:none}

/* ============ Brands ============ */
.brands{padding:50px 0;border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100)}
.brands-title{
  text-align:center;font-size:13px;letter-spacing:.16em;font-weight:700;
  color:var(--gray-600);margin-bottom:28px;
}
/* Infinite luxe marquee */
.brands-marquee{
  position:relative;overflow:hidden;width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 12%,#000 88%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 12%,#000 88%,transparent 100%);
}
.brands-track{
  display:flex;align-items:center;width:max-content;
  animation:brandsScroll 32s linear infinite;
}
.brands-marquee:hover .brands-track{animation-play-state:paused}
@keyframes brandsScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.brand-logo{
  height:56px;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;
  padding:0 48px;
  opacity:.55;filter:grayscale(1);
  transition:opacity .3s ease, filter .3s ease, transform .3s ease;
  text-decoration:none;color:inherit;
}
.brand-logo svg{width:140px;height:60px}
.brand-logo:hover{opacity:1;filter:grayscale(0);transform:scale(1.06);text-decoration:none}
@media (prefers-reduced-motion:reduce){
  .brands-track{animation:none;flex-wrap:wrap;justify-content:center;gap:24px}
}

/* ============ Summer collection ============ */
.summer{padding:60px 0}
.summer-grid{
  background:#eef2f7;border-radius:var(--radius-lg);
  padding:60px;display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:center;
}
.summer-text h2{
  font-size:clamp(32px,4vw,52px);font-weight:900;
  line-height:1;letter-spacing:-.02em;margin:6px 0 18px;
}
.summer-text p{color:var(--gray-600);font-size:15px;margin:0 0 24px;max-width:380px}
.summer-images{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.summer-img{
  aspect-ratio:3/4;border-radius:var(--radius);
  background:#cfd8df center/cover no-repeat;
}

/* ============ Reviews ============ */
.reviews{padding:80px 0}
.reviews-header{
  display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center;
  margin-bottom:40px;padding-bottom:32px;border-bottom:1px solid var(--gray-100);
}
.reviews-header-left h2{
  font-size:clamp(28px,3.4vw,40px);font-weight:900;letter-spacing:-.02em;
  margin:6px 0 10px;
}
.rating-num{color:var(--pink)}
.rating-out{color:var(--gray-500);font-weight:700}
.reviews-sub{color:var(--gray-600);margin:0;font-size:14px;max-width:440px}
.reviews-sub strong{color:var(--black)}

.reviews-summary{
  background:var(--gray-50);border:1px solid var(--gray-100);
  border-radius:var(--radius);padding:20px 22px;
}
.trust-badge{
  display:flex;align-items:center;gap:12px;
  padding-bottom:14px;margin-bottom:14px;
  border-bottom:1px solid var(--gray-100);
}
.trust-badge strong{display:block;font-size:14px;font-weight:800}
.trust-badge span{font-size:11.5px;color:var(--gray-600)}
.rating-bars{display:flex;flex-direction:column;gap:6px}
.rating-row{display:grid;grid-template-columns:24px 1fr 36px;align-items:center;gap:10px;font-size:11.5px;color:var(--gray-600)}
.rating-row .bar{height:6px;background:var(--gray-100);border-radius:4px;overflow:hidden}
.rating-row .bar > div{height:100%;background:#00b67a;border-radius:4px}
.rating-row .pct{text-align:right;font-weight:600;color:var(--black)}

.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review{
  background:#fff;border-radius:var(--radius);
  padding:22px;border:1px solid var(--gray-100);
  display:flex;flex-direction:column;gap:10px;
  transition:box-shadow .2s, transform .2s;
}
.review:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.review-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.stars{color:var(--pink);font-size:15px;letter-spacing:1.5px;margin:0}
.verified{
  display:inline-flex;align-items:center;gap:5px;
  font-size:10.5px;font-weight:600;color:#00b67a;
  background:rgba(0,182,122,.08);border-radius:20px;padding:4px 9px;
}
.review-title{font-size:14px;font-weight:700;margin:2px 0 0;letter-spacing:-.01em}
.review p{margin:0;font-size:13.5px;color:#2a2a2a;line-height:1.55}
.review-meta{margin-top:auto;padding-top:12px;border-top:1px solid var(--gray-100)}
.reviewer{display:flex;align-items:center;gap:10px}
.avatar{
  width:36px;height:36px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:14px;flex-shrink:0;
}
.reviewer strong{display:block;font-size:13px;font-weight:700;color:var(--black);line-height:1.2}
.reviewer small{font-size:11.5px;color:var(--gray-500)}

.reviews-footer{text-align:center;margin-top:32px}
.reviews-footer .link-arrow{font-size:12px}

/* ============ Snapchat ============ */
.snap-section{
  position:relative;
  margin:60px auto;
  max-width:1280px;
  color:#fff;border-radius:var(--radius-lg);
  overflow:hidden;
  min-height:420px;
  display:flex;align-items:center;justify-content:center;
  isolation:isolate;text-align:center;
}
.snap-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;z-index:0;
}
.snap-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(60% 80% at 50% 40%, rgba(8,16,30,.55) 0%, rgba(8,16,30,.82) 100%),
    linear-gradient(180deg, rgba(8,16,30,.6) 0%, rgba(8,16,30,.78) 100%);
}
.snap-inner{
  position:relative;z-index:2;padding:72px 24px;
  display:flex;flex-direction:column;align-items:center;
  max-width:620px;
}
.snap-ghost{
  width:64px;height:64px;border-radius:18px;background:#FFFC00;
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:18px;box-shadow:0 12px 32px rgba(255,252,0,.3);
}
.snap-section .eyebrow-light{color:#FFFC00;letter-spacing:.22em}
.snap-section h2{
  font-size:clamp(30px,3.8vw,52px);font-weight:900;
  margin:10px 0 14px;line-height:1.02;letter-spacing:-.02em;
}
.snap-handle{color:#FFFC00}
.snap-section p{color:#dde3ec;max-width:460px;margin:0 0 28px;font-size:14.5px;line-height:1.6}
.snap-cta{
  display:inline-flex;align-items:center;gap:10px;
  background:#FFFC00;color:#0A0A0A;
  padding:15px 28px;border-radius:12px;
  font-weight:800;font-size:14px;letter-spacing:.01em;
  transition:transform .15s ease, box-shadow .2s ease;
  box-shadow:0 10px 28px rgba(255,252,0,.32);
}
.snap-cta:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(255,252,0,.45);color:#0A0A0A}

/* ============ Contact ============ */
.contact{padding:80px 0}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
  background:linear-gradient(135deg,#0e1020 0%,#1a0e2a 55%,#0a1530 100%);
  border-radius:var(--radius-lg);padding:56px;color:#fff;position:relative;overflow:hidden;
}
.contact-grid::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(50% 70% at 8% 20%, rgba(255,0,102,.35) 0%, transparent 60%),
    radial-gradient(50% 70% at 95% 90%, rgba(29,111,242,.35) 0%, transparent 60%);
}
.contact-intro{position:relative;z-index:1}
.contact-intro .eyebrow{color:#ff7aa6}
.contact-intro h2{
  font-size:clamp(28px,3.4vw,44px);font-weight:900;
  line-height:1.02;letter-spacing:-.02em;margin:8px 0 16px;
}
.contact-intro p{color:#c7cdda;font-size:14.5px;line-height:1.6;max-width:420px;margin:0 0 26px}
.btn-whatsapp{
  display:inline-flex;align-items:center;gap:10px;
  background:#25D366;color:#04210f;
  padding:14px 24px;border-radius:10px;
  font-weight:800;font-size:14px;letter-spacing:.01em;
  box-shadow:0 10px 28px rgba(37,211,102,.35);
  transition:transform .15s ease, box-shadow .2s ease;
}
.btn-whatsapp:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(37,211,102,.45);color:#04210f}
.contact-cards{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.contact-card{
  display:flex;align-items:center;gap:14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;padding:16px;min-width:0;
  transition:background .2s ease, border-color .2s ease, transform .2s ease;
}
a.contact-card:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.25);transform:translateY(-2px)}
.contact-card-icon{
  width:42px;height:42px;border-radius:11px;flex-shrink:0;
  background:rgba(255,255,255,.1);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
}
.contact-card-icon svg{width:20px;height:20px}
.contact-icon-wa{background:#25D366;color:#04210f}
.contact-icon-mail{background:rgba(255,0,102,.18);color:#ff7aa6}
.contact-icon-tiktok{background:#000;color:#fff}
.contact-icon-hours{background:rgba(29,111,242,.2);color:#7eb0ff}
.contact-card > div{min-width:0}
.contact-card strong{display:block;font-size:13.5px;font-weight:800;margin-bottom:2px}
.contact-card span{
  display:block;font-size:12.5px;color:#b9c0cf;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* ============ FAQ ============ */
.faq{padding:80px 0 40px}
.faq-head{text-align:center;max-width:640px;margin:0 auto 40px}
.faq-head h2{
  font-size:clamp(36px,4.4vw,56px);font-weight:900;
  letter-spacing:-.02em;margin:6px 0 12px;
}
.faq-head p{color:var(--gray-600);margin:0;font-size:14.5px}
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-item{
  background:var(--gray-50);
  border:1px solid var(--gray-100);
  border-radius:var(--radius);
  overflow:hidden;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.faq-item[open]{
  border-color:var(--pink);
  box-shadow:0 8px 22px rgba(255,0,102,.08);
  background:#fff;
}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:18px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-size:15px;font-weight:600;color:var(--black);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--pink)}
.faq-chev{
  flex-shrink:0;color:var(--gray-500);
  transition:transform .25s ease, color .2s ease;
}
.faq-item[open] .faq-chev{transform:rotate(180deg);color:var(--pink)}
.faq-answer{padding:0 22px 20px;color:var(--gray-600);font-size:14px;line-height:1.6}
.faq-answer p{margin:0;max-width:680px}
.faq-cta{text-align:center;margin-top:32px;font-size:14px;color:var(--gray-600)}
.faq-cta a{color:var(--black);font-weight:700}
.faq-cta a:hover{color:var(--pink)}

/* ============ Newsletter ============ */
.newsletter{padding:30px 0 60px}
.newsletter-inner{
  background:var(--gray-100);border-radius:var(--radius);
  padding:22px 28px;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;
}
.newsletter-text{display:flex;align-items:center;gap:14px}
.newsletter-icon{
  width:38px;height:38px;border-radius:8px;background:#fff;
  display:flex;align-items:center;justify-content:center;color:var(--pink);
}
.newsletter-text h4{font-size:14px;font-weight:800}
.newsletter-text p{margin:2px 0 0;font-size:12.5px;color:var(--gray-600)}
.newsletter-form{display:flex;gap:8px;flex:1;max-width:480px;min-width:280px}
.newsletter-form input{
  flex:1;padding:12px 16px;border-radius:8px;border:1px solid var(--gray-200);
  background:#fff;font-size:13px;font-family:inherit;
}
.newsletter-form input:focus{outline:2px solid var(--pink);outline-offset:1px;border-color:transparent}
.newsletter-form .btn{padding:12px 22px;font-size:12px}

/* ============ Footer ============ */
.footer{padding:50px 0 24px;border-top:1px solid var(--gray-100);overflow:hidden}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:30px;border-bottom:1px solid var(--gray-100);overflow:hidden;
}
.logo-footer{display:inline-block;margin-bottom:10px}
.footer-desc{font-size:13px;color:var(--gray-600);max-width:280px;margin:0 0 16px}
.socials{display:flex;gap:10px}
.socials a{
  width:36px;height:36px;border-radius:50%;
  border:1px solid var(--gray-200);color:var(--black);
  display:inline-flex;align-items:center;justify-content:center;
}
.socials a:hover{background:var(--black);color:#fff;border-color:var(--black)}
.footer h5{font-size:12px;font-weight:800;letter-spacing:.12em;margin-bottom:14px}
.footer ul li{margin-bottom:8px}
.footer ul li a,.contact-list li{font-size:13px;color:var(--gray-600)}
.footer ul li a:hover{color:var(--pink)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  gap:18px;flex-wrap:wrap;padding-top:20px;
}
.payments{display:flex;gap:10px;flex-wrap:wrap}
.pay{
  font-size:11px;font-weight:700;letter-spacing:.06em;
  padding:6px 12px;border:1px solid var(--gray-200);border-radius:6px;
  color:var(--gray-600);background:#fff;
}
.copyright{margin:0;font-size:12px;color:var(--gray-500)}

/* ============ Responsive ============ */
@media (max-width:1100px){
  .nav{gap:22px}
  .summer-grid{padding:44px;gap:32px}
}
@media (max-width:899px){
  .nav{
    display:none;position:fixed;top:0;left:0;right:0;
    flex-direction:column;gap:0;background:#fff;
    border-top:1px solid var(--gray-100);padding:8px 0;
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:opacity .2s, transform .2s;
    box-shadow:var(--shadow-md);z-index:9999;min-height:200px;padding-top:60px
  }
  .nav.open{display:flex;opacity:1;transform:translateY(0);pointer-events:auto}
  .nav a{padding:14px 24px;border-bottom:1px solid var(--gray-100);color:#000 !important;font-size:16px !important;font-weight:600 !important;display:block;text-decoration:none;line-height:1.4;min-height:48px;background:#fff !important;text-shadow:none !important}
  .menu-toggle{display:inline-flex}
  .header{position:sticky;z-index:100}

  .announce-track{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap}
  .announce-item{flex-shrink:0}

  .usp-bar{grid-template-columns:repeat(2,1fr);gap:8px}
  .usp{border-right:0;border-bottom:1px solid var(--gray-100);padding:12px}
  .usp:nth-last-child(-n+2){border-bottom:0}

  .summer-grid{grid-template-columns:1fr;padding:32px;overflow:hidden}
  .summer-images{grid-template-columns:repeat(3,1fr);overflow:hidden}

  .reviews-header{grid-template-columns:1fr;gap:24px}
  .reviews-grid{grid-template-columns:1fr}

  .snap-section{margin:40px 16px;min-height:360px}
  .snap-inner{padding:48px 20px}
  .snap-ghost{width:56px;height:56px}

  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .newsletter-inner{flex-direction:column;align-items:stretch}
  .newsletter-form{max-width:none}
}
@media (max-width:560px){
  .hero-content h1{font-size:48px}
  .section{padding:56px 0}
  .section-head{flex-direction:column;align-items:flex-start;gap:8px}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}

/* ============================================================
   COLLECTIE PAGE
   ============================================================ */
.nav a.active{color:var(--pink)}
.btn-outline-dark{
  background:transparent;color:var(--black);border:1.5px solid var(--gray-200);
  width:100%;padding:12px 18px;font-size:12px;
}
.btn-outline-dark:hover{border-color:var(--pink);color:var(--pink)}
.btn-lg{padding:16px 28px;font-size:14px}

.breadcrumb{
  font-size:12px;color:var(--gray-500);margin-bottom:18px;
  display:flex;align-items:center;gap:8px;
}
.breadcrumb a{color:var(--gray-500)}
.breadcrumb a:hover{color:var(--pink)}
.breadcrumb strong{color:var(--black);font-weight:600}

/* === Collection hero (dark gradient banner) === */
.collection-hero{
  position:relative;overflow:hidden;isolation:isolate;
  color:#fff;text-align:center;
  padding:90px 0 80px;overflow-x:hidden;
  margin-top:-112px; /* Achter header (72px) + announcement bar (40px) */
}
.collection-hero-bg{
  position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(60% 80% at 12% 30%, rgba(255,80,120,.55) 0%, transparent 60%),
    radial-gradient(55% 80% at 90% 70%, rgba(80,170,255,.45) 0%, transparent 60%),
    radial-gradient(40% 60% at 60% 20%, rgba(180,90,255,.4) 0%, transparent 60%),
    linear-gradient(135deg, #0e1020 0%, #1a0e2a 50%, #0a1530 100%);
}
.collection-hero-bg::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 100%, rgba(0,0,0,.5), transparent 60%);
}

/* Photo variant — uses image with brand logos baked in */
.collection-hero.collection-hero-photo{
  min-height:clamp(340px,46vw,520px);
  display:flex;align-items:flex-end;justify-content:center;
  padding:0;text-align:center;
}
.collection-hero-photo .collection-hero-bg{
  background-size:cover;background-position:center;background-repeat:no-repeat;
  will-change:transform;transform:scale(1.12);
}
.collection-hero-photo .collection-hero-bg::after{
  background:linear-gradient(180deg,rgba(0,0,0,0) 45%,rgba(0,0,0,.35) 72%,rgba(0,0,0,.7) 100%);
}
.collection-hero-photo .collection-hero-inner{
  width:100%;padding-top:0;padding-bottom:40px;
}
.collection-hero-photo .collection-hero-sub{margin:0 auto;max-width:560px;padding:0}
.collection-hero-inner{position:relative;z-index:1}
.brand-strip{
  display:flex;justify-content:center;align-items:center;flex-wrap:wrap;
  gap:38px;margin-bottom:34px;
  color:rgba(255,255,255,.85);
}
.brand-strip span{
  font-size:13px;font-weight:700;letter-spacing:.18em;
  opacity:.9;
}
.collection-hero-title{
  font-size:clamp(36px,5vw,64px);font-weight:900;
  letter-spacing:.02em;line-height:1;margin:0 0 14px;
}
.collection-hero-sub{
  font-size:15px;color:rgba(255,255,255,.75);max-width:560px;margin:0 auto;
}

/* === Horizontal filter bar === */
.filter-bar-wrap{background:var(--gray-50);border-bottom:1px solid var(--gray-100);padding:26px 0}
.filter-bar{
  display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:32px;
  align-items:flex-start;
}
.filter-bar-col h4{
  font-size:11px;font-weight:800;letter-spacing:.14em;
  color:var(--black);margin-bottom:14px;
}
.filter-options{display:flex;flex-direction:column;gap:8px;max-height:180px;flex-wrap:wrap}
.filter-options label,.check-row{
  display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-600);cursor:pointer;
}
.filter-options input,.check-row input{accent-color:var(--pink)}
.price-filter input[type=range]{width:100%;accent-color:var(--pink)}
.price-values{display:flex;justify-content:space-between;font-size:12px;color:var(--gray-600);margin-top:6px}
.price-values span:last-child{color:var(--pink);font-weight:800}
.filter-extras{display:flex;gap:18px;margin-top:12px;flex-wrap:wrap}
.sort-select-lg{
  width:100%;padding:11px 14px;
  border:1px solid var(--gray-200);border-radius:8px;
  font-family:inherit;font-size:13.5px;font-weight:500;
  background:#fff;cursor:pointer;
}
.sort-select-lg:focus{outline:2px solid var(--pink);outline-offset:1px}
.btn-link-reset{
  margin-top:10px;background:transparent;color:var(--gray-600);
  font-size:12px;font-weight:600;text-decoration:underline;padding:4px 0;
}
.btn-link-reset:hover{color:var(--pink)}

/* === Results bar === */
.results-bar{border-bottom:1px solid var(--gray-100);background:#fff;padding:18px 0}
.results-bar-inner{display:flex;align-items:center;justify-content:space-between}
.results-count{font-size:13px;color:var(--gray-600);font-weight:500}
.results-count::first-letter{font-weight:700;color:var(--black)}

.collection-main{padding:36px 0 80px;background:#fff}
.wide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* === Product card with CTA button === */
.card-cta{
  background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius);
  overflow:hidden;transition:box-shadow .2s ease, transform .2s ease;
  display:flex;flex-direction:column;
}
.card-cta:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.card-cta .card-link{display:block;padding:14px 14px 12px;color:inherit;text-decoration:none;flex:1}
.card-cta .card-img{aspect-ratio:1/1;margin-bottom:14px;border-radius:8px}
.card-cta .card-brand{margin-bottom:4px}
.card-cta .card-name{margin-bottom:8px;font-size:14px}
.card-btn{
  display:block;background:var(--black);color:#fff;
  text-align:center;padding:13px 16px;
  font-size:12px;font-weight:800;letter-spacing:.12em;
  text-decoration:none;transition:background .2s ease;
}
.card-btn:hover{background:var(--pink)}
.card-price-row{display:flex;align-items:center;gap:8px}
.card-old-price{font-size:12px;color:var(--gray-500);text-decoration:line-through}
/* Highlight discounted price in pink when paired with an old price */
.card-old-price + .card-price{color:var(--pink);font-weight:800}
.badge-sale{
  background:var(--pink);color:#fff;
  box-shadow:0 6px 18px rgba(255,0,102,.32);
  top:12px;right:12px;left:auto;bottom:auto;
  padding:6px 12px;border-radius:999px;
  font-size:11px;font-weight:800;letter-spacing:.04em;
  font-variant-numeric:tabular-nums;
}
.empty-state{text-align:center;padding:60px 20px;color:var(--gray-600)}
.loading-state{
  grid-column:1/-1;text-align:center;padding:80px 20px;
  color:var(--gray-500);font-size:14px;font-weight:500;
}
.loading-state::before{
  content:'';display:inline-block;width:18px;height:18px;
  border:2px solid var(--gray-200);border-top-color:var(--pink);
  border-radius:50%;margin-right:10px;vertical-align:-3px;
  animation:spin .9s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state h3{font-size:20px;font-weight:800;margin-bottom:6px;color:var(--black)}

/* ============================================================
   PRODUCT DETAIL PAGE
   ============================================================ */
.product-page{padding:24px 0 60px}
.product-page .breadcrumb{margin:8px 0 28px}

.product-layout{
  display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:flex-start;
}

/* Gallery */
.gallery{display:grid;grid-template-columns:80px 1fr;gap:14px;position:sticky;top:96px}
.gallery-thumbs{display:flex;flex-direction:column;gap:10px}
.thumb{
  width:80px;height:96px;border-radius:8px;
  background:var(--gray-100) center/cover no-repeat;
  border:2px solid transparent;cursor:pointer;
}
.thumb.on{border-color:var(--black)}
.gallery-main{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--gray-100)}
.gallery-main img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}
.gallery-badge{top:16px;left:16px;right:auto;bottom:auto;padding:6px 12px;font-size:11px}
.gallery-badge-2{
  top:auto;bottom:16px;left:16px;right:auto;
  padding:9px 13px;font-size:14px;
}
.gallery-badge-2::before{font-size:9.5px}

/* Info */
.product-info{padding:8px 0}
.product-brand{
  display:block;color:var(--pink);font-size:12px;font-weight:800;
  letter-spacing:.14em;margin-bottom:8px;
}
.product-info h1{
  font-size:clamp(26px,2.8vw,36px);font-weight:900;
  letter-spacing:-.02em;line-height:1.1;
}
.product-color{font-size:14px;color:var(--gray-600);margin:8px 0 14px}
.product-color strong{color:var(--black)}
.product-stars{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.product-stars .stars{color:var(--pink);font-size:14px;letter-spacing:1.5px}
.reviews-link{font-size:12.5px;color:var(--gray-600)}
.product-price-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.product-price{font-size:28px;font-weight:900;color:var(--black)}
.product-old-price{font-size:18px;color:var(--gray-500);text-decoration:line-through}
/* When discounted: show current price in pink */
.product-old-price + .product-price{color:var(--pink)}
.save-pill{
  background:var(--pink-soft);color:var(--pink);
  font-size:11.5px;font-weight:700;letter-spacing:.04em;
  padding:5px 10px;border-radius:20px;
}
.vat-note{font-size:12px;color:var(--gray-500);margin:6px 0 28px}

.size-section{margin-bottom:22px}
.size-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px}
.size-head strong{font-size:13px;font-weight:700}
.size-guide{font-size:12px;color:var(--gray-600);text-decoration:underline}
.size-guide:hover{color:var(--pink)}
.size-options{display:flex;gap:8px;flex-wrap:wrap}
.size-options button{
  min-width:52px;padding:11px 14px;
  border:1.5px solid var(--gray-200);border-radius:8px;
  background:#fff;font-size:13px;font-weight:600;
}
.size-options button:hover{border-color:var(--black)}
.size-options button.on{border-color:var(--black);background:var(--black);color:#fff}
.size-error{margin-top:8px;font-size:12px;color:var(--pink);font-weight:600}

.qty-row{display:flex;gap:12px;margin-bottom:18px}
.qty-stepper{
  display:inline-flex;align-items:center;
  border:1.5px solid var(--gray-200);border-radius:8px;overflow:hidden;
}
.qty-stepper button{padding:0 14px;height:48px;font-size:18px;font-weight:600;color:var(--black)}
.qty-stepper button:hover{background:var(--gray-100)}
.qty-stepper span{min-width:40px;text-align:center;font-weight:700}
.btn-cart{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:10px}

.stock-line{
  display:flex;align-items:center;gap:8px;
  font-size:12.5px;color:var(--gray-600);margin-bottom:24px;
}
.stock-line .dot{
  width:8px;height:8px;border-radius:50%;background:#00b67a;
  box-shadow:0 0 0 3px rgba(0,182,122,.18);
}

/* Accordion */
.product-accordion{border-top:1px solid var(--gray-100)}
.product-accordion details{border-bottom:1px solid var(--gray-100);padding:6px 0}
.product-accordion summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;font-size:14px;font-weight:700;
}
.product-accordion summary::-webkit-details-marker{display:none}
.product-accordion summary svg{transition:transform .2s ease;color:var(--gray-500)}
.product-accordion details[open] summary svg{transform:rotate(180deg);color:var(--pink)}
.product-accordion p{margin:0 0 10px;color:var(--gray-600);font-size:13.5px;line-height:1.6;padding-bottom:8px}
.product-accordion ul{margin:0;padding:0 0 14px 18px;color:var(--gray-600);font-size:13.5px;line-height:1.7}

.size-table{width:100%;border-collapse:collapse;margin:8px 0 14px;font-size:13px}
.size-table th,.size-table td{padding:9px 12px;border-bottom:1px solid var(--gray-100);text-align:left}
.size-table th{background:var(--gray-50);font-weight:700;color:var(--black)}
.size-table td{color:var(--gray-600)}

/* Trust strip */
.trust-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  padding:24px;margin:60px 0 50px;
  background:var(--gray-50);border-radius:var(--radius);border:1px solid var(--gray-100);
}
.trust-item{display:flex;align-items:center;gap:12px}
.trust-item svg{flex-shrink:0;color:var(--pink)}
.trust-item strong{display:block;font-size:13px;font-weight:700}
.trust-item span{font-size:11.5px;color:var(--gray-600)}

/* Related */
.related .section-head{margin-bottom:24px}
.related .section-head h2{font-size:clamp(22px,2.4vw,30px)}
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}

/* Toast */
.toast{
  position:fixed;left:50%;bottom:32px;transform:translateX(-50%) translateY(20px);
  background:var(--black);color:#fff;
  padding:14px 22px;border-radius:10px;
  font-size:13.5px;font-weight:600;
  box-shadow:var(--shadow-lg);
  opacity:0;pointer-events:none;
  transition:opacity .25s ease, transform .25s ease;
  z-index:200;max-width:90vw;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Responsive */
@media (max-width:1100px){
  .wide-grid{grid-template-columns:repeat(3,1fr);gap:18px}
  .related-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:899px){
  .collection-hero{padding:60px 0 50px}
  .brand-strip{gap:22px;margin-bottom:24px}
  .brand-strip span{font-size:11px}
  .filter-bar{grid-template-columns:1fr;gap:22px}
  .filter-bar-col{border-bottom:1px solid var(--gray-100);padding-bottom:18px}
  .filter-bar-col:last-child{border-bottom:0;padding-bottom:0}
  .filter-options{max-height:none;flex-wrap:nowrap;flex-direction:row;gap:16px;flex-wrap:wrap}
  .wide-grid{grid-template-columns:repeat(2,1fr)}
  .product-layout{grid-template-columns:1fr;gap:28px}
  .gallery{position:static;grid-template-columns:1fr}
  .gallery-thumbs{flex-direction:row;overflow-x:auto;order:2}
  .thumb{width:64px;height:80px;flex-shrink:0}
  .trust-strip{grid-template-columns:repeat(2,1fr)}
  .related-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .wide-grid{grid-template-columns:1fr 1fr;gap:12px}
  .card-cta .card-link{padding:10px 10px 8px}
  .card-btn{padding:11px;font-size:11px}
  .related-grid{grid-template-columns:1fr 1fr;gap:12px}
  .collection-hero-title{font-size:32px}
}

/* ============================================================
   CART & CHECKOUT
   ============================================================ */
.btn-block{width:100%;display:flex;align-items:center;justify-content:center;gap:10px}
.page-title{font-size:clamp(28px,3.4vw,40px);font-weight:900;letter-spacing:-.02em;margin:4px 0 28px}

.cart-page,.checkout-page{padding:24px 0 80px;background:#fff}
.cart-page .breadcrumb,.checkout-page .breadcrumb{margin:8px 0 8px}

.cart-empty{
  text-align:center;padding:80px 20px;color:var(--gray-600);
  background:var(--gray-50);border-radius:var(--radius);
}
.cart-empty svg{color:var(--gray-500);margin-bottom:18px}
.cart-empty h2{font-size:22px;font-weight:800;color:var(--black);margin-bottom:6px}
.cart-empty p{margin-bottom:22px}

/* Cart layout */
.cart-layout{display:grid;grid-template-columns:1fr 380px;gap:36px;align-items:flex-start}

/* Cart items list */
.cart-items{background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius)}
.cart-items-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 22px;border-bottom:1px solid var(--gray-100);
}
.cart-items-head h2{font-size:15px;font-weight:800;letter-spacing:.02em}
.cart-items-head h2 span{font-weight:500;color:var(--gray-500)}
.link-clear{
  background:transparent;color:var(--gray-600);
  font-size:11px;font-weight:700;letter-spacing:.1em;
  text-decoration:underline;padding:6px 0;
}
.link-clear:hover{color:var(--pink)}

.cart-row{
  display:grid;
  grid-template-columns:96px 1fr auto auto;
  gap:18px;align-items:center;
  padding:18px 22px;border-bottom:1px solid var(--gray-100);
}
.cart-row:last-child{border-bottom:0}
.cart-row-img{
  width:96px;height:96px;border-radius:8px;
  background:var(--gray-100) center/cover no-repeat;
}
.cart-row-info{min-width:0}
.cart-row-brand{
  display:block;color:var(--pink);font-size:11px;font-weight:800;letter-spacing:.12em;margin-bottom:3px;
}
.cart-row-info h3{font-size:14px;font-weight:700;margin:0 0 4px;line-height:1.3}
.cart-row-meta{font-size:12.5px;color:var(--gray-600);margin:0 0 8px}
.cart-row-meta strong{color:var(--black);font-weight:700}
.cart-row-remove{
  background:transparent;color:var(--gray-500);
  font-size:10.5px;font-weight:700;letter-spacing:.1em;
  text-decoration:underline;padding:2px 0;
}
.cart-row-remove:hover{color:var(--pink)}
.cart-row-qty .qty-stepper{height:38px}
.cart-row-qty .qty-stepper button{height:38px;padding:0 11px;font-size:16px}
.cart-row-qty .qty-stepper span{min-width:32px;font-size:13px}
.cart-row-price{text-align:right;min-width:90px}
.cart-row-price strong{display:block;font-size:15px;font-weight:800;color:var(--black)}
.cart-row-price small{display:block;font-size:11px;color:var(--gray-500);margin-top:2px}

/* Cart summary */
.cart-summary{
  background:var(--gray-50);border:1px solid var(--gray-100);
  border-radius:var(--radius);padding:24px;position:sticky;top:96px;
}
.cart-summary h2{font-size:15px;font-weight:800;letter-spacing:.02em;margin-bottom:18px}

.ship-progress{
  background:#fff;border:1px solid var(--gray-100);
  border-radius:8px;padding:12px 14px;margin-bottom:18px;
}
.ship-progress p{margin:0 0 8px;font-size:12.5px;color:var(--gray-600)}
.ship-progress strong{color:var(--black)}
.ship-progress.free p{color:#00b67a;font-weight:600}
.ship-bar{height:6px;background:var(--gray-100);border-radius:6px;overflow:hidden}
.ship-bar > div{height:100%;background:linear-gradient(90deg, var(--pink), #ff5e94);border-radius:6px;transition:width .3s ease}

.summary-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0;font-size:14px;color:var(--gray-600);
}
.summary-row.total{
  border-top:1px solid var(--gray-100);margin-top:8px;padding-top:14px;
  font-size:17px;font-weight:800;color:var(--black);
}
.summary-divider{height:1px;background:var(--gray-100);margin:14px 0}

.btn-link-back{
  display:block;text-align:center;margin-top:14px;
  font-size:13px;color:var(--gray-600);text-decoration:none;font-weight:600;
}
.btn-link-back:hover{color:var(--pink)}

.summary-trust{
  margin-top:22px;padding-top:18px;border-top:1px solid var(--gray-100);
  display:flex;flex-direction:column;gap:8px;
  font-size:12px;color:var(--gray-600);
}
.summary-trust div{display:flex;align-items:center;gap:8px}
.summary-trust svg{color:var(--pink);flex-shrink:0}

/* ============= Checkout ============= */
.checkout-layout{display:grid;grid-template-columns:1.4fr 1fr;gap:36px;align-items:flex-start}

.checkout-form{display:flex;flex-direction:column;gap:18px}
.form-section{
  background:#fff;border:1px solid var(--gray-100);
  border-radius:var(--radius);padding:24px 26px;
}
.form-section h2{
  display:flex;align-items:center;gap:12px;
  font-size:16px;font-weight:800;letter-spacing:-.01em;margin-bottom:18px;
}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;
  background:var(--black);color:#fff;
  font-size:13px;font-weight:800;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field:last-child{margin-bottom:0}
.field > span{font-size:12.5px;font-weight:600;color:var(--gray-600)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:14px;color:var(--black);
  padding:11px 13px;border:1.5px solid var(--gray-200);border-radius:8px;
  background:#fff;transition:border-color .15s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--black);
}
.field input:invalid:not(:placeholder-shown){border-color:#e74c3c}
.field textarea{resize:vertical;min-height:60px}

.payment-info{
  display:flex;gap:10px;align-items:flex-start;
  background:var(--gray-50);border:1px solid var(--gray-100);border-radius:8px;
  padding:12px 14px;font-size:12.5px;color:var(--gray-600);margin-bottom:14px;line-height:1.5;
}
.payment-info svg{flex-shrink:0;color:var(--pink);margin-top:1px}

.payment-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pay-option{
  display:flex;align-items:center;gap:12px;
  padding:13px 14px;border:1.5px solid var(--gray-200);border-radius:10px;
  cursor:pointer;transition:border-color .15s ease, background .15s ease;
}
.pay-option:hover{border-color:var(--black)}
.pay-option input{accent-color:var(--pink);width:18px;height:18px;flex-shrink:0}
.pay-option:has(input:checked){border-color:var(--black);background:var(--gray-50)}
.pay-option strong{display:block;font-size:13.5px;font-weight:700}
.pay-option span{font-size:11.5px;color:var(--gray-500)}

.terms-row{
  display:flex;gap:10px;align-items:flex-start;
  font-size:13px;color:var(--gray-600);margin-bottom:16px;
}
.terms-row input{accent-color:var(--pink);margin-top:2px;width:16px;height:16px;flex-shrink:0}
.terms-row a{color:var(--black);text-decoration:underline;font-weight:600}
.terms-row a:hover{color:var(--pink)}

.btn-whatsapp{background:#25D366;color:#fff}
.btn-whatsapp:hover{background:#1ebe5d}
.whatsapp-help{
  margin:12px 0 0;font-size:12px;color:var(--gray-500);text-align:center;line-height:1.5;
}

/* Checkout summary */
.checkout-summary{
  background:var(--gray-50);border:1px solid var(--gray-100);
  border-radius:var(--radius);padding:24px;position:sticky;top:96px;
}
.checkout-summary h2{font-size:15px;font-weight:800;letter-spacing:.02em;margin-bottom:18px}
.checkout-items{display:flex;flex-direction:column;gap:14px;max-height:340px;overflow-y:auto}
.checkout-item{display:flex;gap:12px;align-items:center}
.ci-img{
  position:relative;width:62px;height:62px;border-radius:8px;flex-shrink:0;
  background:#fff center/cover no-repeat;border:1px solid var(--gray-100);
}
.ci-qty{
  position:absolute;top:-6px;right:-6px;
  background:var(--black);color:#fff;
  width:20px;height:20px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;
}
.ci-info{flex:1;min-width:0}
.ci-brand{display:block;font-size:10px;font-weight:800;letter-spacing:.12em;color:var(--pink);margin-bottom:2px}
.ci-name{margin:0 0 2px;font-size:12.5px;font-weight:700;color:var(--black);line-height:1.3}
.ci-meta{margin:0;font-size:11.5px;color:var(--gray-500)}
.ci-price{font-size:13px;font-weight:700;text-align:right;flex-shrink:0}

/* Cart/checkout responsive */
@media (max-width:899px){
  .cart-layout,.checkout-layout{grid-template-columns:1fr}
  .cart-summary,.checkout-summary{position:static}
  .cart-row{grid-template-columns:80px 1fr;gap:14px;padding:16px}
  .cart-row-img{width:80px;height:80px}
  .cart-row-qty,.cart-row-price{grid-column:2;padding-top:6px}
  .cart-row-qty{justify-self:start}
  .cart-row-price{text-align:left}
  .payment-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .form-section{padding:20px}
}

/* ============================================================
   SIDE CART (slide-out)
   ============================================================ */
.side-cart-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;z-index:300;
}
.side-cart-overlay.open{opacity:1;pointer-events:auto}

.side-cart{
  position:fixed;top:0;right:0;bottom:0;
  width:420px;max-width:100vw;background:#fff;
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .3s ease;
  z-index:310;box-shadow:-12px 0 40px rgba(0,0,0,.18);
  overflow-x:hidden;
}
.side-cart.open{transform:translateX(0)}

.side-cart-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--gray-100);
  flex-shrink:0;
}
.side-cart-head h3{
  font-size:16px;font-weight:800;letter-spacing:.08em;
  display:flex;align-items:center;gap:10px;
}
.side-cart-count{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:22px;padding:0 7px;border-radius:11px;
  background:var(--pink);color:#fff;
  font-size:11px;font-weight:800;letter-spacing:0;
}
.side-cart-close{
  width:36px;height:36px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--gray-600);transition:background .15s ease;background:transparent;
}
.side-cart-close:hover{background:var(--gray-100);color:var(--black)}

.side-cart-body{
  flex:1;overflow-y:auto;padding:6px 24px;
}
.sc-item{
  display:grid;grid-template-columns:88px 1fr;gap:14px;
  padding:18px 0;border-bottom:1px solid var(--gray-100);
}
.sc-item:last-child{border-bottom:0}
.sc-item-img{
  width:88px;height:88px;border-radius:8px;
  background:var(--gray-100) center/cover no-repeat;
}
.sc-item-info{min-width:0;display:flex;flex-direction:column}
.sc-item-info h4{
  font-size:14px;font-weight:700;margin:0 0 4px;line-height:1.3;
}
.sc-item-meta{font-size:12.5px;color:var(--gray-600);margin:0 0 4px}
.sc-item-meta strong{color:var(--black)}
.sc-item-price{font-size:14px;font-weight:800;color:var(--black);margin:0 0 8px}
.sc-item-bottom{
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;margin-top:auto;
}
.qty-stepper.sm{height:32px}
.qty-stepper.sm button{height:32px;padding:0 9px;font-size:14px}
.qty-stepper.sm span{min-width:28px;font-size:12.5px}
.sc-item-remove{
  width:32px;height:32px;border-radius:8px;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--gray-500);background:transparent;
  border:1px solid var(--gray-200);transition:all .15s ease;
}
.sc-item-remove:hover{color:var(--pink);border-color:var(--pink)}

.side-cart-foot{
  flex-shrink:0;padding:18px 24px 22px;
  border-top:1px solid var(--gray-100);background:#fff;
  box-shadow:0 -8px 20px rgba(0,0,0,.04);
}

.side-cart-trust{
  display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;
  margin-bottom:14px;padding-bottom:14px;
  border-bottom:1px solid var(--gray-100);
}
.side-cart-trust div{
  display:flex;align-items:center;gap:8px;
  font-size:12px;color:var(--gray-600);font-weight:500;
}
.side-cart-trust svg{color:#00b67a;flex-shrink:0}

.side-cart-ship-info{
  display:flex;gap:10px;align-items:flex-start;
  background:var(--gray-50);border-radius:8px;
  padding:11px 13px;font-size:12px;color:var(--gray-600);
  line-height:1.5;margin-bottom:12px;
}
.side-cart-ship-info svg{color:var(--blue);flex-shrink:0;margin-top:1px}

.side-cart-progress{margin-bottom:14px}
.scp-text{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  font-size:12.5px;color:var(--gray-600);margin-bottom:6px;
}
.scp-text strong{color:#00b67a;font-weight:800}
.scp-text svg{color:var(--gray-500);flex-shrink:0}
.scp-bar{height:6px;background:var(--gray-100);border-radius:6px;overflow:hidden}
.scp-bar > div{
  height:100%;width:0;
  background:linear-gradient(90deg, #00b67a, #25D366);
  border-radius:6px;transition:width .4s ease;
}

.side-cart-totals{
  background:var(--gray-50);border-radius:8px;
  padding:12px 14px;margin-bottom:14px;
}
.sct-row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;color:var(--gray-600);padding:3px 0;
}
.sct-row.total{
  margin-top:6px;padding-top:9px;border-top:1px solid var(--gray-100);
  font-size:16px;font-weight:800;color:var(--black);
}

.side-cart-buttons{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.side-cart-buttons .btn-outline-dark,
.side-cart-buttons .btn{
  padding:13px 12px;font-size:13px;text-align:center;
  text-decoration:none;display:inline-flex;align-items:center;justify-content:center;
}
.side-cart-buttons .btn-outline-dark{width:auto;height:auto}

.side-cart-empty{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:40px 28px;color:var(--gray-600);
}
/* Force [hidden] to win over display:flex */
.side-cart-empty[hidden],
.side-cart-foot[hidden]{display:none !important}
.side-cart-empty svg{color:var(--gray-400);margin-bottom:16px}
.side-cart-empty h4{font-size:18px;font-weight:800;color:var(--black);margin:0 0 6px}
.side-cart-empty p{margin:0 0 22px;font-size:13.5px}

@media (max-width:480px){
  .side-cart-buttons{grid-template-columns:1fr}
  .side-cart-trust{grid-template-columns:1fr 1fr;gap:6px 12px}
  .side-cart-trust div{font-size:11.5px}
}

/* ============================================================
   MOBILE OPTIMIZATIONS (≤900px)
   ============================================================ */

/* Default: hide mobile-only elements */
.m-toolbar,.m-filter-overlay,.m-sheet-head,.m-sheet-foot{display:none}

@media (max-width:899px){
  /* ---- General ---- */
  .container{padding:0 12px}
  .section{padding:48px 0}
  body{font-size:14px}

  /* ---- Header ---- */
  .header-inner{padding:10px 12px;height:56px;overflow:visible;gap:10px}
  .logo{flex:0 1 auto;min-width:0}
  .logo img{height:auto;max-height:26px;max-width:150px;width:auto;object-fit:contain}
  .icon-btn{width:38px;height:38px;min-width:38px}
  .header-icons{gap:6px;flex-shrink:0;flex-wrap:nowrap}

  /* ---- Hero ---- */
  .hero{min-height:560px}
  .hero-content{padding:40px 0 32px}
  .hero-content h1{font-size:48px;line-height:.95;margin-bottom:12px}
  .hero-content p{font-size:14px;margin:0 0 20px;max-width:320px}
  .hero-ctas{flex-direction:column;gap:10px;width:100%;max-width:260px}
  .hero-ctas .btn{width:100%;justify-content:center;padding:13px 20px}

  /* ---- Page hero / collection hero ---- */
  .collection-hero{padding:50px 0 40px}
  .brand-strip{gap:18px;margin-bottom:20px}
  .brand-strip span{font-size:10.5px;letter-spacing:.12em}
  .collection-hero-title{font-size:30px}
  .collection-hero-sub{font-size:13px;padding:0 16px}

  /* ---- Mobile sticky toolbar ---- */
  .m-toolbar{
    display:flex;align-items:center;
    position:sticky;top:0;z-index:50;
    background:#fff;border-bottom:1px solid var(--gray-100);
    padding:10px 16px;gap:10px;
    box-shadow:0 2px 8px rgba(0,0,0,.04);
    overflow:hidden;
  }
  .m-toolbar-btn{
    flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
    padding:11px 14px;border:1.5px solid var(--gray-200);border-radius:8px;
    background:#fff;font-size:13px;font-weight:700;letter-spacing:.02em;
  }
  .m-toolbar-btn:active{background:var(--gray-50)}
  .m-active-count{
    display:inline-flex;align-items:center;justify-content:center;
    min-width:20px;height:20px;padding:0 6px;border-radius:10px;
    background:var(--pink);color:#fff;font-size:11px;font-weight:800;
  }
  .m-toolbar-divider{width:1px;height:24px;background:var(--gray-200)}
  .m-toolbar-sort{
    flex:1;padding:11px 32px 11px 14px;
    border:1.5px solid var(--gray-200);border-radius:8px;
    font-family:inherit;font-size:13px;font-weight:600;
    background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1L6 6L11 1' stroke='%23000' stroke-width='1.5' stroke-linecap='round'/></svg>") right 12px center no-repeat;
    appearance:none;-webkit-appearance:none;
  }

  /* ---- Filter bar as bottom sheet ---- */
  .m-filter-overlay{
    display:block;position:fixed;inset:0;
    background:rgba(0,0,0,.5);opacity:0;pointer-events:none;
    transition:opacity .25s ease;z-index:90;
  }
  .m-filter-overlay.open{opacity:1;pointer-events:auto}

  .filter-bar-wrap{
    position:fixed;left:0;right:0;bottom:0;top:auto;
    transform:translateY(100%);transition:transform .3s ease;
    background:#fff;z-index:100;border-radius:18px 18px 0 0;
    max-height:85vh;display:flex;flex-direction:column;
    box-shadow:0 -10px 40px rgba(0,0,0,.2);padding:0;
    overflow-x:hidden;overflow-y:auto;
  }
  .filter-bar-wrap.m-open{transform:translateY(0)}
  .filter-bar-wrap > .container{
    padding:0;display:flex;flex-direction:column;flex:1;overflow:hidden;max-width:none;
  }

  .m-sheet-head{
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 22px;border-bottom:1px solid var(--gray-100);flex-shrink:0;
  }
  .m-sheet-head h3{font-size:16px;font-weight:800;letter-spacing:-.01em}
  .m-sheet-close{
    width:36px;height:36px;border-radius:50%;background:transparent;
    display:inline-flex;align-items:center;justify-content:center;color:var(--gray-600);
  }
  .m-sheet-close:active{background:var(--gray-100)}

  .filter-bar{
    grid-template-columns:1fr;gap:0;padding:0 22px;
    overflow-y:auto;flex:1;
  }
  .filter-bar-col{
    padding:18px 0;border-bottom:1px solid var(--gray-100);
  }
  .filter-bar-col:last-child{border-bottom:0}
  .filter-bar-col h4{font-size:11px;margin-bottom:12px;color:var(--gray-600)}
  .filter-options{
    max-height:none;flex-direction:row;flex-wrap:wrap;
    display:grid;grid-template-columns:1fr 1fr;gap:10px 16px;
  }
  .filter-options label{padding:6px 0;font-size:14px;color:var(--black)}
  .filter-options input{width:18px;height:18px}
  .check-row{padding:8px 0;font-size:14px;color:var(--black)}
  .check-row input{width:18px;height:18px}
  .filter-extras{margin-top:8px;flex-direction:column;gap:0}
  .sort-select-lg{display:none}
  .btn-link-reset{display:none}

  .m-sheet-foot{
    display:grid;grid-template-columns:1fr 2fr;gap:10px;
    padding:14px 22px 18px;border-top:1px solid var(--gray-100);
    flex-shrink:0;background:#fff;
  }
  .m-sheet-foot .btn,.m-sheet-foot .btn-outline-dark{
    padding:14px;font-size:13px;font-weight:800;letter-spacing:.06em;
    display:flex;align-items:center;justify-content:center;
  }
  .m-sheet-foot .btn-outline-dark{width:auto}

  /* Hide desktop "Sorteren op" column when mobile sheet — its content moved to m-toolbar */
  .filter-bar-col:nth-child(3){display:none}

  /* ---- Results bar ---- */
  .results-bar{padding:12px 0}
  .results-count{font-size:12.5px}

  /* ---- Product grid (mobile) ---- */
  .collection-main{padding:16px 0 60px}
  .wide-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .card-cta{border-radius:10px}
  .card-cta .card-link{padding:8px 8px 6px}
  .card-cta .card-img{margin-bottom:8px;border-radius:6px}
  .card-cta .card-brand{font-size:9.5px;letter-spacing:.1em;margin-bottom:2px}
  .card-cta .card-name{font-size:12.5px;margin-bottom:4px;line-height:1.3}
  .card-price{font-size:13px}
  .card-old-price{font-size:11px}
  .card-btn{padding:10px;font-size:11px;letter-spacing:.08em}
  .badge{font-size:9px;padding:4px 8px;top:8px;left:8px;right:auto;width:max-content}
  .badge-sale{top:8px;right:8px;left:auto;bottom:auto;font-size:10px;padding:4px 9px;width:max-content}

  /* ---- Product detail page ---- */
  .product-page{padding:14px 0 40px}
  .product-info h1{font-size:22px}
  .product-price{font-size:24px}
  /* Reset gallery sale badge so the generic .badge-sale mobile rule
     (top/right) doesn't stretch it to fill the image into a giant circle. */
  .gallery-badge{top:12px;left:12px;right:auto;bottom:auto;width:max-content}
  .gallery-badge-2{top:auto;right:auto;bottom:12px;left:12px;width:max-content;font-size:12px;padding:5px 10px}
  .gallery-thumbs{padding:0 2px;scroll-snap-type:x mandatory}
  .gallery-thumbs::-webkit-scrollbar{display:none}
  .gallery-thumbs{scrollbar-width:none}
  .size-options button{min-width:46px;padding:10px 12px;font-size:12.5px}
  .qty-stepper button{padding:0 12px;height:44px}
  .btn-cart{height:44px;font-size:13px}

  /* ---- Cart page ---- */
  .cart-page{padding:14px 0 40px}
  .cart-items-head{padding:14px 16px}
  .cart-row{padding:14px 14px}
  .cart-row-info h3{font-size:13px}
  .cart-row-meta{font-size:12px;margin-bottom:6px}
  .cart-row-remove{font-size:10px}
  .cart-row-price strong{font-size:14px}
  .cart-summary{padding:18px}

  /* ---- Checkout ---- */
  .checkout-page{padding:14px 0 40px}
  .form-section{padding:18px 16px;border-radius:10px}
  .form-section h2{font-size:15px;margin-bottom:14px}
  .step-num{width:24px;height:24px;font-size:12px}
  .field input,.field select,.field textarea{font-size:16px;padding:12px 14px}
  /* 16px input font prevents iOS auto-zoom */
  .pay-option{padding:14px}
  .pay-option strong{font-size:13.5px}
  .checkout-summary{padding:18px}
  .checkout-items{max-height:none}

  /* ---- Side cart (mobile) ---- */
  .side-cart{width:100%;max-width:100%}
  .side-cart-head{padding:16px 18px}
  .side-cart-body{padding:6px 18px}
  .side-cart-foot{padding:16px 18px 18px}
  .sc-item-img{width:74px;height:74px}
  .sc-item{grid-template-columns:74px 1fr;gap:12px;padding:14px 0}
  .sc-item-info h4{font-size:13px}

  /* ---- FAQ ---- */
  .faq-item summary{padding:18px 16px;font-size:14px}
  .faq-answer{padding:0 16px 18px}

  /* ---- Reviews ---- */
  .reviews{padding:48px 0}
  .reviews-header-left h2{font-size:24px}
  .review{padding:18px}

  /* ---- Contact ---- */
  .contact{padding:48px 0}
  .contact-grid{grid-template-columns:1fr;gap:28px;padding:32px 22px}
  .contact-intro h2{font-size:28px}
  .contact-intro p{font-size:13.5px;margin-bottom:20px}
  .btn-whatsapp{width:100%;justify-content:center}
  .contact-cards{grid-template-columns:1fr;gap:12px}
  .contact-card{padding:12px 14px;gap:12px}
  .contact-card-icon{width:38px;height:38px;border-radius:10px}
  .contact-card-icon svg{width:18px;height:18px}
  .contact-card strong{font-size:13px}
  .contact-card span{font-size:12px}

  /* ---- Brands ---- */
  .brands{padding:36px 0}
  .brand-logo{height:40px;padding:0 28px}
  .brand-logo svg{width:100px;height:44px}
  .brands-track{animation-duration:22s}

  /* ---- Footer ---- */
  .footer{padding:40px 0 24px}
  .footer h5{font-size:11px}

  /* ---- Center all text on mobile — HOMEPAGE ONLY ---- */
  body[data-page="home"]{text-align:center}
  body[data-page="home"] .hero-content{align-items:center}
  body[data-page="home"] .hero-content p,
  body[data-page="home"] .hero-ctas,
  body[data-page="home"] .contact-intro p{margin-left:auto;margin-right:auto}
  body[data-page="home"] .hero-ctas,
  body[data-page="home"] .newsletter-inner,
  body[data-page="home"] .newsletter-text,
  body[data-page="home"] .newsletter-form{justify-content:center}
  body[data-page="home"] .usp{justify-content:center;text-align:left}
  body[data-page="home"] .contact-intro{align-items:center}
}

/* Extra small phones (≤400px) */
@media (max-width:400px){
  .container{padding:0 12px}
  .hero-content h1{font-size:44px}
  .collection-hero-title{font-size:26px}
  .wide-grid{gap:8px}
  .card-btn{padding:9px;font-size:10.5px}
}

/* Touch optimizations — bigger tap targets globally */
@media (hover:none){
  button,a.btn,.icon-btn,.qty-stepper button{min-height:42px}
  .card-cta:hover{transform:none;box-shadow:none}
  .card:hover .card-img{transform:none}
}
