/* ============================================================
   TWELVE — shop.css
   Dark performance-knit aesthetic. Matches twelvescrubs.com
   homepage + /customize design tokens 1:1.
   ============================================================ */

:root{
  --ink:#16191D;
  --graphite:#22262A;
  --teal-deep:#0F3D46;
  --ceil:#39C6D6;
  --mint:#2DD4BF;
  --bone:#F7F5F0;
  --bone-60:rgba(247,245,240,.6);
  --bone-55:rgba(247,245,240,.55);
  --bone-38:rgba(247,245,240,.38);
  --bone-10:rgba(247,245,240,.10);
  --line:rgba(247,245,240,.10);
  --line-soft:rgba(247,245,240,.06);
  --err:#E5645F;
  --ok:#2DD4BF;
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-press:cubic-bezier(.34,1.56,.64,1);
  --radius:14px;
  --radius-sm:8px;
}

/* ---- reset + base ---------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--bone);
  font-family:'Archivo',-apple-system,'Helvetica Neue',Arial,sans-serif;
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  min-height:100vh;
}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}

/* ---- layout primitives ----------------------------------- */
.wrap{width:min(100% - 40px,1180px);margin-inline:auto}

.eyebrow{
  font-weight:600;
  font-size:.75rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ceil);
  display:flex;align-items:center;gap:10px;
  margin-bottom:18px;
}
.eyebrow .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--mint);
}

h1{
  font-weight:900;
  font-stretch:110%;
  font-size:clamp(2.4rem,7vw,4.6rem);
  line-height:.98;
  letter-spacing:-.015em;
  text-transform:uppercase;
  color:var(--bone);
}

.skip{
  position:absolute;left:-9999px;top:0;
  background:var(--ceil);color:var(--ink);
  padding:10px 14px;font-weight:700;text-transform:uppercase;
  letter-spacing:.18em;font-size:.7rem;
  border-radius:8px;transition:left .2s;
}
.skip:focus{left:12px;top:12px;z-index:100}
:focus-visible{outline:2px solid var(--ceil);outline-offset:3px;border-radius:4px}

/* ---- header (matches homepage exactly) ------------------- */
#hdr{
  position:fixed;inset:0 0 auto 0;
  height:56px;z-index:50;
  display:flex;align-items:center;
  transition:background .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
#hdr.scrolled{
  background:rgba(22,25,29,.82);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom-color:var(--line);
}
#hdr .wrap{
  display:flex;justify-content:space-between;align-items:center;
}
#hdr .mark-link{display:inline-flex;align-items:center}
#hdr .mark{color:var(--bone);height:26px;width:32px}

.site-nav{display:flex;align-items:center;gap:24px}
#hdr a.joinlink{
  font-weight:600;font-size:.75rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ceil);text-decoration:none;
  padding:6px 0;position:relative;
  transition:color .2s;
}
#hdr a.joinlink:hover{color:var(--bone)}
#hdr a.joinlink[aria-current="page"]{color:var(--bone)}
#hdr a.joinlink[aria-current="page"]::after{
  content:"";position:absolute;left:0;right:0;bottom:0;
  height:1.5px;background:var(--ceil);
}

/* cart button */
.cart-btn{
  position:relative;
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;
  border-radius:50%;
  color:var(--bone);
  border:1px solid var(--line);
  transition:border-color .2s,background .2s;
  margin-left:6px;
}
.cart-btn:hover{border-color:var(--ceil);background:rgba(57,198,214,.08)}
.cart-btn svg{width:18px;height:18px}
.cart-count{
  position:absolute;top:-4px;right:-4px;
  min-width:18px;height:18px;padding:0 5px;
  border-radius:9px;background:var(--ceil);color:var(--ink);
  font-size:.62rem;font-weight:800;letter-spacing:.04em;
  display:flex;align-items:center;justify-content:center;
}
.cart-count.is-hidden{display:none}

/* ---- shop hero ------------------------------------------- */
.shop-hero{padding:120px 0 40px}
.shop-hero__subtitle{
  margin-top:18px;max-width:560px;
  font-size:1.05rem;color:var(--bone-60);
}

