html.is-modal-open,
html.is-modal-open body{overflow:hidden;}

#productModal.pmodal,
#addonModal.pmodal{
  z-index:70000;
  align-items:stretch;
  justify-content:flex-start;
  padding:0;
}

/* Final sizing pass requested after desktop/mobile visual checks. */
#productModal.pmodal{
  background:rgba(246,239,233,.54) !important;
}

#productModal .pmodal__overlay,
#productModal .pmodal__overlay::before,
#productModal .pmodal__overlay::after{
  background:transparent !important;
  filter:none !important;
  -webkit-backdrop-filter:none !important;
  backdrop-filter:none !important;
}

@media (min-width:921px){
  #productModal.pmodal{
    justify-content:flex-start !important;
    align-items:stretch !important;
    padding:0 !important;
  }

  #productModal .pmodal__dialog{
    width:min(740px,calc(100vw - 18px)) !important;
    height:100dvh !important;
    max-height:100dvh !important;
    margin:0 !important;
    border-radius:0 14px 14px 0 !important;
  }

  #productModal .pmodal__grid{
    grid-template-columns:minmax(0,54%) minmax(250px,46%) !important;
    min-height:100% !important;
  }

  #productModal .pmodal__media{
    padding:16px 14px 16px 12px !important;
  }

  #productModal .pmodal__mediaInner{
    grid-template-columns:54px minmax(0,1fr) !important;
    grid-template-rows:minmax(0,1fr) 36px !important;
    gap:9px 11px !important;
  }

  #productModal .pmodal__slider{
    height:min(456px,calc(100dvh - 108px)) !important;
    min-height:0 !important;
  }

  #productModal .pmodal__photoFrame{
    height:100% !important;
  }

  #productModal .pmodal__img,
  #productModal .pmodal__slider .pmodal__img{
    object-fit:contain !important;
  }

  #productModal .pmodal__thumbs{
    padding:3px !important;
    gap:8px !important;
  }

  #productModal .pmodal__thumb{
    width:50px !important;
    height:68px !important;
    flex-basis:68px !important;
    border-radius:8px !important;
    box-sizing:border-box !important;
  }

  #productModal .pmodal__content{
    padding:30px 28px 18px !important;
    gap:8px !important;
  }

  #productModal .pmodal__title{
    font-size:25px !important;
  }

  #productModal .pmodal__price{
    font-size:20px !important;
  }

  #productModal .pmodal__desc,
  #productModal .pmodal__label,
  #productModal .pmodal__text{
    font-size:13px !important;
    line-height:1.36 !important;
  }

  #productModal .pmodal__size{
    width:58px !important;
    height:56px !important;
  }

  #productModal .pmodal__sizeCode{
    font-size:14px !important;
  }

  #productModal .pmodal__sizeLabel{
    font-size:10px !important;
  }

  #productModal .pmodal__qty{
    width:102px !important;
    height:34px !important;
    grid-template-columns:34px 34px 34px !important;
  }

  #productModal .pmodal__qtybtn,
  #productModal .pmodal__qtyinput{
    width:34px !important;
    height:32px !important;
    font-size:14px !important;
  }

  #productModal .pmodal__actions .btn--buy{
    min-width:160px !important;
    height:40px !important;
    font-size:14px !important;
  }

  #productModal .pmodal__actions .btn--cart{
    width:40px !important;
    min-width:40px !important;
    height:40px !important;
  }

  #productModal .pmodal__panelHead{
    min-height:42px !important;
    font-size:14px !important;
  }

  #productModal .pmodal__badges{
    margin-top:8px !important;
  }

  #productModal .pmodal__badge{
    min-height:28px !important;
    padding:0 10px !important;
    font-size:10px !important;
  }
}

@media (max-width:920px){
  #productModal.pmodal{
    padding:0 !important;
    align-items:flex-start !important;
    justify-content:center !important;
  }

  #productModal .pmodal__dialog{
    width:min(318px,calc(100vw - 64px)) !important;
    max-width:calc(100vw - 64px) !important;
    max-height:calc(100dvh - 18px) !important;
    margin:9px auto !important;
    border-radius:14px !important;
  }

  #productModal .pmodal__media{
    padding:7px 7px 0 !important;
  }

  #productModal .pmodal__slider{
    max-height:184px !important;
    aspect-ratio:1.42 / 1 !important;
  }

  #productModal .pmodal__thumbs{
    height:36px !important;
    gap:7px !important;
  }

  #productModal .pmodal__thumb{
    width:48px !important;
    height:34px !important;
    flex-basis:48px !important;
  }

  #productModal .pmodal__content{
    padding:12px 12px 14px !important;
    gap:6px !important;
  }

  #productModal .pmodal__title{
    font-size:20px !important;
  }

  #productModal .pmodal__price{
    font-size:18px !important;
  }

  #productModal .pmodal__desc,
  #productModal .pmodal__label,
  #productModal .pmodal__text{
    font-size:12px !important;
    line-height:1.32 !important;
  }

  #productModal .pmodal__size{
    height:46px !important;
    min-width:66px !important;
  }

  #productModal .pmodal__sizeCode{
    font-size:13px !important;
  }

  #productModal .pmodal__sizeLabel{
    font-size:10px !important;
  }

  #productModal .pmodal__qty{
    width:96px !important;
    height:32px !important;
    grid-template-columns:32px 32px 32px !important;
  }

  #productModal .pmodal__qtybtn,
  #productModal .pmodal__qtyinput{
    width:32px !important;
    height:30px !important;
    font-size:14px !important;
  }

  #productModal .pmodal__actions .btn--buy{
    height:38px !important;
    font-size:13px !important;
  }

  #productModal .pmodal__actions .btn--cart{
    width:38px !important;
    min-width:38px !important;
    height:38px !important;
  }

  #productModal .pmodal__panelHead{
    min-height:36px !important;
    font-size:13px !important;
  }

  #productModal .pmodal__badges{
    display:none !important;
  }
}

/* Product modal final repair, 2026-06-03. Keep this block last. */
#productModal.pmodal{
  background:rgba(246,239,233,.56) !important;
}

#productModal .pmodal__overlay,
#productModal .pmodal__overlay::before,
#productModal .pmodal__overlay::after{
  background:transparent !important;
  filter:none !important;
  -webkit-backdrop-filter:none !important;
  backdrop-filter:none !important;
}

#productModal .pmodal__img,
#productModal .pmodal__slider .pmodal__img{
  object-fit:contain !important;
}

#productModal .pmodal__photoFrame{
  overflow:hidden !important;
}

