/*!
 * Bee1 Quick View — front-end styles
 *
 * Preset = data-preset on .bee1-qv-root.
 * Default preset = minimal-mono (Gocha-style).
 * All colors / spacings / radii defined as CSS variables — easy to override per site.
 */

/* =========================================================================
   Preset: Minimal Mono (default)
   Quiet B&W, sharp corners, matches Gocha existing brand.
   ========================================================================= */
.bee1-qv-root,
.bee1-qv-root[data-preset="minimal-mono"] {
  --bee1qv-bg:           #ffffff;
  --bee1qv-fg:           #000000;
  --bee1qv-muted:        #6b7280;
  --bee1qv-border:       #d4d4d8;
  --bee1qv-border-hard:  #000000;
  --bee1qv-cta-bg:       #000000;
  --bee1qv-cta-fg:       #ffffff;
  --bee1qv-cta-hover:    #1a1a1a;
  --bee1qv-badge-bg:     #ed1c24;
  --bee1qv-badge-fg:     #ffffff;
  --bee1qv-backdrop:     rgba(0, 0, 0, 0.55);
  --bee1qv-shadow:       0 16px 48px rgba(0, 0, 0, 0.18);
  --bee1qv-radius:       0px;
  --bee1qv-radius-pill:  999px;   /* Gocha-style rounded size buttons */
  --bee1qv-swatch-radius: 3px;
  --bee1qv-font:         'Assistant', 'Heebo', 'Rubik', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --bee1qv-trans:        220ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* Preset: Bee1 Default — navy + bee gold */
.bee1-qv-root[data-preset="bee1-default"] {
  --bee1qv-bg:          #ffffff;
  --bee1qv-fg:          #171f3b;
  --bee1qv-muted:       #64748b;
  --bee1qv-border:      #e2e8f0;
  --bee1qv-border-hard: #171f3b;
  --bee1qv-cta-bg:      #fbc109;
  --bee1qv-cta-fg:      #171f3b;
  --bee1qv-cta-hover:   #fdc730;
  --bee1qv-badge-bg:    #171f3b;
  --bee1qv-badge-fg:    #fbc109;
  --bee1qv-radius:      12px;
  --bee1qv-radius-pill: 999px;
  --bee1qv-swatch-radius: 4px;
  --bee1qv-font:        'Segoe UI', 'Assistant', system-ui, sans-serif;
}

/* Preset: Warm Boutique — cream + warm dark */
.bee1-qv-root[data-preset="warm-boutique"] {
  --bee1qv-bg:          #faf8f3;
  --bee1qv-fg:          #2b2724;
  --bee1qv-muted:       #6e655e;
  --bee1qv-border:      #e7dfd2;
  --bee1qv-border-hard: #2b2724;
  --bee1qv-cta-bg:      #2b2724;
  --bee1qv-cta-fg:      #faf8f3;
  --bee1qv-cta-hover:   #1f1c1a;
  --bee1qv-badge-bg:    #2b2724;
  --bee1qv-badge-fg:    #faf8f3;
  --bee1qv-radius:      8px;
  --bee1qv-radius-pill: 999px;
  --bee1qv-swatch-radius: 4px;
}

/* =========================================================================
   Trigger button on product card
   ========================================================================= */
.bee1-qv-trigger {
  position: absolute;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 36px;
  min-height: 36px;
  padding: 6px 8px;
  background: #ffffff;
  color: #000000;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: var(--bee1qv-radius, 0);
  cursor: pointer;
  font: 500 13px/1 'Assistant', system-ui, sans-serif;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 200ms ease, transform 200ms ease, background 160ms ease;
  pointer-events: none;
}

.bee1-qv-trigger:focus-visible,
.bee1-qv-trigger:hover {
  background: #000;
  color: #fff;
}

.bee1-qv-trigger__icon { display: inline-block; }
.bee1-qv-trigger__label { display: inline-block; white-space: nowrap; }

/* Show on card hover (desktop) */
.bee1-ulg-card:hover .bee1-qv-trigger,
.bee1-ulg-card:focus-within .bee1-qv-trigger,
.products li.product:hover .bee1-qv-trigger,
.products li.product:focus-within .bee1-qv-trigger {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* Always visible on mobile (no hover) */
@media (max-width: 768px) {
  .bee1-qv-trigger {
    opacity: 1;
    transform: none;
    pointer-events: auto;
    background: rgba(255, 255, 255, 0.95);
  }
}

/* Position variants */
.bee1-qv-trigger--media-top-right    { top: 8px;    right: 8px; }
.bee1-qv-trigger--media-top-left     { top: 8px;    left: 8px; }
.bee1-qv-trigger--media-top-start    { top: 8px;    inset-inline-start: 8px; }
.bee1-qv-trigger--media-top-end      { top: 8px;    inset-inline-end:   8px; }
.bee1-qv-trigger--media-bottom-start { bottom: 8px; inset-inline-start: 8px; }
.bee1-qv-trigger--media-bottom-end   { bottom: 8px; inset-inline-end:   8px; }
.bee1-qv-trigger--variations-row     { position: static; opacity: 1; transform: none; pointer-events: auto; }

.bee1-ulg-card .bee1-qv-trigger.bee1-qv-trigger--ctx-loop-grid,
.bee1-qv-trigger.bee1-qv-trigger--ctx-loop-grid {
  top: 10px !important;
  bottom: auto !important;
  inset-inline-start: 10px !important;
  inset-inline-end: auto !important;
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  min-height: 38px !important;
  padding: 0 !important;
  appearance: none !important;
  background: rgba(255, 255, 255, 0.94) !important;
  color: #111 !important;
  border: 1px solid rgba(0, 0, 0, 0.16) !important;
  border-radius: 999px !important;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.13);
  transform: none !important;
  z-index: 30 !important;
}

.bee1-qv-trigger--ctx-loop-grid > svg,
.bee1-qv-trigger--ctx-loop-grid > img,
.bee1-qv-trigger--ctx-loop-grid .bee1-qv-trigger__icon {
  display: none !important;
}

.bee1-qv-trigger--ctx-loop-grid::before,
.bee1-qv-trigger--ctx-loop-grid::after {
  content: "";
  position: absolute;
  display: block;
  pointer-events: none;
}

.bee1-qv-trigger--ctx-loop-grid::before {
  width: 14px;
  height: 14px;
  border: 1.8px solid currentColor;
  border-radius: 999px;
  top: 9px;
  left: 9px;
}

.bee1-qv-trigger--ctx-loop-grid::after {
  width: 8px;
  height: 1.8px;
  background: currentColor;
  border-radius: 999px;
  top: 24px;
  left: 22px;
  transform: rotate(45deg);
  transform-origin: left center;
}

.bee1-qv-trigger.bee1-qv-trigger--ctx-loop-grid:focus-visible,
.bee1-qv-trigger.bee1-qv-trigger--ctx-loop-grid:hover {
  background: #ffffff !important;
  color: #000000 !important;
  border-color: #000000 !important;
  transform: scale(1.04) !important;
}

@media (max-width: 768px) {
  .bee1-ulg-card .bee1-qv-trigger.bee1-qv-trigger--ctx-loop-grid,
  .bee1-qv-trigger.bee1-qv-trigger--ctx-loop-grid {
    top: 8px !important;
    inset-inline-start: 8px !important;
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    border-color: rgba(0, 0, 0, 0.12) !important;
    box-shadow: 0 5px 16px rgba(0, 0, 0, 0.12) !important;
  }
  .bee1-qv-trigger--ctx-loop-grid::before {
    width: 12px;
    height: 12px;
    top: 8px;
    left: 8px;
  }
  .bee1-qv-trigger--ctx-loop-grid::after {
    width: 7px;
    top: 21px;
    left: 20px;
  }
}

/* =========================================================================
   Modal root (server-rendered shell)
   ========================================================================= */
.bee1-qv-root[hidden] { display: none !important; }

.bee1-qv-root {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--bee1qv-font);
  color: var(--bee1qv-fg);
  opacity: 0;
  transition: opacity var(--bee1qv-trans);
}

