/**
 * Doguify Mascotas Form — estilos específicos del formulario "Alta en Doguify"
 * Reaprovecha la base de doguify-forms.css y añade:
 *   - dg-info-box (caja informativa de step 0)
 *   - dg-mascotas-plans + dg-mascotas-plan + pricing options + features
 *   - dg-modal-popup (popup de exclusivo no disponible)
 */

/* === Info box (aviso "una vez completado el pago...") === */
.dg-info-box {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: #f3f0ff;
    border: 1px solid #e2dcff;
    border-radius: 12px;
    padding: 14px 16px;
    margin: 24px 0 8px;
    color: #2d2570;
    font-size: 14px;
    line-height: 1.5;
}
.dg-info-box svg {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    color: #6b5cff;
    margin-top: 2px;
}

/* === Step header for mascotas plans === */
.doguify-form-mascotas .dg-step-title { font-size: 32px; font-weight: 700; text-align: center; }
.doguify-form-mascotas .dg-step-subtitle { text-align: center; }
.doguify-form-mascotas #panel-planes .dg-step-header { margin-bottom: 32px; }

/* === Plans layout === */
.dg-mascotas-plans {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    max-width: 980px;
    margin: 0 auto;
    align-items: start; /* cada card respeta su altura natural, sin estirarse */
}
@media (max-width: 768px) {
    .dg-mascotas-plans { grid-template-columns: 1fr; gap: 16px; }
}

/* Cuando sólo se muestra el plan Profesional (caso: tipo_negocio = productos)
   centramos la única tarjeta manteniendo su tamaño original (no se estira). */
.dg-mascotas-plans.dg-mascotas-plans-single {
    grid-template-columns: minmax(0, 478px); /* mismo ancho aprox que en 2 columnas: (980 - 24)/2 */
    justify-content: center;
}
@media (max-width: 768px) {
    .dg-mascotas-plans.dg-mascotas-plans-single { grid-template-columns: 1fr; }
}