@media (min-width:921px){
  #productModal.pmodal{
    align-items:stretch !important;
    justify-content:flex-start !important;
    padding:0 !important;
  }

  #productModal .pmodal__dialog{
    width:min(1260px,calc(100vw - 20px)) !important;
    height:100dvh !important;
    max-height:100dvh !important;
    margin:0 !important;
    border-radius:0 14px 14px 0 !important;
  }

  #productModal .pmodal__grid{
    grid-template-columns:minmax(0,61%) minmax(340px,39%) !important;
    min-height:100% !important;
  }

  #productModal .pmodal__media{
    padding:30px 24px 30px 20px !important;
  }

  #productModal .pmodal__mediaInner{
    display:grid !important;
    grid-template-columns:104px minmax(0,1fr) !important;
    grid-template-rows:minmax(0,1fr) auto !important;
    grid-template-areas:
      "thumbs slider"
      "pager badges" !important;
    gap:20px 18px !important;
    height:100% !important;
    min-height:0 !important;
  }

  #productModal .pmodal__slider{
    grid-area:slider !important;
    width:100% !important;
    height:min(78dvh,760px) !important;
    min-height:0 !important;
    aspect-ratio:auto !important;
    align-self:center !important;
  }

  #productModal .pmodal__photoFrame{
    width:100% !important;
    height:100% !important;
    border-radius:13px !important;
    background:#fff !important;
  }

  #productModal .pmodal__thumbs{
    grid-area:thumbs !important;
    width:104px !important;
    height:auto !important;
    max-height:min(78dvh,760px) !important;
    padding:2px !important;
    gap:18px !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
    align-self:center !important;
  }

  #productModal .pmodal__thumb{
    width:96px !important;
    height:122px !important;
    flex:0 0 122px !important;
    border-radius:9px !important;
    padding:3px !important;
    box-sizing:border-box !important;
    object-fit:cover !important;
  }

  #productModal .pmodal__pager{
    grid-area:pager !important;
    width:104px !important;
    height:44px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    align-self:start !important;
  }

  #productModal .pmodal__badges--media{
    grid-area:badges !important;
    display:flex !important;
    justify-content:center !important;
    gap:16px !important;
    margin:0 !important;
  }

  #productModal .pmodal__badges--content{
    display:none !important;
  }

  #productModal .pmodal__badge{
    min-width:154px !important;
    min-height:44px !important;
    padding:0 18px !important;
    border-radius:999px !important;
    font-size:14px !important;
  }

  #productModal .pmodal__content{
    padding:58px 52px 36px !important;
    gap:18px !important;
    overflow-y:auto !important;
  }

  #productModal .pmodal__close{
    top:28px !important;
    right:28px !important;
    width:52px !important;
    height:52px !important;
  }

  #productModal .pmodal__title{
    font-size:39px !important;
    line-height:1.08 !important;
  }

  #productModal .pmodal__price{
    font-size:29px !important;
    line-height:1.1 !important;
  }

  #productModal .pmodal__desc,
  #productModal .pmodal__text{
    font-size:18px !important;
    line-height:1.5 !important;
  }

  #productModal .pmodal__label{
    font-size:17px !important;
  }

  #productModal .pmodal__sizeList{
    gap:16px !important;
  }

  #productModal .pmodal__size{
    width:84px !important;
    height:82px !important;
    min-width:84px !important;
  }

  #productModal .pmodal__sizeCode{
    font-size:20px !important;
  }

  #productModal .pmodal__sizeLabel{
    font-size:14px !important;
  }

  #productModal .pmodal__qty{
    width:160px !important;
    height:52px !important;
    grid-template-columns:52px 56px 52px !important;
  }

  #productModal .pmodal__qtybtn,
  #productModal .pmodal__qtyinput{
    width:auto !important;
    height:50px !important;
    font-size:18px !important;
  }

  #productModal .pmodal__actions .card__btnrow{
    gap:18px !important;
  }

  #productModal .pmodal__actions .btn--buy{
    min-width:244px !important;
    height:58px !important;
    font-size:18px !important;
  }

  #productModal .pmodal__actions .btn--cart{
    width:58px !important;
    min-width:58px !important;
    height:58px !important;
  }

  #productModal .pmodal__panelHead{
    min-height:60px !important;
    font-size:18px !important;
  }
}

@media (max-width:920px){
  html.is-modal-open,
  html.is-modal-open body{
    overflow:hidden !important;
  }

  #productModal.pmodal{
    align-items:stretch !important;
    justify-content:stretch !important;
    padding:0 !important;
    background:rgba(32,30,29,.82) !important;
  }

  #productModal .pmodal__dialog{
    width:100vw !important;
    max-width:none !important;
    height:100dvh !important;
    max-height:100dvh !important;
    margin:0 !important;
    border-radius:0 !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
  }

  #productModal .pmodal__grid{
    display:block !important;
    min-height:0 !important;
  }

  #productModal .pmodal__media{
    padding:10px 10px 0 !important;
    border-right:0 !important;
  }

  #productModal .pmodal__mediaInner{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) 44px !important;
    grid-template-rows:auto auto !important;
    grid-template-areas:
      "slider slider"
      "thumbs pager" !important;
    gap:10px !important;
    height:auto !important;
  }

  #productModal .pmodal__slider{
    grid-area:slider !important;
    width:100% !important;
    height:auto !important;
    max-height:none !important;
    aspect-ratio:1.34 / 1 !important;
    border-radius:16px !important;
  }

  #productModal .pmodal__photoFrame{
    width:100% !important;
    height:100% !important;
    border-radius:16px !important;
    background:#fff !important;
  }

  #productModal .pmodal__zoom{
    display:none !important;
  }

  #productModal .pmodal__close{
    top:18px !important;
    right:18px !important;
    width:42px !important;
    height:42px !important;
    z-index:5 !important;
  }

  #productModal .pmodal__thumbs{
    grid-area:thumbs !important;
    width:100% !important;
    height:48px !important;
    padding:0 !important;
    gap:8px !important;
    display:flex !important;
    overflow-x:auto !important;
    overflow-y:hidden !important;
  }

  #productModal .pmodal__thumb{
    width:58px !important;
    height:46px !important;
    flex:0 0 58px !important;
    border-radius:8px !important;
    padding:2px !important;
    box-sizing:border-box !important;
    object-fit:cover !important;
  }

  #productModal .pmodal__pager{
    grid-area:pager !important;
    position:relative !important;
    left:0 !important;
    top:0 !important;
    width:44px !important;
    height:48px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    transition:transform .28s ease !important;
    transform:translateX(0) !important;
  }

  #productModal.is-image-after-first .pmodal__pager{
    transform:translateX(calc(-100vw + 72px)) !important;
  }

  #productModal.is-image-first .pmodal__nav--prev,
  #productModal.is-image-after-first .pmodal__nav--next{
    display:none !important;
  }

  #productModal.is-image-first .pmodal__nav--next,
  #productModal.is-image-after-first .pmodal__nav--prev{
    display:flex !important;
  }

  #productModal .pmodal__nav{
    width:42px !important;
    height:42px !important;
    border-radius:50% !important;
  }

  #productModal .pmodal__badges,
  #productModal .pmodal__badges--media,
  #productModal .pmodal__badges--content{
    display:none !important;
  }

  #productModal .pmodal__content{
    padding:14px 16px 18px !important;
    gap:10px !important;
  }

  #productModal .pmodal__title{
    font-size:26px !important;
    line-height:1.08 !important;
  }

  #productModal .pmodal__price{
    font-size:22px !important;
    line-height:1.1 !important;
  }

  #productModal .pmodal__desc,
  #productModal .pmodal__text{
    font-size:14px !important;
    line-height:1.36 !important;
  }

  #productModal .pmodal__label{
    font-size:14px !important;
  }

  #productModal .pmodal__divider{
    margin:0 !important;
  }

  #productModal .pmodal__sizeList{
    gap:10px !important;
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }

  #productModal .pmodal__size{
    width:auto !important;
    min-width:0 !important;
    height:58px !important;
  }

  #productModal .pmodal__sizeCode{
    font-size:17px !important;
  }

  #productModal .pmodal__sizeLabel{
    font-size:12px !important;
  }

  #productModal .pmodal__qty{
    width:118px !important;
    height:38px !important;
    grid-template-columns:38px 40px 38px !important;
  }

  #productModal .pmodal__qtybtn,
  #productModal .pmodal__qtyinput{
    height:36px !important;
    font-size:16px !important;
  }

  #productModal .pmodal__actions .card__btnrow{
    grid-template-columns:minmax(0,1fr) 50px !important;
    gap:10px !important;
  }

  #productModal .pmodal__actions .btn--buy{
    height:48px !important;
    min-width:0 !important;
    font-size:16px !important;
  }

  #productModal .pmodal__actions .btn--cart{
    width:50px !important;
    min-width:50px !important;
    height:48px !important;
  }

  #productModal .pmodal__panelHead{
    min-height:44px !important;
    font-size:15px !important;
  }
}

#productModal .pmodal__dialog,
#addonModal .pmodal__dialog{
  width:min(1080px,calc(100vw - 24px));
  height:100vh;
  max-height:100vh;
  border-radius:0 18px 18px 0;
}

#productModal .pmodal__grid,
#addonModal .pmodal__grid{
  grid-template-columns:1.08fr .92fr;
  height:100vh;
  max-height:100vh;
}

#productModal .pmodal__media,
#addonModal .pmodal__media{
  align-items:stretch;
  padding:18px;
}

#productModal .pmodal__mediaInner,
#addonModal .pmodal__mediaInner{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:0;
  padding:0 0 18px;
  border-radius:14px;
  box-shadow:none;
}

#productModal .pmodal__slider,
#addonModal .pmodal__slider{
  flex:1 1 auto;
  min-height:360px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border-radius:18px;
  background:rgba(255,255,255,.38);
}

