/**
 * card-checkout.css — Stripe Payment Element styles
 *
 * Visual reference: docs/designs/stripe-checkout-preview.html
 * CSS values from: docs/designs/stripe-checkout.md
 * High specificity selectors to prevent WooCommerce theme overrides.
 */

/* ── Express Checkout ─────────────────────────────── */
#wc-stripe-card-form .stripe-express { margin-bottom: 24px; }
#wc-stripe-card-form .stripe-express-title { font-size: 14px; font-weight: 500; color: #30313d; margin-bottom: 12px; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif; }
#wc-stripe-card-form .stripe-express-buttons { display: flex; gap: 8px; }
#wc-stripe-card-form .stripe-express-btn {
  flex: 1; height: 44px; border-radius: 5px; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 6px;
  font-size: 14px; font-weight: 500; transition: opacity 0.15s; font-family: inherit;
}
#wc-stripe-card-form .stripe-express-btn:hover { opacity: 0.9; }
#wc-stripe-card-form .stripe-express-btn.apple-pay { background: #000; color: #fff; }
#wc-stripe-card-form .stripe-express-btn.google-pay { background: #fff; color: #3c4043; border: 1px solid #dadce0; font-weight: 400; font-size: 15px; letter-spacing: .2px; }
#wc-stripe-card-form .stripe-express-btn.link-pay { background: #00d66f; color: #fff; font-size: 15px; font-weight: 600; letter-spacing: .3px; }
#wc-stripe-card-form .stripe-express-unavailable {
  text-align: center; font-size: 13px; color: #6d6e78;
  padding: 0; opacity: 0; transition: opacity 0.3s; height: 0; overflow: hidden;
}
#wc-stripe-card-form .stripe-express-unavailable.show { opacity: 1; height: auto; padding: 8px 0; }

/* ── Divider ──────────────────────────────────────── */
#wc-stripe-card-form .stripe-divider { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }
#wc-stripe-card-form .stripe-divider::before,
#wc-stripe-card-form .stripe-divider::after { content: ''; flex: 1; height: 1px; background: #e6e6e6; }
#wc-stripe-card-form .stripe-divider-text { font-size: 13px; color: #6d6e78; white-space: nowrap; }

/* ── Stripe Container ─────────────────────────────── */
#wc-stripe-card-form .stripe-container { border: 1px solid #e6e6e6; border-radius: 8px; background: #fff; overflow: hidden; }
#wc-stripe-card-form .stripe-header { padding: 12px 16px; font-size: 15px; font-weight: 400; color: #30313d; border-bottom: 1px solid #e6e6e6; }

/* ── Accordion ────────────────────────────────────── */
#wc-stripe-card-form .accordion-item { border-bottom: 1px solid #f0f0f0; cursor: pointer; transition: background 0.15s; }
#wc-stripe-card-form .accordion-item:last-child { border-bottom: none; }
#wc-stripe-card-form .accordion-item:hover:not(.active) { background: #fafafa; }
#wc-stripe-card-form .accordion-header {
  display: flex; align-items: center; gap: 12px; padding: 14px 16px;
  font-size: 14px; font-weight: 500; color: #30313d;
}
#wc-stripe-card-form .accordion-header .acc-icon { width: 24px; height: 24px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
#wc-stripe-card-form .accordion-header .acc-label { flex: 1; }
#wc-stripe-card-form .accordion-item.active .accordion-header { color: #0570de; }
#wc-stripe-card-form .accordion-body { display: none; padding: 0 16px 16px; }
#wc-stripe-card-form .accordion-item.active .accordion-body { display: block; }

/* ── Card Form Grid ───────────────────────────────── */
#wc-stripe-card-form .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
#wc-stripe-card-form .field-full { grid-column: 1 / -1; }
#wc-stripe-card-form .stripe-label { display: block; margin-bottom: 4px; font-size: 14px; font-weight: 400; color: #30313d; line-height: 1.3; }
#wc-stripe-card-form .input-wrapper { position: relative; display: flex; align-items: center; }
#wc-stripe-card-form .stripe-input {
  width: 100%; padding: 12px; font-size: 16px; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
  color: #30313d; background: #fff; border: 1px solid #d8d8d8; border-radius: 5px;
  box-shadow: 0px 1px 1px rgba(0,0,0,0.03), 0px 3px 6px rgba(0,0,0,0.02);
  transition: border-color 0.15s, box-shadow 0.15s; outline: none; -webkit-appearance: none;
}
#wc-stripe-card-form .stripe-input:focus { border-color: rgba(5,115,225,0.5); box-shadow: 0px 1px 1px rgba(0,0,0,0.03), 0px 3px 6px rgba(0,0,0,0.02), 0 0 0 3px rgba(5,115,225,0.25); }
#wc-stripe-card-form .stripe-input.error { border-color: #dc2727; box-shadow: 0 0 0 0.1px #dc2727; color: #dc2727; }
#wc-stripe-card-form .stripe-input::placeholder { color: #757680; opacity: 1; }
#wc-stripe-card-form .card-number-input { padding-right: 150px; }

