/**
 * Indre Asada Donations - Frontend Styles
 * Brand colors and responsive design
 * High specificity overrides for WPBakery and Impreza theme conflicts
 */

/* === RESET WPBAKERY & THEME CONFLICTS === */
/* Maximum specificity selectors to force container constraints */
html body div.wpb_wrapper .iad-donation-form,
html body .vc_column_container .iad-donation-form,
html body .vc_row .iad-donation-form,
html body .wpb_column .iad-donation-form,
html body .vc_column-inner .iad-donation-form,
html body .iad-donation-form {
    /* Reset all inherited flexbox/grid properties */
    display: block !important;
    flex-direction: initial !important;
    flex-wrap: initial !important;
    align-items: initial !important;
    justify-content: initial !important;
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    flex-basis: auto !important;

    /* CRITICAL: Force container dimensions */
    width: 100% !important;
    max-width: 720px !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;

    /* Reset positioning */
    position: relative !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    z-index: auto !important;

    /* Force centering and spacing */
    margin: 40px auto !important;
    padding: 50px 40px !important;

    /* Reset typography - CENTER as base */
    font-size: 16px !important;
    line-height: 1.5 !important;
    text-align: center !important;

    /* Force box model */
    box-sizing: border-box !important;
    float: none !important;
    overflow: visible !important;
}

/* CRITICAL: Reset specific child elements to prevent extreme heights */
html body .iad-donation-form div,
html body .iad-donation-form section,
html body .iad-donation-form fieldset,
html body .iad-donation-form p,
html body .iad-donation-form label,
html body .iad-donation-form span:not(.woocommerce-Price-amount):not(.woocommerce-Price-currencySymbol) {
    box-sizing: border-box !important;
    line-height: 1.4 !important;
    min-height: 0 !important;
    max-height: none !important;
    margin-top: 0 !important;
    margin-bottom: 15px !important;
    padding-top: 0 !important;
    overflow: visible !important;
}

/* Reset specific problem elements */
html body .iad-donation-form div,
html body .iad-donation-form section,
html body .iad-donation-form fieldset,
html body .iad-donation-form p {
    height: auto !important;
    min-height: 0 !important;
    line-height: 1.5 !important;
    margin: 0 0 15px 0 !important;
}

/* Reset parent containers that might interfere */
.wpb_wrapper:has(.iad-donation-form),
.vc_column_container:has(.iad-donation-form) {
    display: block !important;
    width: 100% !important;
}

:root {
    --iad-primary: #b59365;
    --iad-background: #d9c7b0;
    --iad-secondary: #ece2d0;
    --iad-hover: #c8b399;
    --iad-text: #4e342e;
    --iad-white: #ffffff;
    --iad-border-radius: 8px;
    --iad-button-radius: 3em;
    --iad-shadow: 0 5px 15px rgba(0,0,0,0.15);
    --iad-transition: all 0.3s ease;
}

/* === DONATION FORM === */
/* High specificity selectors to override theme and page builder styles */
.wpb_wrapper .iad-donation-form,
.vc_column_container .iad-donation-form,
.vc_row .iad-donation-form,
body .iad-donation-form {
    background: var(--iad-background) !important;
    border: 1px solid var(--iad-secondary) !important;
    border-radius: 16px !important;
    padding: 50px 40px !important;
    margin: 40px auto !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
    color: var(--iad-text) !important;
    box-shadow: 0 8px 30px rgba(181, 147, 101, 0.12) !important;
    box-sizing: border-box !important;
    display: block !important;
    width: 100% !important;
    max-width: 720px !important;
    position: relative !important;
    clear: both !important;
    text-align: center !important;
}

.iad-form-title {
    margin: 0 0 25px 0;
    color: var(--iad-text);
    font-size: 28px;
    font-weight: 600;
    text-align: center;
    border-bottom: 2px solid var(--iad-primary);
    padding-bottom: 10px;
}