#productModal .pmodal__slider .pmodal__img,
#productModal .pmodal__img,
#addonModal .pmodal__slider .pmodal__img,
#addonModal .pmodal__img{
  width:100%;
  height:100%;
  max-height:560px;
  object-fit:contain;
  aspect-ratio:auto;
  border-radius:0;
  opacity:1 !important;
  filter:none !important;
  mix-blend-mode:normal !important;
  transform:none !important;
  -webkit-mask-image:none !important;
  mask-image:none !important;
}

#productModal .pmodal__content,
#addonModal .pmodal__content{
  max-height:100vh;
  overflow-y:auto;
  padding:30px 38px 28px;
  gap:13px;
  scrollbar-width:thin;
}

#productModal .pmodal__title,
#addonModal .pmodal__title{
  color:#7d6b66;
  font-family:"Playfair Display", Georgia, serif;
  font-size:30px;
  font-weight:500;
  line-height:1.12;
  letter-spacing:0;
}

#productModal .pmodal__price,
#addonModal .pmodal__price{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  color:#d55265;
  font-family:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size:22px;
  font-weight:700;
  font-variant-numeric:tabular-nums;
  line-height:1.15;
}

#productModal .pmodal__priceOld{
  color:rgba(47,38,37,.42);
  font-size:17px;
  text-decoration:line-through;
  font-weight:600;
}

#productModal .pmodal__priceNew,
#productModal .pmodal__priceCurrent{
  color:#d55265;
  font-weight:700;
}

#productModal .pmodal__discount{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:24px;
  padding:3px 8px;
  border-radius:999px;
  background:rgba(184,77,95,.10);
  color:#b84d5f;
  font-size:12px;
  font-weight:700;
}
#productModal .pmodal__desc,
#addonModal .pmodal__desc{font-size:14px;line-height:1.45;}

#productModal .pmodal__sizeList{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

#productModal .pmodal__size{
  width:72px;
  height:72px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:7px;
  border-radius:10px;
  border:1px solid rgba(124,107,104,.12);
  background:rgba(255,255,255,.62);
  color:#7c6b68;
  cursor:pointer;
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

#productModal .pmodal__size:hover{
  transform:translateY(-1px);
  border-color:rgba(184,77,95,.38);
}

#productModal .pmodal__size.is-active{
  border-color:rgba(184,77,95,.75);
  box-shadow:0 0 0 3px rgba(184,77,95,.10);
}

#productModal .pmodal__sizeCode{
  color:#b84d5f;
  font-weight:700;
  font-size:16px;
}

#productModal .pmodal__sizeLabel{
  color:rgba(124,107,104,.70);
  font-size:11px;
}

#productModal .pmodal__actions .card__btnrow,
#addonModal .pmodal__actions .card__btnrow{
  display:flex;
  gap:14px;
}

#productModal .pmodal__actions .btn--buy,
#addonModal .pmodal__actions .btn--buy{
  min-width:210px;
  height:54px;
  border-radius:22px;
  gap:12px;
}

#productModal .pmodal__actions .btn--cart,
#addonModal .pmodal__actions .btn--cart{
  width:54px;
  min-width:54px;
  height:54px;
  border-radius:999px;
}

#productModal .pmodal__accordion,
#addonModal .pmodal__accordion{
  margin-top:8px;
  border-top:1px solid rgba(0,0,0,.08);
}

#productModal .pmodal__panel,
#addonModal .pmodal__panel{
  border-bottom:1px solid rgba(0,0,0,.08);
}

#productModal .pmodal__panelHead,
#addonModal .pmodal__panelHead{
  width:100%;
  min-height:62px;
  display:grid;
  grid-template-columns:24px 1fr 24px;
  gap:12px;
  align-items:center;
  border:0;
  background:transparent;
  color:#7c4b4f;
  cursor:pointer;
  padding:0;
  text-align:left;
  font-family:"Playfair Display",Georgia,serif;
  font-size:16px;
  font-weight:600;
}

#productModal .pmodal__panelIcon svg,
#addonModal .pmodal__panelIcon svg{
  width:22px;
  height:22px;
  display:block;
}

#productModal .pmodal__panelChevron,
#addonModal .pmodal__panelChevron{
  justify-self:end;
  transition:transform .18s ease;
}

#productModal .pmodal__panel.is-open .pmodal__panelChevron,
#addonModal .pmodal__panel.is-open .pmodal__panelChevron{
  transform:rotate(180deg);
}

#productModal .pmodal__panelBody,
#addonModal .pmodal__panelBody{
  padding:0 0 18px 36px;
  color:rgba(43,43,43,.68);
  font-size:13px;
  line-height:1.55;
}

#productModal .pmodal__panelBody p,
#addonModal .pmodal__panelBody p{
  margin:0 0 10px;
}

#productModal .pmodal__close svg,
#addonModal .pmodal__close svg{
  width:20px;
  height:20px;
}

#productModal .pmodal__close,
#addonModal .pmodal__close,
#productModal .pmodal__nav,
#addonModal .pmodal__nav{
  width:42px;
  height:42px;
  border-radius:50%;
  border:1px solid rgba(126,105,100,.28) !important;
  background:rgba(255,255,255,.18) !important;
  color:#7d6b66 !important;
  box-shadow:none !important;
  -webkit-backdrop-filter:none;
  backdrop-filter:none;
}

#productModal .pmodal__close:hover,
#addonModal .pmodal__close:hover,
#productModal .pmodal__nav:hover,
#addonModal .pmodal__nav:hover{
  background:rgba(255,255,255,.34) !important;
  border-color:rgba(126,105,100,.42) !important;
  box-shadow:none !important;
}

#productModal .pmodal__nav,
#addonModal .pmodal__nav{
  font-size:0;
}

#productModal .pmodal__nav::before,
#addonModal .pmodal__nav::before{
  content:"";
  width:10px;
  height:10px;
  border-top:1.8px solid currentColor;
  border-left:1.8px solid currentColor;
}

#productModal .pmodal__nav--prev::before,
#addonModal .pmodal__nav--prev::before{
  transform:translateX(2px) rotate(-45deg);
}

#productModal .pmodal__nav--next::before,
#addonModal .pmodal__nav--next::before{
  transform:translateX(-2px) rotate(135deg);
}

@media (max-width:920px){
  #productModal.pmodal,
  #addonModal.pmodal{
    align-items:flex-start;
    justify-content:center;
    overflow-y:auto;
  }

  #productModal .pmodal__dialog,
  #productModal .pmodal__grid,
  #productModal .pmodal__content,
  #addonModal .pmodal__dialog,
  #addonModal .pmodal__grid,
  #addonModal .pmodal__content{
    height:auto;
    max-height:none;
  }

  #productModal .pmodal__dialog,
  #addonModal .pmodal__dialog{
    width:100vw;
    min-height:100vh;
    border-radius:0;
  }

  #productModal .pmodal__grid,
  #addonModal .pmodal__grid{
    grid-template-columns:1fr;
  }

  #productModal .pmodal__slider,
  #addonModal .pmodal__slider{
    min-height:280px;
  }

  #productModal .pmodal__content,
  #addonModal .pmodal__content{
    padding:22px 20px 24px;
  }

  #productModal .pmodal__actions .btn--buy,
  #addonModal .pmodal__actions .btn--buy{
    min-width:0;
    flex:1 1 auto;
  }

  #productModal .pmodal__close,
  #addonModal .pmodal__close,
  #productModal .pmodal__nav,
  #addonModal .pmodal__nav{
    width:38px;
    height:38px;
    background:rgba(255,255,255,.16) !important;
  }
}

@media (max-width:640px){
  #productModal .pmodal__close svg,
  #addonModal .pmodal__close svg{
    display:none;
  }

  #productModal .pmodal__close::before,
  #productModal .pmodal__close::after,
  #addonModal .pmodal__close::before,
  #addonModal .pmodal__close::after{
    content:"";
    position:absolute;
    width:14px;
    height:2px;
    border-radius:999px;
    background:currentColor;
  }

  #productModal .pmodal__close::before,
  #addonModal .pmodal__close::before{
    transform:rotate(45deg);
  }

  #productModal .pmodal__close::after,
  #addonModal .pmodal__close::after{
    transform:rotate(-45deg);
  }
}

/* Product modal reference layout */
#productModal.pmodal{
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(248,245,241,.82);
}

#productModal .pmodal__overlay{
  background:rgba(248,245,241,.82);
}