/* ---- shop layout ----------------------------------------- */
.shop-layout{padding:30px 0 100px}
.shop-toolbar{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 0;border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-bottom:36px;
}
.shop-count{
  font-weight:700;font-size:.72rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--bone-60);
}
.filter-toggle{
  display:none;
  font-weight:600;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ceil);
  padding:8px 14px;border:1px solid var(--line);border-radius:999px;
}
.shop-layout__inner{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:48px;align-items:flex-start;
}

/* ---- filter rail ----------------------------------------- */
.filter-rail{
  position:sticky;top:80px;
}
.filter-group{
  border:none;border-bottom:1px solid var(--line);
  padding:18px 0;
}
.filter-group:first-child{padding-top:0}
.filter-group legend{
  font-weight:700;font-size:.7rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--bone);margin-bottom:14px;
}
.filter-group__items{display:flex;flex-direction:column;gap:9px}
.filter-check{
  display:flex;align-items:center;gap:10px;
  cursor:pointer;font-size:.88rem;color:var(--bone-60);
  text-transform:capitalize;transition:color .15s;
}
.filter-check:hover{color:var(--bone)}
.filter-check input{
  appearance:none;width:16px;height:16px;
  border:1.5px solid var(--bone-38);border-radius:3px;
  background:transparent;cursor:pointer;
  transition:all .15s;flex-shrink:0;position:relative;
}
.filter-check input:checked{
  background:var(--ceil);border-color:var(--ceil);
}
.filter-check input:checked::after{
  content:"";position:absolute;left:4px;top:1px;
  width:5px;height:9px;
  border:solid var(--ink);border-width:0 2px 2px 0;
  transform:rotate(45deg);
}
.filter-check span{display:inline-flex;align-items:center;gap:8px}

.filter-clear{
  margin-top:18px;
  font-weight:600;font-size:.7rem;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--ceil);padding:8px 0;
  border-bottom:1px solid transparent;
  transition:border-color .2s;
}
.filter-clear:hover{border-bottom-color:var(--ceil)}

.swatch{
  display:inline-block;width:14px;height:14px;border-radius:50%;
  border:1px solid var(--bone-38);
  flex-shrink:0;
}

/* ---- shop grid ------------------------------------------- */
.shop-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:28px 24px;
}
.shop-empty{
  grid-column:1/-1;
  text-align:center;padding:60px 20px;color:var(--bone-60);
  font-size:.95rem;
}

/* ---- product card ---------------------------------------- */
.card{
  display:block;color:inherit;
  transition:transform .25s var(--ease-out);
}
.card:hover{transform:translateY(-2px)}
.card__media{
  position:relative;
  aspect-ratio:4/5;
  background:var(--graphite);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  margin-bottom:16px;
}
/* Beautiful placeholder when no image uploaded yet — XII mark watermark on graphite */
.card__media::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(60% 40% at 50% 35%, rgba(57,198,214,.06), transparent 70%),
    linear-gradient(180deg, var(--graphite) 0%, #1A1E23 100%);
  z-index:0;
}
.card__media::after{
  content:"XII";
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-stretch:110%;font-size:5rem;
  letter-spacing:-.02em;color:rgba(247,245,240,.06);
  font-style:italic;
  pointer-events:none;z-index:0;
}
.card__img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transition:opacity .35s var(--ease-out);
  z-index:1;
}
.card__img--hover{opacity:0}
.card:hover .card__img--hover{opacity:1}
/* Hide broken/empty images so the placeholder gradient shows through */
.card__img[src=""],.card__img:not([src]){opacity:0}

.badge{
  position:absolute;top:14px;left:14px;z-index:3;
  padding:6px 10px;border-radius:999px;
  font-weight:800;font-size:.6rem;
  letter-spacing:.18em;text-transform:uppercase;
}
.badge--new{background:var(--ceil);color:var(--ink)}
.badge--waitlist{background:var(--bone);color:var(--ink)}
.badge--soldout{background:var(--bone-38);color:var(--ink)}