/* === AMOUNT SELECTION === */
/* Force maximum constraint on amount selection container */
html body div.wpb_wrapper .iad-donation-form .iad-amount-selection,
html body .vc_column_container .iad-donation-form .iad-amount-selection,
html body .vc_row .iad-donation-form .iad-amount-selection,
html body .iad-donation-form .iad-amount-selection {
    margin: 0 auto 30px auto !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: none !important;
    display: block !important;
    box-sizing: border-box !important;
    text-align: center !important;
}

/* Override WPBakery and theme grid systems */
.wpb_wrapper .iad-donation-form .iad-amount-buttons,
.vc_column_container .iad-donation-form .iad-amount-buttons,
.vc_row .iad-donation-form .iad-amount-buttons,
body .iad-donation-form .iad-amount-buttons {
    display: grid !important;
    grid-template-columns: repeat(2, 180px) !important;
    gap: 20px !important;
    margin: 0 auto 30px auto !important;
    padding: 0 !important;
    width: auto !important;
    max-width: none !important;
    justify-content: center !important;
    align-items: stretch !important;
    box-sizing: border-box !important;
}

/* Force button styling with high specificity */
.wpb_wrapper .iad-donation-form .iad-amount-button,
.vc_column_container .iad-donation-form .iad-amount-button,
.vc_row .iad-donation-form .iad-amount-button,
body .iad-donation-form .iad-amount-button {
    background: var(--iad-white) !important;
    border: 2px solid var(--iad-secondary) !important;
    border-radius: var(--iad-button-radius) !important;
    padding: 15px 20px !important;
    cursor: pointer !important;
    transition: var(--iad-transition) !important;
    text-align: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    font-size: 16px !important;
    min-height: 70px !important;
    justify-content: center !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
    float: none !important;
    position: relative !important;
    box-sizing: border-box !important;
}

.iad-amount-button:hover {
    background: var(--iad-hover);
    border-color: var(--iad-primary);
    transform: translateY(-2px);
    box-shadow: var(--iad-shadow);
}

.iad-amount-button.selected {
    background: var(--iad-primary);
    border-color: var(--iad-primary);
    color: var(--iad-white);
    font-weight: 600;
}

.iad-amount-button .amount {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.2;
}

.iad-amount-button .label {
    font-size: 12px;
    opacity: 0.8;
    margin-top: 5px;
    line-height: 1.3;
}

.iad-amount-button.selected .label {
    opacity: 1;
}

/* Custom Amount Field */
.iad-custom-amount-field {
    margin-top: 15px;
    padding: 20px;
    background: var(--iad-white);
    border-radius: var(--iad-border-radius);
    border: 1px solid var(--iad-secondary);
}

.iad-custom-amount-field label {
    display: block;
    margin-bottom: 10px;
    font-weight: 600;
    color: var(--iad-text);
}

.iad-amount-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
}

.iad-amount-input-wrapper .currency-symbol {
    position: absolute;
    left: 15px;
    top: 50%;
    transform: translateY(-50%);
    font-weight: 600;
    color: var(--iad-text);
    z-index: 2;
    pointer-events: none;
    line-height: 1;
}

.iad-amount-input-wrapper input {
    width: 100%;
    padding: 12px 15px 12px 35px;
    border: 2px solid var(--iad-secondary);
    border-radius: var(--iad-border-radius);
    font-size: 16px;
    transition: var(--iad-transition);
    background: var(--iad-white);
    line-height: 1.4;
    box-sizing: border-box;
}

.iad-amount-input-wrapper input:focus {
    outline: none;
    border-color: var(--iad-primary);
    box-shadow: 0 0 0 3px rgba(181, 147, 101, 0.1);
}

