/* ============================================ */
/* OptikModa Formulario Facturación — v1.4      */
/* Alta especificidad para override de OceanWP  */
/* ============================================ */

/* 1. Contenedor Principal */
#optikmoda-form-container {
    max-width: 680px !important;
    margin: 40px auto !important;
    padding: 40px 44px !important;
    border-radius: 16px !important;
    background: #ffffff !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.08) !important;
    font-family: 'Outfit', 'Segoe UI', sans-serif !important;
    color: #333 !important;
    border-top: none !important;
}

/* Título principal oculto */
#optikmoda-form-container > h2 {
    display: none !important;
}

/* Intro */
#optikmoda-form-container .form-intro {
    font-size: 1.05em !important;
    text-align: center !important;
    margin-bottom: 32px !important;
    color: #888 !important;
    line-height: 1.6 !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
}

/* ============================================ */
/* 2. Encabezados de Sección                    */
/* ============================================ */
#optikmoda-form-container h3,
#optikmoda-form-container form h3 {
    font-family: 'Cormorant Garamond', 'Georgia', serif !important;
    font-size: 1.6em !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
    margin-top: 40px !important;
    margin-bottom: 20px !important;
    padding: 0 0 10px 0 !important;
    border: none !important;
    border-bottom: 1px solid #e5e5e5 !important;
    border-left: none !important;
    border-top: none !important;
    background: none !important;
    border-radius: 0 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}

#optikmoda-form-container h3:first-of-type {
    margin-top: 8px !important;
}

/* ============================================ */
/* 3. Labels                                    */
/* ============================================ */
#optikmoda-form-container .om-field label {
    display: block !important;
    font-size: 1.0em !important;
    font-weight: 600 !important;
    color: #444 !important;
    margin-bottom: 6px !important;
    margin-top: 0 !important;
}

#optikmoda-form-container .om-field label .req,
#optikmoda-form-container .om-checkbox-row label .req {
    color: #e05c5c !important;
    margin-left: 2px !important;
}

#optikmoda-form-container .om-hint {
    display: block !important;
    font-size: 1.05em !important;
    color: #999 !important;
    margin-top: 4px !important;
}

/* ============================================ */
/* 4. Campos de Formulario                      */
/* ============================================ */
#optikmoda-form-container .om-field {
    margin-bottom: 16px !important;
}

#optikmoda-form-container .om-field input[type="text"],
#optikmoda-form-container .om-field input[type="email"],
#optikmoda-form-container .om-field input[type="date"],
#optikmoda-form-container .om-field input[type="number"],
#optikmoda-form-container .om-field select,
#optikmoda-form-container .om-field textarea {
    width: 100% !important;
    padding: 11px 14px !important;
    border: 1.5px solid #ecdede !important;
    border-radius: 10px !important;
    box-sizing: border-box !important;
    background-color: #fdf5f5 !important;
    font-size: 1.05em !important;
    font-family: inherit !important;
    color: #333 !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    margin-bottom: 0 !important;
    box-shadow: none !important;
    outline: none !important;
}

#optikmoda-form-container .om-field input:focus,
#optikmoda-form-container .om-field select:focus,
#optikmoda-form-container .om-field textarea:focus {
    border-color: #FF8C00 !important;
    box-shadow: 0 0 0 3px rgba(255,140,0,0.1) !important;
    background-color: #fff !important;
    outline: none !important;
}

#optikmoda-form-container .om-field input::placeholder,
#optikmoda-form-container .om-field textarea::placeholder {
    color: #bbb !important;
    opacity: 1 !important;
}

/* Select flecha custom */
#optikmoda-form-container .om-field select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888' d='M6 9L1 4h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    padding-right: 36px !important;
    cursor: pointer !important;
}

/* Textarea */
#optikmoda-form-container .om-field textarea {
    resize: vertical !important;
    min-height: 90px !important;
}

/* ============================================ */
/* 5. Grid de 2 Columnas                        */
/* ============================================ */
#optikmoda-form-container .om-grid-2 {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
    margin-bottom: 16px !important;
}

#optikmoda-form-container .om-grid-2 .om-field {
    margin-bottom: 0 !important;
}

/* ============================================ */
/* 6. Upload de PDF                             */
/* ============================================ */
#optikmoda-form-container .om-upload-area {
    border: 1.5px dashed #ccc !important;
    border-radius: 10px !important;
    padding: 18px !important;
    text-align: center !important;
    background: #fafafa !important;
    cursor: pointer !important;
    transition: border-color 0.2s, background 0.2s !important;
    position: relative !important;
    margin-bottom: 0 !important;
}

#optikmoda-form-container .om-upload-area:hover {
    border-color: #FF8C00 !important;
    background: #fff9f2 !important;
}

#optikmoda-form-container .om-upload-area input[type="file"] {
    position: absolute !important;
    inset: 0 !important;
    opacity: 0 !important;
    cursor: pointer !important;
    width: 100% !important;
    height: 100% !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}