.card__info{padding:0 4px}
.card__name{
  font-weight:700;font-size:.95rem;
  letter-spacing:.04em;text-transform:uppercase;
  color:var(--bone);margin-bottom:6px;line-height:1.3;
}
.card__price{
  font-weight:600;color:var(--bone-60);
  font-size:.9rem;margin-bottom:10px;
}
.card__swatches{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.card__more{
  font-size:.65rem;color:var(--bone-38);
  font-weight:700;letter-spacing:.12em;margin-left:4px;
}

/* ---- PDP (product detail page) --------------------------- */
.pdp{padding:100px 0 80px}
.pdp__inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;align-items:flex-start;
}
.pdp__gallery{display:flex;flex-direction:column;gap:14px}
.pdp__hero-img{
  aspect-ratio:4/5;
  background:var(--graphite);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  position:relative;
}
.pdp__hero-img::after{
  content:"XII";
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-stretch:110%;font-size:8rem;
  letter-spacing:-.02em;color:rgba(247,245,240,.06);
  font-style:italic;pointer-events:none;
}
.pdp__hero-img img{
  position:relative;z-index:1;
  width:100%;height:100%;object-fit:cover;
}
.pdp__thumbs{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
}
.pdp__thumb{
  aspect-ratio:1;background:var(--graphite);
  border:1px solid var(--line);border-radius:var(--radius-sm);
  overflow:hidden;cursor:pointer;
  transition:border-color .2s;
}
.pdp__thumb:hover,.pdp__thumb.is-active{border-color:var(--ceil)}
.pdp__thumb img{width:100%;height:100%;object-fit:cover}

.pdp__detail{padding-top:12px}
.pdp__eyebrow{
  font-weight:600;font-size:.72rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ceil);margin-bottom:14px;
}
.pdp__title{
  font-weight:900;font-stretch:110%;
  font-size:clamp(1.8rem,4vw,2.8rem);
  line-height:1;letter-spacing:-.015em;
  text-transform:uppercase;margin-bottom:14px;
}
.pdp__price{
  font-size:1.4rem;font-weight:700;
  color:var(--bone);margin-bottom:24px;
}
.pdp__desc{
  font-size:1rem;color:var(--bone-60);
  margin-bottom:32px;line-height:1.7;
}

.pdp__option{margin-bottom:24px}
.pdp__option-label{
  font-weight:700;font-size:.72rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--bone);margin-bottom:12px;display:block;
}
.pdp__option-value{
  font-weight:400;color:var(--bone-60);
  text-transform:none;letter-spacing:0;margin-left:8px;
}

.pdp__sizes{display:flex;flex-wrap:wrap;gap:8px}
.pdp__size-btn{
  min-width:52px;padding:11px 14px;
  border:1px solid var(--line);border-radius:var(--radius-sm);
  background:transparent;color:var(--bone);
  font-weight:600;font-size:.82rem;letter-spacing:.06em;
  cursor:pointer;transition:all .15s;
}
.pdp__size-btn:hover{border-color:var(--bone-38)}
.pdp__size-btn.is-active{
  background:var(--bone);color:var(--ink);border-color:var(--bone);
}
.pdp__size-btn[disabled]{
  color:var(--bone-38);cursor:not-allowed;
  text-decoration:line-through;
}

.pdp__colors{display:flex;flex-wrap:wrap;gap:10px}
.pdp__color-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px 8px 8px;
  border:1px solid var(--line);border-radius:999px;
  background:transparent;color:var(--bone);
  font-size:.85rem;cursor:pointer;transition:border-color .15s;
}
.pdp__color-btn:hover{border-color:var(--bone-38)}
.pdp__color-btn.is-active{border-color:var(--ceil)}
.pdp__color-btn .swatch{width:18px;height:18px}

.pdp__cta{
  display:flex;gap:12px;margin-top:8px;margin-bottom:32px;
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:16px 28px;border-radius:var(--radius-sm);
  font-weight:700;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;
  cursor:pointer;transition:all .15s;border:1px solid transparent;
}
.btn--primary{
  background:var(--ceil);color:var(--ink);flex:1;
}
.btn--primary:hover{background:var(--mint);transform:translateY(-1px)}
.btn--primary:active{transform:translateY(0)}
.btn--ghost{
  background:transparent;color:var(--bone);
  border-color:var(--line);
}
.btn--ghost:hover{border-color:var(--bone)}

