﻿/* ═══════════════════════════════════════════════════════════════════════
   PCI Vault PCD Form — Global Style Overrides
   
   The PCI Vault Svelte PCD form renders with scoped styles (.svelte-*)
   that have high specificity. This global stylesheet uses !important
   to ensure Figma-aligned styling. Selectors include both the Svelte
   hash AND generic class-only fallbacks for robustness.

   Figma tokens (from node 2785:194851):
     Title  → Poppins SemiBold 20px, line-height 1.2, #000
     Label  → Nunito Sans SemiBold 16px, line-height 1.2, #262626
     Body   → Nunito Sans Regular 16px, line-height 1.3, #000
     Button → Poppins Medium 14px, line-height 20px, #000 on #32E696
     Input  → border #7B7B7B 1px, radius 4px, padding 8px 12px, min-h 40px
     Card   → bg #fff, border #e5e7eb, radius 8px, padding 24px,
              shadow 0 2px 4px -2px rgba(0,0,0,0.08)
     Gaps   → 24px between all fields, 8px label→input, 24px month↔year
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Hide PCI Vault card graphic ── */
#pcivault-pcd-form-card-container {
    display: none !important;
}

#pcivault-pcd-form-pre-card-container {
    display: none !important;
}

/* ── Reset stray margins/paddings on all PCD form wrappers ── */
#pcd_form div[class*="card-form"],
#pcd_form div[class*="card-input"] {
    margin: 0 !important;
    padding: 0 !important;
}

/* ── Form container reset ── */
#pcivault-pcd-form-container.card-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    border: none !important;
    background: transparent !important;
    max-width: none !important;
    margin: 0 !important;
}

/* ── Fields wrapper ── */
#pcivault-pcd-form-inner-container.card-form__inner {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* ── Input field wrappers (.card-input) — gap 8px between label and input ── */
.card-input.svelte-9iltyw,
#pcd_form .card-input {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    margin: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
}

.card-input.svelte-9iltyw{
    flex: 1 1 0px !important;
}

/* ── Labels — Nunito Sans SemiBold 16px #262626 ── */
.card-input__label.svelte-9iltyw,
#pcd_form .card-input__label {
    font-family: "Nunito Sans", sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    color: #262626 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ── Text Inputs — white bg, #7B7B7B border, 4px radius, min-h 40px ── */
.card-input__input.svelte-9iltyw,
#pcd_form .card-input__input {
    background: #fff !important;
    border: 1px solid #7B7B7B !important;
    border-radius: 4px !important;
    padding: 8px 12px !important;
    min-height: 40px !important;
    height: auto !important;
    font-family: "Nunito Sans", sans-serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 1.3 !important;
    color: #000 !important;
    outline: none !important;
    transition: border-color 0.2s !important;
    width: 100% !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    box-shadow: none !important;
    margin: 0 !important;
}

.card-input__input.svelte-9iltyw:focus,
#pcd_form .card-input__input:focus {
    border-color: #32E696 !important;
    box-shadow: 0 0 0 1px #32E696 !important;
}

.card-input__input.svelte-9iltyw::placeholder,
#pcd_form .card-input__input::placeholder {
    color: #999 !important;
}

/* ── Select dropdowns (Month / Year) — custom caret ── */
.card-input__input.select.svelte-9iltyw,
#pcd_form .card-input__input.select,
#pcd_form select.card-input__input {
    background-color: #fff !important;
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9L12 15L18 9' stroke='%23262626' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    background-size: 16px 16px !important;
    padding-right: 36px !important;
    cursor: pointer !important;
}

/* ── Expiry / CVV row — stacked (CVV below expiry, 24px gap) ── */
.card-form__row.svelte-9iltyw,
#pcd_form .card-form__row {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
    margin: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
}

.card-form__row.svelte-9iltyw > .card-input,
#pcd_form .card-form__row > .card-input {
    width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ── Select group (month + year side by side, 16px gap) ── */
.card-form__group.svelte-9iltyw,
#pcd_form .card-form__group {
    display: flex !important;
    flex-direction: row !important;
    gap: 16px !important;
    margin: 0 !important;
    padding: 0 !important;
}

.card-form__group.svelte-9iltyw > select,
#pcd_form .card-form__group > select {
    flex: 1 1 0 !important;
    min-width: 0 !important;
}

/* ── Save-card checkbox — Figma: bg #F5F5F5, p-8px, radius 4px, gap 8px ── */
#pcd_form label:has(input[type="checkbox"]) {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px !important;
    margin: 0 !important;
    border-radius: 4px !important;
    background: #F5F5F5 !important;
    cursor: pointer !important;
    font-family: "Nunito Sans", sans-serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
    color: #000 !important;
}

#pcd_form label:has(input[type="checkbox"]) input[type="checkbox"] {
    width: 20px !important;
    height: 20px !important;
    flex-shrink: 0 !important;
    accent-color: #000 !important;
    margin: 0 !important;
}