#productModal .pmodal__overlay::before,
#productModal .pmodal__overlay::after{
  content:none !important;
  display:none !important;
}

#productModal .pmodal__dialog{
  width:min(1360px,calc(100vw - 36px));
  height:min(920px,calc(100dvh - 36px));
  max-height:calc(100dvh - 36px);
  border-radius:18px;
  border:1px solid rgba(126,105,100,.16);
  background:#fff;
  box-shadow:0 28px 70px rgba(68,48,40,.18);
  overflow:hidden;
}

#productModal .pmodal__grid{
  display:grid;
  grid-template-columns:minmax(0,59.5%) minmax(390px,40.5%);
  height:100%;
  max-height:none;
}

#productModal .pmodal__media{
  min-height:0;
  height:100%;
  padding:30px;
  align-items:stretch;
  justify-content:stretch;
  background:#fff !important;
  border-right:1px solid rgba(126,105,100,.12);
  overflow:hidden;
}

#productModal .pmodal__mediaInner{
  display:grid;
  grid-template-columns:114px minmax(0,1fr);
  grid-template-rows:minmax(0,1fr) 72px;
  grid-template-areas:
    "thumbs slider"
    "pager badges";
  gap:22px 26px;
  width:100%;
  height:100%;
  min-height:0;
  padding:0;
  border:0;
  border-radius:0;
  background:#fff !important;
  box-shadow:none;
  overflow:visible;
}

#productModal .pmodal__slider{
  grid-area:slider;
  position:relative;
  min-height:0;
  height:100%;
  align-items:stretch;
  justify-content:center;
  border-radius:16px;
  background:linear-gradient(135deg,#fbf3f1 0%,#f4dfda 100%) !important;
  overflow:hidden;
}

#productModal .pmodal__photoFrame{
  width:100%;
  height:100%;
  max-height:none;
  aspect-ratio:auto;
  border:0;
  border-radius:16px;
  background:transparent !important;
  box-shadow:none;
  overflow:hidden;
}

#productModal .pmodal__photoFrame::after{
  content:none !important;
  display:none !important;
}

#productModal .pmodal__img,
#productModal .pmodal__slider .pmodal__img{
  width:100%;
  height:100%;
  max-height:none;
  object-fit:cover;
  object-position:center;
  border-radius:16px;
  transform:none !important;
  filter:none !important;
  opacity:1 !important;
  background:transparent !important;
}

#productModal .pmodal__zoom{
  position:absolute;
  top:28px;
  right:28px;
  z-index:5;
  width:50px;
  height:50px;
  border-radius:50%;
  border:0;
  background:rgba(255,255,255,.78);
  color:#8a716b;
  display:grid;
  place-items:center;
  box-shadow:0 8px 20px rgba(88,62,46,.10);
  pointer-events:none;
}

#productModal .pmodal__zoom svg{
  width:23px;
  height:23px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}

#productModal .pmodal__thumbs{
  grid-area:thumbs;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  align-items:center;
  gap:18px;
  width:100%;
  height:100%;
  min-height:0;
  padding:0;
  margin:0;
  overflow-x:hidden;
  overflow-y:auto;
  scrollbar-width:none;
}

#productModal .pmodal__thumbs::-webkit-scrollbar{
  display:none;
}

#productModal .pmodal__thumb{
  flex:0 0 156px;
  width:112px;
  height:156px;
  border-radius:12px;
  border:1px solid rgba(126,105,100,.16);
  background:#fff !important;
  object-fit:cover;
  box-shadow:0 6px 16px rgba(88,62,46,.08);
  opacity:1;
}

#productModal .pmodal__thumb.active{
  border-color:#d55265;
  box-shadow:0 0 0 1px #d55265, 0 8px 18px rgba(213,82,101,.12);
}

#productModal .pmodal__pager{
  grid-area:pager;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
}

#productModal .pmodal__nav{
  position:static;
  width:52px;
  height:52px;
  border-radius:50%;
  border:1px solid rgba(126,105,100,.22) !important;
  background:rgba(255,255,255,.54) !important;
  color:#7d6b66 !important;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 8px 18px rgba(88,62,46,.10) !important;
  transform:none !important;
}

#productModal .pmodal__nav[hidden]{
  display:none !important;
}

#productModal .pmodal__nav--prev{
  display:none !important;
}

#productModal .pmodal__nav--next::before{
  width:9px;
  height:9px;
  transform:translateY(-2px) rotate(225deg);
}

#productModal .pmodal__badges{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  min-width:0;
}

#productModal .pmodal__badges--media{
  grid-area:badges;
}

#productModal .pmodal__badges--content{
  display:none;
}

#productModal .pmodal__badge{
  min-height:42px;
  padding:0 22px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border:1px solid rgba(213,82,101,.08);
  background:linear-gradient(180deg,rgba(252,244,245,.92),rgba(249,237,239,.88));
  color:#1f1c1d;
  font-size:14px;
  font-weight:500;
  white-space:nowrap;
  box-shadow:0 8px 18px rgba(126,105,100,.08);
}

#productModal .pmodal__badge svg{
  width:22px;
  height:22px;
  fill:none;
  stroke:#d55265;
  stroke-width:1.7;
  stroke-linecap:round;
  stroke-linejoin:round;
}

#productModal .pmodal__content{
  height:100%;
  max-height:none;
  padding:62px 54px 44px;
  overflow-y:auto;
  gap:18px;
  background:#fff;
}

#productModal .pmodal__close{
  top:24px;
  right:24px;
  width:52px;
  height:52px;
  border:1px solid rgba(126,105,100,.26) !important;
  background:rgba(255,255,255,.66) !important;
  color:#8a716b !important;
  box-shadow:none !important;
}

#productModal .pmodal__close svg{
  display:block;
  width:22px;
  height:22px;
}

#productModal .pmodal__title{
  margin:0;
  color:#8b6f68;
  font-family:"Playfair Display",Georgia,serif;
  font-size:42px;
  font-weight:600;
  line-height:1.05;
}

#productModal .pmodal__price{
  margin:0;
  font-size:28px;
  line-height:1.1;
  color:#d55265;
}

#productModal .pmodal__priceCurrent,
#productModal .pmodal__priceNew{
  color:#d55265;
}

#productModal .pmodal__desc{
  margin:6px 0 4px;
  max-width:none;
  color:#6f6a6a;
  font-size:17px;
  line-height:1.45;
}

#productModal .pmodal__divider{
  margin:4px 0 0;
  height:1px;
  background:rgba(126,105,100,.16);
}

#productModal .pmodal__block{
  gap:12px;
}

#productModal .pmodal__label{
  color:#5d5554;
  font-size:17px;
  font-weight:700;
}

#productModal .pmodal__sizeList{
  gap:16px;
}

#productModal .pmodal__size{
  width:92px;
  height:96px;
  border-radius:10px;
  border:1px solid rgba(126,105,100,.16);
  background:#fff;
  gap:10px;
  box-shadow:none;
}

#productModal .pmodal__size.is-active{
  border-color:#d55265;
  box-shadow:0 0 0 1px #d55265;
}

#productModal .pmodal__sizeCode{
  color:#d55265;
  font-size:18px;
}

#productModal .pmodal__sizeLabel{
  color:#8a8382;
  font-size:14px;
}

#productModal .pmodal__text{
  color:#6f6a6a;
  font-size:18px;
  line-height:1.45;
}

#productModal .pmodal__qty{
  width:156px;
  height:50px;
  grid-template-columns:52px 52px 52px;
  border-radius:12px;
  border:1px solid rgba(126,105,100,.18);
  box-shadow:none;
}

#productModal .pmodal__qtybtn,
#productModal .pmodal__qtyinput{
  width:52px;
  height:48px;
  font-size:20px;
}

#productModal .pmodal__actions{
  margin-top:8px;
}

#productModal .pmodal__actions .card__btnrow{
  display:flex;
  align-items:center;
  gap:18px;
}

#productModal .pmodal__actions .btn--buy{
  min-width:268px;
  height:58px;
  border-radius:28px;
  font-size:18px;
  box-shadow:0 12px 26px rgba(213,82,101,.18) !important;
}

#productModal .pmodal__actions .btn--cart{
  width:58px;
  min-width:58px;
  height:58px;
  border-radius:50%;
}