.pdp__benefits{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:18px;padding:24px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-bottom:32px;
}
.pdp__benefit{
  display:flex;flex-direction:column;align-items:flex-start;gap:6px;
  font-size:.75rem;letter-spacing:.06em;color:var(--bone-60);
  text-transform:uppercase;font-weight:600;
}
.pdp__benefit svg{width:22px;height:22px;color:var(--ceil)}

/* accordion */
.pdp__accordion{border-top:1px solid var(--line)}
.pdp__acc-item{border-bottom:1px solid var(--line)}
.pdp__acc-head{
  width:100%;padding:18px 0;
  display:flex;justify-content:space-between;align-items:center;
  font-weight:700;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--bone);text-align:left;
}
.pdp__acc-head::after{
  content:"+";font-size:1.4rem;font-weight:300;
  color:var(--ceil);transition:transform .2s;
}
.pdp__acc-item.is-open .pdp__acc-head::after{
  content:"−";
}
.pdp__acc-body{
  display:none;padding:0 0 22px;
  color:var(--bone-60);font-size:.95rem;line-height:1.7;
}
.pdp__acc-item.is-open .pdp__acc-body{display:block}

/* ---- cart drawer ----------------------------------------- */
.cart-drawer{
  position:fixed;inset:0;z-index:100;
  pointer-events:none;
  visibility:hidden;opacity:0;
  transition:opacity .25s,visibility 0s linear .25s;
}
.cart-drawer.is-open{
  pointer-events:auto;visibility:visible;opacity:1;
  transition:opacity .25s,visibility 0s;
}
.cart-drawer__scrim{
  position:absolute;inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(2px);
}
.cart-drawer__panel{
  position:absolute;top:0;right:0;
  width:min(420px,100vw);height:100%;
  background:var(--ink);
  border-left:1px solid var(--line);
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .35s var(--ease-out);
}
.cart-drawer.is-open .cart-drawer__panel{transform:translateX(0)}
.cart-drawer__head{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 24px;border-bottom:1px solid var(--line);
}
.cart-drawer__title{
  font-weight:800;font-size:.85rem;
  letter-spacing:.22em;text-transform:uppercase;
}
.cart-drawer__close{
  font-size:1.6rem;color:var(--bone);
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  transition:background .15s;
}
.cart-drawer__close:hover{background:var(--line)}

.cart-drawer__body{flex:1;overflow-y:auto;padding:20px 24px}
.cart-drawer__empty{
  text-align:center;padding:40px 0;color:var(--bone-60);
  font-size:.95rem;
}

.cart-line{
  display:grid;grid-template-columns:80px 1fr;gap:14px;
  padding:16px 0;border-bottom:1px solid var(--line);
}
.cart-line__img{
  width:80px;height:100px;object-fit:cover;
  border-radius:var(--radius-sm);background:var(--graphite);
}
.cart-line__name{
  font-weight:700;font-size:.78rem;
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--bone);margin-bottom:4px;
}
.cart-line__opts{
  font-size:.78rem;color:var(--bone-60);margin-bottom:6px;
}
.cart-line__price{
  font-weight:700;font-size:.85rem;color:var(--bone);margin-bottom:8px;
}
.cart-line__stepper{
  display:flex;align-items:center;gap:6px;
  font-size:.85rem;
}
.cart-line__stepper button{
  width:24px;height:24px;
  border:1px solid var(--line);border-radius:4px;
  color:var(--bone);
  font-weight:600;
  display:flex;align-items:center;justify-content:center;
}
.cart-line__stepper button:hover{border-color:var(--bone)}
.cart-line__remove{
  margin-left:auto;font-size:.7rem;color:var(--bone-60);
  text-transform:uppercase;letter-spacing:.12em;
  border:none !important;width:auto !important;padding:0 6px;
}
.cart-line__remove:hover{color:var(--err)}

.cart-drawer__foot{
  padding:20px 24px;
  border-top:1px solid var(--line);
}
.cart-drawer__shipping{
  font-weight:700;font-size:.66rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ceil);text-align:center;
  margin-bottom:14px;
}
.cart-drawer__subtotal{
  display:flex;justify-content:space-between;
  font-weight:700;font-size:1rem;
  margin-bottom:16px;
}
.cart-drawer__actions{
  display:flex;flex-direction:column;gap:8px;
}

