/* Done Digital Lead Machine Forms Styles */

/* Global theme override protection */
.ddlm-form,
.ddlm-form *,
.ddlm-form *::before,
.ddlm-form *::after {
    box-sizing: border-box !important;
}

/*
 * Wrapper reset — avoid `all: unset` here: it resets every property on this node and is known
 * to interact badly with themes, inheritance, and custom properties. Use explicit resets only.
 */
.ddlm-form {
    display: block;
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 0 !important;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    border: 0;
    max-width: 100%;
    min-width: 0;
    vertical-align: baseline;
    background: transparent;
    box-shadow: none;
    font: inherit;
    color: inherit;
    text-align: inherit;
    text-decoration: none;
    list-style: none;
}

/* Custom form styling - target only custom forms, not widget forms */
.ddlm-custom-form {
    background: #ffffff !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
    padding: 24px !important;
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    /* Font family intentionally omitted so the form inherits the site's body font.
       Headings (<h3>) naturally pick up the theme's heading font via the h1–h6 cascade. */
    line-height: 1.5 !important;
    color: #333 !important;
    width: 100% !important;
}

/* Disable form styling when option is checked */
.ddlm-custom-form.ddlm-disable-styling {
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
}

/* Keep field/button component styling in reduced-styling mode */
.ddlm-custom-form.ddlm-disable-styling .ddlm-form-input {
    width: 100% !important;
    padding: 10px 12px !important;
    border: 1px solid #e1e5e9 !important;
    border-radius: 5px !important;
    font-family: inherit !important;
    box-sizing: border-box !important;
    background: #fff !important;
}