/* ── Submit button — Figma: #32E696, 4px radius, Poppins Medium 14px/20px ── */
.card-form__button.svelte-9iltyw,
#pcd_form .card-form__button,
button.card-form__button.checkout-submit-btn {
    width: 100% !important;
    background: #32E696 !important;
    background-image: none !important;
    color: #000 !important;
    border: none !important;
    border-radius: 4px !important;
    padding: 8px !important;
    min-width: 120px !important;
    font-family: "Poppins", sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    line-height: 20px !important;
    text-align: center !important;
    cursor: pointer !important;
    transition: opacity 0.2s !important;
    margin: 0 !important;
    box-shadow: none !important;
    letter-spacing: normal !important;
    height: auto !important;
    min-height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.card-form__button.svelte-9iltyw:hover,
#pcd_form .card-form__button:hover,
button.card-form__button.checkout-submit-btn:hover {
    opacity: 0.9 !important;
    transform: none !important;
}

.card-form__button.svelte-9iltyw:disabled,
#pcd_form .card-form__button:disabled,
button.card-form__button.checkout-submit-btn:disabled {
    opacity: 0.6 !important;
    cursor: not-allowed !important;
}

/* ── Button loading spinner ── */
.checkout-btn-spinner {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(0, 0, 0, 0.2);
    border-top-color: #000;
    border-radius: 50%;
    animation: pcivault-spin 0.6s linear infinite;
    margin-right: 8px;
    flex-shrink: 0;
}

@keyframes pcivault-spin {
    to { transform: rotate(360deg); }
}

/* ── Injected save-card checkbox — Figma: bg #F5F5F5, p-8px, radius 4px, gap 8px ── */
.checkout-save-card-row {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 8px !important;
    margin: 0 !important;
    border-radius: 4px !important;
    background: #F5F5F5 !important;
    cursor: pointer !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.checkout-save-card-input {
    position: absolute !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    pointer-events: none !important;
}

.checkout-save-card-check {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 24px !important;
    height: 24px !important;
    flex-shrink: 0 !important;
}

.checkout-save-card-check svg {
    width: 24px !important;
    height: 24px !important;
}

.checkout-save-card-text {
    font-family: "Nunito Sans", sans-serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
    color: #000 !important;
}

/* ── CVV field — ensure full width ── */
#cardCvv {
    width: 100% !important;
    max-width: none !important;
}

/* ══════════════════════════════════════════════════════════════════════
   #packs-qp-pcd-form — Packs Quick-Pay Add-Card PCD form
   Mirrors #pcd_form selectors so the PCI Vault PCD form renders
   correctly inside the packs quick-pay modal.
   ══════════════════════════════════════════════════════════════════════ */
#packs-qp-pcd-form div[class*="card-form"],
#packs-qp-pcd-form div[class*="card-input"] {
    margin: 0 !important;
    padding: 0 !important;
}

#packs-qp-pcd-form .card-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    border: none !important;
    background: transparent !important;
    max-width: none !important;
    margin: 0 !important;
}

#packs-qp-pcd-form .card-form__inner {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
    padding: 0 !important;
    margin: 0 !important;
}

#packs-qp-pcd-form .card-input {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
}

#packs-qp-pcd-form .card-input__label {
    font-family: "Nunito Sans", sans-serif !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    color: #262626 !important;
    margin: 0 !important;
    padding: 0 !important;
}

#packs-qp-pcd-form .card-input__input {
    background: #fff !important;
    border: 1px solid #7B7B7B !important;
    border-radius: 4px !important;
    padding: 8px 12px !important;
    min-height: 40px !important;
    height: auto !important;
    font-family: "Nunito Sans", sans-serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 1.3 !important;
    color: #000 !important;
    outline: none !important;
    transition: border-color 0.2s !important;
    width: 100% !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    box-shadow: none !important;
    margin: 0 !important;
}

#packs-qp-pcd-form .card-input__input:focus {
    border-color: #32E696 !important;
    box-shadow: 0 0 0 1px #32E696 !important;
}

#packs-qp-pcd-form .card-input__input::placeholder {
    color: #999 !important;
}

#packs-qp-pcd-form select.card-input__input,
#packs-qp-pcd-form .card-input__input.select {
    background-color: #fff !important;
    background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9L12 15L18 9' stroke='%23262626' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    background-size: 16px 16px !important;
    padding-right: 36px !important;
    cursor: pointer !important;
}

#packs-qp-pcd-form .card-form__row {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
    margin: 0 !important;
    padding: 0 !important;
}

#packs-qp-pcd-form .card-form__group {
    display: flex !important;
    flex-direction: row !important;
    gap: 16px !important;
    margin: 0 !important;
    padding: 0 !important;
}

#packs-qp-pcd-form .card-form__group > select {
    flex: 1 1 0 !important;
    min-width: 0 !important;
}

#packs-qp-pcd-form .card-form__button {
    width: 100% !important;
    background: #32E696 !important;
    background-image: none !important;
    color: #000 !important;
    border: none !important;
    border-radius: 4px !important;
    padding: 8px !important;
    font-family: "Poppins", sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    line-height: 20px !important;
    text-align: center !important;
    cursor: pointer !important;
    min-height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    box-shadow: none !important;
}

#packs-qp-pcd-form .card-form__button:hover {
    opacity: 0.9 !important;
}

#packs-qp-pcd-form .card-form__button:disabled {
    opacity: 0.6 !important;
    cursor: not-allowed !important;
}

/* Checkbox spacing — gap between CVV field and checkbox */
#packs-qp-pcd-form > .addon-modal-pcd-checkbox {
    margin-top: 16px !important;
}

/* Button group spacing — gap between checkbox and buttons */
#packs-qp-pcd-form > .addon-modal-pcd-button-group {
    margin-top: 16px !important;
}

/* Hide original submit in packs-qp form (restructureFormUI creates styled clone) */
#packs-qp-pcd-form .card-form__inner > button[type="submit"],
#packs-qp-pcd-form .card-form__inner > .card-form__button {
    display: none !important;
}