/* ---- toast ----------------------------------------------- */
.toast-host{
  position:fixed;bottom:24px;left:50%;
  transform:translateX(-50%);z-index:200;
  display:flex;flex-direction:column;gap:8px;
  pointer-events:none;
}
.toast{
  background:var(--graphite);color:var(--bone);
  border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:12px 18px;
  display:flex;align-items:center;gap:14px;
  font-size:.85rem;
  pointer-events:auto;
  animation:toast-in .25s var(--ease-out);
}
.toast.is-out{animation:toast-out .25s var(--ease-out) forwards}
.toast__action{
  color:var(--ceil);font-weight:700;font-size:.7rem;
  letter-spacing:.16em;text-transform:uppercase;
}
@keyframes toast-in{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes toast-out{to{transform:translateY(20px);opacity:0}}

/* ---- footer ---------------------------------------------- */
.site-footer{
  border-top:1px solid var(--line);
  padding:28px 0;
}
.site-footer .wrap{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:14px;
}
.site-footer span{
  font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--bone-60);
}
.shipping-note{color:var(--ceil) !important}

body.no-scroll{overflow:hidden}

/* ============================================================
   PDP class shim — product.js uses single-dash naming
   (.pdp-gallery, .pdp-option, .pdp-color, etc).
   These rules give them the same dark-theme treatment as the
   .pdp__* equivalents above.
   ============================================================ */
.pdp-gallery{display:flex;flex-direction:column;gap:14px}
.pdp-gallery__item{
  aspect-ratio:4/5;background:var(--graphite);
  border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;position:relative;
}
.pdp-gallery__item::after{
  content:"XII";position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-stretch:110%;font-size:8rem;
  letter-spacing:-.02em;color:rgba(247,245,240,.06);
  font-style:italic;pointer-events:none;z-index:0;
}
.pdp-gallery__item img{
  position:relative;z-index:1;
  width:100%;height:100%;object-fit:cover;
}

.pdp-option{margin-bottom:24px}
.pdp-option__label{
  display:flex;justify-content:space-between;align-items:baseline;
  font-weight:700;font-size:.72rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--bone);margin-bottom:12px;
}
.pdp-option__value{
  font-weight:400;color:var(--bone-60);
  text-transform:none;letter-spacing:0;
}
.pdp-option__link{
  font-size:.7rem;letter-spacing:.18em;color:var(--ceil);
  border-bottom:1px solid transparent;transition:border-color .2s;
}
.pdp-option__link:hover{border-bottom-color:var(--ceil)}

.pdp-colors{display:flex;flex-wrap:wrap;gap:10px}
.pdp-color{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px 8px 8px;
  border:1px solid var(--line);border-radius:999px;
  background:transparent;color:var(--bone);
  font-size:.85rem;cursor:pointer;transition:border-color .15s;
}
.pdp-color:hover{border-color:var(--bone-38)}
.pdp-color.is-active{border-color:var(--ceil)}
.pdp-color__dot{
  width:18px;height:18px;border-radius:50%;
  border:1px solid var(--bone-38);
}

.pdp-sizes{display:flex;flex-wrap:wrap;gap:8px}
.pdp-size{
  min-width:52px;padding:11px 14px;
  border:1px solid var(--line);border-radius:var(--radius-sm);
  background:transparent;color:var(--bone);
  font-weight:600;font-size:.82rem;letter-spacing:.06em;
  cursor:pointer;transition:all .15s;
}
.pdp-size:hover{border-color:var(--bone-38)}
.pdp-size.is-active{
  background:var(--bone);color:var(--ink);border-color:var(--bone);
}
.pdp-size.is-disabled{
  color:var(--bone-38);cursor:not-allowed;
  text-decoration:line-through;
}

