/* ================================================================
   Quote Popup CF7 – popup.css  v3
   
   DESIGN CONTRACT:
   - All selectors prefixed .qpc7-  → zero collision risk
   - Colour values always come from CSS custom properties
   - !important used ONLY on display/width overrides (theme conflict prevention)
   - Dynamic colours are injected via wp_add_inline_style with !important
     so they always win over theme stylesheets without needing specificity hacks
   ================================================================ */

/* ── Base variables (overridden by inline style from PHP) ── */
:root {
  --qpc7-accent:      #111111;
  --qpc7-accent-text: #ffffff;
  --qpc7-bg:          #ffffff;
  --qpc7-form-bg:     #ffffff;
  --qpc7-surface:     #f5f5f3;
  --qpc7-border:      #e2e0dc;
  --qpc7-text:        #111111;
  --qpc7-muted:       #888880;
  --qpc7-radius:      4px;
}

/* ================================================================
   BUTTON
   display:inline-flex !important → prevents themes setting display:block
   width:auto !important         → prevents themes setting width:100%
   ================================================================ */
.qpc7-quote-btn {
  display:        inline-flex !important;
  width:          auto        !important;
  align-items:    center;
  gap:            7px;
  margin-top:     10px;
  padding:        0 20px;
  height:         44px;
  font-family:    inherit;
  font-size:      0.875rem;
  font-weight:    500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius:  var(--qpc7-radius);
  cursor:         pointer;
  transition:     background-color 0.18s, color 0.18s, border-color 0.18s, opacity 0.18s, transform 0.12s;
  white-space:    nowrap;
  box-sizing:     border-box;
  line-height:    1;
  vertical-align: middle;
  text-decoration:none;
  -webkit-appearance: none;
  appearance:     none;
}
.qpc7-quote-btn:focus-visible {
  outline:        2px solid var(--qpc7-accent);
  outline-offset: 3px;
}
.qpc7-quote-btn:active { transform: scale(0.98); }

.qpc7-btn-icon { display:inline-flex; align-items:center; flex-shrink:0; }
.qpc7-btn-icon svg,
.qpc7-btn-icon img { width:17px; height:17px; display:block; }

/* Outline */
.qpc7-quote-btn.qpc7-btn--outline {
  background-color: transparent;
  color:            var(--qpc7-accent);
  border:           1.5px solid var(--qpc7-accent);
}
.qpc7-quote-btn.qpc7-btn--outline:hover {
  background-color: var(--qpc7-accent);
  color:            var(--qpc7-accent-text);
}
/* Solid */
.qpc7-quote-btn.qpc7-btn--solid {
  background-color: var(--qpc7-accent);
  color:            var(--qpc7-accent-text);
  border:           1.5px solid var(--qpc7-accent);
}
.qpc7-quote-btn.qpc7-btn--solid:hover { opacity:.84; }
/* Ghost */
.qpc7-quote-btn.qpc7-btn--ghost {
  background-color: transparent;
  color:            var(--qpc7-accent);
  border:           1.5px solid transparent;
}
.qpc7-quote-btn.qpc7-btn--ghost:hover { border-color: var(--qpc7-accent); }

.qpc7-btn--sm { height:36px; padding:0 14px; font-size:.8rem; }
.qpc7-btn--sm .qpc7-btn-icon svg,
.qpc7-btn--sm .qpc7-btn-icon img { width:15px; height:15px; }

/* ================================================================
   OVERLAY
   ================================================================ */
.qpc7-overlay {
  position:        fixed;
  inset:           0;
  z-index:         999999;
  display:         flex;
  align-items:     stretch;
  justify-content: flex-end;
  pointer-events:  none;
  /* Hidden via opacity+visibility so it doesn't block clicks when inactive */
  opacity:         0;
  visibility:      hidden;
  transition:      opacity 0.28s ease, visibility 0.28s ease;
}
.qpc7-overlay.is-active {
  pointer-events: all;
  opacity:        1;
  visibility:     visible;
}

/* Backdrop */
.qpc7-backdrop {
  position:   absolute;
  inset:      0;
  background: rgba(10,10,10,.45);
  backdrop-filter:         blur(5px) brightness(.9);
  -webkit-backdrop-filter: blur(5px) brightness(.9);
  opacity:    0;
  transition: opacity .28s ease;
}
.qpc7-overlay.is-active .qpc7-backdrop { opacity:1; }

/* ================================================================
   DRAWER — full-height right panel
   ================================================================ */
.qpc7-drawer {
  position:       relative;
  z-index:        1;
  width:          100%;
  max-width:      460px;
  height:         100%;
  display:        flex;
  flex-direction: column;
  background:     var(--qpc7-bg);
  border-left:    1px solid var(--qpc7-border);
  box-shadow:     -6px 0 32px rgba(0,0,0,.1);
  overflow:       hidden;   /* children scroll individually */
  transform:      translateX(100%);
  transition:     transform .35s cubic-bezier(.22,1,.36,1);
}
.qpc7-overlay.is-active .qpc7-drawer { transform:translateX(0); }