.bee1-qv-root.is-open { opacity: 1; }

.bee1-qv-backdrop {
  position: absolute;
  inset: 0;
  background: var(--bee1qv-backdrop);
  cursor: pointer;
}

.bee1-qv-modal {
  position: relative;
  width: min(1120px, calc(100vw - 48px));
  max-height: min(840px, calc(100vh - 32px));
  background: var(--bee1qv-bg);
  border-radius: var(--bee1qv-radius);
  box-shadow: var(--bee1qv-shadow);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform: translateY(12px) scale(0.98);
  transition: transform var(--bee1qv-trans);
}

.bee1-qv-root.is-open .bee1-qv-modal {
  transform: none;
}

.bee1-qv-close {
  position: absolute;
  top: 12px;
  inset-inline-end: 12px;
  width: 38px;
  height: 38px;
  background: rgba(255, 255, 255, 0.9);
  border: 0;
  color: #303030;
  cursor: pointer;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
  transition: background 160ms ease, color 160ms ease, transform 160ms ease;
}
.bee1-qv-close:hover { background: #f3f3f3; color: #000; transform: scale(1.03); }
.bee1-qv-close:focus-visible { outline: 2px solid rgba(0, 0, 0, 0.22); outline-offset: 2px; }

.bee1-qv-root .bee1-qv-modal button.bee1-qv-close {
  background: rgba(255, 255, 255, 0.9) !important;
  border: 0 !important;
  border-radius: 999px !important;
  color: #303030 !important;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12) !important;
}

.bee1-qv-root .bee1-qv-modal button.bee1-qv-close:hover {
  background: #f3f3f3 !important;
  color: #000000 !important;
}

.bee1-qv-handle { display: none; }

.bee1-qv-body {
  display: grid;
  grid-template-columns: minmax(430px, 1.04fr) minmax(360px, 0.96fr);
  gap: 30px;
  padding: 28px 30px;
  overflow: auto;
}

/* =========================================================================
   Gallery
   ========================================================================= */
.bee1-qv-gallery {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 68px;
  gap: 8px;
  align-items: start;
  direction: ltr;
}

.bee1-qv-gallery__main {
  position: relative;
  background: #f5f5f5;
  aspect-ratio: 2 / 3;
  overflow: hidden;
  grid-column: 1;
}
.bee1-qv-gallery__main img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.bee1-qv-gallery__thumbs {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex-wrap: nowrap;
  grid-column: 2;
  max-height: min(74vh, 720px);
  overflow-y: auto;
  scrollbar-width: thin;
}

.bee1-qv-root .bee1-qv-gallery .bee1-qv-thumb {
  display: block;
  width: 68px !important;
  height: 88px !important;
  min-width: 68px;
  min-height: 88px;
  padding: 0 !important;
  background: #f5f5f5;
  border: 1px solid var(--bee1qv-border);
  border-radius: 2px;
  line-height: 0;
  cursor: pointer;
  overflow: hidden;
  box-sizing: border-box;
}
.bee1-qv-root .bee1-qv-gallery .bee1-qv-thumb img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  max-width: none;
}
.bee1-qv-root .bee1-qv-gallery .bee1-qv-thumb.is-current { border-color: var(--bee1qv-border-hard); }

