/* Done Digital Lead Machine Forms Styles */

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

/* Override any theme form styling */
.ddlm-form {
    all: unset;
    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;
}

/* 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: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
    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;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    border-radius: 0 !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 */
.ddlm-form-heading {
    margin: 0;
    color: #333;
    font-size: 24px;
    font-weight: 600;
    line-height: 1.1;
}

/* 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.1;
}

/* 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;
}

.ddlm-form-submit {
    margin-top: 8px;
}

.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 {
        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 {
        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 */

/* Two-Column Layout */
.ddlm-form-two-column {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.ddlm-field-row {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
}

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

.ddlm-field-column.ddlm-field-half-width {
    flex: 1;
    width: calc(50% - 6px);
}

.ddlm-field-column.ddlm-field-full-width {
    flex: 1 1 100%;
    width: 100%;
}

.ddlm-field-column.ddlm-empty-column {
    flex: 1;
    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) {
        flex-direction: column;
        align-items: stretch;
        
        .ddlm-form-field {
            min-width: auto;
        }
        
        .ddlm-form-submit {
            margin-top: 8px;
        }
    }
}

/* Two-column layout breakpoint - stack only when form width is below 400px */
@media (max-width: 400px) {
    .ddlm-field-row {
        flex-direction: column;
        gap: 16px;
    }
    
    .ddlm-field-column.ddlm-field-half-width,
    .ddlm-field-column.ddlm-field-full-width {
        width: 100%;
    }
}

/* Additional breakpoint for very narrow forms */
@media (max-width: 350px) {
    .ddlm-field-row {
        gap: 8px;
    }
}

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

@media (max-width: 400px) {
    .ddlm-field-row {
        gap: 12px;
    }
}

/* Ensure two-column layout works at normal screen sizes */
@media (min-width: 401px) {
    .ddlm-field-row {
        display: flex;
        gap: 12px;
    }
    
    .ddlm-field-column.ddlm-field-half-width {
        flex: 1;
        width: calc(50% - 6px);
    }
    
    .ddlm-field-column.ddlm-field-full-width {
        flex: 1 1 100%;
        width: 100%;
    }
}

/* 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;
} 