#productModal .pmodal__accordion{
  margin-top:4px;
  border-top:1px solid rgba(126,105,100,.16);
}

#productModal .pmodal__panel{
  border-bottom:1px solid rgba(126,105,100,.16);
}

#productModal .pmodal__panelHead{
  min-height:70px;
  grid-template-columns:28px 1fr 24px;
  color:#845356;
  font-size:20px;
  font-weight:600;
}

#productModal .pmodal__panelIcon svg{
  width:24px;
  height:24px;
}

#productModal .pmodal__panelChevron{
  font-family:Inter,system-ui,sans-serif;
  font-size:18px;
  color:#845356;
}

@media (max-width:920px){
  #productModal.pmodal{
    align-items:flex-start;
    justify-content:center;
    padding:0;
    background:#fff;
    overflow-y:auto;
  }

  #productModal .pmodal__overlay{
    background:#fff;
  }

  #productModal .pmodal__dialog{
    width:100%;
    min-height:100dvh;
    height:auto;
    max-height:none;
    border:0;
    border-radius:0;
    box-shadow:none;
    overflow:visible;
  }

  #productModal .pmodal__grid{
    display:block;
    height:auto;
  }

  #productModal .pmodal__media{
    height:auto;
    padding:28px 28px 0;
    border-right:0;
    overflow:visible;
  }

  #productModal .pmodal__mediaInner,
  #productModal.is-image-first .pmodal__mediaInner{
    display:grid;
    grid-template-columns:minmax(0,1fr) 72px;
    grid-template-areas:
      "slider slider"
      "thumbs pager";
    gap:20px 16px;
    height:auto;
    padding:0;
    overflow:visible;
  }

  #productModal.is-image-after-first .pmodal__mediaInner{
    grid-template-columns:72px minmax(0,1fr);
    grid-template-areas:
      "slider slider"
      "pager thumbs";
  }

  #productModal .pmodal__slider{
    grid-area:slider;
    width:100%;
    min-height:0;
    aspect-ratio:1.28 / 1;
    border-radius:24px;
  }

  #productModal .pmodal__photoFrame{
    border-radius:24px;
  }

  #productModal .pmodal__img,
  #productModal .pmodal__slider .pmodal__img{
    border-radius:24px;
  }

  #productModal .pmodal__zoom{
    display:none;
  }

  #productModal .pmodal__thumbs{
    grid-area:thumbs;
    flex-direction:row;
    justify-content:flex-start;
    gap:16px;
    height:96px;
    width:100%;
    overflow-x:auto;
    overflow-y:hidden;
    padding:0;
  }

  #productModal .pmodal__thumb{
    flex:0 0 156px;
    width:156px;
    height:94px;
    border-radius:10px;
  }

  #productModal .pmodal__pager{
    grid-area:pager;
    min-height:96px;
    justify-content:center;
  }

  #productModal .pmodal__nav{
    width:62px;
    height:62px;
    background:rgba(255,255,255,.44) !important;
    box-shadow:none !important;
  }

  #productModal.is-image-first .pmodal__nav--prev,
  #productModal.is-image-after-first .pmodal__nav--next{
    display:none !important;
  }

  #productModal.is-image-after-first .pmodal__nav--prev{
    display:flex !important;
  }

  #productModal .pmodal__nav--prev::before{
    transform:translateX(2px) rotate(-45deg);
  }

  #productModal .pmodal__nav--next::before{
    transform:translateX(-2px) rotate(135deg);
  }

  #productModal .pmodal__badges--media{
    display:none;
  }

  #productModal .pmodal__content{
    height:auto;
    max-height:none;
    padding:34px 36px 32px;
    overflow:visible;
    gap:20px;
  }

  #productModal .pmodal__close{
    top:48px;
    right:48px;
    width:58px;
    height:58px;
    z-index:8;
    background:rgba(255,255,255,.78) !important;
  }

  #productModal .pmodal__close::before,
  #productModal .pmodal__close::after{
    content:none !important;
    display:none !important;
  }

  #productModal .pmodal__close svg{
    display:block;
  }

  #productModal .pmodal__title{
    font-size:42px;
  }

  #productModal .pmodal__price{
    font-size:34px;
  }

  #productModal .pmodal__desc{
    font-size:24px;
  }

  #productModal .pmodal__label,
  #productModal .pmodal__text{
    font-size:24px;
  }

  #productModal .pmodal__sizeList{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:16px;
  }

  #productModal .pmodal__size{
    width:100%;
    height:102px;
    border-radius:14px;
  }

  #productModal .pmodal__sizeCode{
    font-size:26px;
  }

  #productModal .pmodal__sizeLabel{
    font-size:20px;
  }

  #productModal .pmodal__qty{
    width:226px;
    height:62px;
    grid-template-columns:75px 76px 75px;
    border-radius:30px;
  }

  #productModal .pmodal__qtybtn,
  #productModal .pmodal__qtyinput{
    width:75px;
    height:60px;
    font-size:28px;
  }

  #productModal .pmodal__actions .btn--buy{
    flex:1 1 auto;
    min-width:0;
    height:82px;
    border-radius:42px;
    font-size:28px;
  }

  #productModal .pmodal__actions .btn--cart{
    flex:0 0 82px;
    width:82px;
    min-width:82px;
    height:82px;
  }

  #productModal .pmodal__panelHead{
    min-height:72px;
    font-size:26px;
  }

  #productModal .pmodal__badges--content{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:16px;
    margin-top:4px;
  }

  #productModal .pmodal__badge{
    min-height:56px;
    padding:0 12px;
    font-size:18px;
  }
}

@media (max-width:520px){
  #productModal .pmodal__media{
    padding:14px 14px 0;
  }

  #productModal .pmodal__slider{
    border-radius:22px;
  }

  #productModal .pmodal__photoFrame,
  #productModal .pmodal__img,
  #productModal .pmodal__slider .pmodal__img{
    border-radius:22px;
  }

  #productModal .pmodal__thumbs{
    height:72px;
    gap:9px;
  }

  #productModal .pmodal__thumb{
    flex-basis:82px;
    width:82px;
    height:58px;
  }

  #productModal .pmodal__pager{
    min-height:72px;
  }

  #productModal .pmodal__nav{
    width:48px;
    height:48px;
  }

  #productModal .pmodal__close{
    top:24px;
    right:24px;
    width:44px;
    height:44px;
  }

  #productModal .pmodal__content{
    padding:26px 18px 24px;
    gap:16px;
  }

  #productModal .pmodal__title{
    font-size:34px;
  }

  #productModal .pmodal__price{
    font-size:28px;
  }

  #productModal .pmodal__desc,
  #productModal .pmodal__label,
  #productModal .pmodal__text{
    font-size:19px;
  }

  #productModal .pmodal__size{
    height:84px;
  }

  #productModal .pmodal__sizeCode{
    font-size:22px;
  }

  #productModal .pmodal__sizeLabel{
    font-size:16px;
  }

  #productModal .pmodal__actions .btn--buy{
    height:64px;
    font-size:22px;
  }

  #productModal .pmodal__actions .btn--cart{
    flex-basis:64px;
    width:64px;
    min-width:64px;
    height:64px;
  }

  #productModal .pmodal__panelHead{
    min-height:62px;
    font-size:22px;
  }

  #productModal .pmodal__badges--content{
    gap:8px;
  }

  #productModal .pmodal__badge{
    min-height:46px;
    padding:0 8px;
    gap:6px;
    font-size:13px;
  }

  #productModal .pmodal__badge svg{
    width:20px;
    height:20px;
  }
}