/* ── Header — fixed, never scrolls ── */
.qpc7-header {
  flex-shrink:     0;
  display:         flex;
  align-items:     center;
  justify-content: space-between;
  gap:             12px;
  padding:         20px 20px 16px;
  border-bottom:   1px solid var(--qpc7-border);
  background:      var(--qpc7-bg);
  box-sizing:      border-box;
}
.qpc7-header-left { display:flex; flex-direction:column; gap:3px; flex:1; min-width:0; }
.qpc7-header-tag  { font-size:.66rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--qpc7-muted); }
.qpc7-title       { margin:0; font-size:1.2rem; font-weight:700; color:var(--qpc7-text); line-height:1.2; letter-spacing:-.02em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* Close button — inside flex container, never overflows */
.qpc7-close {
  flex-shrink:     0;
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  width:  34px;
  height: 34px;
  padding: 0;
  margin:  0;
  background: transparent;
  border:     1px solid var(--qpc7-border);
  border-radius: var(--qpc7-radius);
  cursor:  pointer;
  color:   var(--qpc7-muted);
  transition: color .15s, border-color .15s, background .15s;
}
.qpc7-close:hover { color:var(--qpc7-text); border-color:var(--qpc7-text); background:var(--qpc7-surface); }
.qpc7-close svg   { width:14px; height:14px; display:block; }

/* ── Product card — fixed ── */
.qpc7-product-card {
  flex-shrink:   0;
  display:       flex;
  align-items:   center;
  gap:           14px;
  padding:       14px 20px;
  background:    var(--qpc7-surface);
  border-bottom: 1px solid var(--qpc7-border);
}
.qpc7-product-img-wrap {
  position:    relative;
  width:  60px; height:60px;
  flex-shrink: 0;
  border:      1px solid var(--qpc7-border);
  border-radius: var(--qpc7-radius);
  overflow:    hidden;
  background:  #fff;
}
.qpc7-product-img { width:100%; height:100%; object-fit:cover; display:block; transition:opacity .2s; }
.qpc7-product-img.is-loading { opacity:0; }

/* Skeleton shimmer */
.qpc7-img-skeleton {
  position:   absolute;
  inset:      0;
  background: linear-gradient(90deg,var(--qpc7-border) 25%,#ebebeb 50%,var(--qpc7-border) 75%);
  background-size:200% 100%;
  animation:  qpc7-shimmer 1.3s infinite;
}
.qpc7-img-skeleton.is-hidden { display:none; }
@keyframes qpc7-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

.qpc7-product-meta   { flex:1; min-width:0; }
.qpc7-product-label  { font-size:.66rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--qpc7-muted); margin-bottom:2px; }
.qpc7-product-name   { font-size:.9rem; font-weight:600; color:var(--qpc7-text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; line-height:1.3; }
.qpc7-product-variation {
  display:inline-block; margin-top:4px; padding:2px 7px;
  font-size:.73rem; font-weight:500;
  color:var(--qpc7-accent); border:1px solid currentColor; border-radius:3px;
}
.qpc7-product-arrow {
  flex-shrink:0; display:inline-flex; align-items:center; justify-content:center;
  width:30px; height:30px; color:var(--qpc7-muted);
  border:1px solid var(--qpc7-border); border-radius:var(--qpc7-radius);
  text-decoration:none; transition:color .15s, border-color .15s;
}
.qpc7-product-arrow:hover { color:var(--qpc7-text); border-color:var(--qpc7-text); }
.qpc7-product-arrow svg   { width:13px; height:13px; display:block; }

/* ── Rule ── */
.qpc7-rule { flex-shrink:0; height:1px; background:var(--qpc7-border); }

/* ── Form body — this area scrolls ── */
.qpc7-form-body {
  flex:       1;
  overflow-y: auto;
  overflow-x: hidden;
  padding:    22px 20px 32px;
  background-color:    var(--qpc7-form-bg);
  background-image:    var(--qpc7-form-bg-image, none);
  background-size:     cover;
  background-position: center;
  position:   relative;
}
/* Overlay tint when bg image is set */
.qpc7-form-body.has-bg-image::before {
  content:''; position:absolute; inset:0;
  background:rgba(0,0,0,.35); pointer-events:none; z-index:0;
}
.qpc7-form-body.has-bg-image .wpcf7 { position:relative; z-index:1; }
/* Scrollbar */
.qpc7-form-body::-webkit-scrollbar       { width:3px; }
.qpc7-form-body::-webkit-scrollbar-track { background:transparent; }
.qpc7-form-body::-webkit-scrollbar-thumb { background:var(--qpc7-border); }

/* ================================================================
   CF7 OVERRIDES  (scoped to .qpc7-form-body to avoid global bleed)
   ================================================================ */
.qpc7-form-body .wpcf7-form   { margin:0; }
.qpc7-form-body .wpcf7-form p { margin:0 0 13px; }
.qpc7-form-body .wpcf7-form br{ display:none; }

.qpc7-form-body .wpcf7-form input[type="text"],
.qpc7-form-body .wpcf7-form input[type="email"],
.qpc7-form-body .wpcf7-form input[type="tel"],
.qpc7-form-body .wpcf7-form input[type="url"],
.qpc7-form-body .wpcf7-form input[type="number"],
.qpc7-form-body .wpcf7-form textarea,
.qpc7-form-body .wpcf7-form select {
  width:      100%;
  padding:    10px 13px;
  font-size:  .9rem;
  font-family:inherit;
  background: #fff;
  border:     1px solid var(--qpc7-border);
  border-radius: var(--qpc7-radius);
  color:      var(--qpc7-text);
  transition: border-color .18s, box-shadow .18s;
  outline:    none;
  box-sizing: border-box;
  -webkit-appearance:none;
  appearance: none;
}
.qpc7-form-body.has-bg-image .wpcf7-form input[type="text"],
.qpc7-form-body.has-bg-image .wpcf7-form input[type="email"],
.qpc7-form-body.has-bg-image .wpcf7-form input[type="tel"],
.qpc7-form-body.has-bg-image .wpcf7-form textarea,
.qpc7-form-body.has-bg-image .wpcf7-form select {
  background:rgba(255,255,255,.92);
}
.qpc7-form-body .wpcf7-form textarea { min-height:88px; resize:vertical; }

/* Submit — base colour via CSS var; overridden with !important by inline style */
.qpc7-form-body .wpcf7-form input[type="submit"] {
  background-color: var(--qpc7-accent);
  color:            var(--qpc7-accent-text);
  border:           none;
  padding:          0 24px;
  height:           46px;
  width:            100%;
  font-size:        .85rem;
  font-weight:      600;
  font-family:      inherit;
  letter-spacing:   .07em;
  text-transform:   uppercase;
  border-radius:    var(--qpc7-radius);
  cursor:           pointer;
  transition:       opacity .18s, transform .12s;
  margin-top:       4px;
  box-sizing:       border-box;
  -webkit-appearance:none;
  appearance:       none;
}
.qpc7-form-body .wpcf7-form input[type="submit"]:hover  { opacity:.82; }
.qpc7-form-body .wpcf7-form input[type="submit"]:active { transform:scale(.99); }

/* Validation */
.qpc7-form-body .wpcf7-not-valid     { border-color:#d63638 !important; }
.qpc7-form-body .wpcf7-not-valid-tip { color:#d63638; font-size:.78rem; margin-top:3px; display:block; }
.qpc7-form-body .wpcf7-response-output {
  padding:10px 13px; border-radius:var(--qpc7-radius); font-size:.84rem; margin-top:10px; border:none !important;
}
.qpc7-form-body .wpcf7-mail-sent-ok { background:#f0faf4; color:#166534; border:1px solid #bbf7d0 !important; }
.qpc7-form-body .wpcf7-mail-sent-ng { background:#fef2f2; color:#991b1b; border:1px solid #fecaca !important; }

/* Auto-filled hidden fields */
.qpc7-form-body .qpc7-hidden-field { display:none !important; }

/* Notice */
.qpc7-notice { padding:11px 14px; border-radius:var(--qpc7-radius); font-size:.87rem; }
.qpc7-notice--warn { background:#fffbeb; color:#92400e; border:1px solid #fde68a; }

/* ================================================================
   DARK MODE
   ================================================================ */
@media (prefers-color-scheme:dark) {
  :root {
    --qpc7-bg:      #141414;
    --qpc7-surface: #1c1c1c;
    --qpc7-border:  #2c2c2c;
    --qpc7-text:    #f0f0f0;
    --qpc7-muted:   #777;
    --qpc7-form-bg: #1a1a1a;
  }
  .qpc7-drawer { box-shadow:-6px 0 32px rgba(0,0,0,.5); }
  .qpc7-form-body .wpcf7-form input[type="text"],
  .qpc7-form-body .wpcf7-form input[type="email"],
  .qpc7-form-body .wpcf7-form input[type="tel"],
  .qpc7-form-body .wpcf7-form textarea,
  .qpc7-form-body .wpcf7-form select { background:#1e1e1e; border-color:#2c2c2c; color:#f0f0f0; }
}

/* ================================================================
   RESPONSIVE — bottom sheet on mobile
   ================================================================ */
@media (max-width:520px) {
  .qpc7-overlay        { align-items:flex-end; justify-content:center; }
  .qpc7-drawer         { max-width:100%; height:90%; border-left:none; border-top:1px solid var(--qpc7-border); border-radius:14px 14px 0 0; transform:translateY(100%); }
  .qpc7-overlay.is-active .qpc7-drawer { transform:translateY(0); }
  .qpc7-header         { padding:16px 16px 12px; }
  .qpc7-product-card   { padding:12px 16px; }
  .qpc7-form-body      { padding:18px 16px 28px; }
}

/* Body scroll lock */
body.qpc7-popup-open { overflow:hidden; }

/* Reduce motion */
@media (prefers-reduced-motion:reduce) {
  .qpc7-overlay,.qpc7-backdrop,.qpc7-drawer,.qpc7-quote-btn,.qpc7-close {
    transition:none !important; animation:none !important;
  }
}