/* === ADDITIONAL FIELDS === */
/* Force proper spacing for form sections */
.wpb_wrapper .iad-donation-form .iad-additional-fields,
.vc_column_container .iad-donation-form .iad-additional-fields,
.vc_row .iad-donation-form .iad-additional-fields,
body .iad-donation-form .iad-additional-fields {
    margin: 0 auto 25px auto !important;
    padding: 0 !important;
    width: 100% !important;
    display: block !important;
    text-align: center !important;
}

.iad-field-group {
    max-width: 400px;
    margin: 0 auto 20px auto;
    text-align: left;
}

.iad-field-group label {
    display: block;
    margin-bottom: 8px;
    padding-left: 4px;
    font-weight: 600;
    color: var(--iad-text);
    text-align: left;
}

.iad-field-group input,
.iad-field-group textarea {
    width: 100%;
    padding: 12px 15px;
    border: 2px solid var(--iad-secondary);
    border-radius: var(--iad-border-radius);
    font-size: 16px;
    transition: var(--iad-transition);
    background: var(--iad-white);
    font-family: inherit;
    box-sizing: border-box;
}

.iad-field-group input:focus,
.iad-field-group textarea:focus {
    outline: none;
    border-color: var(--iad-primary);
    box-shadow: 0 0 0 3px rgba(181, 147, 101, 0.1);
}

.iad-field-group textarea {
    resize: vertical;
    min-height: 80px;
}

/* Checkboxes */
.iad-checkboxes {
    display: flex;
    flex-direction: column;
    gap: 15px;
    max-width: 380px;
    margin: 25px auto;
    text-align: left;
}

.iad-checkbox-label {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    font-size: 16px;
    line-height: 1.5;
    width: 100%;
    padding: 8px 0;
}

.iad-checkbox-label input[type="checkbox"] {
    display: none;
}

.iad-checkbox-label .checkmark {
    width: 20px;
    height: 20px;
    border: 2px solid var(--iad-secondary);
    border-radius: 4px;
    background: var(--iad-white);
    position: relative;
    transition: var(--iad-transition);
    flex-shrink: 0;
    margin-top: 2px;
}

.iad-checkbox-label .checkmark::after {
    content: '✓';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--iad-white);
    font-size: 14px;
    font-weight: bold;
    opacity: 0;
    transition: var(--iad-transition);
}

.iad-checkbox-label input[type="checkbox"]:checked + .checkmark {
    background: var(--iad-primary);
    border-color: var(--iad-primary);
}

.iad-checkbox-label input[type="checkbox"]:checked + .checkmark::after {
    opacity: 1;
}

/* === SUBMIT SECTION === */
/* Force proper button section styling */
.wpb_wrapper .iad-donation-form .iad-submit-section,
.vc_column_container .iad-donation-form .iad-submit-section,
.vc_row .iad-donation-form .iad-submit-section,
body .iad-donation-form .iad-submit-section {
    text-align: center !important;
    margin-top: 35px !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    display: block !important;
    clear: both !important;
}

/* Force donate button styling */
.wpb_wrapper .iad-donation-form .iad-donate-button,
.vc_column_container .iad-donation-form .iad-donate-button,
.vc_row .iad-donation-form .iad-donate-button,
body .iad-donation-form .iad-donate-button {
    background: var(--iad-primary) !important;
    color: var(--iad-white) !important;
    border: none !important;
    border-radius: var(--iad-button-radius) !important;
    padding: 18px 40px !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: var(--iad-transition) !important;
    min-width: 280px !important;
    margin: 0 auto 15px auto !important;
    box-shadow: 0 4px 20px rgba(181, 147, 101, 0.25) !important;
    display: inline-block !important;
    text-align: center !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
    font-family: inherit !important;
    width: auto !important;
    max-width: none !important;
    float: none !important;
    position: relative !important;
    box-sizing: border-box !important;
}

.iad-donate-button:hover:not(:disabled) {
    background: var(--iad-hover);
    transform: translateY(-2px);
    box-shadow: 0 6px 25px rgba(181, 147, 101, 0.35);
}