/* Product modal requested fixes */
@media (min-width:921px){
  #productModal.pmodal{
    align-items:center;
    justify-content:flex-start;
    padding:16px 16px 16px 24px;
  }

  #productModal .pmodal__dialog{
    width:min(1180px,calc(100vw - 48px));
    height:min(760px,calc(100dvh - 32px));
    max-height:calc(100dvh - 32px);
  }

  #productModal .pmodal__grid{
    grid-template-columns:minmax(0,58%) minmax(350px,42%);
  }

  #productModal .pmodal__media{
    padding:24px;
  }

  #productModal .pmodal__mediaInner{
    grid-template-columns:92px minmax(0,1fr);
    grid-template-rows:minmax(0,1fr) 60px;
    gap:18px 22px;
  }

  #productModal .pmodal__thumbs{
    padding:2px;
    align-items:center;
    gap:14px;
  }

  #productModal .pmodal__thumb{
    box-sizing:border-box;
    flex-basis:126px;
    width:88px;
    height:126px;
    border-radius:11px;
    box-shadow:0 6px 14px rgba(88,62,46,.07);
  }

  #productModal .pmodal__thumb.active{
    border-color:#d55265;
    box-shadow:inset 0 0 0 1px #d55265, 0 7px 16px rgba(213,82,101,.10);
  }

  #productModal .pmodal__badges{
    gap:12px;
  }

  #productModal .pmodal__badge{
    min-height:38px;
    padding:0 18px;
    font-size:13px;
  }

  #productModal .pmodal__content{
    padding:48px 46px 36px;
    gap:14px;
  }

  #productModal .pmodal__close{
    top:20px;
    right:20px;
    width:46px;
    height:46px;
  }

  #productModal .pmodal__title{
    font-size:36px;
  }

  #productModal .pmodal__price{
    font-size:26px;
  }

  #productModal .pmodal__desc{
    font-size:16px;
    margin:4px 0 2px;
  }

  #productModal .pmodal__size{
    width:86px;
    height:88px;
  }

  #productModal .pmodal__actions .btn--buy{
    min-width:240px;
    height:54px;
    font-size:17px;
  }

  #productModal .pmodal__actions .btn--cart{
    width:54px;
    min-width:54px;
    height:54px;
  }

  #productModal .pmodal__panelHead{
    min-height:62px;
    font-size:18px;
  }

  #productModal .pmodal__zoom{
    pointer-events:auto;
    cursor:zoom-in;
    top:20px;
    right:20px;
    width:44px;
    height:44px;
    transition:background .18s ease, color .18s ease, transform .18s ease;
  }

  #productModal .pmodal__zoom:hover,
  #productModal.is-photo-zoomed .pmodal__zoom{
    background:#fff !important;
    color:#d55265;
    transform:scale(1.04);
  }

  #productModal .pmodal__photoFrame{
    cursor:default;
  }

  #productModal.is-photo-zoomed .pmodal__photoFrame{
    cursor:zoom-out;
  }

  #productModal.is-photo-zoomed .pmodal__img{
    transform:scale(1.85) !important;
    transform-origin:var(--zoom-x,50%) var(--zoom-y,50%);
  }
}

@media (max-width:920px){
  #productModal.pmodal{
    align-items:flex-start;
    justify-content:center;
    padding:18px 0;
    background:rgba(0,0,0,.76);
    overflow-x:hidden;
    overflow-y:auto;
  }

  #productModal .pmodal__overlay{
    background:rgba(0,0,0,.76);
  }

  #productModal .pmodal__dialog{
    width:min(390px,calc(100vw - 24px));
    min-height:0;
    max-width:calc(100vw - 24px);
    margin:0 auto;
    border-radius:0;
    overflow:hidden;
  }

  #productModal .pmodal__media{
    padding:14px 14px 0;
  }

  #productModal .pmodal__mediaInner,
  #productModal.is-image-first .pmodal__mediaInner,
  #productModal.is-image-after-first .pmodal__mediaInner{
    position:relative;
    display:grid;
    grid-template-columns:1fr;
    grid-template-areas:
      "slider"
      "thumbs";
    gap:14px;
    width:100%;
    min-width:0;
  }

  #productModal .pmodal__slider{
    aspect-ratio:1.31 / 1;
    border-radius:18px;
  }

  #productModal .pmodal__photoFrame,
  #productModal .pmodal__img,
  #productModal .pmodal__slider .pmodal__img{
    border-radius:18px;
  }

  #productModal .pmodal__thumbs{
    box-sizing:border-box;
    height:62px;
    gap:10px;
    padding:2px 58px 2px 2px;
    min-width:0;
  }

  #productModal.is-image-after-first .pmodal__thumbs{
    padding:2px 2px 2px 58px;
  }

  #productModal .pmodal__thumb{
    box-sizing:border-box;
    flex:0 0 72px;
    width:72px;
    height:52px;
    border-radius:9px;
  }

  #productModal .pmodal__thumb.active{
    box-shadow:inset 0 0 0 1px #d55265, 0 5px 12px rgba(213,82,101,.10);
  }

  #productModal .pmodal__pager{
    position:absolute;
    left:calc(100% - 50px);
    bottom:8px;
    width:44px;
    min-height:44px;
    z-index:4;
    grid-area:auto;
    transition:left .28s ease, transform .28s ease;
  }

  #productModal.is-image-after-first .pmodal__pager{
    left:6px;
  }

  #productModal .pmodal__nav{
    width:44px;
    height:44px;
    background:rgba(255,255,255,.74) !important;
    transition:opacity .18s ease, transform .28s ease, background .18s ease;
  }

  #productModal .pmodal__badges--media,
  #productModal .pmodal__badges--content{
    display:none !important;
  }

  #productModal .pmodal__content{
    padding:24px 22px 26px;
    gap:14px;
    min-width:0;
  }

  #productModal .pmodal__close{
    top:28px;
    right:28px;
    width:44px;
    height:44px;
  }

  #productModal .pmodal__title{
    font-size:34px;
  }

  #productModal .pmodal__price{
    font-size:28px;
  }

  #productModal .pmodal__desc,
  #productModal .pmodal__label,
  #productModal .pmodal__text{
    font-size:19px;
  }

  #productModal .pmodal__sizeList{
    gap:10px;
  }

  #productModal .pmodal__size{
    height:84px;
  }

  #productModal .pmodal__actions .btn--buy{
    height:64px;
    font-size:22px;
  }

  #productModal .pmodal__actions .btn--cart{
    flex-basis:64px;
    width:64px;
    min-width:64px;
    height:64px;
  }
}

@media (max-width:430px){
  #productModal.pmodal{
    padding:10px 0;
  }

  #productModal .pmodal__dialog{
    width:min(390px,calc(100vw - 16px));
    max-width:calc(100vw - 16px);
  }

  #productModal .pmodal__media{
    padding:10px 10px 0;
  }

  #productModal .pmodal__content{
    padding:22px 16px 24px;
  }

  #productModal .pmodal__title{
    font-size:31px;
  }
}

/* Final modal correction: left docked desktop, no blurred backdrop, compact mobile. */
#productModal.pmodal{
  background:rgba(255,255,255,.58) !important;
}

#productModal .pmodal__overlay{
  background:rgba(255,255,255,.58) !important;
  -webkit-backdrop-filter:none !important;
  backdrop-filter:none !important;
}

#productModal .pmodal__overlay::before,
#productModal .pmodal__overlay::after{
  content:none !important;
  display:none !important;
  opacity:0 !important;
  filter:none !important;
  -webkit-backdrop-filter:none !important;
  backdrop-filter:none !important;
}

