
/* MMS Product Shelf — "binder sleeve" grid */
.mps-shelf-wrap{
  --mps-cols-d: 6;
  --mps-cols-t: 4;
  --mps-cols-m: 2;
  --mps-gap: 12px;
  padding: 14px;
  box-sizing: border-box;
}
.mps-shelf-wrap *, .mps-shelf-wrap *::before, .mps-shelf-wrap *::after{ box-sizing: border-box; }

.mps-shelf-wrap.is-fullbleed{
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

/* Full-bleed safety: prevent mobile horizontal scroll caused by 100vw math */
@media (max-width: 782px){
  .mps-shelf-wrap.is-fullbleed{
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
    padding-left: 14px;
    padding-right: 14px;
  }
}
.mps-template-wide{
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 0;
}

.mps-grid{
  display: grid;
  grid-template-columns: repeat(var(--mps-cols-d), minmax(0, 1fr));
  gap: var(--mps-gap);
  align-items: stretch;
  grid-auto-flow: row dense;
}

@media (max-width: 980px){
  .mps-grid{ grid-template-columns: repeat(var(--mps-cols-t), minmax(0, 1fr)); }
}
@media (max-width: 600px){
  .mps-grid{ grid-template-columns: repeat(var(--mps-cols-m), minmax(0, 1fr)); }
}

.mps-card{ min-width: 0; }

.mps-sleeve{
  border: 1px solid rgba(0,0,0,.18);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.93)),
    radial-gradient(120% 80% at 20% 10%, rgba(255,255,255,.9), rgba(255,255,255,0));
  box-shadow: 0 12px 36px rgba(0,0,0,.08);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 100%;
  position: relative;
}

.mps-sleeve::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(120deg, rgba(255,255,255,.0) 0%, rgba(255,255,255,.12) 25%, rgba(255,255,255,.0) 60%),
    linear-gradient(0deg, rgba(0,0,0,.02), rgba(0,0,0,0));
  mix-blend-mode: screen;
  opacity: .9;
}

.mps-media{
  position: relative;
  aspect-ratio: 3 / 4;
  background: rgba(0,0,0,.04);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  max-height: 340px;
}
@media (max-width: 600px){
  .mps-media{ max-height: 280px; }
}


/* Smart layout: landscape cards get a wider sleeve + landscape aspect ratio */
.mps-shelf-wrap[data-smart-landscape="1"] .mps-card.mps-is-landscape{ grid-column: span 2; }
.mps-shelf-wrap[data-smart-landscape="1"] .mps-card.mps-is-landscape .mps-media{ aspect-ratio: 16 / 9; }

/* Safety: if the grid has only 1 column at a breakpoint, don't span 2 */
.mps-shelf-wrap.mps-cols-d-1[data-smart-landscape="1"] .mps-card.mps-is-landscape{ grid-column: span 1; }
@media (max-width: 980px){
  .mps-shelf-wrap.mps-cols-t-1[data-smart-landscape="1"] .mps-card.mps-is-landscape{ grid-column: span 1; }
}
@media (max-width: 600px){
  .mps-shelf-wrap.mps-cols-m-1[data-smart-landscape="1"] .mps-card.mps-is-landscape{ grid-column: span 1; }
}

.mps-owned-badge{
  position:absolute;
  top: 10px;
  left: 10px;
  z-index: 5;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  background: rgba(0,0,0,.72);
  color: #fff;
  border: 1px solid rgba(255,255,255,.25);
  backdrop-filter: blur(8px);
}

.mps-img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display:block;
}