.dg-mascotas-plan {
    background: #fff;
    border: 1px solid #e7e7ec;
    border-radius: 16px;
    padding: 24px 22px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    transition: border-color .2s ease, box-shadow .2s ease, transform .15s ease;
}
.dg-mascotas-plan-highlight {
    border-color: #c8c1ff;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
.dg-mascotas-plan:hover { border-color: #b3aaff; }
.dg-mascotas-plan.selecting { transform: translateY(-2px); }

/* Header */
.dg-mascotas-plan-head {
    display: flex;
    align-items: center;
    gap: 10px;
}
.dg-mascotas-plan-brand {
    font-size: 22px;
    font-weight: 700;
    color: #14141e;
}
.dg-mascotas-plan-badge {
    background: #14141e;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 14px;
    letter-spacing: .03em;
}

/* Pricing options */
.dg-mascotas-pricing {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 2px;
}
.dg-mascotas-price-option {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 14px;
    border-radius: 12px;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background .12s ease, border-color .12s ease, transform .08s ease;
    -webkit-tap-highlight-color: rgba(70, 94, 209, .15); /* feedback nativo en móvil */
    user-select: none;
}
/* Feedback inmediato al pulsar (independiente de :checked).
   Cubre la ventana de 1-2 frames donde Safari/iOS pueden no haber actualizado :checked todavía. */
.dg-mascotas-price-option:active {
    background: #ece8ff;
    transform: scale(.985);
}
.dg-mascotas-price-option:hover {
    background: #f5f3ff;
}
.dg-mascotas-price-option.sel:hover {
    background: #ece8ff;
}
.dg-mascotas-price-option input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.dg-mascotas-radio {
    width: 18px;
    height: 18px;
    border: 2px solid #c4c4cc;
    border-radius: 50%;
    flex-shrink: 0;
    position: relative;
    transition: border-color .15s ease;
}
.dg-mascotas-price-option.sel { background: #ece8ff; border-color: #d8d1ff; }
.dg-mascotas-price-option.sel .dg-mascotas-radio { border-color: #465ED1; }
.dg-mascotas-price-option.sel .dg-mascotas-radio::after {
    content: "";
    position: absolute;
    inset: 3px;
    background: #465ED1;
    border-radius: 50%;
}
.dg-mascotas-price-text {
    font-size: 15px;
    color: #14141e;
    line-height: 1.4;
}
.dg-mascotas-price-text small {
    display: block;
    font-size: 13px;
    color: #14141e;
    font-weight: 400;
    margin-top: 2px;
}

/* Includes line for Exclusivo */
.dg-mascotas-includes {
    font-size: 14px;
    color: #14141e;
    margin: 4px 0 0;
    margin-bottom: 0 !important;
    font-weight: 500;
}

/* Features list — sin flex-grow para que el card no tenga huecos */
.dg-mascotas-features {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 9px;
}
/* En el Exclusivo, las features van pegadas a la línea "Incluye los servicios..." */
.dg-mascotas-plan-highlight .dg-mascotas-features {
    margin-top: 0 !important;
}
.dg-mascotas-features li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 14px;
    color: #14141e;
    line-height: 1.4;
}
.dg-mascotas-features svg {
    width: 18px;
    height: 18px;
    color: #465ED1;
    flex-shrink: 0;
    margin-top: 1px;
}

/* CTA buttons */
.dg-mascotas-cta {
    margin-top: 6px;
    width: 100%;
    padding: 14px 18px;
    border-radius: 999px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: background .12s ease, color .12s ease, transform .08s ease, opacity .12s ease;
    font-family: inherit;
    -webkit-tap-highlight-color: transparent;
}
.dg-mascotas-cta:active:not(:disabled) {
    transform: scale(.97);
}
.dg-mascotas-cta-pro {
    background: transparent;
    color: #14141e;
    border: 1.5px solid #14141e;
}
.dg-mascotas-cta-pro:hover { background: #14141e; color: #fff; }

.dg-mascotas-cta-exc {
    background: #14141e;
    color: #fff;
    border: 1.5px solid #14141e;
}
.dg-mascotas-cta-exc:hover { background: #2a2a3a; }

.dg-mascotas-cta:disabled { opacity: .65; cursor: progress; }

/* === Popup (exclusivo no disponible) === */
.dg-modal-popup {
    max-width: 460px;
    padding: 32px 28px;
    text-align: center;
}
.dg-popup-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: #fff3e0;
    color: #e67e22;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
}
.dg-popup-icon svg { width: 28px; height: 28px; }
.dg-popup-title {
    font-size: 20px;
    font-weight: 700;
    margin: 0 0 12px;
    color: #14141e;
}
.dg-popup-text {
    font-size: 15px;
    color: #555;
    line-height: 1.5;
    margin: 0 0 24px;
}
.dg-popup-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
@media (max-width: 480px) {
    .dg-popup-actions { flex-direction: column; }
}
.dg-popup-btn {
    flex: 1;
    padding: 12px 18px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all .15s ease;
    font-family: inherit;
    min-width: 140px;
}
.dg-popup-btn-secondary {
    background: transparent;
    color: #14141e;
    border: 1.5px solid #d1d1d8;
}
.dg-popup-btn-secondary:hover { background: #f3f3f5; border-color: #14141e; }
.dg-popup-btn-primary {
    background: #14141e;
    color: #fff;
    border: 1.5px solid #14141e;
}
.dg-popup-btn-primary:hover { background: #2a2a3a; }
.dg-popup-btn:disabled { opacity: .65; cursor: progress; }

/* === Utilidad: ocultar elemento desde JS sin depender de inline style === */
.dg-hidden { display: none !important; }

/* === Categorías de negocio (chips multi-select) === */
.dg-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
}
.dg-chip {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    border: 1.5px solid #252525;
    border-radius: 999px;
    background: #fff;
    cursor: pointer;
    font-size: 14px;
    line-height: 1.2;
    color: #252525;
    transition: background .15s ease, color .15s ease;
    user-select: none;
}
.dg-chip input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
    width: 0;
    height: 0;
}
.dg-chip:hover,
.dg-chip.selected {
    background: #252525;
    color: #fff;
}
#field-categories.has-error .dg-chips {
    padding: 4px;
    border-radius: 12px;
    box-shadow: 0 0 0 2px rgba(220,38,38,.15);
}

/* Aviso inline rojo cuando hay conflicto productos + plan Exclusivo preseleccionado */
.dg-plan-conflict-warning {
    background: #fff5f5;
    border: 1.5px solid #fca5a5;
    color: #991b1b;
    padding: 12px 16px;
    border-radius: 12px;
    font-size: 14px;
    line-height: 1.45;
    margin-top: 6px;
}