@media (min-width:921px){
  #productModal.pmodal{
    align-items:stretch !important;
    justify-content:flex-start !important;
    padding:0 !important;
  }

  #productModal .pmodal__dialog{
    width:min(980px,calc(100vw - 18px)) !important;
    height:100dvh !important;
    max-height:100dvh !important;
    margin:0 !important;
    border-radius:0 16px 16px 0 !important;
    box-shadow:16px 0 46px rgba(68,48,40,.10) !important;
  }

  #productModal .pmodal__grid{
    grid-template-columns:minmax(0,56%) minmax(330px,44%) !important;
    height:100dvh !important;
    max-height:100dvh !important;
  }

  #productModal .pmodal__media{
    padding:18px !important;
  }

  #productModal .pmodal__mediaInner{
    grid-template-columns:76px minmax(0,1fr) !important;
    grid-template-rows:minmax(0,1fr) 54px !important;
    gap:14px 16px !important;
  }

  #productModal .pmodal__slider,
  #productModal .pmodal__photoFrame{
    border-radius:14px !important;
  }

  #productModal .pmodal__img,
  #productModal .pmodal__slider .pmodal__img{
    border-radius:14px !important;
    object-fit:cover !important;
  }

  #productModal .pmodal__thumbs{
    padding:3px !important;
    gap:12px !important;
  }

  #productModal .pmodal__thumb{
    flex:0 0 104px !important;
    width:72px !important;
    height:104px !important;
    border-radius:10px !important;
  }

  #productModal .pmodal__thumb.active{
    border-color:#d55265 !important;
    box-shadow:inset 0 0 0 1px #d55265, 0 5px 12px rgba(213,82,101,.10) !important;
  }

  #productModal .pmodal__badges{
    gap:10px !important;
  }

  #productModal .pmodal__badge{
    min-height:34px !important;
    padding:0 14px !important;
    gap:7px !important;
    font-size:12px !important;
  }

  #productModal .pmodal__badge svg{
    width:18px !important;
    height:18px !important;
  }

  #productModal .pmodal__content{
    padding:42px 38px 28px !important;
    gap:12px !important;
  }

  #productModal .pmodal__close{
    top:18px !important;
    right:18px !important;
    width:42px !important;
    height:42px !important;
  }

  #productModal .pmodal__title{
    font-size:32px !important;
  }

  #productModal .pmodal__price{
    font-size:24px !important;
  }

  #productModal .pmodal__desc{
    font-size:15px !important;
    line-height:1.4 !important;
  }

  #productModal .pmodal__label{
    font-size:15px !important;
  }

  #productModal .pmodal__size{
    width:76px !important;
    height:78px !important;
  }

  #productModal .pmodal__sizeCode{
    font-size:16px !important;
  }

  #productModal .pmodal__sizeLabel{
    font-size:12px !important;
  }

  #productModal .pmodal__text{
    font-size:16px !important;
  }

  #productModal .pmodal__qty{
    width:132px !important;
    height:44px !important;
    grid-template-columns:44px 44px 44px !important;
  }

  #productModal .pmodal__qtybtn,
  #productModal .pmodal__qtyinput{
    width:44px !important;
    height:42px !important;
    font-size:18px !important;
  }

  #productModal .pmodal__actions .btn--buy{
    min-width:210px !important;
    height:50px !important;
    font-size:16px !important;
  }

  #productModal .pmodal__actions .btn--cart{
    width:50px !important;
    min-width:50px !important;
    height:50px !important;
  }

  #productModal .pmodal__panelHead{
    min-height:56px !important;
    font-size:17px !important;
  }

  #productModal .pmodal__zoom{
    top:18px !important;
    right:18px !important;
    width:40px !important;
    height:40px !important;
    pointer-events:auto !important;
  }
}

@media (max-width:920px){
  #productModal.pmodal{
    align-items:flex-start !important;
    justify-content:center !important;
    padding:8px 0 !important;
    overflow-x:hidden !important;
    background:rgba(0,0,0,.72) !important;
  }

  #productModal .pmodal__overlay{
    background:rgba(0,0,0,.72) !important;
  }

  #productModal .pmodal__dialog{
    width:min(384px,calc(100vw - 20px)) !important;
    max-width:calc(100vw - 20px) !important;
    min-height:0 !important;
    margin:0 auto !important;
    transform:none !important;
    border-radius:0 !important;
    box-shadow:none !important;
  }

  #productModal .pmodal__grid,
  #productModal .pmodal__media,
  #productModal .pmodal__content{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    box-sizing:border-box !important;
  }

  #productModal .pmodal__media{
    padding:10px 10px 0 !important;
  }

  #productModal .pmodal__slider{
    aspect-ratio:1.26 / 1 !important;
    border-radius:18px !important;
  }

  #productModal .pmodal__content{
    padding:20px 16px 22px !important;
  }

  #productModal .pmodal__title{
    font-size:30px !important;
  }

  #productModal .pmodal__price{
    font-size:25px !important;
  }

  #productModal .pmodal__desc,
  #productModal .pmodal__label,
  #productModal .pmodal__text{
    font-size:17px !important;
  }
}

/* Compact product modal pass: keep the whole photo visible and reduce controls. */
@media (min-width:921px){
  #productModal .pmodal__dialog{
    width:min(890px,calc(100vw - 14px)) !important;
  }

  #productModal .pmodal__grid{
    grid-template-columns:minmax(0,52%) minmax(300px,48%) !important;
  }

  #productModal .pmodal__media{
    padding:14px 16px 16px 14px !important;
  }

  #productModal .pmodal__mediaInner{
    grid-template-columns:62px minmax(0,1fr) !important;
    grid-template-rows:minmax(0,1fr) 42px !important;
    gap:10px 14px !important;
    align-items:center !important;
  }

  #productModal .pmodal__slider{
    height:min(540px,calc(100dvh - 124px)) !important;
    align-self:center !important;
    background:#fff !important;
  }

  #productModal .pmodal__photoFrame{
    height:100% !important;
    background:#fff !important;
  }

  #productModal .pmodal__img,
  #productModal .pmodal__slider .pmodal__img{
    width:100% !important;
    height:100% !important;
    object-fit:contain !important;
    object-position:center center !important;
    background:#fff !important;
  }

  #productModal .pmodal__thumbs{
    padding:4px !important;
    gap:10px !important;
    align-content:flex-start !important;
  }

  #productModal .pmodal__thumb{
    flex:0 0 78px !important;
    width:58px !important;
    height:78px !important;
    border-radius:9px !important;
    object-fit:cover !important;
  }

  #productModal .pmodal__badges{
    gap:8px !important;
  }

  #productModal .pmodal__badge{
    min-height:30px !important;
    padding:0 12px !important;
    font-size:11px !important;
  }

  #productModal .pmodal__content{
    padding:34px 32px 22px !important;
    gap:10px !important;
  }

  #productModal .pmodal__close{
    top:14px !important;
    right:14px !important;
    width:38px !important;
    height:38px !important;
  }

  #productModal .pmodal__title{
    font-size:28px !important;
    line-height:1.08 !important;
  }

  #productModal .pmodal__price{
    font-size:22px !important;
    gap:8px !important;
  }

  #productModal .pmodal__desc{
    font-size:14px !important;
    line-height:1.38 !important;
  }

  #productModal .pmodal__divider{
    margin:4px 0 !important;
  }

  #productModal .pmodal__label{
    font-size:14px !important;
  }

  #productModal .pmodal__sizeList{
    gap:10px !important;
  }

  #productModal .pmodal__size{
    width:68px !important;
    height:66px !important;
    border-radius:9px !important;
  }

  #productModal .pmodal__sizeCode{
    font-size:15px !important;
  }

  #productModal .pmodal__sizeLabel{
    font-size:11px !important;
  }

  #productModal .pmodal__text{
    font-size:14px !important;
    line-height:1.45 !important;
  }

  #productModal .pmodal__qty{
    width:116px !important;
    height:38px !important;
    grid-template-columns:38px 38px 38px !important;
  }

  #productModal .pmodal__qtybtn,
  #productModal .pmodal__qtyinput{
    width:38px !important;
    height:36px !important;
    font-size:16px !important;
  }

  #productModal .pmodal__actions{
    margin-top:2px !important;
  }

  #productModal .pmodal__actions .card__btnrow{
    gap:12px !important;
  }

  #productModal .pmodal__actions .btn--buy{
    min-width:180px !important;
    height:44px !important;
    font-size:15px !important;
  }

  #productModal .pmodal__actions .btn--cart{
    width:44px !important;
    min-width:44px !important;
    height:44px !important;
  }

  #productModal .pmodal__panelHead{
    min-height:48px !important;
    font-size:15px !important;
  }

  #productModal .pmodal__panelIcon svg{
    width:17px !important;
    height:17px !important;
  }

  #productModal .pmodal__zoom{
    top:14px !important;
    right:14px !important;
    width:36px !important;
    height:36px !important;
  }
}

