/* ==========================================================================
   Milaa.nl — Components
   ========================================================================== */

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  padding: .9rem 1.6rem;
  font-size: var(--fs-sm); font-weight: 600; letter-spacing: var(--tracking);
  border-radius: var(--r-pill);
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease),
              transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--c-cta); color: #fff; box-shadow: var(--sh-1); }
.btn--primary:hover { background: var(--c-cta-hover); color: #fff; box-shadow: var(--sh-2); }
.btn--gold { background: var(--c-brand); color: #2a2014; }
.btn--gold:hover { background: var(--c-brand-deep); color: #fff; }
.btn--outline { border: 1.5px solid var(--c-ink); color: var(--c-ink); background: transparent; }
.btn--outline:hover { background: var(--c-ink); color: var(--c-bg); }
.btn--ghost { color: var(--c-ink); padding-inline: .4rem; }
.btn--ghost:hover { color: var(--c-brand-deep); }
.btn--block { width: 100%; }
.btn--lg { padding: 1.05rem 2rem; font-size: var(--fs-base); }

.link-underline { position: relative; font-weight: 600; font-size: var(--fs-sm); letter-spacing: var(--tracking); }
.link-underline::after { content:""; position:absolute; left:0; bottom:-3px; width:100%; height:1.5px; background: var(--c-brand); transform: scaleX(.4); transform-origin: left; transition: transform var(--dur) var(--ease); }
.link-underline:hover::after { transform: scaleX(1); }

/* ---- Badges (max 2 per product card — enforce in template logic) ---- */
.badge {
  display: inline-flex; align-items: center; gap: .35em;
  padding: .3rem .65rem; border-radius: var(--r-pill);
  font-size: .68rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  background: var(--c-surface); color: var(--c-ink); box-shadow: var(--sh-1);
}
.badge--gold { background: var(--c-brand); color: #2a2014; }
.badge--rose { background: var(--c-accent); color: #fff; }
.badge--trust { background: var(--c-trust); color: #fff; }
.badge--sale { background: var(--c-sale); color: #fff; }
.badge--soft { background: var(--c-brand-soft); color: var(--c-brand-deep); box-shadow: none; }

/* material / property pills on PDP */
.pill {
  display: inline-flex; align-items: center; gap: .4em;
  padding: .45rem .85rem; border-radius: var(--r-pill);
  font-size: var(--fs-xs); font-weight: 600; letter-spacing: .04em;
  background: var(--c-surface-alt); color: var(--c-ink-soft); border: 1px solid var(--c-line);
}
.pill .dot { width: .55em; height: .55em; border-radius: 50%; background: var(--c-brand); }

/* ---- Header / nav ---- */
.topbar {
  background: var(--c-trust); color: #fff;
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase;
  text-align: center; padding: .6rem 1rem;
}
.topbar strong { color: var(--c-brand); }

.header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(247,241,232,.86); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--c-line);
}
.header__row { display: flex; align-items: center; gap: var(--sp-5); padding-block: var(--sp-4); }
.brand { font-family: var(--font-display); font-size: 1.7rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.brand span { color: var(--c-brand-deep); }
.nav { display: flex; gap: var(--sp-5); margin-left: var(--sp-4); }
.nav a { font-size: var(--fs-sm); font-weight: 500; letter-spacing: var(--tracking); padding-block: .3rem; }
.nav a:hover { color: var(--c-brand-deep); }
.header__actions { margin-left: auto; display: flex; align-items: center; gap: var(--sp-4); }
.icon-btn { display: inline-flex; align-items: center; gap: .4rem; font-size: var(--fs-sm); }
.icon-btn .count { background: var(--c-cta); color:#fff; font-size: .65rem; font-weight:700; border-radius: var(--r-pill); padding: .05rem .4rem; }

/* ---- Hero ---- */
.hero { position: relative; overflow: hidden; }
.hero__inner { display: grid; grid-template-columns: 1.05fr 1fr; align-items: center; gap: var(--sp-7); padding-block: var(--sp-9); }
.hero__copy .eyebrow { margin-bottom: var(--sp-4); display: block; }
.hero h1 { font-size: var(--fs-hero); margin-bottom: var(--sp-4); }
.hero__copy p { max-width: 44ch; margin-bottom: var(--sp-6); font-size: var(--fs-lg); color: var(--c-muted); }
.hero__actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.hero__media { aspect-ratio: 4/5; border-radius: var(--r-xl); box-shadow: var(--sh-3); }
.hero__usps { display: flex; gap: var(--sp-5); margin-top: var(--sp-6); flex-wrap: wrap; }
.hero__usps li { font-size: var(--fs-sm); color: var(--c-ink-soft); display: flex; align-items: center; gap: .5rem; }
.hero__usps .tick { color: var(--c-brand-deep); font-weight: 700; }

/* ---- Trust strip ---- */
.trust-strip { border-block: 1px solid var(--c-line); }
.trust-strip ul { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--sp-4); padding-block: var(--sp-5); }
.trust-strip li { display: flex; align-items: center; gap: var(--sp-3); justify-content: center; text-align: left; }
.trust-strip .ic { width: 38px; height: 38px; border-radius: 50%; background: var(--c-brand-soft); color: var(--c-brand-deep); display: grid; place-items: center; font-size: 1.05rem; flex: none; }
.trust-strip .t { font-size: var(--fs-sm); font-weight: 600; }
.trust-strip .s { font-size: var(--fs-xs); color: var(--c-muted); }

/* ---- Shop by Moment ---- */
.moments { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); }
.moment { position: relative; aspect-ratio: 3/4; border-radius: var(--r-lg); overflow: hidden; display: flex; align-items: flex-end; box-shadow: var(--sh-1); }
.moment .ph { position: absolute; inset: 0; }
.moment__label { position: relative; z-index: 2; width: 100%; padding: var(--sp-4); background: linear-gradient(to top, rgba(42,36,32,.55), transparent); color: #fff; }
.moment__label .m { font-family: var(--font-display); font-size: 1.25rem; }
.moment__label .a { font-size: var(--fs-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; opacity: .9; }
.moment:hover .ph { transform: scale(1.05); transition: transform var(--dur) var(--ease); }

/* ---- Product grid / card ---- */
.product-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-5); }
.card { background: var(--c-surface); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-1); transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease); }
.card:hover { box-shadow: var(--sh-3); transform: translateY(-4px); }
.card__media { position: relative; aspect-ratio: 1/1; }
.card__media .ph { position: absolute; inset: 0; }
.card__badges { position: absolute; top: var(--sp-3); left: var(--sp-3); display: flex; gap: .4rem; z-index: 2; }
.card__wish { position: absolute; top: var(--sp-3); right: var(--sp-3); z-index: 2; width: 34px; height: 34px; border-radius: 50%; background: rgba(255,255,255,.9); display: grid; place-items: center; box-shadow: var(--sh-1); }
.card__body { padding: var(--sp-4); }
.card__meta { font-size: var(--fs-xs); color: var(--c-muted); letter-spacing: var(--tracking-wide); text-transform: uppercase; }
.card__title { font-family: var(--font-display); font-size: 1.2rem; margin: .25rem 0 .4rem; }
.card__rating { font-size: var(--fs-xs); color: var(--c-muted); display: flex; align-items: center; gap: .35rem; margin-bottom: .5rem; }
.stars { color: var(--c-star); letter-spacing: .05em; }
.card__price { display: flex; align-items: baseline; gap: .5rem; }
.price { font-weight: 700; font-size: var(--fs-lg); }
.price--old { color: var(--c-muted); font-weight: 500; font-size: var(--fs-sm); text-decoration: line-through; }
.card__foot { margin-top: var(--sp-4); }

/* ---- Category layout + filters ---- */
.cat-head { padding-block: var(--sp-7) var(--sp-5); }
.breadcrumb { font-size: var(--fs-xs); color: var(--c-muted); letter-spacing: var(--tracking); margin-bottom: var(--sp-4); }
.breadcrumb a:hover { color: var(--c-brand-deep); }
.cat-head h1 { margin-bottom: var(--sp-3); }
.cat-intro { max-width: 70ch; color: var(--c-muted); }

.cat-layout { display: grid; grid-template-columns: 250px 1fr; gap: var(--sp-6); align-items: start; }
.filters { position: sticky; top: 90px; }
.filter-group { border-bottom: 1px solid var(--c-line); padding-block: var(--sp-4); }
.filter-group > summary { display: flex; justify-content: space-between; align-items: center; cursor: pointer; font-weight: 600; font-size: var(--fs-sm); list-style: none; }
.filter-group > summary::-webkit-details-marker { display: none; }
.filter-group > summary::after { content: "+"; color: var(--c-brand-deep); font-size: 1.1rem; }
.filter-group[open] > summary::after { content: "–"; }
.filter-opt { display: flex; align-items: center; gap: var(--sp-3); padding-top: var(--sp-3); font-size: var(--fs-sm); color: var(--c-ink-soft); cursor: pointer; }
.filter-opt input { accent-color: var(--c-cta); width: 16px; height: 16px; }
.filter-opt .n { margin-left: auto; color: var(--c-muted); font-size: var(--fs-xs); }
.swatch { width: 16px; height: 16px; border-radius: 50%; border: 1px solid var(--c-line); }

.cat-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-5); }
.cat-toolbar .count { font-size: var(--fs-sm); color: var(--c-muted); }
.sort select { border: 1px solid var(--c-line); background: var(--c-surface); border-radius: var(--r-pill); padding: .55rem 1rem; font-size: var(--fs-sm); }
.chips { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: var(--sp-5); }
.chip { display: inline-flex; align-items: center; gap: .45rem; padding: .4rem .8rem; border-radius: var(--r-pill); background: var(--c-brand-soft); color: var(--c-brand-deep); font-size: var(--fs-xs); font-weight: 600; }
.chip button { color: var(--c-brand-deep); font-weight: 700; }

.filter-toggle { display: none; }

/* ---- PDP ---- */
.pdp { display: grid; grid-template-columns: 1.1fr 1fr; gap: var(--sp-7); padding-block: var(--sp-6); align-items: start; }
.gallery { display: grid; grid-template-columns: 72px 1fr; gap: var(--sp-3); }
.gallery__thumbs { display: flex; flex-direction: column; gap: var(--sp-3); }
.gallery__thumb { aspect-ratio: 1; border-radius: var(--r-md); overflow: hidden; border: 1.5px solid transparent; cursor: pointer; }
.gallery__thumb.is-active { border-color: var(--c-brand); }
.gallery__thumb .ph { position: absolute; inset: 0; }
.gallery__thumb { position: relative; }
.gallery__main { position: relative; aspect-ratio: 4/5; border-radius: var(--r-lg); overflow: hidden; }
.gallery__main .ph { position: absolute; inset: 0; }
.gallery__badges { position: absolute; top: var(--sp-4); left: var(--sp-4); display: flex; gap: .5rem; z-index: 2; }

.pdp__info .meta { font-size: var(--fs-xs); color: var(--c-muted); letter-spacing: var(--tracking-wide); text-transform: uppercase; }
.pdp__info h1 { font-size: var(--fs-h1); margin: var(--sp-2) 0 var(--sp-3); }
.pdp__rating { display: flex; align-items: center; gap: .5rem; font-size: var(--fs-sm); color: var(--c-muted); margin-bottom: var(--sp-4); }
.pdp__price { display: flex; align-items: baseline; gap: .6rem; margin-bottom: var(--sp-4); }
.pdp__price .price { font-size: 1.7rem; }
.pdp__pills { display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: var(--sp-5); }
.pdp__desc { color: var(--c-ink-soft); margin-bottom: var(--sp-5); }
.usp-list { margin-bottom: var(--sp-5); }
.usp-list li { display: flex; gap: var(--sp-3); padding-block: .4rem; font-size: var(--fs-sm); color: var(--c-ink-soft); }
.usp-list .tick { color: var(--c-brand-deep); font-weight: 700; flex: none; }

.gift-toggle { display: flex; align-items: center; gap: var(--sp-3); background: var(--c-accent-soft); border: 1px solid var(--c-accent); border-radius: var(--r-md); padding: var(--sp-4); margin-bottom: var(--sp-5); }
.gift-toggle .g-ic { font-size: 1.3rem; }
.gift-toggle .g-text { font-size: var(--fs-sm); }
.gift-toggle .g-text strong { display: block; }
.gift-toggle .switch { margin-left: auto; }
.switch { position: relative; width: 46px; height: 26px; flex: none; }
.switch input { opacity: 0; width: 0; height: 0; }
.switch .track { position: absolute; inset: 0; background: var(--c-line); border-radius: var(--r-pill); transition: background var(--dur-fast); }
.switch .track::before { content:""; position:absolute; top:3px; left:3px; width:20px; height:20px; background:#fff; border-radius:50%; transition: transform var(--dur-fast); box-shadow: var(--sh-1); }
.switch input:checked + .track { background: var(--c-cta); }
.switch input:checked + .track::before { transform: translateX(20px); }

.buy-row { display: flex; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.qty { display: flex; align-items: center; border: 1.5px solid var(--c-line); border-radius: var(--r-pill); overflow: hidden; }
.qty button { width: 42px; height: 100%; font-size: 1.1rem; color: var(--c-ink-soft); }
.qty input { width: 38px; text-align: center; border: none; background: none; }

.pay-row { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; padding-block: var(--sp-4); border-top: 1px solid var(--c-line); margin-top: var(--sp-2); }
.pay-row .lbl { font-size: var(--fs-xs); color: var(--c-muted); }
.pay-badge { font-size: .7rem; font-weight: 700; padding: .3rem .55rem; border-radius: var(--r-sm); border: 1px solid var(--c-line); background: var(--c-surface); }
.ship-note { font-size: var(--fs-sm); color: var(--c-success); display: flex; align-items: center; gap: .5rem; margin-bottom: var(--sp-3); }

/* ---- Tabs ---- */
.tabs { border-top: 1px solid var(--c-line); margin-top: var(--sp-6); }
.tablist { display: flex; gap: var(--sp-5); flex-wrap: wrap; border-bottom: 1px solid var(--c-line); }
.tablist button { padding: var(--sp-4) 0; font-weight: 600; font-size: var(--fs-sm); color: var(--c-muted); border-bottom: 2px solid transparent; margin-bottom: -1px; }
.tablist button.is-active { color: var(--c-ink); border-color: var(--c-brand); }
.tabpanel { padding-block: var(--sp-5); max-width: 70ch; color: var(--c-ink-soft); display: none; }
.tabpanel.is-active { display: block; }
.spec-table { width: 100%; border-collapse: collapse; }
.spec-table td { padding: .6rem 0; border-bottom: 1px solid var(--c-line-2); font-size: var(--fs-sm); }
.spec-table td:first-child { color: var(--c-muted); width: 40%; }

/* ---- Footer ---- */
.footer { background: var(--c-trust); color: #d8dbe2; padding-block: var(--sp-8) var(--sp-5); margin-top: var(--sp-9); }
.footer a { color: #d8dbe2; font-size: var(--fs-sm); }
.footer a:hover { color: var(--c-brand); }
.footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--sp-6); }
.footer h4 { color: #fff; font-size: var(--fs-sm); letter-spacing: var(--tracking-wide); text-transform: uppercase; margin-bottom: var(--sp-4); font-family: var(--font-body); }
.footer__brand .brand { color: #fff; }
.footer__brand p { color: #aab0bd; font-size: var(--fs-sm); margin-top: var(--sp-3); max-width: 32ch; }
.footer li { padding-block: .35rem; }
.footer__bottom { border-top: 1px solid rgba(255,255,255,.12); margin-top: var(--sp-6); padding-top: var(--sp-5); display: flex; justify-content: space-between; gap: var(--sp-4); flex-wrap: wrap; font-size: var(--fs-xs); color: #aab0bd; }
.footer__pay { display: flex; gap: .5rem; }

/* ---- Newsletter ---- */
.newsletter { text-align: center; }
.newsletter form { display: flex; gap: var(--sp-3); max-width: 480px; margin: var(--sp-5) auto 0; }
.newsletter input { flex: 1; border: 1px solid var(--c-line); background: var(--c-surface); border-radius: var(--r-pill); padding: .9rem 1.4rem; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 1024px) {
  .product-grid, .moments { grid-template-columns: repeat(3, 1fr); }
  .hero__inner { grid-template-columns: 1fr; }
  .hero__media { order: -1; aspect-ratio: 16/10; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .nav { display: none; }
  .pdp, .cat-layout { grid-template-columns: 1fr; }
  .gallery { grid-template-columns: 1fr; }
  .gallery__thumbs { flex-direction: row; order: 2; }
  .product-grid, .moments { grid-template-columns: repeat(2, 1fr); }
  .trust-strip ul { grid-template-columns: repeat(2,1fr); }
  .filters { position: static; display: none; }
  .filters.is-open { display: block; }
  .filter-toggle { display: inline-flex; }
  .footer__grid { grid-template-columns: 1fr; }
}
@media (max-width: 440px) {
  .product-grid, .moments { grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
}