.ddlm-custom-form.ddlm-disable-styling .ddlm-submit-btn {
    width: 100% !important;
    height: 48px !important;
    padding: 12px 24px !important;
    background: var(--ddlm-primary-color, #007cba) !important;
    color: var(--ddlm-button-text-color, #ffffff) !important;
    border: none !important;
    border-radius: 8px !important;
}

/* Popup dialog: always show card background (disable-styling is for embedded/theme blocks only) */
.ddlm-popup-dialog .ddlm-custom-form.ddlm-disable-styling {
    background: #ffffff !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
    padding: 24px !important;
    border-radius: var(--ddlm-form-border-radius, 15px) !important;
}

.ddlm-form form {
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 0 !important;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Form heading and subheading (tight line-height: wrapper uses 1.5 for body copy).
   font-family is intentionally not set here so the theme's cascade applies:
   - Heading (<h3>): theme's h1–h6 rule wins, so it uses the site's heading font.
   - Subheading (<p>): inherits the site's body font. */
.ddlm-form-heading {
    margin: 0;
    color: #333;
    font-size: 24px;
    font-weight: 600;
    line-height: 1.2 !important;
}

/* Add bottom margin when subheading is disabled */
.ddlm-form-heading.ddlm-heading-no-subheading {
    margin: 0 0 15px 0 !important;
}

.ddlm-form-subheading {
    margin: 0 0 15px 0 !important;
    color: #666;
    font-size: 18px;
    line-height: 1.35 !important;
}

/* Inline markup in heading/subheading: parent is already 600 / normal weight — step up bold so <b> reads */
.ddlm-form-heading b,
.ddlm-form-heading strong {
    font-weight: 700;
}

.ddlm-form-subheading b,
.ddlm-form-subheading strong {
    font-weight: 700;
}

.ddlm-form-heading i,
.ddlm-form-heading em,
.ddlm-form-subheading i,
.ddlm-form-subheading em {
    font-style: italic;
}

.ddlm-form-heading u,
.ddlm-form-subheading u {
    text-decoration: underline;
}

/* Heading field styles */
.ddlm-heading-field {
    margin: 20px 0 15px 0;
    padding: 0;
    border: none;
    background: none;
}

.ddlm-field-heading {
    margin: 0 0 12px 0 !important;
    padding: 0 !important;
    font-weight: 600 !important;
    color: #333 !important;
    line-height: 1.2 !important;
    border: none !important;
    background: none !important;
}

.ddlm-field-description {
    margin: 0 !important;
    padding: 0 0 16px 0 !important;
    color: #959595 !important;
    line-height: 1.4 !important;
    font-weight: normal !important;
    border: none !important;
    background: none !important;
}

/* When horizontal line is present, reduce description bottom padding */
.ddlm-field-description + .ddlm-heading-line {
    margin-top: 8px !important;
}

.ddlm-heading-line {
    border: none !important;
    height: 1px !important;
    background: #e0e0e0 !important;
    margin: 16px 0 20px 0 !important;
    padding: 0 !important;
}

.ddlm-form-content {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.ddlm-form-field {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* Strong overrides to prevent theme interference */
.ddlm-form-content > *,
.ddlm-form-field > * {
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Additional theme override for any form-related elements */
.ddlm-form * {
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Override any theme input styling */
.ddlm-form-input,
.ddlm-form-input:focus,
.ddlm-form-input:hover,
.ddlm-form-input:active {
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Override theme form element styling */
.ddlm-form form,
.ddlm-form form:focus,
.ddlm-form form:hover,
.ddlm-form form:active {
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 0 !important;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Override any theme form element styling */
.ddlm-form fieldset,
.ddlm-form fieldset:focus,
.ddlm-form fieldset:hover,
.ddlm-form fieldset:active {
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 0 !important;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    border: none !important;
}

/* Override theme textarea styling */
.ddlm-textarea,
.ddlm-textarea:focus,
.ddlm-textarea:hover,
.ddlm-textarea:active {
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Override theme select styling */
.ddlm-select,
.ddlm-select:focus,
.ddlm-select:hover,
.ddlm-select:active {
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Override theme label styling */
.ddlm-field-label {
    margin: 0 !important;
    margin-bottom: 4px !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Override specific theme selectors that target our form elements */
#top .ddlm-form-input,
#top .ddlm-textarea,
#top .ddlm-select,
#top .ddlm-form input[type="text"],
#top .ddlm-form input[type="email"],
#top .ddlm-form input[type="tel"],
#top .ddlm-form input[type="password"],
#top .ddlm-form input[type="number"],
#top .ddlm-form input[type="url"],
#top .ddlm-form input[type="search"],
#top .ddlm-form textarea,
#top .ddlm-form select {
    margin: 0 !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}

/* Override any other potential theme selectors */
.ddlm-form input,
.ddlm-form textarea,
.ddlm-form select,
.ddlm-form button {
    margin: 0 !important;
    margin-bottom: 0 !important;
}

.ddlm-field-label {
    font-size: 14px;
    font-weight: 500;
    color: #333;
    margin-bottom: 4px;
}

.ddlm-required {
    color: #a8bed9;
    margin-left: 2px;
}

.ddlm-form-input {
    width: 100% !important;
    padding: 10px 12px !important;
    border: 1px solid #e1e5e9 !important;
    border-radius: 5px !important;
    font-size: 16px;
    font-family: inherit !important;
    transition: all 0.2s ease !important;
    box-sizing: border-box !important;
    background: #fff !important;
}

.ddlm-form-input:focus {
    outline: none !important;
    border-color: var(--ddlm-primary-color, #007cba) !important;
    box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1) !important;
}

.ddlm-form-input::placeholder {
    color: #999 !important;
    opacity: 1 !important;
}

.ddlm-textarea {
    min-height: 100px !important;
    resize: vertical !important;
    font-family: inherit !important;
}

.ddlm-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e") !important;
    background-position: right 12px center !important;
    background-repeat: no-repeat !important;
    background-size: 16px !important;
    padding-right: 40px !important;
    appearance: none !important;
}

.ddlm-checkbox-group,
.ddlm-radio-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ddlm-checkbox-label,
.ddlm-radio-label {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-size: 14px;
    color: #333;
    padding: 8px 0;
}

.ddlm-checkbox,
.ddlm-radio {
    margin-right: 8px;
    width: 16px;
    height: 16px;
    accent-color: var(--ddlm-primary-color, #007cba);
}

.ddlm-checkbox-text,
.ddlm-radio-text {
    flex: 1;
    line-height: 1.25;
}

/* Spacing before submit comes from parent flex gap (.ddlm-form-two-column / .ddlm-form-content) */
.ddlm-form-submit {
    margin-top: 0;
}

.ddlm-submit-btn {
    width: 100% !important;
    height: 48px !important;
    padding: 12px 24px !important;
    background: var(--ddlm-primary-color, #007cba) !important;
    color: var(--ddlm-button-text-color, #ffffff) !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 16px;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    font-family: inherit !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.ddlm-submit-btn:hover {
    background: var(--ddlm-primary-color, #007cba) !important;
    opacity: 0.9 !important;
    transform: translateY(-1px) !important;
}

.ddlm-submit-btn:active {
    transform: translateY(0);
}

.ddlm-submit-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.ddlm-form-message {
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 14px;
    margin-top: 16px;
}

.ddlm-form-message.ddlm-success {
    background: rgba(var(--ddlm-primary-color-rgb, 0, 124, 186), 0.08);
    color: var(--ddlm-primary-color, #007cba);
    border: 1px solid rgba(var(--ddlm-primary-color-rgb, 0, 124, 186), 0.1);
    text-align: center;
}

.ddlm-form-message.ddlm-error {
    background: #e2f3ff;
    color: #0066cc;
    border: 1px solid #b3d9ff;
}

.ddlm-form-message.ddlm-loading {
    background: #e2f3ff;
    color: #0066cc;
    border: 1px solid #b3d9ff;
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] {
        padding: 20px;
        margin: 0 10px;
    }
    
    .ddlm-form-input {
        font-size: 16px; /* Prevents zoom on iOS */
        padding: 14px 16px;
    }
    
    .ddlm-submit-btn {
        padding: 14px 24px;
        font-size: 16px;
        height: 52px !important;
    }
}

@media (max-width: 480px) {
    .ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] {
        padding: 16px;
        border-radius: 8px;
    }
    
    .ddlm-form-content {
        gap: 12px;
    }
    
    .ddlm-form-field {
        gap: 6px;
    }
    
    .ddlm-field-label {
        font-size: 13px;
    }
    
    .ddlm-form-input {
        padding: 12px 14px;
        font-size: 16px;
    }
    
    .ddlm-submit-btn {
        padding: 12px 20px;
        font-size: 16px;
        height: 38px !important;
    }
}

/* Loading state */
.ddlm-submit-btn.ddlm-loading {
    position: relative !important;
    color: transparent !important;
    /* Ensure the button itself doesn't spin */
    transform: none !important;
    animation: none !important;
}

.ddlm-submit-btn.ddlm-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 -10px;
    border: 2px solid #ffffff;
    border-radius: 50%;
    border-top-color: transparent;
    animation: ddlm-spin 1s linear infinite;
    /* Ensure only the spinner rotates */
    transform-origin: center;
    z-index: 1;
}

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

/* Error states */
.ddlm-form-input.ddlm-error {
    border-color: #007cba;
    box-shadow: 0 0 0 3px rgba(0, 124, 186, 0.1);
}

/* Success animation */
.ddlm-form.ddlm-submitted {
    animation: ddlm-success-pulse 0.6s ease;
}

@keyframes ddlm-success-pulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.02); }
    100% { transform: scale(1); }
}

/* Layout Options */

/* Size container + stacking context: half-width follows form width; resists theme bleed */
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] {
    container-type: inline-size;
    container-name: ddlm-form;
    isolation: isolate;
    position: relative;
    z-index: 0;
    max-width: 100%;
}

/* Two-Column Layout — vertical rhythm uses column gap only (no row margin-bottom) */
.ddlm-form-two-column {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.ddlm-form .ddlm-field-row {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: stretch;
    gap: 12px;
    margin-bottom: 0;
}

.ddlm-field-column {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0;
}

.ddlm-form .ddlm-field-column.ddlm-field-half-width {
    flex: 1 1 0 !important;
    width: auto !important;
    max-width: calc(50% - 6px);
}

.ddlm-form .ddlm-field-column.ddlm-field-full-width {
    flex: 1 1 100% !important;
    width: 100%;
    max-width: 100%;
}

.ddlm-form .ddlm-field-column.ddlm-empty-column {
    flex: 1 1 0 !important;
    width: auto !important;
    max-width: calc(50% - 6px);
}


/* In-Line Form Layout */
.ddlm-form-inline {
    display: flex;
    align-items: flex-end;
    gap: 12px;
    flex-wrap: nowrap;
}

.ddlm-form-inline .ddlm-form-field {
    flex: 1;
    min-width: 150px;
    margin-bottom: 0;
}

.ddlm-form-inline .ddlm-form-submit {
    flex-shrink: 0;
    margin-bottom: 0;
}

.ddlm-form-inline .ddlm-submit-btn {
    white-space: nowrap;
}

/* Only apply responsive wrapping and stacking on frontend forms, not in preview */
.ddlm-form:not(#ddlm-form-preview) .ddlm-form-inline {
    flex-wrap: wrap;
}

@media (max-width: 768px) {
    .ddlm-form:not(#ddlm-form-preview) .ddlm-form-inline {
        flex-direction: column;
        align-items: stretch;
    }

    .ddlm-form:not(#ddlm-form-preview) .ddlm-form-inline .ddlm-form-field {
        min-width: auto;
    }

    .ddlm-form:not(#ddlm-form-preview) .ddlm-form-inline .ddlm-form-submit {
        margin-top: 8px;
    }
}

/* Stack half-width columns when the form itself is narrow (container query) */
@container ddlm-form (max-width: 400px) {
    .ddlm-field-row {
        flex-direction: column !important;
        flex-wrap: nowrap !important;
        gap: 12px;
    }

    .ddlm-field-column.ddlm-field-half-width,
    .ddlm-field-column.ddlm-field-full-width,
    .ddlm-field-column.ddlm-empty-column {
        width: 100% !important;
        max-width: 100% !important;
        flex: 1 1 auto !important;
    }
}

/* Browsers without container queries: stack on typical phone/tablet portrait widths */
@supports not (container-type: inline-size) {
    @media (max-width: 768px) {
        .ddlm-form .ddlm-field-row {
            flex-direction: column !important;
            flex-wrap: nowrap !important;
            gap: 12px;
        }

        .ddlm-field-column.ddlm-field-half-width,
        .ddlm-field-column.ddlm-field-full-width,
        .ddlm-field-column.ddlm-empty-column {
            width: 100% !important;
            max-width: 100% !important;
            flex: 1 1 auto !important;
        }
    }
}

@media (max-width: 350px) {
    .ddlm-form .ddlm-field-row {
        gap: 8px;
    }
}

@media (max-width: 480px) {
    .ddlm-form-inline {
        gap: 8px;
    }
}

/* Field Modal Styles */
.ddlm-field-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ddlm-field-modal > div {
    background: white;
    padding: 20px;
    border-radius: 8px;
    max-width: 500px;
    width: 90%;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.ddlm-field-modal h3 {
    margin-top: 0;
    margin-bottom: 20px;
    color: #333;
}

.ddlm-field-modal label {
    display: block;
    margin-bottom: 5px;
    font-weight: 500;
    color: #333;
}

.ddlm-field-modal input[type="text"] {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 14px;
    box-sizing: border-box;
}

.ddlm-field-modal select {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 14px;
    box-sizing: border-box;
    background: white;
}

.ddlm-field-modal textarea {
    width: 100% !important;
    max-width: 100% !important;
    padding: 8px 12px !important;
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    box-sizing: border-box !important;
    min-height: 80px !important;
    resize: vertical !important;
    font-family: inherit !important;
    margin: 0 !important;
    display: block !important;
}

/* Override any conflicting styles */
.ddlm-field-modal .ddlm-form-textarea {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 100% !important;
}

/* Override WordPress core and theme styles */
.ddlm-field-modal textarea,
.ddlm-field-modal .ddlm-form-textarea,
.ddlm-field-modal #edit_heading_description {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 100% !important;
    box-sizing: border-box !important;
    display: block !important;
}

.ddlm-field-modal input[type="checkbox"] {
    margin-right: 8px;
}

.ddlm-field-modal .button {
    margin-left: 10px;
}

/* Ensure the width dropdown is visible */
#edit_field_width {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    padding: 8px 12px !important;
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    background: white !important;
    color: #333 !important;
}

#edit_field_width option {
    padding: 4px 8px;
    background: white;
    color: #333;
}

/* === DDLM_EMBED_SHIELD:start (also printed in wp_footer for late cascade — keep in sync) === */
/* ========= Embedded / shortcode / popup / preview: parity with iframe preview + theme resistance ========= */
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] form.ddlm-form-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-heading,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-subheading {
    /* font-family intentionally not forced: let the site/theme style the h3 and p
       so headings use the heading font family and subheadings use the body font family. */
    font-style: normal !important;
    text-decoration: none !important;
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    letter-spacing: normal !important;
    text-transform: none !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-heading {
    color: #333 !important;
    line-height: 1.2 !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-subheading {
    color: #666 !important;
    line-height: 1.35 !important;
}

/* Beat theme resets on heading children (font-weight inherit, font-style on h3/p, etc.) */
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-heading b,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-heading strong,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-subheading b,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-subheading strong {
    font-weight: 700 !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-heading i,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-heading em,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-subheading i,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-subheading em {
    font-style: italic !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-heading u,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-subheading u {
    text-decoration: underline !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-heading,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-description {
    /* font-family intentionally not forced: let the site/theme style the h4 and p
       so headings use the heading font family and descriptions use the body font family. */
    font-style: normal !important;
    text-decoration: none !important;
    box-shadow: none !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-label,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] label.ddlm-field-label {
    display: block !important;
    font-family: inherit !important;
    font-style: normal !important;
    font-weight: 500 !important;
    color: #333 !important;
    letter-spacing: normal !important;
    text-transform: none !important;
    text-decoration: none !important;
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-field {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    clear: both !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] input.ddlm-form-input,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] textarea.ddlm-form-input,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] textarea.ddlm-textarea,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] select.ddlm-form-input,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] select.ddlm-select {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 10px 12px !important;
    border: 1px solid #e1e5e9 !important;
    border-radius: 5px !important;
    font-size: 16px !important;
    line-height: 1.4 !important;
    font-family: inherit !important;
    font-weight: 400 !important;
    font-style: normal !important;
    color: #333 !important;
    background-color: #fff !important;
    box-shadow: none !important;
    text-shadow: none !important;
    letter-spacing: normal !important;
    text-transform: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    height: auto !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] select.ddlm-form-input.ddlm-select {
    padding-right: 40px !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e") !important;
    background-position: right 12px center !important;
    background-repeat: no-repeat !important;
    background-size: 16px !important;
    background-color: #fff !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-submit-btn {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: 48px !important;
    padding: 12px 24px !important;
    margin: 0 !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 16px !important;
    line-height: 1.2 !important;
    font-family: inherit !important;
    font-weight: 500 !important;
    text-align: center !important;
    text-decoration: none !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    box-shadow: none !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--ddlm-primary-color, #007cba) !important;
    background-color: var(--ddlm-primary-color, #007cba) !important;
    color: var(--ddlm-button-text-color, #ffffff) !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-submit-btn:hover,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-submit-btn:focus {
    background: var(--ddlm-primary-color, #007cba) !important;
    background-color: var(--ddlm-primary-color, #007cba) !important;
    color: var(--ddlm-button-text-color, #ffffff) !important;
    opacity: 0.9 !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-submit {
    margin: 0 !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-checkbox-label,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-radio-label {
    display: flex !important;
    align-items: center !important;
    font-family: inherit !important;
    font-weight: 400 !important;
    color: #333 !important;
    text-decoration: none !important;
    line-height: 1.25 !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-checkbox-text,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-radio-text {
    line-height: 1.25 !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-checkbox,
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-radio {
    width: 16px !important;
    height: 16px !important;
    margin: 0 8px 0 0 !important;
    flex-shrink: 0 !important;
    /* Theme resets often strip accent-color / use appearance:none — re-assert form primary */
    accent-color: var(--ddlm-primary-color, #007cba) !important;
    -webkit-appearance: auto !important;
    appearance: auto !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-message {
    box-sizing: border-box !important;
    max-width: 100% !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] input.ddlm-form-input[type="text"],
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] input.ddlm-form-input[type="email"],
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] input.ddlm-form-input[type="tel"],
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] input.ddlm-form-input[type="number"],
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] input.ddlm-form-input[type="url"],
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] input.ddlm-form-input[type="search"],
.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] input.ddlm-form-input[type="password"] {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 10px 12px !important;
    border: 1px solid #e1e5e9 !important;
    border-radius: 5px !important;
    font-size: 16px !important;
    line-height: 1.4 !important;
    font-family: inherit !important;
    font-weight: 400 !important;
    font-style: normal !important;
    color: #333 !important;
    background-color: #fff !important;
    box-shadow: none !important;
    text-shadow: none !important;
    letter-spacing: normal !important;
    text-transform: none !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    height: auto !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-form-two-column {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: 100% !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-row {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    gap: 12px !important;
    margin-bottom: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-column {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    min-width: 0 !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-column.ddlm-field-half-width {
    flex: 1 1 0 !important;
    width: auto !important;
    max-width: calc(50% - 6px) !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-column.ddlm-field-full-width {
    flex: 1 1 100% !important;
    width: 100% !important;
    max-width: 100% !important;
}

.ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-column.ddlm-empty-column {
    flex: 1 1 0 !important;
    width: auto !important;
    max-width: calc(50% - 6px) !important;
}

/* Embedded two-column: stack only on typical phone portrait (narrow + tall). Excludes phone landscape and tablet portrait. */
@media (max-width: 540px) and (orientation: portrait) {
    .ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-row {
        flex-direction: column !important;
        flex-wrap: nowrap !important;
        gap: 12px !important;
    }

    .ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-column.ddlm-field-half-width,
    .ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-column.ddlm-field-full-width,
    .ddlm-form.ddlm-custom-form[data-ddlm-embed="1"] .ddlm-field-column.ddlm-empty-column {
        width: 100% !important;
        max-width: 100% !important;
        flex: 1 1 auto !important;
    }
}
/* === DDLM_EMBED_SHIELD:end === */
