.dcp-calculator-form-container {
    /* max-width: 800px; */
    margin: 0 auto;
    padding: 40px;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.dcp-product-form .form-section {
    margin-bottom: 40px;
    padding-bottom: 30px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.dcp-product-form .form-section h2 {
    color: #e0e0e0;
    margin-bottom: 20px;
    font-size: 1.5em;
    font-weight: 600;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.dcp-product-form .form-row {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 20px;
}

.dcp-product-form .form-group {
    flex: 1;
    min-width: 250px;
}

.dcp-product-form label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: #b0b0b0;
}

.dcp-product-form select,
.dcp-product-form input[type="number"],
.dcp-product-form input[type="text"] {
    width: 100%;
    padding: 12px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 6px;
    font-size: 14px;
    background: rgba(255, 255, 255, 0.05);
    color: #e0e0e0;
    transition: all 0.3s ease;
}

.dcp-product-form select::placeholder,
.dcp-product-form input::placeholder {
    color: rgba(255, 255, 255, 0.4);
}

.dcp-product-form select:focus,
.dcp-product-form input:focus {
    border-color: #f27523;
    outline: none;
    box-shadow: 0 0 15px rgba(242, 117, 35, 0.3), inset 0 0 8px rgba(242, 117, 35, 0.1);
    background: rgba(255, 255, 255, 0.08);
}

.dcp-product-form select.error,
.dcp-product-form input.error {
    border-color: #ff6b6b;
    background: rgba(255, 107, 107, 0.05);
}

.checkbox-group {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 15px;
}

.form-check {
    display: flex;
    align-items: center;
    padding: 12px;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition: all 0.3s ease;
}

.form-check:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(242, 117, 35, 0.3);
}

.form-check input[type="checkbox"] {
    margin-right: 10px;
    width: 18px;
    height: 18px;
    accent-color: #f27523;
    cursor: pointer;
}

.form-check label {
    margin-bottom: 0;
    font-weight: normal;
    cursor: pointer;
    color: #d0d0d0;
}

.price-summary {
    background: linear-gradient(135deg, rgba(242, 117, 35, 0.1) 0%, rgba(200, 90, 25, 0.1) 100%);
    padding: 25px;
    border-radius: 8px;
    margin-top: 30px;
    border: 1px solid rgba(242, 117, 35, 0.2);
}

.price-display {
    text-align: center;
    margin: 25px 0;
    padding: 30px;
    background: linear-gradient(135deg, rgba(242, 117, 35, 0.15) 0%, rgba(200, 90, 25, 0.1) 100%);
    border-radius: 8px;
    border: 2px solid rgba(242, 117, 35, 0.4);
    box-shadow: 0 8px 24px rgba(242, 117, 35, 0.15);
}

.price-amount {
    font-size: 2.8em;
    font-weight: bold;
    color: #f27523;
    margin: 10px 0;
    text-shadow: 0 0 20px rgba(242, 117, 35, 0.4);
}

.price-display h3 {
    color: #e0e0e0;
    margin-bottom: 10px;
    font-size: 1.2em;
}

.price-display small {
    color: #a0a0a0;
    font-size: 0.9em;
}

.form-actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
}