/* =========================================================================
   Info column
   ========================================================================= */
.bee1-qv-info {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 15px;
  padding: 48px 4px 10px 12px;
  text-align: start;
}

.bee1-qv-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.bee1-qv-badge {
  display: inline-block;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  background: var(--bee1qv-badge-bg);
  color: var(--bee1qv-badge-fg);
  border-radius: var(--bee1qv-radius);
}
.bee1-qv-badge--sale { background: var(--bee1qv-badge-bg); }

.bee1-qv-root .bee1-qv-title {
  font-size: clamp(24px, 2.15vw, 32px);
  font-weight: 700;
  line-height: 1.22;
  margin: 0;
  color: var(--bee1qv-fg);
  text-align: start;
}

.bee1-qv-price {
  position: relative;
  font-size: 24px;
  font-weight: 700;
  padding-inline-start: 0;
}
.bee1-qv-price::before {
  content: '';
  position: absolute;
  inset-inline-start: 0;
  top: 6%;
  bottom: 6%;
  width: 3px;
  display: none;
  background: var(--bee1qv-badge-bg, #ed1c24);
}
.bee1-qv-price del { color: var(--bee1qv-muted); font-weight: 400; margin-inline-end: 8px; }
.bee1-qv-price ins { text-decoration: none; color: var(--bee1qv-badge-bg, #ed1c24); }

.bee1-qv-root .bee1-qv-summary {
  max-width: 48ch;
  margin-top: -2px;
  color: #202020;
  font-size: 15px;
  line-height: 1.55;
  overflow: hidden;
  display: -webkit-box !important;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.bee1-qv-attributes {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 8px;
}

.bee1-qv-attr__header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 16px;
  margin-bottom: 8px;
}
.bee1-qv-attr__name { font-weight: 700; }
.bee1-qv-attr__value { color: var(--bee1qv-muted); font-size: 13px; }

.bee1-qv-attr__options {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.bee1-qv-model-colors {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.bee1-qv-model-colors__header {
  font-size: 16px;
  font-weight: 700;
}

.bee1-qv-model-colors__options {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.bee1-qv-model-color {
  position: relative;
  width: 36px;
  height: 36px;
  min-width: 36px;
  padding: 0;
  border: 1px solid var(--bee1qv-border-hard);
  border-radius: var(--bee1qv-swatch-radius, 3px);
  background: #cccccc;
  cursor: pointer;
  transition: border-color 140ms ease, transform 140ms ease, outline-color 140ms ease;
}

.bee1-qv-model-color:hover {
  transform: translateY(-1px);
}

.bee1-qv-model-color.is-current {
  outline: 1px solid var(--bee1qv-border-hard);
  outline-offset: 3px;
  border-color: #ffffff;
  border-width: 2px;
}

/* Text option = size button — Gocha-style: pill/round with outline.
   We use --bee1qv-radius-pill so Minimal Mono = 999px (full pill),
   while other presets can pick narrower radii. */
.bee1-qv-opt {
  position: relative;
  min-width: 38px;
  height: 38px;
  padding: 0 10px;
  background: var(--bee1qv-bg);
  color: var(--bee1qv-fg);
  border: 1px solid var(--bee1qv-border);
  border-radius: var(--bee1qv-radius-pill, 999px);
  font: 500 14px/1 var(--bee1qv-font);
  cursor: pointer;
  transition: border-color 140ms ease, background 140ms ease, color 140ms ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.bee1-qv-opt:not(:disabled):hover { border-color: var(--bee1qv-border-hard); }
.bee1-qv-opt.is-selected {
  border-color: var(--bee1qv-border-hard);
  border-width: 1.5px;
  font-weight: 600;
}
.bee1-qv-opt.is-unavailable,
.bee1-qv-opt:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  text-decoration: none;
  color: var(--bee1qv-muted);
}
/* X overlay on unavailable text option, Gocha-style */
.bee1-qv-opt.is-unavailable.bee1-qv-opt--text::after {
  content: '';
  position: absolute;
  inset: 50% 8% auto;
  height: 1px;
  background: currentColor;
  transform: translateY(-50%) rotate(-22deg);
  opacity: 0.85;
  pointer-events: none;
}

.bee1-qv-opt--swatch {
  width: 36px;
  height: 36px;
  min-width: 36px;
  padding: 0;
  border-radius: var(--bee1qv-swatch-radius, 3px);
  border: 1px solid var(--bee1qv-border-hard);
  background-color: #ccc;
}
.bee1-qv-opt--swatch.is-selected {
  outline: 1px solid var(--bee1qv-border-hard);
  outline-offset: 3px;
  border-color: #fff;
  border-width: 2px;
}
.bee1-qv-opt--swatch.is-unavailable::after {
  content: '';
  position: absolute;
  inset: 50% 12% auto;
  height: 1px;
  background: var(--bee1qv-fg);
  transform: translateY(-50%) rotate(-30deg);
  opacity: 0.65;
}

/* =========================================================================
   Actions
   ========================================================================= */
.bee1-qv-actions {
  display: flex;
  flex-direction: row;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.bee1-qv-add {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-width: 168px;
  min-height: 42px;
  padding: 12px 24px;
  background: var(--bee1qv-cta-bg);
  color: var(--bee1qv-cta-fg);
  border: 1px solid var(--bee1qv-cta-bg);
  border-radius: var(--bee1qv-radius);
  font: 600 15px/1 var(--bee1qv-font);
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: background 160ms ease, transform 160ms ease;
}
.bee1-qv-add:not(:disabled):hover { background: var(--bee1qv-cta-hover); border-color: var(--bee1qv-cta-hover); }
.bee1-qv-add:disabled { background: #8f8f8f; border-color: #8f8f8f; opacity: 1; cursor: not-allowed; }
.bee1-qv-add.is-loading { opacity: 0.7; }

.bee1-qv-more {
  text-align: center;
  font-size: 13px;
  color: var(--bee1qv-muted);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.bee1-qv-more:hover { color: var(--bee1qv-fg); }

.bee1-qv-conversion-trust {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-top: 4px;
}

.bee1-qv-conversion-trust__item {
  position: relative;
  min-height: 56px;
  padding: 8px 6px;
  background: #f5f5f5;
  border: 1px solid #eeeeee;
  border-radius: 8px;
  color: #1c1c1c;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  text-align: center;
  font: 600 12px/1.15 var(--bee1qv-font);
  cursor: help;
  outline: none;
}

.bee1-qv-conversion-trust__item:focus-visible {
  border-color: #000000;
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.09);
}

.bee1-qv-conversion-trust__item svg {
  width: 19px;
  height: 19px;
  display: block;
  color: #000000;
}

.bee1-qv-conversion-trust__label {
  display: block;
  max-width: 100%;
  white-space: normal;
}

.bee1-qv-conversion-trust__tooltip {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 9px);
  z-index: 10;
  width: max-content;
  max-width: 220px;
  padding: 8px 10px;
  background: #111111;
  color: #ffffff;
  border-radius: 6px;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.18);
  font: 500 12px/1.35 var(--bee1qv-font);
  text-align: center;
  opacity: 0;
  transform: translateX(-50%) translateY(3px);
  pointer-events: none;
  transition: opacity 150ms ease, transform 150ms ease;
}

.bee1-qv-conversion-trust__tooltip::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 100%;
  width: 9px;
  height: 9px;
  background: #111111;
  transform: translate(-50%, -5px) rotate(45deg);
}

.bee1-qv-conversion-trust__item:hover .bee1-qv-conversion-trust__tooltip,
.bee1-qv-conversion-trust__item:focus-visible .bee1-qv-conversion-trust__tooltip {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.bee1-qv-message {
  min-height: 1.2em;
  margin: 0;
  font-size: 13px;
}
.bee1-qv-message.is-error { color: #c00; }
.bee1-qv-message.is-success { color: #1a7f37; }

/* =========================================================================
   Loader
   ========================================================================= */
.bee1-qv-loader {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
}
.bee1-qv-loader__spinner {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 3px solid var(--bee1qv-border);
  border-top-color: var(--bee1qv-fg);
  animation: bee1qvSpin 0.8s linear infinite;
}
@keyframes bee1qvSpin { to { transform: rotate(360deg); } }

/* =========================================================================
   Body scroll lock + cart pulse
   ========================================================================= */
html.bee1-qv-locked,
html.bee1-qv-locked body {
  overflow: hidden;
}

.bee1-qv-cart-pulse {
  animation: bee1qvPulse 420ms ease;
}
@keyframes bee1qvPulse {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.18); }
  100% { transform: scale(1); }
}

.bee1-qv-fly-ghost {
  position: fixed;
  z-index: 100000;
  pointer-events: none;
  object-fit: cover;
  border-radius: var(--bee1qv-radius);
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.2);
}

/* =========================================================================
   Mobile bottom-sheet
   ========================================================================= */
@media (max-width: 768px) {
  .bee1-qv-root { align-items: flex-end; justify-content: stretch; }
  .bee1-qv-modal {
    width: 100%;
    max-height: 92vh;
    border-radius: 0;
    transform: translateY(100%);
  }
  .bee1-qv-root.is-open .bee1-qv-modal { transform: translateY(0); }
  .bee1-qv-handle {
    display: block;
    width: 36px;
    height: 4px;
    margin: 8px auto 4px;
    background: var(--bee1qv-border);
    border-radius: 999px;
    cursor: grab;
    touch-action: none;
  }
  .bee1-qv-body {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 16px;
  }
  .bee1-qv-gallery {
    display: flex;
    flex-direction: column;
    direction: inherit;
  }
  .bee1-qv-gallery__thumbs {
    flex-direction: row;
    overflow-x: auto;
    overflow-y: hidden;
    max-height: none;
  }
  .bee1-qv-root .bee1-qv-gallery .bee1-qv-thumb {
    width: 56px !important;
    height: 74px !important;
    min-width: 56px;
    min-height: 74px;
    flex: 0 0 auto;
  }
  .bee1-qv-info { justify-content: flex-start; padding: 0; }
  .bee1-qv-root .bee1-qv-title { font-size: 21px; line-height: 1.2; }
  .bee1-qv-price { font-size: 20px; }
  .bee1-qv-gallery__main { aspect-ratio: 1 / 1; }
  .bee1-qv-actions { flex-direction: column; align-items: stretch; }
  .bee1-qv-add { width: 100%; }
  .bee1-qv-conversion-trust { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* =========================================================================
   RTL
   ========================================================================= */
[dir="rtl"] .bee1-qv-modal { direction: rtl; }
[dir="rtl"] .bee1-qv-close { inset-inline-end: 10px; }

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  .bee1-qv-root,
  .bee1-qv-modal,
  .bee1-qv-opt,
  .bee1-qv-add,
  .bee1-qv-trigger { transition: none !important; }
  .bee1-qv-loader__spinner { animation-duration: 1.6s; }
}