.mps-noimg{
  font-weight: 900;
  opacity: .55;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.mps-info{
  padding: 12px 12px 14px;
  display:flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  z-index: 2;
}

.mps-title{
  margin: 0;
  font-size: 14px;
  line-height: 1.15;
  font-weight: 900;
}

.mps-shelf-wrap .mps-title-link{
  display: inline-block;
  cursor: pointer;
  color: #0b57d0 !important; /* classic blue link */
  text-decoration: underline !important;
}
.mps-shelf-wrap .mps-title-link .mps-title{
  color: #0b57d0 !important;
  text-decoration: underline !important;
}
.mps-shelf-wrap .mps-title-link:hover,
.mps-shelf-wrap .mps-title-link:hover .mps-title{
  color: #0847a6 !important;
  text-decoration: underline !important;
}

.mps-shelf-wrap.is-compact-title .mps-title{
  font-size: 13px;
}

.mps-access-label{
  font-size: 12px;
  font-weight: 800;
  opacity: .85;
}

.mps-desc{
  font-size: 12px;
  opacity: .82;
  line-height: 1.25;
}

.mps-price{
  font-weight: 900;
  font-size: 13px;
}

.mps-actions{
  display:flex;
  gap: 8px;
  margin-top: auto;
  flex-wrap: wrap;
}

.mps-buy-form{ margin: 0; }

.mps-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.18);
  font-weight: 900;
  text-decoration: none;
  background: #fff;
  cursor: pointer;
  line-height: 1;
}

.mps-btn:hover{ transform: translateY(-1px); }
.mps-btn:active{ transform: translateY(0px); }

.mps-btn.is-disabled{
  opacity: .55;
  user-select:none;
  cursor: not-allowed;
}

.mps-btn-secondary{
  background: rgba(255,255,255,.75);
}

/* Carousel */
.mps-carousel{ position: relative; width: 100%; height: 100%; overflow:hidden; }
.mps-track{ display:flex; height:100%; width:100%; transform: translateX(0%); transition: transform 220ms ease; }
.mps-slide{ flex: 0 0 100%; height: 100%; }

.mps-nav{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 30px;
  height: 30px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.18);
  background: rgba(255,255,255,.6);
  backdrop-filter: blur(6px);
  cursor: pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 18px;
  line-height: 1;
  z-index: 3;
}
.mps-prev{ left: 10px; }
.mps-next{ right: 10px; }


/* Dots (Instagram-style) theming */
.mps-shelf-wrap{
  --mps-dots-pill-bg: rgba(0,0,0,.22);
  --mps-dot-off: rgba(255,255,255,.60);
  --mps-dot-on: rgba(255,255,255,.95);
  --mps-dots-label: rgba(255,255,255,.90);
}
.mps-shelf-wrap.mps-dots-theme-dark{
  --mps-dots-pill-bg: rgba(0,0,0,.22);
  --mps-dot-off: rgba(255,255,255,.60);
  --mps-dot-on: rgba(255,255,255,.95);
  --mps-dots-label: rgba(255,255,255,.90);
}
.mps-shelf-wrap.mps-dots-theme-light{
  --mps-dots-pill-bg: rgba(255,255,255,.78);
  --mps-dot-off: rgba(0,0,0,.30);
  --mps-dot-on: rgba(0,0,0,.88);
  --mps-dots-label: rgba(0,0,0,.70);
}
.mps-shelf-wrap.mps-dots-theme-high{
  --mps-dots-pill-bg: rgba(0,0,0,.40);
  --mps-dot-off: rgba(255,255,255,.75);
  --mps-dot-on: rgba(255,255,255,1);
  --mps-dots-label: rgba(255,255,255,.95);
}
.mps-shelf-wrap.mps-dots-theme-brand{
  --mps-dots-pill-bg: rgba(0,0,0,.22);
  --mps-dot-off: rgba(255,255,255,.55);
  --mps-dot-on: rgba(0,255,160,.95);
  --mps-dots-label: rgba(255,255,255,.90);
}
.mps-shelf-wrap.mps-dots-theme-none{
  --mps-dots-pill-bg: transparent;
  --mps-dot-off: rgba(0,0,0,.45);
  --mps-dot-on: rgba(0,0,0,.95);
  --mps-dots-label: rgba(0,0,0,.70);
}