.form-actions button {
    padding: 15px 40px;
    min-width: 200px;
    border: none;
    border-radius: 6px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.form-actions .button.primary {
    background: linear-gradient(135deg, #f27523 0%, #d85a12 100%);
    color: #ffffff;
    box-shadow: 0 8px 20px rgba(242, 117, 35, 0.3);
}

.form-actions .button.primary:hover:not(:disabled) {
    background: linear-gradient(135deg, #f88c42 0%, #e56815 100%);
    transform: translateY(-3px);
    box-shadow: 0 12px 30px rgba(242, 117, 35, 0.5);
}

.form-actions .button.primary:disabled {
    background: linear-gradient(135deg, #444 0%, #333 100%);
    color: #777;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.form-actions .button.secondary {
    background: rgba(255, 255, 255, 0.1);
    color: #b0b0b0;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.form-actions .button.secondary:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.3);
}

.form-messages {
    width: 100%;
    text-align: center;
    margin-top: 15px;
}

.form-messages .message {
    padding: 15px;
    border-radius: 6px;
    margin: 5px 0;
    font-weight: 500;
    animation: fadeIn 0.3s ease-in;
}

.form-messages .message.success {
    background: rgba(76, 175, 80, 0.15);
    color: #81c784;
    border: 1px solid rgba(76, 175, 80, 0.3);
}

.form-messages .message.error {
    background: rgba(244, 67, 54, 0.15);
    color: #ef5350;
    border: 1px solid rgba(244, 67, 54, 0.3);
}

/* Estilos para validación */
select.error, input.error {
    border-color: #ff6b6b !important;
    background-color: rgba(255, 107, 107, 0.05) !important;
}

/* Estilos para mensajes */
.form-messages {
    min-height: 50px;
    margin-top: 15px;
}

.form-messages .message {
    padding: 12px 20px;
    border-radius: 6px;
    margin: 10px 0;
    font-weight: 500;
    animation: fadeIn 0.3s ease-in;
}

.form-messages .message.success {
    background-color: rgba(76, 175, 80, 0.15);
    color: #81c784;
    border: 1px solid rgba(76, 175, 80, 0.3);
}

.form-messages .message.error {
    background-color: rgba(244, 67, 54, 0.15);
    color: #ef5350;
    border: 1px solid rgba(244, 67, 54, 0.3);
}

/* Estilos para estados de los campos */
select.touched:invalid,
input.touched:invalid {
    border-color: #ff6b6b;
}

select.touched:valid,
input.touched:valid {
    /*border-color: #81c784;*/
}

/* Estilo inicial de los campos (sin tocar) */
select:not(.touched),
input[type="number"]:not(.touched) {
    border-color: rgba(255, 255, 255, 0.2);
    background-color: rgba(255, 255, 255, 0.03);
}

/* Estilo para el botón cuando está deshabilitado */
.button.primary:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    background: linear-gradient(135deg, #444 0%, #333 100%);
}

/* Animación suave para cambios de estado */
select, input[type="number"], input[type="checkbox"] {
    transition: all 0.3s ease;
}

/* Indicador visual para campos requeridos no tocados */
.form-group label::after {
    content: " *";
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.9em;
}

/* Cuando se toca, el asterisco cambia de color */
select.touched + label::after,
input.touched + label::after {
    color: #ff6b6b;
}

/* Cuando es válido, el asterisco desaparece */
select.touched:valid + label::after,
input.touched:valid + label::after {
    content: "";
}

/* Animación */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Mejorar visualización del precio */
.price-amount {
    font-size: 2.5em;
    font-weight: 700;
    color: #f27523;
    text-shadow: 0 0 20px rgba(242, 117, 35, 0.3);
    transition: all 0.3s ease;
}

.price-amount.updating {
    color: #f88c42;
    transform: scale(1.05);
}

/* ============================================
   CORRECCIÓN DE SELECTS - SE VEAN SIEMPRE
   ============================================ */

/* Override de estilos de Forminator/otros plugins */
.dcp-product-form .forminator-select,
.dcp-product-form .select2-container,
.dcp-product-form select {
    opacity: 1 !important;
    visibility: visible !important;
    display: block !important;
    position: static !important;
    width: 100% !important;
    height: auto !important;
    clip: auto !important;
    -webkit-clip-path: none !important;
    clip-path: none !important;
}

/* Ocultar elementos duplicados de Select2 si existen */
.dcp-product-form .select2-hidden-accessible {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* Asegurar que nuestro select nativo sea visible */
.dcp-product-form select.forminator-select--field,
.dcp-product-form #dcp_type,
.dcp-product-form #aspect_ratio,
.dcp-product-form #audio_format,
.dcp-product-form #subtitle_type {
    -webkit-appearance: menulist !important;
    -moz-appearance: menulist !important;
    appearance: menulist !important;
    background-image: none !important;
    padding-right: 30px !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 6px !important;
    color: #e0e0e0 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    height: 46px !important;
}

/* Flecha del select */
.dcp-product-form select:after {
    content: "▼" !important;
    position: absolute !important;
    right: 15px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    pointer-events: none !important;
    color: #666 !important;
}

/* Eliminar cualquier contenedor de Select2 que esté interfiriendo */
.dcp-product-form .select2-container {
    display: none !important;
}

.dcp-product-form .select2-selection {
    display: none !important;
}

/* Si persiste el problema, forzar visibilidad con !important */
.dcp-product-form .form-group select {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Reset específico para el formulario DCP */
#dcp-calculator-form select {
    all: revert !important;
    display: block !important;
    width: 100% !important;
    padding: 12px !important;
    margin-bottom: 15px !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 6px !important;
    background: rgba(255, 255, 255, 0.05) !important;
    color: #e0e0e0 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    box-sizing: border-box !important;
}

#dcp-calculator-form select option {
    background: #2a2a3e !important;
    color: #e0e0e0 !important;
}

#dcp-calculator-form select option:checked {
    background: linear-gradient(#f27523, #f27523) !important;
    background-color: #f27523 !important;
    color: #ffffff !important;
}

#dcp-calculator-form .form-check {
	display: flex;
}

/* Opcional: si hay un theme que está ocultando los selects */
.dcp-calculator-form-container * {
    box-sizing: border-box !important;
}

.dcp-calculator-form-container form * {
    max-height: none !important;
    overflow: visible !important;
}

.wc-block-cart__submit-container .wc-block-components-button__text {
	background: linear-gradient(135deg, #f27523 0%, #d85a12 100%);
	color: #ffffff;
	box-shadow: 0 8px 20px rgba(242, 117, 35, 0.3);
	text-transform: uppercase;
	padding: 15px 40px;
	min-width: 200px;
	border: none;
	border-radius: 6px;
	font-size: 16px;
	font-weight: 600;
	letter-spacing: 0.5px;
	transition: all 0.3s ease;
}
.wc-block-cart__submit-container .wc-block-components-button.wp-element-button.wc-block-cart__submit-button.contained {
	text-decoration: none;
}
.wc-block-cart__submit-container .wc-block-components-button__text:hover {
	background: linear-gradient(135deg, #f88c42 0%, #e56815 100%);
	transform: translateY(-3px);
	box-shadow: 0 12px 30px rgba(242, 117, 35, 0.5);
}



/* ============================================
   CONTENEDOR FILEMAIL CON ESTILOS DE TU WEB
   ============================================ */

.filemail-widget-container {
    background: #181d36 !important; /* Color de fondo de tu web */
    border-radius: 12px !important;
    padding: 30px !important;
    margin: 20px 0 !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    box-shadow: 
        0 10px 30px rgba(0, 0, 0, 0.3),
        inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
    position: relative !important;
    overflow: hidden !important;
}

/* Efecto de brillo sutil */
.filemail-widget-container::before {
    content: '' !important;
    position: absolute !important;
    top: -50% !important;
    left: -50% !important;
    width: 200% !important;
    height: 200% !important;
    background: linear-gradient(
        to bottom right,
        rgba(248, 140, 66, 0.1) 0%,
        rgba(248, 140, 66, 0.05) 25%,
        transparent 50%
    ) !important;
    pointer-events: none !important;
    z-index: 1 !important;
}

/* Área de arrastrar y soltar de Filemail */
.filemail-widget-container .fm-dropzone {
    background: rgba(255, 255, 255, 0.03) !important;
    border: 3px dashed rgba(255, 255, 255, 0.15) !important;
    border-radius: 10px !important;
    padding: 40px 20px !important;
    text-align: center !important;
    transition: all 0.3s ease !important;
    position: relative !important;
    z-index: 2 !important;
}

.filemail-widget-container .fm-dropzone:hover,
.filemail-widget-container .fm-dropzone.dragover {
    background: rgba(255, 255, 255, 0.05) !important;
    border-color: #f88c42 !important;
    border-style: solid !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(242, 117, 35, 0.2) !important;
}

/* Icono de subida */
.filemail-widget-container .fm-dropzone .fm-upload-icon {
    color: #f88c42 !important;
    font-size: 50px !important;
    margin-bottom: 15px !important;
    display: block !important;
}

/* Texto del dropzone */
.filemail-widget-container .fm-dropzone p {
    color: rgba(255, 255, 255, 0.8) !important;
    font-size: 16px !important;
    margin-bottom: 10px !important;
}

.filemail-widget-container .fm-dropzone small {
    color: rgba(255, 255, 255, 0.5) !important;
    font-size: 13px !important;
    display: block !important;
}

/* Botones de Filemail */
.filemail-widget-container .fm-btn {
    background: linear-gradient(135deg, #f88c42 0%, #e56815 100%) !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 12px 25px !important;
    color: white !important;
    font-weight: 500 !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 5px 15px rgba(242, 117, 35, 0.3) !important;
    cursor: pointer !important;
}

.filemail-widget-container .fm-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 20px rgba(242, 117, 35, 0.4) !important;
}

/* Lista de archivos */
.filemail-widget-container .fm-file-list {
    margin-top: 20px !important;
    background: rgba(255, 255, 255, 0.03) !important;
    border-radius: 8px !important;
    padding: 15px !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.filemail-widget-container .fm-file-item {
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 6px !important;
    padding: 12px 15px !important;
    margin-bottom: 8px !important;
    border: 1px solid rgba(255, 255, 255, 0.05) !important;
    transition: all 0.3s ease !important;
}

.filemail-widget-container .fm-file-item:hover {
    background: rgba(255, 255, 255, 0.08) !important;
    transform: translateX(5px) !important;
}

/* Barra de progreso */
.filemail-widget-container .fm-progress-bar {
    background: rgba(255, 255, 255, 0.1) !important;
    border-radius: 4px !important;
    height: 6px !important;
    overflow: hidden !important;
    margin-top: 8px !important;
}

.filemail-widget-container .fm-progress-bar .fm-progress {
    background: linear-gradient(90deg, #f88c42, #ffa726) !important;
    height: 100% !important;
    border-radius: 4px !important;
    transition: width 0.3s ease !important;
}

/* Encabezados dentro del widget */
.filemail-widget-container h3,
.filemail-widget-container h4 {
    color: #ffffff !important;
    margin-top: 0 !important;
    position: relative !important;
    z-index: 2 !important;
}

/* Campos de entrada */
.filemail-widget-container input[type="email"],
.filemail-widget-container input[type="text"],
.filemail-widget-container textarea {
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 6px !important;
    color: rgba(255, 255, 255, 0.8) !important;
    padding: 10px 15px !important;
    transition: all 0.3s ease !important;
}

.filemail-widget-container input[type="email"]:focus,
.filemail-widget-container input[type="text"]:focus,
.filemail-widget-container textarea:focus {
    background: rgba(255, 255, 255, 0.08) !important;
    border-color: #f88c42 !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(248, 140, 66, 0.2) !important;
}

/* Placeholders */
.filemail-widget-container ::placeholder {
    color: rgba(255, 255, 255, 0.4) !important;
}




@media (max-width: 768px) {
    .dcp-calculator-form-container {
        padding: 25px;
    }
    
    .form-row {
        flex-direction: column;
        gap: 15px;
    }
    
    .form-group {
        min-width: 100%;
    }
    
    .checkbox-group {
        grid-template-columns: 1fr;
    }
    
    .form-actions {
        flex-direction: column;
    }
    
    .form-actions button {
        width: 100%;
    }
    
    .price-amount {
        font-size: 2em;
    }
}