/* ── Brand Badges ─────────────────────────────────── */
#wc-stripe-card-form .card-icons { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); display: flex; align-items: center; gap: 4px; pointer-events: none; }
#wc-stripe-card-form .brand-badge {
  height: 24px; width: 36px; border: 1px solid #e6e6e6; border-radius: 4px;
  overflow: hidden; display: flex; align-items: center; justify-content: center; background: #fff;
}
#wc-stripe-card-form .brand-badge img { height: 18px; width: auto; max-width: 30px; object-fit: contain; }
#wc-stripe-card-form .brand-badge.hidden { display: none; }

/* ── CVC Icon ─────────────────────────────────────── */
#wc-stripe-card-form .cvc-icon { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); pointer-events: none; }

/* ── Error Messages ───────────────────────────────── */
#wc-stripe-card-form .stripe-error-message { display: flex; align-items: flex-start; gap: 4px; margin-top: 4px; }
#wc-stripe-card-form .stripe-error-message svg { width: 12px; height: 12px; flex-shrink: 0; margin-top: 2px; }
#wc-stripe-card-form .stripe-error-text { font-size: 13px; color: #df1b41; line-height: 1.4; }

/* ── Save Checkbox ────────────────────────────────── */
#wc-stripe-card-form .stripe-save-card { display: flex; align-items: flex-start; gap: 10px; margin-top: 16px; font-size: 14px; color: #30313d; cursor: pointer; }
#wc-stripe-card-form .stripe-save-card input[type="checkbox"] { width: 18px; height: 18px; margin-top: 1px; accent-color: #0570de; flex-shrink: 0; }

/* ── Pay Button ───────────────────────────────────── */
#wc-stripe-card-form .stripe-pay-button {
  width: 100%; padding: 12px; border: none; border-radius: 5px; background: #0570de; color: #fff;
  font-size: 16px; font-weight: 600; cursor: pointer; transition: background 0.15s; -webkit-appearance: none;
  margin-top: 16px; position: relative; font-family: inherit;
}
#wc-stripe-card-form .stripe-pay-button:hover { background: #0b81fa; }
#wc-stripe-card-form .stripe-pay-button.loading { color: transparent; pointer-events: none; }
#wc-stripe-card-form .stripe-pay-button.loading::after {
  content: ''; position: absolute; width: 20px; height: 20px;
  border: 2px solid rgba(255,255,255,0.3); border-top-color: #fff; border-radius: 50%;
  animation: wc-stripe-spin 0.6s linear infinite; top: 50%; left: 50%; margin: -10px 0 0 -10px;
}
@keyframes wc-stripe-spin { to { transform: rotate(360deg); } }

/* ── Trust Badge ──────────────────────────────────── */
#wc-stripe-card-form .stripe-trust-badge { display: flex; align-items: center; justify-content: center; gap: 4px; margin-top: 12px; font-size: 12px; color: #6d6e78; }

/* ── Unavailable Content ──────────────────────────── */
#wc-stripe-card-form .acc-unavailable { text-align: center; padding: 24px 16px; font-size: 14px; color: #6d6e78; line-height: 1.6; }
#wc-stripe-card-form .acc-unavailable-icon { width: 36px; height: 36px; margin: 0 auto 10px; border-radius: 50%; background: #f6f6f6; display: flex; align-items: center; justify-content: center; }
#wc-stripe-card-form .acc-link { color: #0570de; cursor: pointer; text-decoration: none; font-weight: 500; }
#wc-stripe-card-form .acc-link:hover { text-decoration: underline; }
#wc-stripe-card-form .acc-loading { text-align: center; padding: 28px 16px; }
#wc-stripe-card-form .acc-spinner { width: 22px; height: 22px; border: 2px solid #e6e6e6; border-top-color: #0570de; border-radius: 50%; animation: wc-stripe-spin 0.6s linear infinite; margin: 0 auto 8px; }

/* ── Compact Mode (Block checkout) ────────────────── */
#wc-stripe-card-form .stripe-compact { border: none; box-shadow: none; background: transparent; }
#wc-stripe-card-form .stripe-compact .form-grid { gap: 12px; }

/* ── Mobile ───────────────────────────────────────── */
@media (max-width: 767px) {
  #wc-stripe-card-form .form-grid { grid-template-columns: 1fr; }
  #wc-stripe-card-form .card-number-input { padding-right: 130px; }
}
