/** Shopify CDN: Minification failed

Line 23:68 Unexpected "{"
Line 23:69 Expected identifier but found "%"
Line 23:124 Unexpected "{"
Line 23:125 Expected identifier but found "%"

**/
/* CREST | Premium Dual — components */

/* announcement */
.announcement{background:var(--c-ink);color:var(--c-bg);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;height:var(--ann-h);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.announcement__track{display:flex;gap:3rem;animation:ann-rot calc(var(--rot, 12s)) steps(var(--count, 3)) infinite}
.announcement__item{white-space:nowrap}
@keyframes ann-rot{to{transform:translateX(calc(-100% / var(--count, 3)))}}

/* header */
.site-header{position:sticky;top:0;z-index:60;background:var(--c-bg);border-bottom:1px solid var(--c-line);transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease)}
.site-header.is-transparent{background:transparent;border-color:transparent;color:#FFFFFF}
.site-header.is-transparent .header__icon-btn{color:#FFFFFF}
.header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1.5rem;height:var(--hdr-h);padding-inline:var(--gutter)}
.header__nav{display:flex;gap:1.85rem;align-items:center}
.header__nav a{font-size:.8rem;font-weight:500;letter-spacing:.16em;{% if settings.uppercase_nav %}text-transform:uppercase;{% endif %};position:relative;padding-block:.5rem}
.header__nav a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.header__nav a:hover{opacity:1}
.header__nav a:hover::after{transform:scaleX(1)}
.header__nav .active{opacity:1}
.header__nav .active::after{transform:scaleX(1)}
.header__logo{display:flex;justify-content:center;align-items:center}
.header__logo--text{font-family:var(--f-head);font-size:1.55rem;letter-spacing:.3em;font-weight:600}
.header__right{display:flex;justify-content:flex-end;gap:.25rem;align-items:center}
.header__icon-btn{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .25s var(--ease)}
.header__icon-btn:hover{background:rgba(0,0,0,.05)}
.is-transparent .header__icon-btn:hover{background:rgba(255,255,255,.1)}
.header__icon-btn svg{width:20px;height:20px}
.cart-count{position:absolute;top:6px;right:6px;min-width:16px;height:16px;padding:0 4px;font-size:.62rem;background:var(--c-accent);color:#FFFFFF;border-radius:50%;display:flex;align-items:center;justify-content:center;letter-spacing:0;font-weight:600}
.mobile-menu-btn{display:none}
@media(max-width:960px){
  .header{grid-template-columns:auto 1fr auto}
  .header__nav{display:none}
  .mobile-menu-btn{display:flex}
}

/* side switch — tiny pill in header */
.side-switch{display:inline-flex;background:rgba(0,0,0,.06);border-radius:999px;padding:3px;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase}
.is-transparent .side-switch{background:rgba(255,255,255,.12)}
.side-switch a{padding:.4rem .85rem;border-radius:999px;transition:background .25s var(--ease),color .25s var(--ease)}
.side-switch a.is-active{background:var(--c-ink);color:var(--c-bg)}
.is-transparent .side-switch a.is-active{background:#FFFFFF;color:var(--c-ink)}

/* footer */
.site-footer{background:var(--c-ink);color:#FFFFFF;padding:var(--pad) 0 2rem}
.site-footer a{color:#FFFFFF}
.footer__grid{display:grid;grid-template-columns:repeat(var(--cols,4),minmax(0,1fr));gap:3rem}
.footer__brand{font-family:var(--f-head);font-size:1.6rem;letter-spacing:.3em;color:#FFFFFF}
.footer__col h4{font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:#FFFFFF;margin-bottom:1rem}
.footer__col ul{list-style:none;display:grid;gap:.6rem;font-size:.92rem}
.footer__socials{display:flex;gap:.75rem;margin-top:1rem}
.footer__socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .25s var(--ease)}
.footer__socials a:hover{background:rgba(255,255,255,.08);opacity:1}
.footer__bottom{margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem}
@media(max-width:960px){.footer__grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:560px){.footer__grid{grid-template-columns:1fr;gap:1.75rem}.footer__grid > *{max-width:none}.footer__grid p{max-width:none !important}}

/* splash landing — retail */
.splash{position:relative;height:100vh;min-height:640px;width:100%;color:#FFFFFF;overflow:hidden;isolation:isolate;background:#FFFFFF}
.splash__brand{position:absolute;top:28px;left:50%;transform:translateX(-50%);z-index:10;text-align:center;pointer-events:none}
.splash__brand .logo-text{font-family:var(--f-head);font-size:1.9rem;letter-spacing:.36em;font-weight:500;color:#FFFFFF;text-shadow:0 1px 20px rgba(0,0,0,.35)}
.splash__brand .eyebrow{color:rgba(255,255,255,.85);margin-top:.4rem;font-size:.7rem;letter-spacing:.32em;text-transform:uppercase}
.splash__tagline{position:absolute;bottom:38px;left:50%;transform:translateX(-50%);font-family:var(--f-head);font-size:.78rem;letter-spacing:.34em;text-transform:uppercase;color:rgba(255,255,255,.85);text-align:center;z-index:10;white-space:nowrap}
.splash__grid{position:absolute;inset:0;display:grid;grid-template-columns:1fr 1fr}
.splash__side{position:relative;overflow:hidden;display:flex;align-items:flex-end;justify-content:center;cursor:pointer;transition:flex-grow .8s var(--ease)}
.splash__media{position:absolute;inset:0;transition:transform 1.4s var(--ease),filter .6s var(--ease);transform:scale(1.04);filter:brightness(.95) saturate(1.05)}
.splash__media img,.splash__media video{width:100%;height:100%;object-fit:cover}
.splash__side::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 35%,rgba(0,0,0,.55) 100%);pointer-events:none;transition:opacity .5s var(--ease)}
.splash__content{position:relative;z-index:3;text-align:center;padding:0 1.5rem 4.5rem;transform:translateY(0);transition:transform .6s var(--ease)}
.splash__label{font-family:var(--f-head);font-size:clamp(2.4rem,5.5vw,4.6rem);font-weight:500;letter-spacing:.18em;line-height:1;color:#FFFFFF;text-transform:uppercase;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.splash__sub{margin-bottom:.85rem;font-size:.7rem;letter-spacing:.36em;text-transform:uppercase;color:rgba(255,255,255,.95);font-weight:500}
.splash__cta{display:inline-flex;align-items:center;gap:.55rem;margin-top:1.5rem;padding:.9rem 1.9rem;background:rgba(255,255,255,.12);-webkit-backdrop-filter:blur(14px) saturate(140%);backdrop-filter:blur(14px) saturate(140%);color:#FFFFFF;border:1px solid rgba(255,255,255,.45);border-radius:0;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600;opacity:1;transform:none;transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease),letter-spacing .3s var(--ease)}
.splash__cta:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.85);color:#FFFFFF;letter-spacing:.34em}
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){.splash__cta{background:rgba(0,0,0,.35)}}
.splash__side:hover .splash__media{transform:scale(1.08);filter:brightness(1) saturate(1.1)}
.splash__side:hover .splash__content{transform:translateY(-4px)}
.splash__side:hover::after{opacity:.85}
@media(hover:hover){
  .splash__grid:hover .splash__side:not(:hover) .splash__media{filter:brightness(.85) saturate(.95)}
}
.splash__divider{position:absolute;top:0;bottom:0;left:50%;width:1px;background:rgba(255,255,255,.5);z-index:4;pointer-events:none}
.splash__divider::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border:1px solid rgba(255,255,255,.85);border-radius:50%;background:rgba(255,255,255,.08);backdrop-filter:blur(8px)}
.splash__divider::after{content:attr(data-divider-label);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--f-head);font-size:.78rem;letter-spacing:.18em;color:#FFFFFF;font-weight:500}
@media(max-width:768px){
  .splash__grid{grid-template-columns:1fr;grid-template-rows:1fr 1fr}
  .splash__divider{top:50%;bottom:auto;left:0;right:0;width:100%;height:1px}
  .splash__label{font-size:clamp(2rem,9vw,3.4rem);letter-spacing:.16em}
  .splash__brand .logo-text{font-size:1.4rem}
  .splash__tagline{font-size:.68rem;letter-spacing:.28em}
  .splash__content{padding-bottom:3rem}
  .splash__cta{padding:.78rem 1.5rem;font-size:.66rem}
}

/* splash entry animation */
.splash__brand,.splash__tagline,.splash__side{animation:fade-up 1s var(--ease) both}
.splash__tagline{animation-delay:.4s}
.splash__side:first-child{animation-delay:.15s}
.splash__side:last-child{animation-delay:.3s}
@keyframes fade-up{from{opacity:0;transform:translateY(30px) translateX(var(--tx,0))}to{opacity:1}}
.splash__brand{--tx:-50%}.splash__tagline{--tx:-50%}

/* small link row under splash */
.splash__foot{position:absolute;bottom:14px;right:20px;z-index:12;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.85)}

/* hero (for-her / for-him landing) */
.hero{position:relative;height:min(92vh,900px);min-height:520px;width:100%;overflow:hidden;color:#FFFFFF;display:flex;align-items:flex-end}
.hero__media{position:absolute;inset:0}
.hero__media img,.hero__media video{width:100%;height:100%;object-fit:cover}
.hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(0,0,0,.5) 100%)}
.hero__inner{position:relative;padding:0 var(--gutter) 4rem;width:100%;max-width:var(--max);margin-inline:auto}
.hero__eyebrow{font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:1rem}
.hero__title{font-family:var(--f-head);font-size:clamp(2.4rem,6vw,5.2rem);line-height:1.02;letter-spacing:-.01em;max-width:18ch}
.hero__sub{margin-top:1rem;max-width:44ch;color:rgba(255,255,255,.9)}
.hero__cta{margin-top:2rem;display:flex;gap:.75rem;flex-wrap:wrap}
/* hero CTAs — colors set per-section via --hero-c1-* / --hero-c2-* vars on the section */
.hero .hero__cta .btn{--bg:var(--hero-c1-bg, var(--btn-bg));--fg:var(--hero-c1-fg, var(--btn-fg));--br:var(--hero-c1-br, var(--btn-br))}
.hero .hero__cta .btn:hover{--bg:var(--hero-c1-hbg, var(--btn-hover-bg));--fg:var(--hero-c1-hfg, var(--btn-hover-fg));--br:var(--hero-c1-hbr, var(--btn-hover-br))}
.hero .hero__cta .btn--ghost{--bg:var(--hero-c2-bg, var(--btn-alt-bg));--fg:var(--hero-c2-fg, var(--btn-alt-fg));--br:var(--hero-c2-br, var(--btn-alt-br))}
.hero .hero__cta .btn--ghost:hover{--bg:var(--hero-c2-hbg, var(--btn-alt-hover-bg));--fg:var(--hero-c2-hfg, var(--btn-alt-hover-fg));--br:var(--hero-c2-hbr, var(--btn-alt-hover-br))}

/* featured collections grid */
.fcol{
  --cols-d: 3; --cols-t: 2; --cols-m: 2;
  display:grid;gap:var(--gutter);
  grid-template-columns:repeat(var(--cols-d), minmax(0,1fr));
}
.fcol--2{--cols-d:2}
@media(max-width:960px){.fcol{grid-template-columns:repeat(var(--cols-t), minmax(0,1fr));gap:12px}.fcol--2{grid-template-columns:1fr}}
@media(max-width:560px){.fcol{grid-template-columns:repeat(var(--cols-m), minmax(0,1fr));gap:10px}}
.fcol__card{position:relative;display:block;overflow:hidden;border-radius:var(--radius);background:var(--c-line);aspect-ratio:4/5}
.fcol__card img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.fcol__card:hover img{transform:scale(1.06)}
.fcol__card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.6))}
.fcol__meta{position:absolute;inset:auto 0 0 0;padding:1.5rem;color:#FFFFFF;z-index:2}
.fcol__meta h3{font-size:clamp(1.4rem,2vw,2rem);margin-bottom:.35rem}
.fcol__meta span{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;opacity:.75}
.fcol__tall{grid-row:span 2;aspect-ratio:auto;min-height:100%}

/* editorial / split panels */
.editorial{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.editorial--rev{direction:rtl}
.editorial--rev > *{direction:ltr}
.editorial__media{aspect-ratio:4/5;overflow:hidden;background:var(--c-line)}
.editorial__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.editorial:hover .editorial__media img{transform:scale(1.04)}
.editorial__body{padding:clamp(2rem,6vw,5rem);display:flex;flex-direction:column;justify-content:center;background:var(--c-bg)}
.editorial__body h2{margin-bottom:1.2rem}
.editorial__body p{max-width:48ch;color:var(--c-muted);margin-bottom:1.5rem}
@media(max-width:768px){.editorial{grid-template-columns:1fr}}

/* product card */
.card{display:flex;flex-direction:column;gap:.75rem;position:relative}
.card__media{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius);background:var(--prod-fit-bg)}
.card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:var(--prod-fit);padding:var(--prod-fit-pad);transition:opacity .5s var(--ease)}
.card__media img + img{opacity:0;display:none}
/* Only re-enable the hover swap when the theme setting turns it on and renders a 2nd image */
.card__media img + img.is-hover{display:block}
.card.hover-swap:hover .card__media img:first-child{opacity:0}
.card.hover-swap:hover .card__media img + img{opacity:1}
.card__link{position:absolute;inset:0;z-index:1}
.card__badges{position:absolute;top:12px;left:12px;display:flex;flex-direction:column;gap:6px;z-index:2}
.card__qv{
  position:absolute;top:10px;left:10px;width:38px;height:38px;
  background:rgba(255,255,255,.94);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(-4px);
  transition:opacity .3s var(--ease),transform .3s var(--ease),background .25s var(--ease);
  z-index:4;color:var(--c-ink, #000000);box-shadow:0 2px 10px rgba(0,0,0,.08);
}
.card__qv svg{width:19px;height:19px}
.card__qv:hover{background:#FFFFFF;transform:translateY(-4px) scale(1.05)}
.card:hover .card__qv{opacity:1;transform:none}
/* shift badges down when QV is shown */
.card:hover .card__badges,
.card__qv + .card__badges{top:56px}

.card__wish{
  position:absolute;top:10px;right:10px;width:38px;height:38px;
  background:rgba(255,255,255,.94);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(-4px);
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  z-index:4;box-shadow:0 2px 10px rgba(0,0,0,.08);
}
.card:hover .card__wish{opacity:1;transform:none}

/* circular bag quick-add button — bottom-right, always visible */
.card__bag{
  position:absolute;right:10px;bottom:10px;width:42px;height:42px;
  background:#000000;color:#FFFFFF;border-radius:50%;border:0;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:5;
  box-shadow:0 4px 14px rgba(0,0,0,.18);
  transition:transform .25s var(--ease),background .25s var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.card__bag:hover{background:var(--c-accent, #000000);transform:translateY(-2px)}
.card__bag svg{display:block}

/* quick-add panel — overlay over the card image area */
.card__qa{
  position:absolute;top:0;left:0;right:0;
  aspect-ratio:4/5;
  z-index:7;
  border-radius:var(--radius);
  overflow:hidden;
  background:#FFFFFF;
  display:flex;flex-direction:column;
  opacity:0;transform:translateY(8px);
  transition:opacity .25s var(--ease),transform .25s var(--ease);
  pointer-events:none;
  box-shadow:0 0 0 1px rgba(0,0,0,.06);
}
.card__qa[hidden]{display:none}
.card.is-qa-open .card__qa{opacity:1;transform:none;pointer-events:auto}
.card.is-qa-open .card__link{pointer-events:none}
.card__qa-inner{flex:1;min-height:0;overflow-y:auto;padding:.85rem .85rem .55rem;display:flex;flex-direction:column;gap:.6rem;color:var(--c-ink, #000000)}
.card__qa-row{display:flex;flex-direction:column;gap:.35rem}
.card__qa-label{font-size:.7rem;letter-spacing:.02em;color:var(--c-ink, #000000);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card__qa-label span{color:var(--c-muted, #000000);font-weight:400}
.card__qa-pills{display:flex;flex-wrap:wrap;gap:5px;justify-content:flex-start}
.card__qa-pill{
  width:30px;height:30px;padding:0;border-radius:50%;
  border:1px solid var(--c-line, #000000);background:#FFFFFF;color:var(--c-ink, #000000);
  font-size:.66rem;cursor:pointer;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.card__qa-pill:hover{border-color:var(--c-ink, #000000)}
.card__qa-pill.is-active{background:var(--c-ink, #000000);color:#FFFFFF;border-color:var(--c-ink, #000000)}
.card__qa-pill{position:relative}
.card__qa-pill.is-soldout{color:var(--c-muted, #000000);cursor:not-allowed;background:#FFFFFF}
.card__qa-pill.is-soldout::after{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(to top right, transparent calc(50% - 1.2px), rgba(0,0,0,.65) calc(50% - .2px), rgba(0,0,0,.65) calc(50% + .2px), transparent calc(50% + 1.2px));pointer-events:none}
.card__qa-swatches{display:flex;flex-wrap:wrap;gap:5px;justify-content:flex-start}
.card__qa-swatch{
  width:30px;height:30px;padding:2px;border-radius:50%;
  border:1px solid var(--c-line, #000000);background:#FFFFFF;
  cursor:pointer;flex-shrink:0;overflow:hidden;
  display:inline-flex;align-items:center;justify-content:center;
  transition:border-color .2s var(--ease),outline .2s var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.card__qa-swatch img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.card__qa-swatch-dot{width:100%;height:100%;border-radius:50%;display:block}
.card__qa-swatch.is-active{border-color:var(--c-ink, #000000);outline:2px solid var(--c-ink, #000000);outline-offset:1px}
.card__qa-qty-row{align-items:center;flex-direction:row;justify-content:space-between;gap:.5rem}
.card__qa-qty{display:inline-flex;align-items:center;border:1px solid var(--c-line, #000000);border-radius:999px;overflow:hidden;flex-shrink:0}
.card__qa-qty-btn{width:26px;height:26px;border:0;background:#FFFFFF;color:var(--c-ink, #000000);cursor:pointer;font-size:.95rem;line-height:1;padding:0}
.card__qa-qty-btn:hover{background:#FFFFFF}
.card__qa-qty-input{width:30px;height:26px;border:0;text-align:center;font-size:.78rem;background:#FFFFFF;color:var(--c-ink, #000000);outline:none;padding:0}
.card__qa-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:.4rem .85rem .7rem;flex-shrink:0}
.card__qa-cancel,.card__qa-add{
  height:36px;border:0;cursor:pointer;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
  -webkit-tap-highlight-color:transparent;padding:0;
}
.card__qa-cancel{background:var(--btn-bg, #000000);color:var(--btn-fg, #FFFFFF);border:1px solid var(--btn-br, #000000);border-radius:6px}
.card__qa-cancel:hover{background:var(--btn-hover-bg, #000);color:var(--btn-hover-fg, #FFFFFF);border-color:var(--btn-hover-br, #000)}
.card__qa-add{background:var(--btn-alt-bg, #FFFFFF);color:var(--btn-alt-fg, #000000);border:1.5px solid var(--btn-alt-br, #000000);border-radius:6px}
.card__qa-add:hover{background:var(--btn-alt-hover-bg, #000000);color:var(--btn-alt-hover-fg, #FFFFFF);border-color:var(--btn-alt-hover-br, #000000)}
.card__qa-add[disabled]{opacity:.45;cursor:not-allowed;background:var(--btn-alt-bg, #FFFFFF);color:var(--btn-alt-fg, #000000)}

@media(max-width:560px){
  .card__bag{width:38px;height:38px;right:8px;bottom:8px}
  .card__qa-inner{padding:.75rem .7rem .5rem;gap:.55rem}
  .card__qa-pill{width:30px;height:30px;font-size:.66rem}
  .card__qa-swatch{width:32px;height:32px}
  .card__qa-actions{padding:.45rem .7rem .7rem}
  .card__qa-cancel,.card__qa-add{height:38px;font-size:.68rem;letter-spacing:.14em}
}

/* CIRCULAR size pills inside the card — leaves room for .card__bag on the right */
.card__sizes{
  position:absolute;left:10px;right:62px;bottom:10px;z-index:3;
  display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-start;
  background:rgba(255,255,255,.96);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  padding:6px 8px;border-radius:var(--radius);
  opacity:0;transform:translateY(8px);
  transition:opacity .35s var(--ease),transform .35s var(--ease);
  box-shadow:0 6px 20px rgba(0,0,0,.08);
}
.card:hover .card__sizes{opacity:1;transform:none}
.card__size{
  width:32px;height:32px;aspect-ratio:1;padding:0;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.7rem;line-height:1;
  border:1px solid var(--c-line);border-radius:50%;background:#FFFFFF;
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease),transform .2s var(--ease);
  cursor:pointer;flex-shrink:0;
  -webkit-tap-highlight-color:transparent;
}
.card__size:hover{background:var(--c-ink, #000000);color:#FFFFFF;border-color:var(--c-ink, #000000);transform:translateY(-1px)}
.card__size.is-soldout{
  position:relative;color:var(--c-muted);cursor:not-allowed;background:#FFFFFF;
}
.card__size.is-soldout::after{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(to top right, transparent calc(50% - 1.2px), rgba(0,0,0,.65) calc(50% - .2px), rgba(0,0,0,.65) calc(50% + .2px), transparent calc(50% + 1.2px));pointer-events:none}
.card__size.is-added{background:var(--c-ink, #000000);color:#FFFFFF;border-color:var(--c-ink, #000000)}

/* CIRCULAR color swatch row — below title, thumbnails of the variant image */
.card__colors{
  display:flex;flex-wrap:wrap;gap:6px;margin-top:.35rem;
}
.card__color{
  width:40px;height:40px;aspect-ratio:1;
  border-radius:50%;padding:2px;
  border:1px solid var(--c-line);
  background:var(--prod-fit-bg, #FFFFFF);
  cursor:pointer;overflow:hidden;position:relative;flex-shrink:0;
  transition:border-color .2s var(--ease),transform .2s var(--ease),box-shadow .2s var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.card__color img{
  width:100%;height:100%;object-fit:var(--prod-fit, contain);
  border-radius:50%;display:block;
}
.card__color--dot{padding:0;border:1px solid rgba(0,0,0,.12);background-clip:padding-box}
.card__color--dot::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:inset 0 0 0 2px rgba(255,255,255,.18)}
.card__color:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,.08);border-color:var(--c-muted)}
.card__color.is-active{
  border-color:var(--c-ink, #000000);
  outline:2px solid var(--c-ink, #000000);outline-offset:1px;
  transform:none;
}
.card__color[data-soldout]{opacity:.4}
.card__color[data-soldout]::before{
  content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(to top right, transparent calc(50% - 1px), rgba(0,0,0,.35) 50%, transparent calc(50% + 1px));
}
.card__color-count{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;aspect-ratio:1;
  font-size:.7rem;letter-spacing:.01em;color:var(--c-muted);
  border:1px solid var(--c-line);border-radius:50%;background:#FFFFFF;
  flex-shrink:0;
}

@media(max-width:560px){
  .card__color,.card__color-count{width:34px;height:34px}
  .card__color-count{font-size:.66rem}
}

/* on touch devices, quick elements always visible */
@media (hover:none){
  .card__qv, .card__wish{opacity:1;transform:none}
}

/* Mobile: sizes are JS-moved to the end of the card — style as a flat row
   that sits *below* the color swatches. */
@media (max-width:960px){
  .card__sizes[data-placement="mobile"]{
    opacity:1;transform:none;
    position:relative;left:auto;right:auto;bottom:auto;
    margin-top:.4rem;
    padding:0;
    background:transparent;
    box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;
    justify-content:flex-start;
    gap:5px;
  }
  .card__sizes[data-placement="mobile"] .card__size{
    background:var(--c-bg, #FFFFFF);
    border-color:var(--c-line, #000000);
    width:34px;height:34px;font-size:.68rem;
  }
}

@media(max-width:560px){
  .card__qv,.card__wish{width:34px;height:34px}
  .card__qv svg,.card__wish svg{width:16px;height:16px}
  .card__size{font-size:.68rem;padding:.4rem .5rem;min-width:32px}
  .card__color{width:28px;height:28px}
}

/* ================= QUICK VIEW MODAL ================= */
.qv{
  position:fixed;inset:0;z-index:210;
  display:flex;align-items:flex-end;justify-content:center;
  background:rgba(0,0,0,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;transition:opacity .35s var(--ease);
}
.qv.is-open{opacity:1;pointer-events:auto}
.qv__card{
  background:#FFFFFF !important;
  color:var(--c-ink, #000000);
  width:100%;max-width:880px;max-height:92vh;overflow:auto;
  border-radius:var(--radius) var(--radius) 0 0;
  box-shadow:0 -20px 60px rgba(0,0,0,.3);
  transform:translateY(24px);transition:transform .4s var(--ease);
  position:relative;
  padding-bottom:env(safe-area-inset-bottom, 0);
}
.qv.is-open .qv__card{transform:none}
.qv__close{position:absolute;top:14px;right:14px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#FFFFFF;z-index:2;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.qv__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;padding:1.5rem}
.qv__media{background:var(--prod-fit-bg);border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5}
.qv__media img{width:100%;height:100%;object-fit:var(--prod-fit);display:block;padding:var(--prod-fit-pad)}
.qv__info{display:flex;flex-direction:column;gap:1rem}
.qv__vendor{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-muted)}
.qv__title{font-family:var(--f-head);font-size:clamp(1.4rem,2.2vw,1.8rem);line-height:1.1}
.qv__price{display:flex;gap:.6rem;align-items:baseline;font-size:1.1rem}
.qv__price .sale{color:var(--c-sale-price, var(--c-her));font-weight:600}
.qv__price del{color:var(--c-muted);font-size:.9rem}
.qv__opts > *{margin-top:1rem}
.qv__detail-link{margin-top:.5rem;display:inline-block;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;border-bottom:1px solid currentColor;padding-bottom:2px}

@media(max-width:720px){
  .qv{align-items:flex-end}
  .qv__grid{grid-template-columns:1fr;padding:1rem}
  .qv__card{border-radius:var(--radius) var(--radius) 0 0;max-height:94vh}
  .qv__media{aspect-ratio:1/1}
  .qv__title{font-size:1.25rem}
}
.card__title{font-family:var(--f-head);font-size:1.05rem;font-weight:500;letter-spacing:-.005em}
.card__vendor{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted)}
.card__price{font-size:.96rem;display:flex;gap:.5rem;align-items:baseline}
.card__price del{color:var(--c-muted);font-size:.82rem}
.card__price .sale{color:var(--c-sale-price, var(--c-her));font-weight:600}
.card__swatches{display:flex;gap:.3rem;margin-top:.15rem}
.card__swatches span{width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.08)}

.products-grid{
  --cols-d: 4; --cols-t: 3; --cols-m: 2;
  display:grid;
  grid-template-columns:repeat(var(--cols-d), minmax(0,1fr));
  gap:28px 20px;
}
@media(max-width:960px){.products-grid{grid-template-columns:repeat(var(--cols-t), minmax(0,1fr))}}
@media(max-width:700px){.products-grid{grid-template-columns:repeat(var(--cols-m), minmax(0,1fr));gap:22px 14px}}

/* bestsellers carousel */
.row-scroll{display:grid;grid-auto-flow:column;grid-auto-columns:calc((100% - 3*20px)/4);gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:1rem;scrollbar-width:thin}
.row-scroll > *{scroll-snap-align:start}
@media(max-width:960px){.row-scroll{grid-auto-columns:70%}}
@media(max-width:560px){.row-scroll{grid-auto-columns:78%}}

/* collection page */
.collection-header{padding:calc(var(--pad) * .7) 0 calc(var(--pad) * .35);text-align:center}
.collection-header h1{font-size:clamp(2.2rem,5vw,3.6rem)}
.collection-header p{max-width:58ch;margin:1rem auto 0;color:var(--c-muted)}
.collection-toolbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-block:1px solid var(--c-line);position:sticky;top:var(--hdr-h);background:var(--c-bg);z-index:40;gap:1rem;flex-wrap:wrap}
.collection-toolbar .count{color:var(--c-muted);font-size:.88rem}
.toolbar__btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem .9rem;border:1px solid var(--btn-alt-br, var(--c-line));border-radius:999px;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;background:var(--btn-alt-bg, transparent);color:var(--btn-alt-fg, var(--c-ink));transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease)}
.toolbar__btn:hover{background:var(--btn-alt-hover-bg, transparent);color:var(--btn-alt-hover-fg, var(--c-ink));border-color:var(--btn-alt-hover-br, var(--c-ink))}
.toolbar__btn svg{width:14px;height:14px}
.collection-grid{padding:2rem 0 var(--pad)}

/* drawer — always solid (explicit hex, forced opaque) */
.drawer{
  position:fixed;top:0;right:0;height:100dvh;width:min(480px,92vw);
  background:#FFFFFF !important;
  color:var(--c-ink, #000000);
  z-index:100;box-shadow:-24px 0 60px rgba(0,0,0,.22);
  transform:translateX(102%);transition:transform .5s var(--ease);
  display:flex;flex-direction:column;
  will-change:transform;
  isolation:isolate;
}
.drawer.is-open{transform:translateX(0)}
.drawer__overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  z-index:99;opacity:0;pointer-events:none;transition:opacity .4s var(--ease);
}
.drawer__overlay.is-open{opacity:1;pointer-events:auto}
.drawer__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.2rem 1.5rem;
  border-bottom:1px solid var(--c-line, #000000);
  background:#FFFFFF !important;
  position:relative;z-index:2;
}
.drawer__head h2{font-size:1.05rem;letter-spacing:.18em;text-transform:uppercase;font-family:var(--f-head);font-weight:500;color:var(--c-ink, #000000)}
.drawer__head .header__icon-btn{color:var(--c-ink, #000000) !important;background:transparent}
.drawer__head .header__icon-btn:hover{background:rgba(0,0,0,.06)}
.drawer__body{
  overflow-y:auto;flex:1;
  padding:1rem 1.5rem;
  background:#FFFFFF !important;
  color:var(--c-ink, #000000);
}
.drawer__foot{
  padding:1.2rem 1.5rem calc(1.2rem + env(safe-area-inset-bottom, 0));
  border-top:1px solid var(--c-line, #000000);
  background:#FFFFFF !important;
  position:sticky;bottom:0;z-index:2;
}
.drawer__foot .btn{width:100%}
.drawer__foot .btn--brand{font-size:.92rem;letter-spacing:.18em;padding:1.15rem 1.2rem}

/* Free-shipping strip inside drawer — explicit solid */
.drawer__body .free-ship{background:transparent;color:var(--c-ink, #000000);padding:1.1rem 1.5rem 1.25rem;border-bottom:1px solid var(--c-line, #000000)}

/* cart items */
.cart-line{display:grid;grid-template-columns:80px 1fr auto;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--c-line)}
.cart-line__img{aspect-ratio:1/1;background:var(--c-line);overflow:hidden;border-radius:var(--radius)}
.cart-line__img img{width:100%;height:100%;object-fit:cover}
.cart-line__title{font-family:var(--f-head);font-size:1rem;line-height:1.25}
.cart-line__variant{color:var(--c-muted);font-size:.82rem;margin-top:.25rem}
.cart-line__price{font-size:.92rem;margin-top:.4rem}
.qty{display:inline-flex;border:1px solid var(--c-line);border-radius:999px}
.qty button{width:30px;height:30px;font-size:1.1rem;line-height:1}
.qty input{width:34px;border:0;text-align:center;background:transparent}
.cart-line__remove{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--c-muted);margin-top:.6rem}
.cart-line__remove:hover{color:var(--c-ink)}

.free-ship{padding:1rem 1.5rem 1.15rem;background:transparent;font-size:.86rem;color:#000000;line-height:1.35}
.free-ship__row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.55rem}
.free-ship__text{flex:1;min-width:0;color:#000000}
.free-ship__text strong{font-weight:600;color:#000000}
.free-ship__pct{font-weight:700;font-size:.9rem;letter-spacing:.02em;color:#000000 !important;flex-shrink:0;font-variant-numeric:tabular-nums}
.free-ship .free-ship__bar{display:block !important;width:100% !important;height:8px !important;background:#FFFFFF !important;border:1px solid #000000 !important;border-radius:999px !important;overflow:hidden !important;position:relative !important;margin:0 !important;padding:0 !important}
.free-ship .free-ship__fill{display:block !important;height:100% !important;width:0;min-width:8px !important;background:#000000 !important;background-color:#000000 !important;border-radius:999px !important;transition:width .6s var(--ease)}

/* PDP */
.pdp{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:clamp(2rem,4vw,4rem);padding:2rem 0 var(--pad);align-items:flex-start}
@media(max-width:960px){.pdp{grid-template-columns:1fr}}
.pdp__gallery{display:grid;gap:8px;grid-template-columns:1fr 1fr}
.pdp__gallery img{width:100%;border-radius:var(--radius);background:var(--prod-fit-bg);object-fit:var(--prod-fit)}
.pdp__gallery .pdp__media--tall{grid-column:span 2;aspect-ratio:21/9;object-fit:cover}
@media(max-width:768px){.pdp__gallery{grid-template-columns:1fr}.pdp__gallery .pdp__media--tall{aspect-ratio:4/5}}
.pdp__info{position:sticky;top:calc(var(--hdr-h) + 1rem);align-self:flex-start}
.pdp__vendor{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-muted);margin-bottom:.5rem}
.pdp__title{font-family:var(--f-head);font-size:clamp(1.8rem,2.6vw,2.4rem);line-height:1.05;letter-spacing:-.01em}
.pdp__price{display:flex;align-items:baseline;gap:.6rem;margin-top:.8rem;font-size:1.3rem}
.pdp__price del{color:var(--c-muted);font-size:1rem}
.pdp__price .save{background:var(--c-sale-bg, var(--c-her));color:var(--c-sale-fg, #FFFFFF);font-size:.7rem;padding:.2rem .5rem;letter-spacing:.12em;text-transform:uppercase;border-radius:var(--radius);font-weight:600}
.pdp__opt{margin-top:1.5rem}
.pdp__opt-label{display:flex;justify-content:space-between;align-items:baseline;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:.6rem;color:var(--c-muted)}
.opt-pills{display:flex;flex-wrap:wrap;gap:.5rem}
.opt-pills button{
  width:52px;height:52px;aspect-ratio:1;padding:0;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--c-line);border-radius:50%;
  background:transparent;font-size:.88rem;line-height:1;
  transition:border-color .2s var(--ease),background .2s var(--ease),color .2s var(--ease),transform .2s var(--ease);
  cursor:pointer;flex-shrink:0;
  -webkit-tap-highlight-color:transparent;
}
.opt-pills button:hover{border-color:var(--c-ink);transform:translateY(-1px)}
.opt-pills button[aria-checked="true"]{background:var(--c-ink);color:var(--c-bg);border-color:var(--c-ink);transform:none}
.opt-pills button[data-soldout]{position:relative;color:var(--c-muted);cursor:not-allowed}
.opt-pills button[data-soldout]::after{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(to top right,transparent calc(50% - 1px),var(--c-line) 50%,transparent calc(50% + 1px))}
.swatch-pills{display:flex;gap:.5rem;flex-wrap:wrap}
.swatch-pills button{width:38px;height:38px;border-radius:50%;border:1px solid var(--c-line);padding:2px;transition:border-color .2s var(--ease)}
.swatch-pills button > span{display:block;width:100%;height:100%;border-radius:50%}
.swatch-pills button[aria-checked="true"]{border-color:var(--c-ink);outline:2px solid var(--c-ink);outline-offset:2px}

/* PDP color swatches as CIRCULAR variant-image thumbs */
.swatch-pills--thumbs{gap:.6rem}
.swatch-pills--thumbs button.swatch-thumb{
  width:58px;height:58px;aspect-ratio:1;
  border-radius:50%;padding:3px;
  background:var(--prod-fit-bg, #FFFFFF);
  border:1px solid var(--c-line);overflow:hidden;position:relative;
  transition:border-color .2s var(--ease),transform .2s var(--ease);
  flex-shrink:0;
}
.swatch-pills--thumbs button.swatch-thumb img{
  width:100%;height:100%;object-fit:var(--prod-fit, contain);
  border-radius:50%;display:block;
}
.swatch-pills--thumbs button.swatch-thumb:hover{transform:translateY(-1px);border-color:var(--c-muted)}
.swatch-pills--thumbs button.swatch-thumb[aria-checked="true"]{border-color:var(--c-ink, #000000);outline:2px solid var(--c-ink, #000000);outline-offset:2px}
.swatch-pills--thumbs button.swatch-thumb[data-soldout]{opacity:.45}
.swatch-pills--thumbs button.swatch-thumb[data-soldout]::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:linear-gradient(to top right, transparent calc(50% - 1px), rgba(0,0,0,.4) 50%, transparent calc(50% + 1px));
  pointer-events:none;
}
@media(max-width:560px){
  .swatch-pills--thumbs button.swatch-thumb{width:52px;height:52px}
}

/* ATC + dynamic checkout (Shop Pay etc.) — stacked, full-width, consistent */
.pdp__atc{margin-top:1.5rem;display:flex !important;flex-direction:column;gap:.6rem;opacity:1 !important;visibility:visible !important}
.pdp__atc > *{width:100%}
.pdp__atc .btn{width:100%;flex:none}

/* ==== HARD FAILSAFE — primary action buttons: explicit hex colors,
   never inherit from CSS custom properties (which some merchant configs
   or third-party scripts can blank out). ==== */
.pdp__atc,
.pdp__atc > *,
.pdp__atc .btn,
.pdp__atc .shopify-payment-button,
.pdp__atc .shopify-payment-button__button,
.drawer__foot,
.drawer__foot .btn{
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto;
}

/* Primary (Add to bag / Checkout): driven by Buttons → Primary settings */
.pdp__atc .btn--brand,
.drawer__foot .btn--brand{
  background-color:var(--btn-bg, #000000) !important;
  color:var(--btn-fg, #FFFFFF) !important;
  border:1px solid var(--btn-br, #000000) !important;
  box-shadow:0 2px 10px rgba(0,0,0,.08);
}
.pdp__atc .btn--brand:hover,
.drawer__foot .btn--brand:hover{
  background-color:var(--btn-hover-bg, #000000) !important;
  color:var(--btn-hover-fg, #FFFFFF) !important;
  border-color:var(--btn-hover-br, #000000) !important;
  box-shadow:0 8px 24px rgba(0,0,0,.15);
}

/* Secondary (Shop-Pay unbranded): driven by Buttons → Secondary settings */
.pdp__atc .shopify-payment-button__button--unbranded{
  background-color:var(--btn-alt-bg, #FFFFFF) !important;
  color:var(--btn-alt-fg, #000000) !important;
  border:2px solid var(--btn-alt-br, #000000) !important;
  box-shadow:none !important;
}
.pdp__atc .shopify-payment-button__button--unbranded:hover{
  background-color:var(--btn-alt-hover-bg, #000000) !important;
  color:var(--btn-alt-hover-fg, #FFFFFF) !important;
  border-color:var(--btn-alt-hover-br, #000000) !important;
}

/* Our custom Buy Now — uses Secondary button settings as the fallback,
   block-level overrides via --bn-* still win when set per-block */
.pdp__atc .btn--buy-now{
  background-color: var(--bn-bg, var(--btn-alt-bg, #FFFFFF)) !important;
  color: var(--bn-text, var(--btn-alt-fg, #000000)) !important;
  border: 2px solid var(--bn-border, var(--btn-alt-br, #000000)) !important;
  box-shadow: none;
  transition: background-color .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease);
}
.pdp__atc .btn--buy-now:hover{
  background-color: var(--bn-hbg, var(--btn-alt-hover-bg, #000000)) !important;
  color: var(--bn-htext, var(--btn-alt-hover-fg, #FFFFFF)) !important;
  border-color: var(--bn-hbg, var(--btn-alt-hover-br, #000000)) !important;
}

/* Disabled state: still obviously a button, just dimmer */
.pdp__atc .btn[disabled],
.pdp__atc .btn.is-disabled,
.drawer__foot .btn[disabled]{
  opacity:.55 !important;
  background-color:#000000 !important;
  color:#FFFFFF !important;
  cursor:not-allowed;
}

/* Shopify-injected dynamic payment button wrapper */
.pdp__atc .shopify-payment-button{width:100%;margin:0}
.pdp__atc .shopify-payment-button__button{
  width:100% !important;
  min-height:54px;
  border-radius:var(--radius) !important;
  font-size:.88rem !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
  font-weight:500 !important;
}
.pdp__atc .shopify-payment-button__button--unbranded{
  background:transparent !important;
  color:var(--c-ink, #000000) !important;
  border:1px solid var(--c-ink, #000000) !important;
  box-shadow:none !important;
}
.pdp__atc .shopify-payment-button__button--unbranded:hover{
  background:var(--c-ink, #000000) !important;
  color:#FFFFFF !important;
}
.pdp__atc .shopify-payment-button__more-options{
  font-size:.72rem !important;letter-spacing:.16em;text-transform:uppercase;
  color:var(--c-muted) !important;margin-top:.4rem !important;
}

@media(max-width:768px){
  .pdp__atc{margin-top:1.1rem;gap:.6rem}
  .pdp__atc .btn--lg,
  .pdp__atc .btn--brand,
  .pdp__atc .shopify-payment-button__button,
  .drawer__foot .btn--brand,
  .drawer__foot .btn--lg{
    min-height:60px !important;
    padding:1.25rem 1.5rem !important;
    font-size:1rem !important;
    letter-spacing:.16em;
    font-weight:600 !important;
  }
}
@media(max-width:560px){
  .pdp__atc{margin-top:1rem}
  .pdp__atc .btn--lg,
  .pdp__atc .btn--brand,
  .pdp__atc .shopify-payment-button__button,
  .drawer__foot .btn--brand,
  .drawer__foot .btn--lg{
    min-height:58px !important;
    padding:1.2rem 1.3rem !important;
    font-size:.98rem !important;
    letter-spacing:.14em;
  }
}
.low-stock{margin-top:.9rem;font-size:.84rem;color:var(--c-her);display:flex;align-items:center;gap:.5rem}
.low-stock::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--c-her);box-shadow:0 0 0 0 var(--c-her);animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(0,0,0,.5)}70%{box-shadow:0 0 0 8px rgba(0,0,0,0)}100%{box-shadow:0 0 0 0 rgba(0,0,0,0)}}
.trust{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1.5rem;padding:1.2rem;border:1px solid var(--c-line);border-radius:var(--radius)}
.trust__item{display:flex;gap:.6rem;font-size:.84rem}
.trust__item svg{width:22px;height:22px;flex-shrink:0;color:var(--c-accent)}
.accordion{margin-top:2rem;border-top:1px solid var(--c-line)}
.accordion details{border-bottom:1px solid var(--c-line)}
.accordion summary{list-style:none;cursor:pointer;padding:1.2rem 0;font-size:.9rem;letter-spacing:.12em;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center}
.accordion summary::-webkit-details-marker{display:none}
.accordion summary::after{content:"+";font-size:1.4rem;transition:transform .3s var(--ease)}
.accordion details[open] summary::after{content:"–"}
.accordion div.accordion__body{padding:0 0 1.2rem;color:var(--c-muted);font-size:.94rem;line-height:1.7}

/* sticky atc bar */
.sticky-atc{position:fixed;left:0;right:0;bottom:0;background:var(--c-bg);border-top:1px solid var(--c-line);padding:.75rem 1rem;display:flex;gap:.75rem;align-items:center;z-index:55;transform:translateY(110%);transition:transform .4s var(--ease);box-shadow:0 -10px 30px rgba(0,0,0,.05)}
.sticky-atc.is-visible{transform:translateY(0)}
.sticky-atc__img{width:46px;height:46px;border-radius:var(--radius);background:var(--c-line);overflow:hidden;flex-shrink:0}
.sticky-atc__img img{width:100%;height:100%;object-fit:cover}
.sticky-atc__text{flex:1;font-size:.82rem;line-height:1.2;min-width:0}
.sticky-atc__text strong{display:block;font-family:var(--f-head);font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.sticky-atc .btn{padding:.75rem 1.1rem;font-size:.75rem}

/* popups — solid, opaque card on a dimmed + blurred backdrop */
.popup{
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  z-index:200;display:flex;align-items:center;justify-content:center;
  padding:1rem;opacity:0;pointer-events:none;transition:opacity .4s var(--ease);
}
.popup.is-open{opacity:1;pointer-events:auto}
.popup__card{
  background:#ffffff !important;   /* solid, always */
  color:var(--c-ink, #000000);
  max-width:520px;width:100%;padding:2.5rem;
  position:relative;border-radius:var(--radius);
  box-shadow:0 30px 80px rgba(0,0,0,.3);
  transform:translateY(12px) scale(.98);transition:transform .4s var(--ease);
}
.popup.is-open .popup__card{transform:none}
.popup__close{position:absolute;top:14px;right:14px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--c-bg, #FFFFFF);color:var(--c-ink, #000000)}
.popup__close:hover{background:#FFFFFF}
.popup__eyebrow{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--c-accent, #000000)}
.popup__title{font-family:var(--f-head);font-size:1.8rem;margin:.6rem 0 .8rem;line-height:1.1;color:var(--c-ink, #000000)}
.popup__form{display:flex;gap:.5rem;margin-top:1.2rem}
.popup__form input{
  flex:1;padding:.95rem 1rem;
  background:var(--c-bg, #FFFFFF);
  color:var(--c-ink, #000000);
  border:1px solid var(--c-line, #000000);border-radius:var(--radius);
}
.popup__form input:focus{outline:none;border-color:var(--c-ink, #000000);background:#FFFFFF}
.popup__code{
  margin-top:1rem;padding:1rem;text-align:center;
  background:var(--c-bg, #FFFFFF);color:var(--c-ink, #000000);
  border:1px dashed var(--c-accent, #000000);border-radius:var(--radius);
  font-family:var(--f-head);font-size:1.3rem;letter-spacing:.3em;
}

/* search overlay */
.search-overlay{position:fixed;inset:0;background:rgba(255,255,255,.98);z-index:90;display:flex;flex-direction:column;padding:var(--hdr-h) var(--gutter) 0;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.search-overlay.is-open{opacity:1;pointer-events:auto}
.search-overlay__inner{max-width:820px;margin:3rem auto 0;width:100%}
.search-overlay input{width:100%;font-family:var(--f-head);font-size:clamp(1.5rem,3vw,2.4rem);padding:1rem 0;border:0;border-bottom:1px solid var(--c-line);background:transparent}
.search-overlay input:focus{outline:none;border-bottom-color:var(--c-ink)}

/* 404 */
.e404{text-align:center;padding:calc(var(--pad) * 1.5) 0}
.e404 h1{font-size:clamp(4rem,10vw,9rem);line-height:1}

/* mobile nav */
.mobile-nav{position:fixed;inset:0;background:#FFFFFF;color:#000000;z-index:80;transform:translateX(100%);transition:transform .35s var(--ease);padding:24px}
.mobile-nav.is-open{transform:none}
.mobile-nav ul{list-style:none;margin-top:1.5rem;padding:0}
.mobile-nav li{border-bottom:1px solid rgba(0,0,0,.12)}
.mobile-nav a{display:block;padding:.7rem 0;font-family:var(--f-head);font-size:1.05rem;color:#000000;text-decoration:none;letter-spacing:.01em}
.mobile-nav [data-mobile-close]{color:#000000}

/* cursor */
.crest-cursor{position:fixed;top:0;left:0;pointer-events:none;z-index:999;width:46px;height:46px;border:1px solid #FFFFFF;border-radius:50%;transform:translate(-50%,-50%);mix-blend-mode:difference;transition:transform .15s var(--ease),opacity .2s var(--ease);opacity:0}
.crest-cursor.active{opacity:1}
.crest-cursor.grow{transform:translate(-50%,-50%) scale(1.6)}
@media(hover:none){.crest-cursor{display:none}}

/* press strip */
.press{display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:2rem;padding:3rem 0;border-block:1px solid var(--c-line);opacity:.7}
.press span{font-family:var(--f-head);font-size:1.1rem;letter-spacing:.14em;font-style:italic;color:var(--c-muted)}

/* testimonials */
.testimonials{
  --cols-d: 3;
  display:grid;
  grid-template-columns:repeat(var(--cols-d), minmax(0,1fr));
  gap:1rem
}
.testimonial{padding:1.8rem;border:1px solid var(--c-line);border-radius:var(--radius);background:var(--c-bg)}
.testimonial__stars{color:var(--c-accent);letter-spacing:.2em;font-size:.9rem;margin-bottom:.8rem}
.testimonial__text{font-family:var(--f-head);font-size:1.05rem;line-height:1.45;font-style:italic}
.testimonial__who{margin-top:1rem;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--c-muted)}
@media(max-width:900px){.testimonials{grid-template-columns:1fr;gap:.75rem}}

/* marquee */
.marquee{overflow:hidden;background:var(--c-ink);color:var(--c-bg);padding:1.2rem 0}
.marquee__track{display:flex;gap:3rem;white-space:nowrap;animation:marq 28s linear infinite;will-change:transform}
.marquee__track span{font-family:var(--f-head);font-size:clamp(1.4rem,3vw,2.4rem);letter-spacing:.02em}
.marquee__track span::after{content:"✦";margin-left:3rem;color:var(--c-accent)}
@keyframes marq{to{transform:translateX(-50%)}}

/* newsletter section */
.newsletter{text-align:center;padding:var(--pad) 0;background:var(--c-ink);color:var(--c-bg)}
.newsletter h2{color:#FFFFFF;font-size:clamp(2rem,4vw,3rem);margin-bottom:.5rem}
.newsletter p{color:rgba(255,255,255,.7);max-width:46ch;margin:0 auto 1.5rem}
.newsletter form{max-width:480px;margin:0 auto;display:flex;gap:.5rem}
.newsletter input{flex:1;padding:1rem 1.2rem;background:transparent;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius);color:#FFFFFF}
.newsletter input::placeholder{color:rgba(255,255,255,.5)}
.newsletter input:focus{outline:none;border-color:#FFFFFF}
/* newsletter CTA — uses centralized Buttons settings */

/* collection filters */
.filters{display:flex;gap:.5rem;flex-wrap:wrap}
.filters a{padding:.5rem 1rem;border:1px solid var(--btn-alt-br, var(--c-line));border-radius:999px;font-size:.82rem;background:var(--btn-alt-bg, transparent);color:var(--btn-alt-fg, var(--c-ink));transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease)}
.filters a:hover{background:var(--btn-alt-hover-bg, var(--c-ink));color:var(--btn-alt-hover-fg, var(--c-bg));border-color:var(--btn-alt-hover-br, var(--c-ink))}
.filters a.is-active{background:var(--btn-bg, var(--c-ink));color:var(--btn-fg, var(--c-bg));border-color:var(--btn-br, var(--c-ink))}

/* breadcrumbs */
.crumbs{font-size:.78rem;letter-spacing:.1em;color:var(--c-muted);padding:1rem 0}
.crumbs a:hover{color:var(--c-ink)}
.crumbs span{margin:0 .5rem}

/* toast */
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);background:var(--c-ink);color:var(--c-bg);padding:.9rem 1.4rem;border-radius:999px;font-size:.84rem;letter-spacing:.08em;text-transform:uppercase;box-shadow:0 10px 30px rgba(0,0,0,.2);opacity:0;pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease);z-index:120}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* =========================================================
   GLOBAL CIRCLE OVERRIDE — every variant selector (size & color,
   PDP & card, desktop & mobile) is a perfect round pill with a
   visible border, and sold-out circles carry a clear diagonal
   strike. Placed late in the file so it wins the cascade.
   ========================================================= */
.opt-pills,
.swatch-pills,
.card__colors,
.card__sizes{
  display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;
}
.opt-pills button,
.swatch-pills button,
.swatch-pills--thumbs button,
.swatch-pills--thumbs button.swatch-thumb,
.card__color,
.card__size,
.card__color-count{
  border-radius:50% !important;
  aspect-ratio:1 / 1 !important;
  padding:0 !important;
  display:inline-flex !important;
  align-items:center;justify-content:center;
  flex-shrink:0;
  line-height:1;
  overflow:hidden;position:relative;
  background:#FFFFFF;
  border:1.5px solid rgba(0,0,0,.28) !important;   /* visible outline */
  color:var(--c-ink, #000000);
  transition:background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease);
}
.opt-pills button:hover,
.swatch-pills button:hover,
.swatch-pills--thumbs button.swatch-thumb:hover,
.card__color:hover,
.card__size:hover{
  border-color:var(--c-ink, #000000) !important;
  transform:translateY(-1px);
}
/* Selected / active state */
.opt-pills button[aria-checked="true"],
.card__size.is-added{
  background:var(--c-ink, #000000) !important;
  color:#FFFFFF !important;
  border-color:var(--c-ink, #000000) !important;
}
.swatch-pills--thumbs button.swatch-thumb[aria-checked="true"],
.card__color.is-active{
  border-color:var(--c-ink, #000000) !important;
  outline:2px solid var(--c-ink, #000000);outline-offset:1px;
}
/* Images inside circle swatches */
.swatch-pills--thumbs button img,
.card__color img{
  width:100%;height:100%;
  object-fit:var(--prod-fit, contain);
  border-radius:50%;
  display:block;
}
/* ===== Sold-out: visible diagonal strike clipped to the circle ===== */
.opt-pills button[data-soldout],
.swatch-pills button[data-soldout],
.swatch-pills--thumbs button.swatch-thumb[data-soldout],
.card__size.is-soldout,
.card__color[data-soldout]{
  color:rgba(0,0,0,.35) !important;
  cursor:not-allowed;
  background:#FFFFFF !important;
  border-color:rgba(0,0,0,.2) !important;
}
.opt-pills button[data-soldout]::after,
.swatch-pills button[data-soldout]::after,
.swatch-pills--thumbs button.swatch-thumb[data-soldout]::after,
.card__size.is-soldout::after,
.card__color[data-soldout]::before{
  content:"";
  position:absolute;inset:0;
  border-radius:50%;
  background:linear-gradient(
    to top right,
    transparent calc(50% - 1.25px),
    rgba(0,0,0,.55) calc(50% - 0.25px),
    rgba(0,0,0,.55) calc(50% + 0.25px),
    transparent calc(50% + 1.25px)
  );
  pointer-events:none;
}
.opt-pills button[data-soldout]:hover,
.swatch-pills button[data-soldout]:hover,
.card__size.is-soldout:hover{
  transform:none;
  border-color:rgba(0,0,0,.2) !important;
}
/* Sizing — desktop */
.opt-pills button{width:52px;height:52px;font-size:.88rem;font-weight:500}
.swatch-pills button{width:40px;height:40px}
.swatch-pills--thumbs button.swatch-thumb{width:58px;height:58px}
.card__color,.card__color-count{width:40px;height:40px}
.card__size{width:34px;height:34px;font-size:.72rem;font-weight:500}
/* Sizing — tablet / phone */
@media(max-width:768px){
  .opt-pills button{width:48px;height:48px;font-size:.92rem}
  .swatch-pills button{width:44px;height:44px}
  .swatch-pills--thumbs button.swatch-thumb{width:52px;height:52px}
  .card__color,.card__color-count{width:34px;height:34px}
  .card__size{width:32px;height:32px;font-size:.68rem}
}

/* =========================================================
   MOBILE OVERHAUL — 90% of traffic is on phones.
   Reorder PDP, always-visible card quick-add, swipeable gallery,
   bottom nav, WhatsApp FAB, safe-area, tap targets.
   ========================================================= */

/* Default PDP block order (desktop keeps natural flow) */
.pdp__block{order:0}

/* --- PDP: swipeable gallery + reordered mobile layout --- */
.pdp__slide{background:var(--prod-fit-bg);border-radius:var(--radius);overflow:hidden;padding:var(--prod-fit-pad)}
.pdp__slide img,.pdp__slide video{width:100%;height:100%;object-fit:var(--prod-fit);display:block}

.pdp__gallery--grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.pdp__gallery--stacked{display:grid;grid-template-columns:1fr;gap:8px}
.pdp__gallery--grid .pdp__slide{aspect-ratio:4/5}
.pdp__gallery--stacked .pdp__slide{aspect-ratio:4/5}

/* === Thumbnails-left + main-image-right layout === */
.pdp__gallery--thumbs{display:flex;gap:16px;align-items:flex-start}
.pdp__thumbs{display:flex;flex-direction:column;gap:10px;flex-shrink:0;align-items:center;width:84px;position:sticky;top:calc(var(--hdr-h) + 16px)}
.pdp__thumbs-nav{
  width:36px;height:36px;border:1px solid transparent;background:transparent;border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  color:var(--c-muted);font-size:1.1rem;line-height:1;
  transition:color .2s var(--ease),background .2s var(--ease),border-color .2s var(--ease);
}
.pdp__thumbs-nav:hover{color:var(--c-ink);border-color:var(--c-line)}
.pdp__thumbs-nav:disabled{opacity:.25;cursor:default}
.pdp__thumbs-list{
  display:flex;flex-direction:column;gap:10px;
  max-height:560px;overflow-y:auto;padding:2px;
  scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth;
}
.pdp__thumbs-list::-webkit-scrollbar{display:none}
.pdp__thumb{
  width:72px;height:90px;padding:4px;
  background:var(--prod-fit-bg, #FFFFFF);
  border:1px solid var(--c-line, #000000);
  border-radius:var(--radius);cursor:pointer;overflow:hidden;
  opacity:.6;flex-shrink:0;
  transition:opacity .25s var(--ease),border-color .25s var(--ease),transform .2s var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.pdp__thumb:hover{opacity:.9;transform:translateY(-1px)}
.pdp__thumb.is-active{opacity:1;border-color:var(--c-ink, #000000);outline:1px solid var(--c-ink, #000000);outline-offset:1px}
.pdp__thumb img{width:100%;height:100%;object-fit:contain;display:block}

.pdp__main{
  flex:1;position:relative;overflow:hidden;border-radius:var(--radius);
  background:var(--prod-fit-bg, #FFFFFF);
  aspect-ratio:1/1;
}
.pdp__main img{
  width:100%;height:100%;object-fit:contain;
  padding:var(--prod-fit-pad, 8px);display:block;
  transition:opacity .3s var(--ease);
}

/* On mobile: hide the thumbnails layout, show the swipeable carousel */
.pdp__gallery--mobile-carousel{display:none}
.pdp__thumbs-mobile{display:none}
@media(max-width:960px){
  .pdp__gallery--thumbs{display:none !important}
  .pdp__gallery--mobile-carousel{
    display:flex !important;overflow-x:auto;scroll-snap-type:x mandatory;
    gap:10px;scrollbar-width:none;-webkit-overflow-scrolling:touch;
    width:100%;max-width:100%;
  }
  .pdp__gallery--mobile-carousel::-webkit-scrollbar{display:none}
  .pdp__gallery--mobile-carousel .pdp__slide{
    flex:0 0 100%;width:100%;scroll-snap-align:center;
    aspect-ratio:1/1;
    background:var(--prod-fit-bg, #FFFFFF);border-radius:var(--radius);
    overflow:hidden;display:block;
  }
  .pdp__gallery--mobile-carousel .pdp__slide img{
    width:100%;height:100%;object-fit:var(--prod-fit, contain);
    padding:var(--prod-fit-pad, 8px);display:block;
  }

  /* Horizontal thumbnail strip under the mobile carousel */
  .pdp__thumbs-mobile{
    display:flex;align-items:center;gap:8px;
    padding:.9rem 0 .3rem;
  }
  .pdp__thumbs-mobile-nav{
    width:38px;height:38px;flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    background:transparent;border:0;cursor:pointer;
    color:var(--c-ink, #000000);font-size:1.15rem;line-height:1;
    transition:opacity .2s var(--ease);
  }
  .pdp__thumbs-mobile-nav:disabled{opacity:.25;cursor:default}
  .pdp__thumbs-mobile-list{
    flex:1;display:flex;gap:10px;overflow-x:auto;
    scroll-snap-type:x proximity;scroll-behavior:smooth;
    scrollbar-width:none;-ms-overflow-style:none;
    padding:3px;
  }
  .pdp__thumbs-mobile-list::-webkit-scrollbar{display:none}
  .pdp__mthumb{
    width:72px;height:72px;flex-shrink:0;padding:4px;
    background:var(--prod-fit-bg, #FFFFFF);
    border:1px solid var(--c-line, #000000);
    border-radius:var(--radius);
    cursor:pointer;overflow:hidden;opacity:.55;
    scroll-snap-align:center;
    transition:opacity .25s var(--ease),border-color .25s var(--ease);
    -webkit-tap-highlight-color:transparent;
  }
  .pdp__mthumb img{width:100%;height:100%;object-fit:contain;display:block}
  .pdp__mthumb.is-active{
    opacity:1;border-color:var(--c-ink, #000000);
    outline:1px solid var(--c-ink, #000000);outline-offset:1px;
  }
}

/* dots hidden on desktop */
.pdp__dots{display:none}

@media(max-width:960px){
  /* Make the whole PDP a single column with block-level ordering */
  .pdp{display:flex;flex-direction:column;gap:1rem;grid-template-columns:none;align-items:stretch}
  .pdp__info{display:contents}
  .pdp__info > form{display:contents}
  .pdp__info > form > script{display:none}

  /* vendor / title / rating / price come FIRST, above gallery */
  .pdp__block--vendor,.pdp__block--title,.pdp__block--rating,.pdp__block--price{order:1}
  .pdp__gallery,.pdp__gallery--mobile-carousel{order:2;margin:.5rem 0;width:100%}
  .pdp__thumbs-mobile{order:3;width:100%}
  .pdp__dots{order:3}
  .pdp__block{order:4}       /* everything else after gallery */
  .pdp__block--custom_image,.pdp__block--description,.pdp__block--accordion{order:5}
  .pdp__block--share,.pdp__block--spacer{order:6}

  /* tighter top/bottom spacing between stacked blocks */
  .pdp__block{margin-top:0}
  .pdp__block--vendor + .pdp__block--title{margin-top:-.2rem}
  .pdp__block--title{margin-bottom:.1rem}

  /* Gallery becomes a horizontal swipeable carousel (stays inside container padding).
     NOTE: target only --grid and --stacked here — never --thumbs, which uses its own
     mobile-carousel sibling element. */
  .pdp__gallery--grid,
  .pdp__gallery--stacked{
    display:flex;grid-template-columns:none;
    overflow-x:auto;scroll-snap-type:x mandatory;
    gap:10px;scrollbar-width:none;-webkit-overflow-scrolling:touch;
  }
  .pdp__gallery--grid::-webkit-scrollbar,
  .pdp__gallery--stacked::-webkit-scrollbar{display:none}
  .pdp__gallery--grid .pdp__slide,
  .pdp__gallery--stacked .pdp__slide{
    flex:0 0 100%;scroll-snap-align:center;aspect-ratio:4/5;
    border-radius:var(--radius);
  }

  /* Dots under gallery */
  .pdp__dots{display:flex;justify-content:center;gap:6px;padding:.6rem 0}
  .pdp__dot{width:6px;height:6px;border-radius:50%;background:var(--c-line);transition:background .25s var(--ease),width .25s var(--ease)}
  .pdp__dot[aria-current="true"]{background:var(--c-ink);width:18px;border-radius:3px}
}

/* --- Card: always-show quick-add + wish on touch devices --- */
@media (hover: none){
  .card__quick{opacity:1;transform:none}
  .card__wish{opacity:1;transform:none}
  .card__media img + img{opacity:0}   /* no hover 2nd image */
  .card:active .card__media img:first-child{opacity:.85}
}

/* --- Heading responsiveness: keep readable on small screens --- */
@media(max-width:560px){
  :root{--gutter:20px;--pad:64px}
  .h1{font-size:clamp(1.9rem,7vw,2.4rem)}
  .h2{font-size:clamp(1.55rem,5.5vw,2rem)}
  .h-display{font-size:clamp(2.6rem,10vw,4rem)}
  .hero__title{font-size:clamp(2rem,8vw,3rem) !important}
  .hero__sub{font-size:1rem}
  .pdp__title{font-size:clamp(1.45rem,6vw,1.9rem)}
  .pdp__price{font-size:1.15rem}
  .fcol__meta h3{font-size:1.1rem}
  .fcol__meta{padding:1rem}
  .collection-header{padding:2rem 0 1rem}
  .section{padding-block:52px}
  .section--sm{padding-block:32px}
  .testimonial{padding:1.3rem}
  .testimonial__text{font-size:.95rem}
  .newsletter{padding-block:64px}
  .announcement{height:32px;font-size:.68rem;letter-spacing:.18em}
}

/* --- Tap targets: min 44x44 everywhere that matters --- */
@media(max-width:768px){
  .header__icon-btn{width:44px;height:44px}
  .header__icon-btn svg{width:22px;height:22px}
  .pdp__opt{margin-top:1.3rem}
  .opt-pills{gap:.5rem;display:flex;flex-wrap:wrap}
  .opt-pills button{width:48px;height:48px;min-width:0;min-height:0;padding:0;font-size:.92rem}
  .swatch-pills button{width:44px;height:44px}
  .qty button{width:40px;height:40px;font-size:1.2rem}
  .qty input{width:44px;font-size:1rem}
  .btn{padding:1rem 1.4rem;min-height:48px}
  .btn--lg{padding:1.2rem 1.6rem;min-height:54px;font-size:.92rem}
  .filters a{padding:.7rem 1.1rem;min-height:40px;display:inline-flex;align-items:center}
  .toolbar__btn{min-height:42px;padding:.7rem 1rem}
  .card__wish{width:40px;height:40px}
  input,select,textarea{font-size:16px !important}   /* prevent iOS zoom */
}

/* --- Header mobile cleanup --- */
@media(max-width:960px){
  .site-header{border-bottom:1px solid var(--c-line)}
  .header{grid-template-columns:auto 1fr auto;height:64px;padding-inline:12px}
  .site-header.is-transparent .header{height:64px}
  .header__logo--text{max-width:110px}
  .header__right{gap:0}
  /* keep only cart + menu on mobile — search/account live in mobile nav */
  .header__right .md-hide{display:none !important}
}

/* --- Mobile bottom nav --- */
.mobile-bnav{
  position:fixed;left:0;right:0;bottom:0;
  z-index:70;display:none;
  background:rgba(255,255,255,.94);backdrop-filter:saturate(160%) blur(16px);-webkit-backdrop-filter:saturate(160%) blur(16px);
  border-top:1px solid var(--c-line);
  padding-bottom:env(safe-area-inset-bottom, 0);
}
.mobile-bnav__row{display:grid;grid-template-columns:repeat(5,1fr);height:60px}
.mobile-bnav a{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:var(--c-muted);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;
  position:relative;transition:color .25s var(--ease);
}
.mobile-bnav a svg{width:22px;height:22px;transition:transform .25s var(--ease)}
.mobile-bnav a.is-active{color:var(--c-ink)}
.mobile-bnav a.is-active svg{transform:translateY(-1px)}
.mobile-bnav a:active svg{transform:scale(.9)}
.mobile-bnav .bnav-badge{
  position:absolute;top:7px;right:calc(50% - 18px);
  min-width:16px;height:16px;padding:0 4px;
  background:var(--c-accent);color:#FFFFFF;font-size:.6rem;font-weight:700;letter-spacing:0;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
}
@media(max-width:960px){
  .mobile-bnav{display:block}
  /* lift all sticky-bottom elements above the nav */
  body{padding-bottom:calc(60px + env(safe-area-inset-bottom, 0))}
  .sticky-atc{bottom:calc(60px + env(safe-area-inset-bottom, 0))}
  .crest-wa{bottom:calc(72px + env(safe-area-inset-bottom, 0))}
  /* drawer covers the viewport including the bnav area — let its foot sit
     flush at the bottom (it already respects safe-area-inset via drawer__foot padding) */
}
/* Cart page: stop the summary aside from being position:sticky on mobile,
   so the Checkout button is never clipped by a too-short viewport. */
@media(max-width:900px){
  .cart-layout > aside{position:relative !important;top:auto !important;height:auto !important}
}

/* --- Floating WhatsApp button --- */
.crest-wa{
  position:fixed;right:16px;bottom:16px;z-index:65;
  width:56px;height:56px;border-radius:50%;
  background:#000000;color:#FFFFFF;
  display:none;align-items:center;justify-content:center;
  box-shadow:0 10px 28px rgba(0,0,0,.4);
  transition:transform .3s var(--ease);
}
.crest-wa:hover{transform:scale(1.05);opacity:1}
.crest-wa svg{width:26px;height:26px}
@media(max-width:960px){ .crest-wa{display:flex} }

/* --- Announcement tightening --- */
@media(max-width:560px){
  .announcement__item{padding:0 .25rem}
  .announcement__track{gap:2rem}
}

/* --- Splash mobile polish --- */
@media(max-width:768px){
  .splash{min-height:100dvh;height:100dvh}
  .splash__brand{top:22px}
  .splash__brand .logo-text{font-size:1.4rem;letter-spacing:.3em}
  .splash__brand .eyebrow{font-size:.66rem;letter-spacing:.2em}
  .splash__side{min-height:50dvh}
  .splash__label{font-size:clamp(2.8rem,14vw,4.6rem) !important;line-height:.95}
  .splash__sub{font-size:.66rem}
  .splash__cta{opacity:1;transform:none;padding:.8rem 1.4rem;font-size:.7rem}  /* always visible on touch */
  .splash__tagline{bottom:calc(env(safe-area-inset-bottom, 0) + 16px);font-size:.82rem}
  .splash__foot{bottom:calc(env(safe-area-inset-bottom, 0) + 6px);right:12px;font-size:.62rem}
}

/* --- PDP accordion summary taller tap target on mobile --- */
@media(max-width:768px){
  .accordion summary,.accordion-single summary{padding:1.4rem 0 !important;min-height:56px}
}

/* --- Cart drawer full-height sheet feel on mobile --- */
@media(max-width:560px){
  .drawer{width:100vw;border-radius:0}
  .drawer__head{padding:1rem 1.1rem}
  .drawer__body{padding:.8rem 1.1rem}
  .drawer__foot{padding:1rem 1.1rem}
}

/* --- Sticky ATC mobile polish --- */
.sticky-atc{background:#FFFFFF;color:var(--c-ink, #000000)}
.sticky-atc__text strong{color:var(--c-ink, #000000)}
.sticky-atc .btn{font-weight:600}
@media(max-width:560px){
  .sticky-atc{padding:.65rem .8rem;gap:.6rem}
  .sticky-atc__img{width:42px;height:42px}
  .sticky-atc__text{font-size:.78rem}
  .sticky-atc__text strong{font-size:.9rem}
  .sticky-atc .btn{padding:.95rem 1.2rem;font-size:.8rem;letter-spacing:.12em}
}

/* --- Row-scroll stays inside container padding on mobile --- */
@media(max-width:768px){
  .row-scroll{scroll-padding:0;padding-inline:0;margin-inline:0}
}

/* --- Reveal animations cheaper on mobile (battery friendly) --- */
@media(max-width:768px){
  [data-reveal],.stagger > *{transition-duration:.5s !important;transform:translateY(14px)}
}

/* --- Cart drawer upsell --- */
.cart-upsell{margin:1rem 1.25rem;padding:.85rem;border:1px solid #000000;border-radius:6px;background:#FFFFFF;color:#000000}
.cart-upsell__title{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;margin-bottom:.65rem;color:#000000}
.cart-upsell__row{display:flex;align-items:center;gap:.85rem}
.cart-upsell__img{flex-shrink:0;width:64px;height:64px;display:block;background:#FFFFFF;border:1px solid #000000;border-radius:4px;overflow:hidden}
.cart-upsell__img img{width:100%;height:100%;object-fit:contain;display:block}
.cart-upsell__info{flex:1;min-width:0}
.cart-upsell__name{display:block;font-weight:500;color:#000000;font-size:.88rem;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cart-upsell__price{margin-top:.15rem;font-size:.82rem;color:#000000;font-weight:600;font-variant-numeric:tabular-nums}
.cart-upsell__btn{flex-shrink:0;background:#000000;color:#FFFFFF;border:1px solid #000000;border-radius:999px;padding:.55rem .95rem;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:background .2s,color .2s}
.cart-upsell__btn:hover{background:#FFFFFF;color:#000000}
.cart-upsell__btn[disabled]{opacity:.45;cursor:not-allowed}
@media(max-width:480px){
  .cart-upsell{margin:.85rem 1rem;padding:.7rem}
  .cart-upsell__img{width:54px;height:54px}
  .cart-upsell__btn{padding:.45rem .75rem;font-size:.7rem}
}


/* Mobile nav collapsible children */
.mobile-nav details{display:block}
.mobile-nav details summary{display:flex;align-items:center;justify-content:space-between;list-style:none;cursor:pointer;padding:.7rem 0;font-family:var(--f-head);font-size:1.05rem;color:#000;letter-spacing:.01em}
.mobile-nav details summary::-webkit-details-marker{display:none}
.mobile-nav details summary > a{padding:0;border:0;flex:1;color:inherit;font:inherit;text-decoration:none}
.mobile-nav details summary .mobile-nav__caret{font-size:1.2rem;line-height:1;width:24px;text-align:center;transition:transform .2s var(--ease-soft,ease)}
.mobile-nav details[open] > summary .mobile-nav__caret{transform:rotate(45deg)}
.mobile-nav .has-children > details > ul.mobile-nav__sub{list-style:none;margin:0 0 .4rem;padding:0 0 0 .9rem;border-left:1px solid rgba(0,0,0,.08)}
.mobile-nav .mobile-nav__sub li{border-bottom:0}
.mobile-nav .mobile-nav__sub a{padding:.5rem 0;font-size:.95rem;font-family:var(--f-body);color:#222}
.mobile-nav .has-children{border-bottom:1px solid rgba(0,0,0,.12)}
.mobile-nav .has-children > details > summary{padding:.7rem 0}


/* Cart upsell horizontal carousel */
.cart-upsell__carousel{display:flex;gap:.6rem;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:.25rem 0 .5rem;scrollbar-width:thin}
.cart-upsell__carousel::-webkit-scrollbar{height:4px}
.cart-upsell__carousel::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border-radius:4px}
.cart-upsell__card{flex:0 0 auto;width:160px;scroll-snap-align:start;display:flex;flex-direction:column;gap:.4rem;padding:.5rem;border:1px solid var(--c-line);border-radius:var(--radius);background:#fff;text-align:left;direction:ltr}
.cart-upsell__card .cart-upsell__img{display:block;width:100%;aspect-ratio:1/1;overflow:hidden;border-radius:calc(var(--radius) - 1px);background:var(--prod-fit-bg,#fff)}
.cart-upsell__card .cart-upsell__img img{width:100%;height:100%;object-fit:contain;padding:6px}
.cart-upsell__card .cart-upsell__info{display:flex;flex-direction:column;gap:2px;min-height:46px}
.cart-upsell__card .cart-upsell__name{font-size:.78rem;line-height:1.25;color:var(--c-ink);text-decoration:none;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cart-upsell__card .cart-upsell__price{font-size:.82rem;font-weight:600;color:var(--c-ink)}
.cart-upsell__card .cart-upsell__btn{margin-top:.15rem;width:100%;padding:.5rem .6rem;border:0;border-radius:999px;background:#000;color:#fff;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}
.cart-upsell__card .cart-upsell__btn:hover{opacity:.9}
