/* customerstorereviews front.css (v11-touchfix)
   Fix goals:
   - Carousel scroll works on iOS/Android (real swipe + drag)
   - No invisible overlay blocking homepage products
   - Desktop not cut off
   - Modal never intercepts clicks when closed
*/

.csr-wrap{
  font-family: inherit !important;
  color: #111827 !important;
  width: 100% !important;
  box-sizing: border-box !important;

  /* IMPORTANT: do NOT create a high stacking layer */
  position: static !important;
  z-index: auto !important;
}

.csr-wrap .csr-form-block{
  margin-top: 26px !important;
}


/* Keep inside theme container but never clip */
.csr-wrap{
  max-width: 1200px !important;
  margin: 40px auto !important;
  padding: 16px !important;
  overflow: visible !important;
}

.csr-wrap, .csr-wrap *{ box-sizing:border-box !important; }

.csr-review-text{
  overflow-wrap:anywhere;
  word-break:break-word;
}

.csr-wrap img,
.csr-wrap video{
  max-width:100% !important;
  height:auto !important;
  display:block !important;
}

/* ---------- Title ---------- */
.csr-wrap .csr-title{
  text-align:center !important;
  font-size:32px !important;
  font-weight:800 !important;
  margin:0 0 18px 0 !important;
}

/* ---------- Stars ---------- */
.csr-wrap .csr-star{
  font-size:20px !important;
  line-height:1 !important;
  color:#d1d5db !important;
  display:inline-block !important;
}
.csr-wrap .csr-star.is-on{ color:#e3b341 !important; }
.csr-wrap .csr-card-stars .csr-star{ font-size:18px !important; }
.csr-wrap .csr-summary-stars .csr-star{ font-size:22px !important; }

/* ---------- Carousel ---------- */
.csr-wrap .csr-carousel{
  display:flex !important;
  gap:20px !important;

  /* scrolling */
  overflow-x:auto !important;
  overflow-y:hidden !important;
  -webkit-overflow-scrolling:touch !important;

  /* iOS/Android friendliness */
  scroll-snap-type:x proximity !important;
  overscroll-behavior-x:contain !important;

  padding:6px 6px 18px !important;
  align-items:stretch !important;

  /* allow horizontal pan for browsers that support touch-action */
  touch-action: pan-x !important;

  /* make sure it can be interacted with */
  pointer-events:auto !important;
}

.csr-wrap .csr-carousel > *{ flex:0 0 auto !important; }

.csr-wrap .csr-carousel.is-dragging{
  cursor: grabbing;
}

/* Make scrollbar easier to grab on desktop */
.csr-wrap .csr-carousel::-webkit-scrollbar{ height:12px; }
.csr-wrap .csr-carousel::-webkit-scrollbar-thumb{ border-radius:999px; }

/* ---------- Cards ---------- */
.csr-wrap .csr-card{
  width:min(360px, 82vw) !important;
  min-width:min(360px, 82vw) !important;
  background:#fff !important;
  border:1px solid #eef0f3 !important;
  border-radius:18px !important;
  padding:18px !important;
  box-shadow:0 10px 30px rgba(17,24,39,.06) !important;
  scroll-snap-align:start !important;

  display:flex !important;
  flex-direction:column !important;
}

.csr-wrap .csr-card-head{
  display:flex !important;
  align-items:flex-start !important;
  justify-content:space-between !important;
  gap:12px !important;
}

.csr-wrap .csr-card-date{
  opacity:.6 !important;
  font-size:14px !important;
  white-space:nowrap !important;
}

.csr-wrap .csr-card-name{
  font-size:18px !important;
  font-weight:800 !important;
  margin-top:12px !important;
}

.csr-wrap .csr-card-title{
  font-size:18px !important;
  font-weight:900 !important;
  margin-top:10px !important;
}

.csr-wrap .csr-card-body{
  font-size:16px !important;
  line-height:1.55 !important;
  margin-top:10px !important;
  opacity:.9 !important;
}

/* Thumbnail never blows out */
.csr-wrap .csr-card-media{
  margin-top:12px !important;
  display:flex !important;
  gap:10px !important;
  align-items:center !important;
}
.csr-wrap .csr-card-media img,
.csr-wrap .csr-card-media video{
  width:96px !important;
  height:68px !important;
  max-width:96px !important;
  max-height:68px !important;
  object-fit:cover !important;
  border-radius:10px !important;
}

/* ---------- Buttons ---------- */
.csr-wrap .csr-top-actions{
  display:flex !important;
  justify-content:center !important;
  margin-top:8px !important;
}

.csr-wrap .csr-btn{
  appearance:none !important;
  border:0 !important;
  cursor:pointer !important;
  border-radius:999px !important;
  padding:14px 22px !important;
  font-weight:800 !important;
  font-size:16px !important;
  line-height:1 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  text-decoration:none !important;
}
.csr-wrap .csr-btn-dark{ background:#111827 !important; color:#fff !important; }
.csr-wrap .csr-btn-gold{ background:#e3b341 !important; color:#fff !important; }
.csr-wrap .csr-btn-ghost{
  background:transparent !important;
  border:1px solid #e5e7eb !important;
  color:#111827 !important;
}

/* Link-like */
.csr-wrap .csr-link{
  display:inline-flex !important;
  margin-top:14px !important;
  background:transparent !important;
  border:0 !important;
  padding:0 !important;
  color:#e3b341 !important;
  text-decoration:underline !important;
  cursor:pointer !important;
  font-weight:700 !important;
  font-size:16px !important;
  align-self:flex-start !important;
}

/* ---------- Summary ---------- */
.csr-wrap .csr-summary{
  margin-top:26px !important;
  display:grid !important;
  grid-template-columns:1fr 1fr 1fr !important;
  gap:18px !important;
  align-items:center !important;
  border-top:1px solid #eef0f3 !important;
  padding-top:22px !important;
}
@media (max-width:900px){
  .csr-wrap .csr-summary{ grid-template-columns:1fr !important; }
}

.csr-wrap .csr-summary-left{ display:flex !important; flex-direction:column !important; gap:10px !important; }
.csr-wrap .csr-summary-stars{ display:flex !important; align-items:center !important; gap:10px !important; flex-wrap:wrap !important; }
.csr-wrap .csr-avg{ font-weight:800 !important; color:#e3b341 !important; }
.csr-wrap .csr-total{ opacity:.75 !important; font-size:14px !important; }

.csr-wrap .csr-summary-mid{ display:flex !important; flex-direction:column !important; gap:10px !important; }

.csr-wrap .csr-bar-row{
  display:grid !important;
  grid-template-columns:130px 1fr 40px !important;
  gap:12px !important;
  align-items:center !important;
}
.csr-wrap .csr-bar{ height:14px !important; background:#eeeeee !important; border-radius:999px !important; overflow:hidden !important; }
.csr-wrap .csr-bar-fill{ display:block !important; height:100% !important; background:#e3b341 !important; border-radius:999px !important; }
.csr-wrap .csr-bar-count{ text-align:right !important; opacity:.7 !important; }

/* ---------- Photos strip ---------- */
.csr-wrap .csr-photos{
  margin-top:22px !important;
  border-top:1px solid #eef0f3 !important;
  padding-top:18px !important;
}
.csr-wrap .csr-photos-head{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:12px !important;
}
.csr-wrap .csr-photos-title{ font-weight:800 !important; font-size:16px !important; opacity:.85 !important; }

.csr-wrap .csr-photos-strip{
  display:flex !important;
  gap:10px !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  padding:12px 2px 2px !important;
  -webkit-overflow-scrolling:touch !important;
}

.csr-wrap .csr-photo{
  flex:0 0 auto !important;
  width:92px !important;
  height:92px !important;
  border-radius:14px !important;
  overflow:hidden !important;
  background:#f3f4f6 !important;
  border:1px solid #eef0f3 !important;
  display:block !important;
}
.csr-wrap .csr-photo img,
.csr-wrap .csr-photo video{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
}

/* ---------- Accordion ---------- */
.csr-wrap .csr-accordion{ display:none !important; margin-top:22px !important; }
.csr-wrap .csr-accordion.is-open{ display:block !important; }

.csr-wrap .csr-accordion-inner{
  max-width:720px !important;
  margin:0 auto !important;
  text-align:center !important;
  padding:26px 18px !important;
  background:#fff !important;
  border:1px solid #eef0f3 !important;
  border-radius:24px !important;
  box-shadow:0 10px 30px rgba(17,24,39,.06) !important;
}

/* ---------- Form ---------- */
.csr-wrap .csr-form-title{
  margin:0 0 16px 0 !important;
  font-size:24px !important;
  font-weight:900 !important;
}
.csr-wrap .csr-field{ max-width:720px !important; margin:18px auto !important; }
.csr-wrap .csr-label{ display:block !important; margin:0 0 10px 0 !important; font-size:14px !important; color:#6b7280 !important; font-weight:700 !important; }

.csr-wrap input.csr-input,
.csr-wrap textarea.csr-textarea{
  width:100% !important;
  border:1px solid #e5e7eb !important;
  background:#fff !important;
  color:#111827 !important;
  padding:14px 18px !important;
  font-size:16px !important;
  outline:none !important;
  box-shadow:none !important;
}
.csr-wrap input.csr-input{ border-radius:999px !important; }
.csr-wrap textarea.csr-textarea{
  border-radius:18px !important;
  min-height:170px !important;
  resize:vertical !important;
}
.csr-wrap input.csr-input:focus,
.csr-wrap textarea.csr-textarea:focus{
  border-color:#d1d5db !important;
  box-shadow:0 0 0 3px rgba(17,24,39,.10) !important;
}

/* Stars in form */
.csr-wrap .csr-stars-input{
  display:flex !important;
  justify-content:center !important;
  gap:6px !important;
}
.csr-wrap .csr-stars-input .csr-star-btn{
  all:unset !important;
  cursor:pointer !important;
  font-size:30px !important;
  line-height:1 !important;
  padding:6px !important;
  color:#d1d5db !important;
  display:inline-block !important;
}
.csr-wrap .csr-stars-input .csr-star-btn.is-on{ color:#e3b341 !important; }

/* Upload zone */
.csr-wrap .csr-upload{
  border:2px dashed #d1d5db !important;
  border-radius:16px !important;
  padding:22px !important;
  position:relative !important;
  text-align:center !important;
  color:#6b7280 !important;
}
.csr-wrap .csr-upload-ico{ width:34px !important; height:34px !important; margin:0 auto 8px !important; display:block !important; }
.csr-wrap .csr-browse{ color:#111827 !important; text-decoration:underline !important; font-weight:800 !important; }
.csr-wrap .csr-file{
  position:absolute !important;
  inset:0 !important;
  opacity:0 !important;
  cursor:pointer !important;
}
.csr-wrap .csr-filelist{ margin-top:10px !important; font-size:14px !important; color:#6b7280 !important; }

.csr-wrap .csr-privacy-label{
  display:inline-flex !important;
  align-items:center !important;
  gap:10px !important;
  font-size:14px !important;
  color:#6b7280 !important;
  font-weight:700 !important;
}

.csr-wrap .csr-actions-row{
  display:flex !important;
  justify-content:center !important;
  gap:12px !important;
  margin-top:16px !important;
  flex-wrap:wrap !important;
}
.csr-wrap .csr-note{ margin-top:14px !important; opacity:.75 !important; font-size:14px !important; }

/* Messages */
.csr-wrap .csr-form-msg{ margin:0 auto 14px !important; max-width:720px !important; text-align:left !important; }
.csr-wrap .csr-form-msg.is-error{ background:rgba(185,28,28,0.08) !important; border:1px solid rgba(185,28,28,0.35) !important; padding:12px 14px !important; border-radius:12px !important; }
.csr-wrap .csr-form-msg.is-success{ background:rgba(16,185,129,0.10) !important; border:1px solid rgba(16,185,129,0.35) !important; padding:12px 14px !important; border-radius:12px !important; }
.csr-wrap .csr-form-msg.is-info{ background:rgba(59,130,246,0.10) !important; border:1px solid rgba(59,130,246,0.35) !important; padding:12px 14px !important; border-radius:12px !important; }

.csr-wrap .csr-has-error .csr-label{ color:#b91c1c !important; }
.csr-wrap .csr-error{ border-color:#b91c1c !important; box-shadow:0 0 0 3px rgba(185,28,28,0.15) !important; }
.csr-wrap .csr-field-error{ margin-top:8px !important; font-size:14px !important; font-weight:700 !important; color:#b91c1c !important; }

/* ---------- Modal (CRITICAL: cannot intercept clicks when closed) ---------- */
.csr-wrap .csr-modal{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
}
.csr-wrap .csr-modal.is-open{
  display:block !important;
  visibility:visible !important;
  pointer-events:auto !important;
  position:fixed !important;
  inset:0 !important;
  z-index:9999 !important;
}
.csr-wrap .csr-modal-backdrop{ position:absolute !important; inset:0 !important; background:rgba(0,0,0,.55) !important; }

.csr-wrap .csr-modal-panel{
  position:relative !important;
  width:min(920px, calc(100% - 24px)) !important;
  max-height:calc(100% - 24px) !important;
  margin:12px auto !important;
  background:#fff !important;
  border-radius:16px !important;
  overflow:auto !important;
  padding:16px !important;
  -webkit-overflow-scrolling:touch !important;
  overscroll-behavior:contain !important;
}
.csr-wrap .csr-modal-head{
  display:flex !important;
  justify-content:space-between !important;
  align-items:center !important;
  border-bottom:1px solid #eef0f3 !important;
  padding-bottom:10px !important;
  margin-bottom:10px !important;
}
.csr-wrap .csr-x{ border:0 !important; background:transparent !important; font-size:24px !important; line-height:1 !important; cursor:pointer !important; }

.csr-wrap .csr-row{ padding:12px 0 !important; border-bottom:1px solid #f1f5f9 !important; }
.csr-wrap .csr-row-top{ display:flex !important; justify-content:space-between !important; gap:10px !important; align-items:center !important; }
.csr-wrap .csr-row-name{ font-weight:900 !important; }
.csr-wrap .csr-row-title{ font-weight:900 !important; margin-top:4px !important; }
.csr-wrap .csr-row-content{ margin-top:6px !important; opacity:.9 !important; }
.csr-wrap .csr-row-photo img{ max-width:260px !important; border-radius:12px !important; margin-top:8px !important; }

/* === CSR: iOS-friendly carousel + visible progress bar === */

.csr-wrap .csr-carousel{
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  scroll-snap-type: x proximity !important;
  padding-bottom: 18px !important;
}

/* Custom progress bar shown on all devices (iOS included) */
.csr-wrap .csr-progress{
  width: 100% !important;
  max-width: 100% !important;
  height: 8px !important;
  margin: 8px 0 0 0 !important;
  background: rgba(17,24,39,0.10) !important;
  border-radius: 999px !important;
  overflow: hidden !important;
}

.csr-wrap .csr-progress-fill{
  display: block !important;
  height: 100% !important;
  width: 0% !important;
  background: rgba(227,179,65,0.95) !important;
  border-radius: 999px !important;
  transition: width 120ms linear !important;
}