.iad-donate-button:disabled {
    background: #ccc;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.iad-donate-button .loading-spinner {
    font-size: 16px;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.iad-secure-notice {
    font-size: 14px;
    color: var(--iad-text);
    opacity: 0.8;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

/* === FORM MESSAGES === */
.iad-form-messages {
    margin-top: 20px;
    padding: 15px;
    border-radius: var(--iad-border-radius);
    font-size: 16px;
    font-weight: 500;
}

.iad-form-messages.success {
    background: #d4edda;
    border: 1px solid #c3e6cb;
    color: #155724;
}

.iad-form-messages.warning {
    background: #fff3cd;
    border: 1px solid #ffecb5;
    color: #856404;
}

.iad-form-messages.error {
    background: #f8d7da;
    border: 1px solid #f5c6cb;
    color: #721c24;
}

/* === PROGRESS BAR === */
.iad-donation-progress {
    margin-top: 30px;
    padding: 25px;
    background: var(--iad-white);
    border-radius: var(--iad-border-radius);
    border: 1px solid var(--iad-secondary);
}

.iad-progress-header {
    text-align: center;
    margin-bottom: 15px;
    font-size: 18px;
    font-weight: 600;
    color: var(--iad-text);
}

.iad-progress-header .current-amount {
    color: var(--iad-primary);
    font-size: 24px;
    font-weight: 700;
}

.iad-progress-header .goal-amount {
    color: var(--iad-text);
    font-weight: 700;
}

.iad-progress-bar {
    width: 100%;
    height: 12px;
    background: var(--iad-secondary);
    border-radius: 6px;
    overflow: hidden;
    margin: 15px 0;
}

.iad-progress-bar .progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--iad-primary), var(--iad-hover));
    border-radius: 6px;
    transition: width 0.6s ease-in-out;
    position: relative;
}

.iad-progress-bar .progress-fill::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(
        90deg,
        transparent,
        rgba(255,255,255,0.3),
        transparent
    );
    animation: shimmer 2s infinite;
}