.mps-dots{
  position:absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  display:flex;
  flex-direction: column;
  align-items:center;
  gap: 3px;
  justify-content:center;
  z-index: 3;
  padding: 5px 9px;
  border-radius: 999px;
  background: var(--mps-dots-pill-bg);
  backdrop-filter: blur(6px);
  box-shadow: 0 6px 18px rgba(0,0,0,.10);
}
.mps-dots-row{ display:flex; gap: 6px; justify-content:center; }
.mps-dots-label{ font-size: 11px; line-height: 1; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--mps-dots-label); }
.mps-dots span{
  width: 6px;
  height: 6px;
  border-radius: 999px;
  border: none;
  background: var(--mps-dot-off);
  transition: transform .12s ease, background .12s ease;
}
.mps-dots span.is-on{ background: var(--mps-dot-on); }

/* Flip */
.mps-flip{ width: 100%; height: 100%; perspective: 1000px; cursor: pointer; }
.mps-flip-inner{
  width: 100%;
  height: 100%;
  position: relative;
  transition: transform 260ms ease;
  transform-style: preserve-3d;
}
.mps-flip:hover .mps-flip-inner,
.mps-flip.is-flipped .mps-flip-inner{ transform: rotateY(180deg); }
.mps-front, .mps-back{
  position:absolute;
  inset:0;
  backface-visibility: hidden;
}
.mps-back{ transform: rotateY(180deg); }

/* Navigation styles */
.mps-carousel.nav-dots .mps-nav{ display:none; }
.mps-carousel.nav-arrows .mps-dots{ display:none; }
.mps-carousel.nav-none .mps-nav,
.mps-carousel.nav-none .mps-dots{ display:none; }

/* Both: arrows only on hover (desktop), never on mobile */
.mps-carousel.nav-both .mps-nav{ opacity: 0; pointer-events: none; transition: opacity .15s ease; }
.mps-carousel.nav-both:hover .mps-nav{ opacity: 1; pointer-events: auto; }
@media (max-width: 782px){
  .mps-carousel.nav-both .mps-nav{ display:none; }
}




@media (max-width: 782px){
  /* On 2-column mobile grids, let landscape cards take the full row (both columns) */
  .mps-shelf-wrap.mps-cols-m-2[data-smart-landscape="1"] .mps-card.mps-is-landscape{ grid-column: 1 / -1; }
}

.mps-shelf-wrap.mps-dots-theme-none .mps-dots{ backdrop-filter: none; box-shadow: none; }


/* Mobile dots positioning: keep dots+label lower so they don't cover card meta */
@media (max-width: 782px){
  .mps-dots{ bottom: 3px; padding: 4px 8px; gap: 2px; }
  .mps-dots-label{ font-size: 10px; }
}

/* Desktop: make dots pill look clickable when used as a toggle */
@media (hover:hover) and (pointer:fine){
  .mps-carousel.nav-dots .mps-dots,
  .mps-carousel.nav-both .mps-dots{ cursor: pointer; }
}


/* Shelf: subtle toast + loading state */
.mps-toast{
  position: fixed;
  left: 14px;
  bottom: 14px;
  z-index: 999999;
  padding: 10px 12px;
  border-radius: 14px;
  font-weight: 800;
  font-size: 13px;
  background: rgba(0,0,0,.78);
  color: #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .18s ease, transform .18s ease;
  pointer-events: none;
}
.mps-toast.is-on{ opacity: 1; transform: translateY(0); }

.mps-btn.is-loading{
  opacity: .75;
  cursor: progress;
}

/* Compatibility: if a floating cart widget is hidden via [hidden] or display:none, we try to wake it */
.mps-cart-wake{ opacity: 1 !important; visibility: visible !important; }


/* Make product titles look like classic clickable hyperlinks */
.mps-shelf-wrap .mps-card-title a{
  color:#0645AD !important;
  text-decoration: underline !important;
  text-underline-offset: 2px;
}
.mps-shelf-wrap .mps-card-title a:hover,
.mps-shelf-wrap .mps-card-title a:focus{
  color:#0B3D91 !important;
}



/* Smart Logic stats */
.mps-stats{margin-top:6px;font-size:12px;opacity:.88;display:flex;flex-direction:column;gap:2px}
.mps-stat-line{display:flex;justify-content:space-between;gap:8px}
.mps-stat-label{font-weight:800}
.mps-stat-value{font-variant-numeric:tabular-nums;font-weight:900}