.pdp-accordion{margin-top:32px;border-top:1px solid var(--line)}
.pdp-accordion__item{
  border-bottom:1px solid var(--line);
}
.pdp-accordion__item summary{
  padding:18px 0;cursor:pointer;
  font-weight:700;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--bone);list-style:none;
  display:flex;justify-content:space-between;align-items:center;
}
.pdp-accordion__item summary::-webkit-details-marker{display:none}
.pdp-accordion__item summary::after{
  content:"+";font-size:1.4rem;font-weight:300;color:var(--ceil);
}
.pdp-accordion__item[open] summary::after{content:"−"}
.pdp-accordion__body{
  padding:0 0 22px;color:var(--bone-60);
  font-size:.95rem;line-height:1.7;
}

.pdp-benefits{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  padding:24px 0;margin:32px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.pdp-benefit{
  display:flex;flex-direction:column;align-items:flex-start;gap:6px;
  font-size:.75rem;letter-spacing:.06em;color:var(--bone-60);
  text-transform:uppercase;font-weight:600;
}
.pdp-benefit svg{width:22px;height:22px;color:var(--ceil)}

.pdp-related{padding:60px 0 0;border-top:1px solid var(--line);margin-top:60px}
.pdp-related__grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:24px;
  margin-top:24px;
}
.section-eyebrow{
  font-weight:700;font-size:.75rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--bone);
}

.card--mini .card__media{aspect-ratio:1}

/* The PDP layout itself — top-level <main id="pdp"> needs spacing for fixed header */
#pdp{padding-top:100px;padding-bottom:80px}
#pdp > .pdp-layout, #pdp > .pdp-inner, #pdp > section{padding-inline:max(20px,calc((100vw - 1180px) / 2))}
#pdp > .pdp{padding:0}
#pdp .shop-empty{padding:100px 20px}

/* If product.js wraps the gallery + detail in a row, make it 2-col */
#pdp section.pdp,
#pdp div.pdp{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
  max-width:1180px;margin-inline:auto;
  padding:100px 20px 60px;
  align-items:flex-start;
}

#pdp .pdp-side{padding-top:12px}
#pdp .pdp-eyebrow{
  font-weight:600;font-size:.72rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ceil);margin-bottom:14px;
}
#pdp .pdp-title{
  font-weight:900;font-stretch:110%;
  font-size:clamp(1.8rem,4vw,2.8rem);
  line-height:1;letter-spacing:-.015em;
  text-transform:uppercase;color:var(--bone);margin-bottom:14px;
}
#pdp .pdp-price{
  font-size:1.4rem;font-weight:700;
  color:var(--bone);margin-bottom:30px;
}
#pdp .pdp-microcopy{
  margin-top:14px;font-size:.66rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--bone-60);text-align:center;
}
#pdp .pdp-qty{
  display:inline-flex;align-items:center;gap:14px;
  border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:8px 14px;
}
#pdp .pdp-qty button{
  width:24px;height:24px;color:var(--bone);
  font-weight:600;font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;
}
#pdp .btn--block{display:flex;width:100%}
#pdp .btn{margin-top:8px}

/* benefits + related sections inside #pdp need their own wrap to align */
#pdp .pdp-benefits,
#pdp .pdp-related{
  max-width:1180px;margin-inline:auto;
  padding-inline:20px;
}

/* ---- responsive ------------------------------------------ */
@media (max-width:900px){
  .shop-layout__inner{grid-template-columns:1fr;gap:0}
  .filter-rail{
    position:fixed;inset:0;z-index:60;
    background:var(--ink);padding:80px 24px 24px;
    transform:translateX(-100%);transition:transform .3s var(--ease-out);
    overflow-y:auto;
  }
  .filter-rail.is-open{transform:translateX(0)}
  .filter-toggle{display:inline-flex}
  .pdp__inner{grid-template-columns:1fr;gap:32px}
  .pdp{padding:80px 0 60px}
}

@media (max-width:560px){
  .shop-hero{padding:100px 0 24px}
  .shop-grid{grid-template-columns:repeat(2,1fr);gap:20px 12px}
  .card__name{font-size:.78rem}
  .card__price{font-size:.78rem}
  #hdr .site-nav{gap:14px}
  #hdr a.joinlink{font-size:.62rem;letter-spacing:.18em}
  .pdp__benefits{grid-template-columns:1fr;gap:12px}
}