@media (max-width:920px){
  #productModal.pmodal{
    padding:6px 0 !important;
  }

  #productModal .pmodal__dialog{
    width:min(344px,calc(100vw - 44px)) !important;
    max-width:calc(100vw - 44px) !important;
  }

  #productModal .pmodal__media{
    padding:8px 8px 0 !important;
  }

  #productModal .pmodal__slider{
    aspect-ratio:1.45 / 1 !important;
    max-height:214px !important;
    border-radius:14px !important;
    background:#fff !important;
  }

  #productModal .pmodal__photoFrame{
    height:100% !important;
    background:#fff !important;
  }

  #productModal .pmodal__img,
  #productModal .pmodal__slider .pmodal__img{
    width:100% !important;
    height:100% !important;
    object-fit:contain !important;
    object-position:center center !important;
    background:#fff !important;
  }

  #productModal .pmodal__thumbs{
    height:42px !important;
    gap:8px !important;
    padding:3px 0 !important;
  }

  #productModal .pmodal__thumb{
    flex:0 0 54px !important;
    width:54px !important;
    height:38px !important;
    border-radius:8px !important;
  }

  #productModal .pmodal__pager{
    width:42px !important;
  }

  #productModal .pmodal__nav{
    width:34px !important;
    height:34px !important;
    font-size:24px !important;
  }

  #productModal .pmodal__content{
    padding:14px 14px 16px !important;
    gap:8px !important;
  }

  #productModal .pmodal__close{
    width:36px !important;
    height:36px !important;
    top:12px !important;
    right:12px !important;
  }

  #productModal .pmodal__title{
    font-size:23px !important;
    line-height:1.08 !important;
  }

  #productModal .pmodal__price{
    font-size:20px !important;
    line-height:1.15 !important;
    gap:7px !important;
  }

  #productModal .pmodal__desc,
  #productModal .pmodal__label,
  #productModal .pmodal__text{
    font-size:13px !important;
    line-height:1.38 !important;
  }

  #productModal .pmodal__divider{
    margin:3px 0 !important;
  }

  #productModal .pmodal__sizeList{
    gap:8px !important;
  }

  #productModal .pmodal__size{
    height:54px !important;
    min-width:78px !important;
    border-radius:10px !important;
  }

  #productModal .pmodal__sizeCode{
    font-size:15px !important;
  }

  #productModal .pmodal__sizeLabel{
    font-size:11px !important;
  }

  #productModal .pmodal__qty{
    width:108px !important;
    height:36px !important;
    grid-template-columns:36px 36px 36px !important;
  }

  #productModal .pmodal__qtybtn,
  #productModal .pmodal__qtyinput{
    width:36px !important;
    height:34px !important;
    font-size:15px !important;
  }

  #productModal .pmodal__actions .card__btnrow{
    gap:10px !important;
  }

  #productModal .pmodal__actions .btn--buy{
    height:44px !important;
    min-width:0 !important;
    font-size:15px !important;
  }

  #productModal .pmodal__actions .btn--cart{
    width:44px !important;
    min-width:44px !important;
    height:44px !important;
  }

  #productModal .pmodal__panelHead{
    min-height:42px !important;
    font-size:15px !important;
  }

  #productModal .pmodal__panelIcon svg{
    width:16px !important;
    height:16px !important;
  }
}

/* Absolute final modal sizing: this block must stay last. */
#productModal.pmodal{
  background:rgba(246,239,233,.54) !important;
}

#productModal .pmodal__overlay,
#productModal .pmodal__overlay::before,
#productModal .pmodal__overlay::after{
  background:transparent !important;
  filter:none !important;
  -webkit-backdrop-filter:none !important;
  backdrop-filter:none !important;
}

@media (min-width:921px){
  #productModal.pmodal{
    justify-content:flex-start !important;
    align-items:stretch !important;
    padding:0 !important;
  }

  #productModal .pmodal__dialog{
    width:min(740px,calc(100vw - 18px)) !important;
    height:100dvh !important;
    max-height:100dvh !important;
    margin:0 !important;
    border-radius:0 14px 14px 0 !important;
  }

  #productModal .pmodal__grid{
    grid-template-columns:minmax(0,54%) minmax(250px,46%) !important;
    min-height:100% !important;
  }

  #productModal .pmodal__media{
    padding:16px 14px 16px 12px !important;
  }

  #productModal .pmodal__mediaInner{
    grid-template-columns:54px minmax(0,1fr) !important;
    grid-template-rows:minmax(0,1fr) 36px !important;
    gap:9px 11px !important;
  }

  #productModal .pmodal__slider{
    height:min(456px,calc(100dvh - 108px)) !important;
    min-height:0 !important;
  }

  #productModal .pmodal__photoFrame{
    height:100% !important;
  }

  #productModal .pmodal__img,
  #productModal .pmodal__slider .pmodal__img{
    object-fit:contain !important;
  }

  #productModal .pmodal__thumbs{
    padding:3px !important;
    gap:8px !important;
  }

  #productModal .pmodal__thumb{
    width:50px !important;
    height:68px !important;
    flex-basis:68px !important;
    border-radius:8px !important;
    box-sizing:border-box !important;
  }

  #productModal .pmodal__content{
    padding:30px 28px 18px !important;
    gap:8px !important;
  }

  #productModal .pmodal__title{
    font-size:25px !important;
  }

  #productModal .pmodal__price{
    font-size:20px !important;
  }

  #productModal .pmodal__desc,
  #productModal .pmodal__label,
  #productModal .pmodal__text{
    font-size:13px !important;
    line-height:1.36 !important;
  }

  #productModal .pmodal__size{
    width:58px !important;
    height:56px !important;
  }

  #productModal .pmodal__sizeCode{
    font-size:14px !important;
  }

  #productModal .pmodal__sizeLabel{
    font-size:10px !important;
  }

  #productModal .pmodal__qty{
    width:102px !important;
    height:34px !important;
    grid-template-columns:34px 34px 34px !important;
  }

  #productModal .pmodal__qtybtn,
  #productModal .pmodal__qtyinput{
    width:34px !important;
    height:32px !important;
    font-size:14px !important;
  }

  #productModal .pmodal__actions .btn--buy{
    min-width:160px !important;
    height:40px !important;
    font-size:14px !important;
  }

  #productModal .pmodal__actions .btn--cart{
    width:40px !important;
    min-width:40px !important;
    height:40px !important;
  }

  #productModal .pmodal__panelHead{
    min-height:42px !important;
    font-size:14px !important;
  }

  #productModal .pmodal__badges{
    margin-top:8px !important;
  }

  #productModal .pmodal__badge{
    min-height:28px !important;
    padding:0 10px !important;
    font-size:10px !important;
  }
}

@media (max-width:920px){
  #productModal.pmodal{
    padding:0 !important;
    align-items:flex-start !important;
    justify-content:center !important;
  }

  #productModal .pmodal__dialog{
    width:min(318px,calc(100vw - 64px)) !important;
    max-width:calc(100vw - 64px) !important;
    max-height:calc(100dvh - 18px) !important;
    margin:9px auto !important;
    border-radius:14px !important;
  }

  #productModal .pmodal__media{
    padding:7px 7px 0 !important;
  }

  #productModal .pmodal__slider{
    max-height:184px !important;
    aspect-ratio:1.42 / 1 !important;
  }

  #productModal .pmodal__thumbs{
    height:36px !important;
    gap:7px !important;
  }

  #productModal .pmodal__thumb{
    width:48px !important;
    height:34px !important;
    flex-basis:48px !important;
  }

  #productModal .pmodal__content{
    padding:12px 12px 14px !important;
    gap:6px !important;
  }

  #productModal .pmodal__title{
    font-size:20px !important;
  }

  #productModal .pmodal__price{
    font-size:18px !important;
  }

  #productModal .pmodal__desc,
  #productModal .pmodal__label,
  #productModal .pmodal__text{
    font-size:12px !important;
    line-height:1.32 !important;
  }

  #productModal .pmodal__size{
    height:46px !important;
    min-width:66px !important;
  }

  #productModal .pmodal__sizeCode{
    font-size:13px !important;
  }

  #productModal .pmodal__sizeLabel{
    font-size:10px !important;
  }

  #productModal .pmodal__qty{
    width:96px !important;
    height:32px !important;
    grid-template-columns:32px 32px 32px !important;
  }

  #productModal .pmodal__qtybtn,
  #productModal .pmodal__qtyinput{
    width:32px !important;
    height:30px !important;
    font-size:14px !important;
  }

  #productModal .pmodal__actions .btn--buy{
    height:38px !important;
    font-size:13px !important;
  }

  #productModal .pmodal__actions .btn--cart{
    width:38px !important;
    min-width:38px !important;
    height:38px !important;
  }

  #productModal .pmodal__panelHead{
    min-height:36px !important;
    font-size:13px !important;
  }

  #productModal .pmodal__badges{
    display:none !important;
  }
}
