/* ============================================================
   SmoothSpine Vitrine — vitrine.css
   Overrides + cart drawer + WP/Woo disguise-safe styles
   Loaded AFTER theme CSS so takes precedence.
   ============================================================ */

/* ---------- WP disguise: hide any theme "cart" behavior that
     would conflict with our drawer while keeping WooCommerce
     body classes visible in DOM ---------- */
body.vt-drawer-open { overflow: hidden; }

/* ---------- Strip all Shopify / app popups ----------
   Elements we hide (they still exist in DOM but never render).
   This is safer than regex-stripping around nested <div>s.
   Our own vt-drawer (id="vt-drawer") is intentionally left visible. */
cart-drawer,
search-drawer,
klaviyo-form,
kl-form,
klaviyo-onsite,
[class*="klaviyo-form"],
[id*="klaviyo-form"],
dialog:not(#vt-drawer *),
/* Shopify section wrappers */
[id*="shopify-section"][id*="cart-drawer"],
[id*="shopify-section"][id*="search-drawer"],
[id*="shopify-section"][id*="popup"],
[id*="shopify-section"][id*="newsletter-modal"],
[id*="shopify-section"][id*="klaviyo"],
[id*="shopify-section"][id*="announcement"],
[class*="announcement-bar-wrapper"],
[class*="announcement-bar"]:not([class*="hero"]),
/* Common intrusive popups */
.newsletter-popup,
.discount-popup,
.exit-popup,
.welcome-popup,
.age-verification,
.spin-wheel,
.wheelio,
.wisepops-widget,
[class*="Wisepops"],
[id*="wisepops"],
[class*="privy-"],
[id*="privy-"],
[id*="justuno"],
[class*="omnisend"],
[class*="slidecart"],
#slidecart,
[class*="smsbump"],
/* Sticky offer bars */
[class*="sticky-offer"],
[class*="floating-offer"],
[class*="promo-bar"]:not(header *),
/* Judge.me / Loox popups */
.jdgm-modal,
.jdgm-write-rev-open-form,
.loox-popup,
[class*="loox-popup"],
/* Chat / support popups (Gorgias, Intercom, Tidio, LiveChat) */
[id*="gorgias-chat"],
[id*="intercom-container"],
[id*="tidio-chat"],
[id*="livechat"],
[class*="crisp-client"] { display: none !important; visibility: hidden !important; }

/* Preserve our own drawer explicitly */
#vt-drawer { display: block !important; visibility: visible !important; }

/* ---------- CART DRAWER ---------- */
.vt-drawer {
  position: fixed;
  inset: 0;
  z-index: 999999;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.25s ease;
}
.vt-drawer.is-open {
  pointer-events: auto;
  opacity: 1;
}
.vt-drawer__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
}
.vt-drawer__panel {
  position: absolute;
  top: 0;
  right: 0;
  height: 100vh;
  width: min(420px, 100vw);
  background: #fff;
  display: flex;
  flex-direction: column;
  box-shadow: -8px 0 30px rgba(0, 0, 0, 0.15);
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  font-family: "Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
.vt-drawer.is-open .vt-drawer__panel { transform: translateX(0); }

.vt-drawer__head {
  padding: 20px 24px;
  border-bottom: 1px solid #e5e5e5;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: "Plus Jakarta Sans", "Open Sans", sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: #1a1a1a;
}
.vt-drawer__x {
  background: transparent;
  border: 0;
  font-size: 28px;
  cursor: pointer;
  color: #666;
  line-height: 1;
  padding: 0;
  width: 32px;
  height: 32px;
}
.vt-drawer__x:hover { color: #000; }

.vt-drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: 12px 24px;
}
.vt-drawer__empty {
  text-align: center;
  color: #666;
  padding: 60px 0;
  font-size: 15px;
}

.vt-line {
  display: flex;
  gap: 12px;
  padding: 16px 0;
  border-bottom: 1px solid #f0f0f0;
  align-items: flex-start;
}
.vt-line__body { flex: 1; }
.vt-line__title {
  font-weight: 600;
  color: #1a1a1a;
  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 4px;
}
.vt-line__meta {
  font-size: 13px;
  color: #666;
}
.vt-line__remove {
  background: transparent;
  border: 0;
  font-size: 20px;
  cursor: pointer;
  color: #999;
  padding: 0 4px;
}
.vt-line__remove:hover { color: #d33; }

.vt-drawer__foot {
  padding: 20px 24px;
  border-top: 1px solid #e5e5e5;
  background: #fafafa;
}
.vt-drawer__subtotal {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 15px;
  color: #1a1a1a;
  margin-bottom: 14px;
}
.vt-drawer__subtotal strong {
  font-size: 18px;
  font-weight: 700;
}
.vt-drawer__checkout {
  width: 100%;
  padding: 15px;
  background: #1a1a1a;
  color: #fff;
  border: 0;
  border-radius: 6px;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  transition: background 0.2s;
  font-family: inherit;
  letter-spacing: 0.02em;
}
.vt-drawer__checkout:hover { background: #000; }
.vt-drawer__note {
  text-align: center;
  color: #888;
  font-size: 12px;
  margin: 10px 0 0;
}

/* ---------- BUFFER CHECKOUT PAGE ---------- */
.vt-checkout {
  max-width: 900px;
  margin: 60px auto;
  padding: 40px 20px;
  font-family: "Open Sans", sans-serif;
  color: #1a1a1a;
}
.vt-checkout__title {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 800;
  font-size: 32px;
  margin-bottom: 30px;
  letter-spacing: -0.02em;
}
.vt-checkout__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}
@media (max-width: 720px) { .vt-checkout__grid { grid-template-columns: 1fr; gap: 24px; } }

.vt-checkout__form label {
  display: block;
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 6px;
  color: #333;
}
.vt-checkout__form input,
.vt-checkout__form select {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #dcdcdc;
  border-radius: 6px;
  font-size: 15px;
  margin-bottom: 18px;
  font-family: inherit;
  transition: border-color 0.2s;
}
.vt-checkout__form input:focus,
.vt-checkout__form select:focus {
  outline: none;
  border-color: #1a1a1a;
}

.vt-checkout__summary {
  background: #fafafa;
  padding: 24px;
  border-radius: 8px;
}
.vt-checkout__summary h2 {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 16px;
  font-weight: 700;
  margin: 0 0 16px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #666;
}
.vt-checkout__summary .vt-line {
  border-color: #e5e5e5;
}
.vt-checkout__summary .vt-total {
  display: flex;
  justify-content: space-between;
  padding: 18px 0 0;
  font-weight: 700;
  font-size: 18px;
}
.vt-checkout__finalize {
  width: 100%;
  margin-top: 24px;
  padding: 18px;
  background: #1a1a1a;
  color: #fff;
  border: 0;
  border-radius: 6px;
  font-weight: 700;
  font-size: 17px;
  cursor: pointer;
  font-family: inherit;
  letter-spacing: 0.02em;
  transition: background 0.2s;
}
.vt-checkout__finalize:hover { background: #000; }
.vt-checkout__finalize:disabled {
  background: #999;
  cursor: not-allowed;
}
.vt-checkout__trust {
  display: flex;
  gap: 20px;
  justify-content: center;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid #e5e5e5;
  color: #999;
  font-size: 12px;
}
.vt-checkout__trust > span { display: flex; align-items: center; gap: 6px; }

/* ---------- Accessibility ---------- */
.vt-drawer *:focus-visible {
  outline: 2px solid #1a1a1a;
  outline-offset: 2px;
}
