/**
 * VeneGift Prepaid Cards - Estilos
 * Usa design tokens del tema (_design-tokens.css)
 */

/* ============================================
   CONTENEDOR PRINCIPAL
   ============================================ */

.vg-prepaid-fields {
    margin: var(--vg-space-6) 0;
}

/* ============================================
   SECCIONES
   ============================================ */

.vg-prepaid-section {
    background: var(--vg-bg-white);
    border: var(--vg-border-thin) solid var(--vg-border-light);
    border-radius: var(--vg-radius-lg);
    padding: var(--vg-space-5);
    margin-bottom: var(--vg-space-4);
}

.vg-prepaid-section-title {
    color: var(--vg-primary);
    font-size: var(--vg-font-md);
    font-weight: var(--vg-font-semibold);
    margin: 0 0 var(--vg-space-4) 0;
    padding-bottom: var(--vg-space-2);
    border-bottom: var(--vg-border-normal) solid var(--vg-secondary);
}

/* ============================================
   CAMPOS DE TITULAR
   ============================================ */

.vg-prepaid-row {
    display: flex;
    gap: var(--vg-space-4);
}

.vg-prepaid-field {
    flex: 1;
}

.vg-prepaid-field label {
    display: block;
    color: var(--vg-text-primary);
    font-size: var(--vg-font-sm);
    font-weight: var(--vg-font-medium);
    margin-bottom: var(--vg-space-2);
}

.vg-prepaid-field label .required {
    color: var(--vg-error-text);
}

.vg-prepaid-input {
    width: 100%;
    height: var(--vg-input-height-md);
    padding: var(--vg-input-padding-md);
    font-size: var(--vg-font-base);
    font-family: var(--vg-font-family);
    color: var(--vg-text-input);
    background: var(--vg-bg-white);
    border: var(--vg-border-thin) solid var(--vg-border-normal);
    border-radius: var(--vg-radius-md);
    transition: var(--vg-transition-fast);
    box-sizing: border-box;
}

.vg-prepaid-input:focus {
    outline: none;
    border-color: var(--vg-primary);
    box-shadow: var(--vg-shadow-focus);
}

.vg-prepaid-input::placeholder {
    color: var(--vg-text-muted);
}

/* ============================================
   CAMPO DE MONTO
   ============================================ */

.vg-prepaid-monto-input {
    display: flex;
    align-items: center;
    background: var(--vg-bg-white);
    border: var(--vg-border-thin) solid var(--vg-border-normal);
    border-radius: var(--vg-radius-md);
    overflow: hidden;
    transition: var(--vg-transition-fast);
    max-width: 240px; /* Ancho compacto para 3 dígitos */
    margin: 0 auto; /* Centrado */
}

.vg-prepaid-monto-input:focus-within {
    border-color: var(--vg-primary);
    box-shadow: var(--vg-shadow-focus);
}

.vg-prepaid-monto-input .input-prefix,
.vg-prepaid-monto-input .input-suffix {
    padding: 0 var(--vg-space-3);
    color: var(--vg-text-secondary);
    font-weight: var(--vg-font-semibold);
    background: var(--vg-bg-light);
    height: var(--vg-input-height-md);
    display: flex;
    align-items: center;
}

.vg-prepaid-monto-input .vg-prepaid-input {
    border: none;
    border-radius: 0;
    text-align: center;
    font-size: var(--vg-font-xl);
    font-weight: var(--vg-font-bold);
}

.vg-prepaid-monto-input .vg-prepaid-input:focus {
    box-shadow: none;
}

.vg-prepaid-monto-info {
    margin-top: var(--vg-space-2);
    font-size: var(--vg-font-sm);
    color: var(--vg-text-secondary);
    text-align: center;
}

/* ============================================
   DISPLAY DE PRECIO
   ============================================ */

.vg-prepaid-price-display {
    margin-top: var(--vg-space-4);
    padding: var(--vg-space-4);
    background: var(--vg-gradient-success);
    border: var(--vg-border-thin) solid var(--vg-success-border);
    border-radius: var(--vg-radius-lg);
    text-align: center;
}

.vg-prepaid-placeholder {
    color: var(--vg-text-muted);
    font-style: italic;
}

