@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600&display=swap');

:root{
  --wqb-green:#18764A;
  --wqb-black:#000000;
  --wqb-border:#e5e7eb;
  --wqb-muted:#6b7280;
  --wqb-radius:4px;
}

.wqb-sidecart, .wqb-modal, .wqb-qtywrap, .wqb-float{
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

.wqb-sidecart{position:fixed; inset:0; z-index:99999; visibility:hidden; opacity:0; transition:opacity .2s ease, visibility .2s ease;}
.wqb-sidecart.active{visibility:visible; opacity:1;}
.wqb-overlay{position:absolute; inset:0; background:rgba(0,0,0,.55); cursor:pointer;}
.wqb-panel{position:absolute; top:0; right:-460px; width:460px; max-width:92vw; height:100%; background:#fff; display:flex; flex-direction:column; transition:right .25s ease; box-shadow:-2px 0 14px rgba(0,0,0,.12);}
.wqb-sidecart.active .wqb-panel{right:0;}

.wqb-header{padding:14px 16px; border-bottom:1px solid var(--wqb-border); display:flex; justify-content:space-between; align-items:center; background:#fff;}
.wqb-header h3{margin:0; font-size:16px; font-weight:600; color:#111827;}
.wqb-close{width:32px; height:32px; border:1px solid var(--wqb-border); border-radius:var(--wqb-radius); background:#fff !important; font-size:18px; line-height:1; display:flex; align-items:center; justify-content:center; cursor:pointer; color:#111827 !important; transition: all 0.3s ease !important;}
.wqb-close:hover{background:#fff !important; color:#111827 !important; border-color:#18764A !important;}

.wqb-body{flex:1; overflow:auto; padding:16px;}
.wqb-items{display:flex; flex-direction:column; gap:10px; margin-bottom:12px;}
.wqb-empty{text-align:center; color:var(--wqb-muted); padding:18px 0; margin:0;}

.wqb-item{display:flex; gap:10px; padding:10px; border:1px solid var(--wqb-border); border-radius:var(--wqb-radius); background:#fff;}
.wqb-item-imglink{display:block; line-height:0;}
.wqb-item-imglink:hover{opacity:1;}
.wqb-item-img{width:64px; height:64px; border-radius:var(--wqb-radius); object-fit:cover; background:#f3f4f6;}
.wqb-item-mid{flex:1; min-width:0;}
.wqb-item-name{display:block; font-size:14px; font-weight:500; color:#111827 !important; text-decoration:none; overflow-wrap:break-word; word-wrap:break-word; hyphens:auto;}
.wqb-item-name:hover{color:#111827 !important; text-decoration:none !important;}
.wqb-item-price-wrap{margin-top:4px; display:flex; align-items:center; gap:6px;}
.wqb-item-price{font-size:13px; font-weight:600; color:var(--wqb-green);}
.wqb-cart-discount{font-size:11px; font-weight:600; color:#fff; background:#18764A; padding:2px 5px; border-radius:3px;}
.wqb-tier-info{font-size:11px; font-weight:500; color:#18764A; margin-top:4px; font-style:italic;}
.wqb-item-qty{display:flex; align-items:center; gap:8px; margin-top:8px;}

.wqb-savings-banner{
  background:linear-gradient(135deg, #18764A 0%, #0f5132 100%);
  color:#fff;
  padding:12px 16px;
  border-radius:8px;
  margin-bottom:12px;
  font-size:14px;
  font-weight:600;
  text-align:center;
  box-shadow:0 2px 8px rgba(24,118,74,0.2);
}

.wqb-cartbtn{width:32px; height:32px; border:none; border-radius:var(--wqb-radius); background:var(--wqb-green) !important; color:#fff !important; display:flex; align-items:center; justify-content:center; font-size:18px; line-height:1; cursor:pointer; transition: none !important;}
.wqb-cartbtn:hover{background:var(--wqb-green) !important; color:#fff !important;}
.wqb-cartqty{min-width:22px; text-align:center; font-weight:500; color:var(--wqb-black);}

.wqb-item-right{display:flex; flex-direction:column; align-items:flex-end; gap:6px;}
.wqb-item-sub{font-size:13px; font-weight:600; color:#111827;}
.wqb-remove{width:26px; height:26px; border:1px solid var(--wqb-border); border-radius:var(--wqb-radius); background:#fff !important; color:#dc2626 !important; font-size:16px; line-height:1; display:flex; align-items:center; justify-content:center; cursor:pointer; transition: all 0.3s ease !important;}
.wqb-remove:hover{background:#fff !important; color:#dc2626 !important; border-color:#18764A !important;}

.wqb-summary{border-top:1px solid var(--wqb-border); border-bottom:1px solid var(--wqb-border); padding:12px 0; margin:12px 0;}
.wqb-total-row{display:flex; justify-content:space-between; align-items:center; font-size:14px; font-weight:600; color:#111827;}
.wqb-total{color:var(--wqb-green); font-weight:600;}
.wqb-note{text-align:center; font-size:12px; color:var(--wqb-muted); margin-top:8px; font-weight:500;}

.wqb-contact h4{margin:0 0 10px; font-size:13px; font-weight:600; color:#111827;}
.wqb-field{margin-bottom:10px;}
.wqb-label{display:block; margin-bottom:6px; font-size:13px; font-weight:500; color:#374151;}
.wqb-field input, .wqb-field textarea{width:100%; padding:10px 12px; border:1px solid var(--wqb-border); border-radius:var(--wqb-radius); font-size:14px; background:#fff; font-family: 'Montserrat', sans-serif;}
.wqb-field input:focus, .wqb-field textarea:focus{outline:none; border-color:rgba(24,118,74,.55); box-shadow:0 0 0 3px rgba(24,118,74,.12);}

.wqb-message{margin-top:10px; padding:10px 12px; border-radius:var(--wqb-radius); font-size:13px; font-weight:500;}
.wqb-message.is-ok{background:rgba(24,118,74,.12); color:#0f5132; border:1px solid rgba(24,118,74,.20);}
.wqb-message.is-bad{background:#fef2f2; color:#7f1d1d; border:1px solid #fecaca;}

.wqb-footer{padding:14px 16px; border-top:1px solid var(--wqb-border); background:#fff; display:flex; gap:10px;}
.wqb-copy{flex:1; height:44px; border:2px solid var(--wqb-green) !important; border-radius:var(--wqb-radius); background:#fff !important; color:var(--wqb-green) !important; font-size:14px; font-weight:600; cursor:pointer; font-family: 'Montserrat', sans-serif; transition: none !important; padding:0 24px;}
.wqb-copy:hover{background:#fff !important; color:var(--wqb-green) !important; border-color:var(--wqb-green) !important;}
.wqb-copy:disabled{opacity:.6; cursor:not-allowed;}
.wqb-copy.is-copied{background:var(--wqb-green); color:#fff; border-color:var(--wqb-green);}
.wqb-send{flex:1; height:44px; border:none; border-radius:var(--wqb-radius); background:var(--wqb-green) !important; color:#fff !important; font-size:14px; font-weight:600; cursor:pointer; font-family: 'Montserrat', sans-serif; transition: none !important; padding:0 24px;}
.wqb-send:hover{background:var(--wqb-green) !important; color:#fff !important;}
.wqb-send:disabled{opacity:.6; cursor:not-allowed;}

/* Shortcode controls */
.wqb-qtywrap{display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin:14px 0;}
.wqb-qtybtn{width:44px; height:44px; border:none; border-radius:var(--wqb-radius); background:var(--wqb-green) !important; color:#fff !important; font-size:22px; line-height:1; display:flex; align-items:center; justify-content:center; cursor:pointer; font-family: 'Montserrat', sans-serif; transition: none !important;}
.wqb-qtybtn:hover{background:var(--wqb-green) !important; color:#fff !important;}
.wqb-qty{min-width:30px; text-align:center; font-size:16px; font-weight:500; color:var(--wqb-black); font-family: 'Montserrat', sans-serif;}
.wqb-add, .wqb-select-variant{height:44px; padding:0 16px; border:none; border-radius:var(--wqb-radius); background:var(--wqb-green) !important; color:#fff !important; font-size:14px; font-weight:600; cursor:pointer; font-family: 'Montserrat', sans-serif; transition: none !important;}
.wqb-add:hover, .wqb-select-variant:hover{background:var(--wqb-green) !important; color:#fff !important;}
.wqb-add:disabled, .wqb-select-variant:disabled{opacity:.6; cursor:not-allowed;}

/* Floating icon */
.wqb-float{position:fixed; bottom:26px; right:26px; width:58px; height:58px; border-radius:999px; background:var(--wqb-green); display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:99998; box-shadow:0 10px 24px rgba(0,0,0,.18);}
.wqb-float svg{width:26px; height:26px; fill:#fff;}
.wqb-float--hidden{display:none;}
.wqb-badge{position:absolute; top:-6px; right:-6px; width:24px; height:24px; border-radius:999px; background:#ef4444; color:#fff; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:600;}

/* Variant Modal */
.wqb-modal{position:fixed; inset:0; z-index:100000; visibility:hidden; opacity:0; transition:opacity .2s ease, visibility .2s ease;}
.wqb-modal.active{visibility:visible; opacity:1;}
.wqb-modal-overlay{position:absolute; inset:0; background:rgba(0,0,0,.55);}
.wqb-modal-panel{position:relative; width:min(720px, 92vw); max-height:82vh; margin:8vh auto; background:#fff; border-radius:var(--wqb-radius); border:1px solid var(--wqb-border); overflow:hidden;}
.wqb-modal-header{display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border-bottom:1px solid var(--wqb-border);}
.wqb-modal-title{margin:0; font-size:15px; font-weight:600; color:#111827;}
.wqb-modal-close{width:32px; height:32px; border:1px solid var(--wqb-border); border-radius:var(--wqb-radius); background:#fff !important; font-size:18px; line-height:1; display:flex; align-items:center; justify-content:center; cursor:pointer; color:#111827 !important; transition: all 0.3s ease !important;}
.wqb-modal-close:hover{background:#fff !important; color:#111827 !important; border-color:#18764A !important;}
.wqb-modal-body{padding:12px 14px; overflow:auto; max-height:calc(82vh - 56px);}
.wqb-modal-loading{text-align:center; padding:18px 0; color:var(--wqb-muted); font-size:14px;}

.wqb-var{display:flex; align-items:center; gap:10px; padding:10px; border:1px solid var(--wqb-border); border-radius:var(--wqb-radius); margin-bottom:10px; background:#fff;}
.wqb-var-img{width:52px; height:52px; border-radius:var(--wqb-radius); object-fit:cover; background:#f3f4f6;}
.wqb-var-mid{flex:1; min-width:0;}
.wqb-var-name{font-size:14px; font-weight:500; color:#111827; overflow-wrap:break-word; word-wrap:break-word; hyphens:auto; font-family: 'Montserrat', sans-serif;}
.wqb-var-price-wrap{margin-top:4px; display:flex; align-items:center; gap:6px; flex-wrap:wrap;}
.wqb-var-price{font-size:15px; font-weight:600; color:var(--wqb-green); font-family: 'Montserrat', sans-serif;}
.wqb-var-discount{font-size:12px; font-weight:600; color:#fff; background:#18764A; padding:2px 6px; border-radius:4px;}
.wqb-var-save{font-size:11px; font-weight:500; color:#18764A; width:100%; margin-top:2px;}
.wqb-var-price-calc{font-size:13px; font-weight:600; color:var(--wqb-muted); font-family: 'Montserrat', sans-serif;}
.wqb-var-right{display:flex; align-items:center; gap:8px; flex-wrap:wrap; justify-content:flex-end;}
.wqb-var-minus, .wqb-var-plus{width:32px; height:32px; border:none; border-radius:var(--wqb-radius); background:var(--wqb-green) !important; color:#fff !important; font-size:18px; line-height:1; display:flex; align-items:center; justify-content:center; cursor:pointer; font-family: 'Montserrat', sans-serif; transition: none !important;}
.wqb-var-minus:hover, .wqb-var-plus:hover{background:var(--wqb-green) !important; color:#fff !important;}
.wqb-var-qty{min-width:22px; text-align:center; font-weight:500; color:var(--wqb-black); font-family: 'Montserrat', sans-serif;}
.wqb-var-add{height:32px; padding:0 12px; border:none; border-radius:var(--wqb-radius); background:var(--wqb-green) !important; color:#fff !important; font-size:13px; font-weight:600; cursor:pointer; font-family: 'Montserrat', sans-serif; transition: none !important;}
.wqb-var-add:hover{background:var(--wqb-green) !important; color:#fff !important;}
.wqb-var-add:disabled{opacity:.6; cursor:not-allowed;}

@media (max-width:768px){
  .wqb-panel{width:100%; max-width:100%;}
  
  /* Modal responsiveness */
  .wqb-modal-panel{width:95vw !important;}
  
  /* Variant items in modal - better mobile layout */
  .wqb-var{
    flex-wrap:wrap;
  }
  
  .wqb-var-mid{
    flex:1 1 100%;
    min-width:100%;
  }
  
  .wqb-var-right{
    flex:1 1 100%;
    justify-content:flex-start;
    margin-top:8px;
  }
  
  /* Cart items better mobile layout */
  .wqb-item{
    flex-wrap:wrap;
  }
  
  .wqb-item-mid{
    flex:1 1 calc(100% - 74px);
    min-width:0;
  }
  
  .wqb-item-right{
    flex:1 1 100%;
    flex-direction:row;
    justify-content:space-between;
    align-items:center;
    margin-top:8px;
  }
  
  /* Single product mobile layout */
  .wqb-sp-row{
    flex-direction:column;
    align-items:flex-start;
    gap:16px;
  }
  
  .wqb-sp-price{
    align-self:flex-start;
  }
  
  .wqb-sp-actions{
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
    width:100%;
    min-width:100%;
  }
  
  .wqb-sp-qty{
    width:100%;
    justify-content:space-between;
  }
  
  .wqb-sp-add-btn{
    width:100%;
  }
  
  /* Footer buttons mobile */
  .wqb-footer{
    flex-direction:column;
  }
  
  .wqb-copy, .wqb-send{
    width:100%;
    border-radius:var(--wqb-radius) !important;
    padding:12px 24px !important;
  }
  
  /* Variant selector mobile - keep as row with wrap */
  .wqb-sp-variant-selector{
    flex-direction:row;
    flex-wrap:wrap;
    gap:10px;
  }
  
  .wqb-sp-variant-btn{
    flex:0 1 auto;
  }
}


/* Force center align modal */
.wqb-modal{
  display:flex;
  align-items:center;
  justify-content:center;
}
.wqb-modal-panel{
  margin:0 !important;
}


/* Single Product Variant UI */
.wqb-sp{ margin: 18px 0; }
.wqb-sp-variant-selector{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:18px; }
.wqb-sp-variant-btn{
  padding: 12px 26px;
  border-radius: 4px !important;
  border: 1px solid #18764A !important;
  background: #fff !important;
  color:#18764A !important;
  font-family: 'Montserrat', sans-serif;
  font-size:14px !important;
  font-weight:500;
  line-height:1;
  cursor:pointer;
  transition: all 0.3s ease !important;
}

/* Variant pills show label + price */
.wqb-sp-variant-btn{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
}
.wqb-sp-variant-price{
  font-size:12px;
  opacity:0.9;
}
.wqb-sp-variant-btn:hover{
  background: #18764A !important;
  color:#fff !important;
  border-color: #18764A !important;
}
.wqb-sp-variant-btn.active{
  background:#18764A !important;
  color:#fff !important;
  border-color: #18764A !important;
}
.wqb-sp-variant-btn.active:hover{
  background:#18764A !important;
  color:#fff !important;
  border-color: #18764A !important;
}
.wqb-sp-variant-btn[disabled], .wqb-sp-variant-btn[aria-disabled="true"]{
  opacity:.45;
  cursor:not-allowed;
}

.wqb-sp-row{
  display:flex;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
}

.wqb-sp-price{
  font-size:26px !important;
  font-weight:800;
  color:#2f3d3a;
  font-family: 'Montserrat', sans-serif;
}

.wqb-sp-actions{
  display:flex;
  align-items:center;
  gap:18px;
  flex:1;
  min-width: 280px;
}

.wqb-sp-qty{
  display:flex;
  align-items:center;
  border:1px solid #18764A !important;
  border-radius:4px !important;
  overflow:hidden;
}
.wqb-sp-qty-minus, .wqb-sp-qty-plus{
  padding: 12px 18px;
  border:0;
  background:transparent !important;
  font-size:22px;
  cursor:pointer;
  color:#18764A !important;
  font-family: 'Montserrat', sans-serif;
  transition: none !important;
}
.wqb-sp-qty-minus:hover, .wqb-sp-qty-plus:hover{
  background:transparent !important;
  color:#18764A !important;
}
.wqb-sp-qty-input{
  width:56px;
  text-align:center;
  border:0 !important;
  outline:0;
  font-size:18px;
  font-family: 'Montserrat', sans-serif;
}
.wqb-sp-add-btn{
  flex:1;
  padding: 16px 26px;
  border-radius:4px !important;
  border:0;
  background: #18764A !important;
  color:#fff !important;
  font-size:16px !important;
  font-weight:600;
  letter-spacing:.5px;
  cursor:pointer;
  font-family: 'Montserrat', sans-serif;
  transition: none !important;
  text-transform: none !important;
}
.wqb-sp-add-btn:hover{
  background: #18764A !important;
  color:#fff !important;
}

/* New Address and Payment Fields Styling */
.wqb-field-row {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
}

.wqb-field-city {
  flex: 2;
}

.wqb-field-state {
  flex: 1;
}

.wqb-field-zip {
  flex: 1;
}

.wqb-field select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--wqb-border);
  border-radius: var(--wqb-radius);
  font-size: 14px;
  background: #fff;
  font-family: 'Montserrat', sans-serif;
  cursor: pointer;
}

.wqb-field select:focus {
  outline: none;
  border-color: rgba(24, 118, 74, .55);
  box-shadow: 0 0 0 3px rgba(24, 118, 74, .12);
}

.wqb-insurance-field .wqb-radio-group {
  display: flex;
  gap: 20px;
  margin-top: 8px;
}

.wqb-radio-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  color: #374151;
}

.wqb-radio-label input[type="radio"] {
  width: auto;
  margin: 0;
  cursor: pointer;
}

.wqb-radio-label span {
  user-select: none;
}

.wqb-error-message {
  color: #dc2626;
  font-size: 12px;
  margin-top: 4px;
  font-weight: 500;
}

.wqb-field-error {
  border-color: #dc2626 !important;
}

/* Google Places Autocomplete Dropdown Styling */
.pac-container {
  font-family: 'Montserrat', sans-serif;
  border-radius: var(--wqb-radius);
  border: 1px solid var(--wqb-border);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  margin-top: 4px;
  z-index: 100000 !important;
}

.pac-item {
  padding: 10px 12px;
  border-top: 1px solid var(--wqb-border);
  font-size: 13px;
  cursor: pointer;
}

.pac-item:hover {
  background-color: rgba(24, 118, 74, 0.08);
}

.pac-item-query {
  font-weight: 600;
  color: #111827;
}

.pac-matched {
  font-weight: 600;
  color: var(--wqb-green);
}

.pac-icon {
  display: none;
}

/* Read-only field styling */
input[readonly] {
  background-color: #f9fafb !important;
  cursor: not-allowed;
}

/* Responsive adjustments */
@media (max-width: 480px) {
  .wqb-field-row {
    flex-direction: column;
  }
  
  .wqb-field-city,
  .wqb-field-state,
  .wqb-field-zip {
    flex: 1;
  }
}