@keyframes shimmer {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

.iad-progress-stats {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
    font-size: 14px;
    color: var(--iad-text);
}

.iad-progress-stats .percentage {
    font-size: 18px;
    font-weight: 700;
    color: var(--iad-primary);
}

/* === RECENT DONATIONS === */
.iad-recent-donations {
    margin-top: 30px;
    padding: 25px;
    background: var(--iad-white);
    border-radius: var(--iad-border-radius);
    border: 1px solid var(--iad-secondary);
}

.iad-recent-donations h3 {
    margin: 0 0 20px 0;
    color: var(--iad-text);
    font-size: 20px;
    text-align: center;
}

.iad-donations-list {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.iad-donation-item {
    padding: 15px;
    background: var(--iad-background);
    border-radius: var(--iad-border-radius);
    border-left: 4px solid var(--iad-primary);
}

.iad-donation-item .donor-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    font-weight: 600;
}

.iad-donation-item .donor-name {
    color: var(--iad-text);
}

.iad-donation-item .donation-amount {
    color: var(--iad-primary);
    font-weight: 700;
}

.iad-donation-item .donation-message {
    margin-bottom: 8px;
    font-style: italic;
    color: var(--iad-text);
    opacity: 0.8;
}

.iad-donation-item .donation-time {
    font-size: 12px;
    color: var(--iad-text);
    opacity: 0.6;
}

/* === THANK YOU PAGE === */
.iad-thank-you-message {
    background: var(--iad-background);
    border: 1px solid var(--iad-secondary);
    border-radius: var(--iad-border-radius);
    padding: 30px;
    margin: 20px 0;
    text-align: center;
    box-shadow: var(--iad-shadow);
}

.iad-thank-you-message h3 {
    color: var(--iad-primary);
    font-size: 28px;
    margin-bottom: 20px;
}

.donation-impact {
    margin: 25px 0;
    padding: 20px;
    background: var(--iad-white);
    border-radius: var(--iad-border-radius);
}

.donation-impact h4 {
    color: var(--iad-text);
    margin-bottom: 15px;
}

.impact-amount {
    font-size: 18px;
    color: var(--iad-text);
    margin-bottom: 15px;
}

.goal-progress-update {
    margin-top: 10px;
    padding: 10px;
    background: var(--iad-background);
    border-radius: var(--iad-border-radius);
    font-size: 14px;
}

.donation-social-sharing {
    margin-top: 25px;
}

.donation-social-sharing h4 {
    color: var(--iad-text);
    margin-bottom: 15px;
}

.social-buttons {
    display: flex;
    justify-content: center;
    gap: 15px;
    flex-wrap: wrap;
}

.social-button {
    display: inline-block;
    padding: 10px 20px;
    border-radius: var(--iad-button-radius);
    text-decoration: none;
    font-weight: 600;
    color: var(--iad-white);
    transition: var(--iad-transition);
}

.social-button.facebook {
    background: #4267B2;
}

.social-button.twitter {
    background: #1DA1F2;
}

.social-button.linkedin {
    background: #0077B5;
}

.social-button:hover {
    transform: translateY(-2px);
    box-shadow: var(--iad-shadow);
}

/* === CHECKOUT CUSTOMIZATIONS === */
.iad-donation-checkout {
    background: var(--iad-background);
    border: 1px solid var(--iad-secondary);
    border-radius: var(--iad-border-radius);
    padding: 20px;
    margin-bottom: 20px;
}

.iad-donation-notice {
    color: var(--iad-text);
    font-size: 16px;
    margin-bottom: 10px;
}

.iad-secure-notice {
    display: flex;
    align-items: center;
    color: var(--iad-text);
    font-size: 14px;
}


/* === RESPONSIVE DESIGN === */

/* Tablet */
@media (max-width: 1024px) {
    .iad-donation-form {
        padding: 25px;
    }

    .iad-amount-buttons {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .iad-form-title {
        font-size: 24px;
    }

    .social-buttons {
        flex-direction: column;
        align-items: center;
    }
}

/* Mobile */
@media (max-width: 600px) {
    .iad-donation-form {
        padding: 20px;
        margin: 10px 0;
    }

    .iad-amount-buttons {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .iad-amount-button {
        padding: 12px 15px;
        min-height: 60px;
    }

    .iad-form-title {
        font-size: 22px;
    }

    .iad-donate-button {
        width: 100%;
        padding: 15px 20px;
        font-size: 16px;
    }

    .iad-progress-stats {
        flex-direction: column;
        gap: 10px;
        text-align: center;
    }

    .iad-checkboxes {
        gap: 12px;
    }

    .iad-checkbox-label {
        font-size: 15px;
    }

    .donor-info {
        flex-direction: column;
        align-items: flex-start !important;
        gap: 5px;
    }

    .social-buttons {
        gap: 10px;
    }

    .social-button {
        width: 100%;
        max-width: 200px;
        text-align: center;
    }
}

/* Extra small mobile */
@media (max-width: 360px) {
    .iad-donation-form {
        padding: 15px;
    }

    .iad-form-title {
        font-size: 20px;
    }

    .iad-amount-button .amount {
        font-size: 16px;
    }

    .iad-amount-button .label {
        font-size: 11px;
    }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    :root {
        --iad-primary: #8b6914;
        --iad-background: #ffffff;
        --iad-secondary: #666666;
        --iad-hover: #a67c00;
        --iad-text: #000000;
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Print styles */
@media print {
    .iad-donation-form,
    .iad-recent-donations,
    .donation-social-sharing {
        box-shadow: none;
        border: 1px solid #ccc;
    }

    .iad-donate-button,
    .social-buttons {
        display: none;
    }
}