.vg-prepaid-price-calculated {
    display: flex;
    flex-direction: column;
    gap: var(--vg-space-1);
}

.vg-prepaid-label {
    font-size: var(--vg-font-sm);
    color: var(--vg-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.vg-prepaid-amount {
    font-size: var(--vg-font-xl);
    font-weight: var(--vg-font-bold);
    color: var(--vg-primary);
}

.vg-prepaid-usd-equiv {
    font-size: var(--vg-font-sm);
    color: var(--vg-text-secondary);
}

.vg-prepaid-error {
    color: var(--vg-error-text);
    font-weight: var(--vg-font-medium);
}

/* ============================================
   ADVERTENCIA CRÍTICA DE ALTO RIESGO
   ============================================ */

.vg-prepaid-critical-warning {
    background: var(--vg-error-bg);
    border: 3px solid var(--vg-error-accent);
    border-radius: var(--vg-radius-lg);
    margin: var(--vg-space-6) 0;
    box-shadow: var(--vg-shadow-lg);
    animation: vg-pulse-border 2s ease-in-out infinite;
}

@keyframes vg-pulse-border {
    0%, 100% {
        border-color: var(--vg-error-accent);
        box-shadow: 0 0 0 0 var(--vg-error-accent);
    }
    50% {
        border-color: var(--vg-error-text);
        box-shadow: 0 0 0 8px rgba(220, 38, 38, 0.1);
    }
}

/* Header de advertencia */
.vg-prepaid-warning-header {
    background: var(--vg-error-accent);
    padding: var(--vg-space-4);
    display: flex;
    align-items: center;
    gap: var(--vg-space-3);
    border-radius: var(--vg-radius-lg) var(--vg-radius-lg) 0 0;
}

.vg-prepaid-warning-icon {
    font-size: 32px;
    line-height: 1;
    animation: vg-shake 0.5s ease-in-out infinite;
}

@keyframes vg-shake {
    0%, 100% { transform: rotate(0deg); }
    25% { transform: rotate(-10deg); }
    75% { transform: rotate(10deg); }
}

.vg-prepaid-warning-title {
    color: var(--vg-bg-white);
    font-size: var(--vg-font-lg);
    font-weight: var(--vg-font-bold);
    margin: 0;
    line-height: var(--vg-line-height-tight);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Contenido de advertencia */
.vg-prepaid-warning-content {
    padding: var(--vg-space-5);
    background: var(--vg-bg-white);
    border-radius: 0 0 var(--vg-radius-lg) var(--vg-radius-lg);
}

/* Bloques de advertencia */
.vg-prepaid-warning-block {
    padding: var(--vg-space-4);
    margin-bottom: var(--vg-space-3);
    border-radius: var(--vg-radius-md);
    border-left: 4px solid;
}

.vg-prepaid-warning-block:last-child {
    margin-bottom: 0;
}

.vg-prepaid-warning-block h4 {
    font-size: var(--vg-font-base);
    font-weight: var(--vg-font-bold);
    margin: 0 0 var(--vg-space-2) 0;
    line-height: var(--vg-line-height-tight);
}

.vg-prepaid-warning-block p {
    font-size: var(--vg-font-sm);
    line-height: var(--vg-line-height-relaxed);
    margin: 0;
}

.vg-prepaid-warning-block ul {
    margin: var(--vg-space-2) 0 0 0;
    padding-left: var(--vg-space-5);
    font-size: var(--vg-font-sm);
    line-height: var(--vg-line-height-relaxed);
}

.vg-prepaid-warning-block li {
    margin-bottom: var(--vg-space-1);
}

/* Estilos por tipo de advertencia */
.vg-prepaid-warning-primary {
    background: var(--vg-info-bg);
    border-left-color: var(--vg-info-accent);
}

.vg-prepaid-warning-primary h4 {
    color: var(--vg-info-text);
}

.vg-prepaid-warning-success {
    background: var(--vg-success-bg);
    border-left-color: var(--vg-success-accent);
}

.vg-prepaid-warning-success h4 {
    color: var(--vg-success-text);
}

.vg-prepaid-warning-danger {
    background: var(--vg-warning-bg);
    border-left-color: var(--vg-warning-accent);
}

.vg-prepaid-warning-danger h4 {
    color: var(--vg-warning-text);
}

.vg-prepaid-stat-highlight {
    font-size: var(--vg-font-base) !important;
    font-weight: var(--vg-font-bold);
    color: var(--vg-warning-text);
}

.vg-prepaid-warning-error {
    background: var(--vg-error-bg);
    border-left-color: var(--vg-error-accent);
}

.vg-prepaid-warning-error h4 {
    color: var(--vg-error-text);
}

.vg-prepaid-warning-neutral {
    background: var(--vg-bg-light);
    border-left-color: var(--vg-text-secondary);
}

.vg-prepaid-warning-neutral p {
    color: var(--vg-text-primary);
    font-weight: var(--vg-font-medium);
}

.vg-prepaid-warning-critical {
    background: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
    border: 2px solid var(--vg-error-accent);
    border-left-width: 4px;
}

.vg-prepaid-warning-critical h4 {
    color: var(--vg-error-text);
    font-size: var(--vg-font-md);
}

.vg-prepaid-no-list {
    list-style: none;
    padding-left: var(--vg-space-4);
}

.vg-prepaid-no-list li {
    font-weight: var(--vg-font-bold);
    color: var(--vg-error-text);
}

.vg-prepaid-warning-accept {
    background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
    border-left-color: var(--vg-info-accent);
}

.vg-prepaid-warning-accept h4 {
    color: var(--vg-info-text);
}

.vg-prepaid-accept-list {
    list-style: none;
    padding-left: var(--vg-space-4);
}

.vg-prepaid-accept-list li {
    font-weight: var(--vg-font-medium);
    color: var(--vg-text-primary);
}

/* Checkbox de términos */
.vg-prepaid-terminos-check {
    padding: var(--vg-space-4);
    background: var(--vg-bg-white);
    border: 2px solid var(--vg-error-accent);
    border-radius: var(--vg-radius-md);
    box-shadow: var(--vg-shadow-md);
}

.vg-prepaid-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: var(--vg-space-3);
    cursor: pointer;
    font-size: var(--vg-font-sm);
    color: var(--vg-text-primary);
    line-height: var(--vg-line-height-normal);
}

.vg-prepaid-checkbox-critical {
    font-weight: var(--vg-font-medium);
}

.vg-prepaid-checkbox-text {
    flex: 1;
}

.vg-prepaid-checkbox-text strong {
    color: var(--vg-error-text);
    font-weight: var(--vg-font-bold);
}

.vg-prepaid-checkbox-label input[type="checkbox"] {
    width: 22px;
    height: 22px;
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: var(--vg-error-accent);
    cursor: pointer;
}

.vg-prepaid-checkbox-label .required {
    color: var(--vg-error-text);
    font-size: var(--vg-font-lg);
    font-weight: var(--vg-font-bold);
}

/* ============================================
   ESTADOS DE ERROR
   ============================================ */

.vg-prepaid-error-field {
    border-color: var(--vg-error-accent) !important;
    background: var(--vg-error-bg) !important;
}

.vg-prepaid-error-terms {
    background: var(--vg-error-bg);
    border: var(--vg-border-thin) solid var(--vg-error-border);
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 600px) {
    .vg-prepaid-row {
        flex-direction: column;
        gap: var(--vg-space-3);
    }

    .vg-prepaid-section {
        padding: var(--vg-space-4);
    }

    .vg-prepaid-monto-input .vg-prepaid-input {
        font-size: var(--vg-font-lg);
    }

    .vg-prepaid-amount {
        font-size: var(--vg-font-lg);
    }
}

/* ============================================
   POLÍTICA DE COMPRA ESTÁNDAR (VISA)
   ============================================ */

.vg-prepaid-policy-notice {
    background: var(--vg-bg-white);
    border: 2px solid var(--vg-info-accent);
    border-radius: var(--vg-radius-lg);
    margin: var(--vg-space-6) 0;
    box-shadow: var(--vg-shadow-md);
}

/* Header de política */
.vg-prepaid-policy-header {
    background: var(--vg-info-accent);
    padding: var(--vg-space-4);
    display: flex;
    align-items: center;
    gap: var(--vg-space-3);
    border-radius: var(--vg-radius-lg) var(--vg-radius-lg) 0 0;
}

.vg-prepaid-policy-icon {
    font-size: 28px;
    line-height: 1;
}

.vg-prepaid-policy-title {
    color: var(--vg-bg-white);
    font-size: var(--vg-font-lg);
    font-weight: var(--vg-font-bold);
    margin: 0;
    line-height: var(--vg-line-height-tight);
}

/* Contenido de política */
.vg-prepaid-policy-content {
    padding: var(--vg-space-5);
    background: var(--vg-bg-white);
    border-radius: 0 0 var(--vg-radius-lg) var(--vg-radius-lg);
}

.vg-prepaid-policy-list {
    margin: 0;
    padding-left: var(--vg-space-5);
    list-style: none;
}

.vg-prepaid-policy-list li {
    position: relative;
    padding-left: var(--vg-space-4);
    margin-bottom: var(--vg-space-3);
    font-size: var(--vg-font-sm);
    line-height: var(--vg-line-height-relaxed);
    color: var(--vg-text-primary);
}

.vg-prepaid-policy-list li:last-child {
    margin-bottom: 0;
}

.vg-prepaid-policy-list li::before {
    content: "•";
    position: absolute;
    left: 0;
    color: var(--vg-info-accent);
    font-weight: var(--vg-font-bold);
}

.vg-prepaid-policy-list li strong {
    color: var(--vg-warning-text);
}

/* Checkbox estándar (no crítico) */
.vg-prepaid-checkbox-standard {
    font-weight: var(--vg-font-normal);
}

.vg-prepaid-checkbox-standard .vg-prepaid-checkbox-text strong {
    color: var(--vg-primary);
}

/* Borde del checkbox estándar */
.vg-prepaid-section.vg-prepaid-terminos:has(.vg-prepaid-checkbox-standard) .vg-prepaid-terminos-check {
    border-color: var(--vg-info-accent);
}

.vg-prepaid-checkbox-standard input[type="checkbox"] {
    accent-color: var(--vg-info-accent);
}

/* ============================================
   OCULTAR PRECIO WOOCOMMERCE
   ============================================ */

.single-product .product .vg-prepaid-fields ~ .price,
.single-product .product .summary .price:has(~ .vg-prepaid-fields) {
    display: none !important;
}

/* ============================================
   FIX: LAYOUT DEL FORMULARIO WOOCOMMERCE/ELEMENTOR
   ============================================ */

/* Contenedor de campos - ancho completo */
.vg-prepaid-fields {
    width: 100% !important;
    display: block !important;
    clear: both !important;
    flex-basis: 100% !important;
}

/* Override del selector de custom-pro-t.min.css:
   form.cart:not(.grouped_form):not(.variations_form) { display: flex; flex-wrap: nowrap; }
   Necesitamos un selector igual o más específico */
.woocommerce div.product form.cart:not(.grouped_form):not(.variations_form):has(.vg-prepaid-fields),
.elementor-add-to-cart form.cart:not(.grouped_form):not(.variations_form):has(.vg-prepaid-fields),
form.cart:not(.grouped_form):not(.variations_form):has(.vg-prepaid-fields) {
    display: flex !important;
    flex-wrap: wrap !important;
    flex-direction: column !important;
}

/* Botón añadir al carrito */
.woocommerce div.product form.cart:has(.vg-prepaid-fields) .single_add_to_cart_button,
.elementor-add-to-cart form.cart:has(.vg-prepaid-fields) .single_add_to_cart_button,
form.cart:has(.vg-prepaid-fields) .single_add_to_cart_button {
    display: block !important;
    width: 100% !important;
    margin-top: var(--vg-space-4) !important;
    float: none !important;
    order: 99 !important;
}

/* Ocultar selector de cantidad */
.woocommerce div.product form.cart:has(.vg-prepaid-fields) .quantity,
.elementor-add-to-cart form.cart:has(.vg-prepaid-fields) .quantity,
form.cart:has(.vg-prepaid-fields) .quantity {
    display: none !important;
}