#optikmoda-form-container .om-upload-label {
    display: block !important;
    font-size: 1.0em !important;
    color: #888 !important;
    pointer-events: none !important;
    margin: 0 !important;
}

/* ============================================ */
/* 7. Privacidad y Checkbox                     */
/* ============================================ */
#optikmoda-form-container .om-privacy-box {
    background: #fdf5f5 !important;
    border: 1.5px solid #ecdede !important;
    border-radius: 10px !important;
    padding: 16px 20px !important;
    margin-bottom: 16px !important;
    font-size: 1.0em !important;
    color: #555 !important;
    line-height: 1.6 !important;
}

#optikmoda-form-container .om-privacy-box p {
    margin: 0 0 8px 0 !important;
}

#optikmoda-form-container .om-privacy-box p:last-child {
    margin-bottom: 0 !important;
}

#optikmoda-form-container .om-privacy-box strong {
    color: #333 !important;
}

#optikmoda-form-container .om-privacy-box a {
    color: #FF8C00 !important;
    text-decoration: underline !important;
}

#optikmoda-form-container .om-checkbox-row {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    margin-bottom: 24px !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
}

#optikmoda-form-container .om-checkbox-row input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    min-width: 16px !important;
    margin-top: 2px !important;
    margin-right: 0 !important;
    accent-color: #FF8C00 !important;
    cursor: pointer !important;
}

#optikmoda-form-container .om-checkbox-row label {
    font-size: 1.0em !important;
    color: #444 !important;
    cursor: pointer !important;
    line-height: 1.5 !important;
    font-weight: normal !important;
    display: inline !important;
    margin: 0 !important;
}

/* ============================================ */
/* 8. Botón de Envío                            */
/* ============================================ */
#optikmoda-form-container #submit-button {
    background: #E87722 !important;
    background-image: none !important;
    color: white !important;
    padding: 14px 22px !important;
    border: none !important;
    cursor: pointer !important;
    width: 100% !important;
    font-size: 1.05em !important;
    font-weight: 600 !important;
    font-family: inherit !important;
    border-radius: 50px !important;
    transition: background 0.2s, transform 0.15s !important;
    letter-spacing: 0.02em !important;
    margin-top: 4px !important;
    box-shadow: none !important;
    text-transform: none !important;
}

#optikmoda-form-container #submit-button:hover:not(:disabled) {
    background: #CF6A1C !important;
    transform: translateY(-1px) !important;
}

#optikmoda-form-container #submit-button:disabled {
    background: #ccc !important;
    cursor: not-allowed !important;
}

/* ============================================ */
/* 9. Pie del formulario                        */
/* ============================================ */
#optikmoda-form-container .om-form-footer {
    margin-top: 16px !important;
    font-size: 1.05em !important;
    color: #999 !important;
    text-align: center !important;
    line-height: 1.8 !important;
}

#optikmoda-form-container .om-form-footer a {
    color: #FF8C00 !important;
    text-decoration: none !important;
    font-weight: 600 !important;
}

#optikmoda-form-container .om-form-footer a:hover {
    text-decoration: underline !important;
}

#optikmoda-form-container .om-footer-contact {
    margin-top: 6px !important;
    color: #888 !important;
}

#optikmoda-form-container .om-footer-contact a {
    color: #888 !important;
    font-weight: 400 !important;
}

#optikmoda-form-container .om-footer-sep {
    margin: 0 6px !important;
    color: #ccc !important;
}

/* ============================================ */
/* 10. Mensajes AJAX                            */
/* ============================================ */
#optikmoda-form-container #form-message {
    padding: 16px 20px !important;
    margin-top: 20px !important;
    border-radius: 10px !important;
    font-size: 1.05em !important;
    font-weight: 500 !important;
    text-align: center !important;
    line-height: 1.5 !important;
}

#optikmoda-form-container #form-message.hidden { display: none !important; }

#optikmoda-form-container #form-message.success {
    background: #eafaf1 !important;
    color: #1a6636 !important;
    border: 1.5px solid #a8dfc0 !important;
}

#optikmoda-form-container #form-message.error {
    background: #fdf2f2 !important;
    color: #8b2020 !important;
    border: 1.5px solid #f1a8a8 !important;
}

#optikmoda-form-container #form-message.loading {
    background: #fffbf0 !important;
    color: #7a5a00 !important;
    border: 1.5px solid #f0dfa0 !important;
}

/* ============================================ */
/* 11. Responsive                               */
/* ============================================ */
@media (max-width: 640px) {
    #optikmoda-form-container {
        padding: 28px 20px !important;
        margin: 20px 12px !important;
    }

    #optikmoda-form-container .om-grid-2 {
        grid-template-columns: 1fr !important;
    }
}

/* ============================================ */
/* 12. Animación de entrada                     */
/* ============================================ */
@keyframes omFadeIn {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

#optikmoda-form-container { animation: omFadeIn 0.4s ease-out; }
#optikmoda-form-container #form-message:not(.hidden) { animation: omFadeIn 0.3s ease-out; }
