/* Overall form layout */
.sos-donations-form {
    max-width: 960px;
    margin: 0 auto;
    padding: 2rem 1.5rem;
}

.sos-donations-field-group {
    margin-bottom: 2rem;
}

.sos-donations-field-title {
    margin-bottom: 0.75rem;
    font-weight: 600;
}

/* Rows & columns (structure / positioning) */
.sos-donations-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 2rem;
}

.sos-donations-row-between {
    justify-content: space-between;
}

.sos-donations-col {
    flex: 1 1 0;
    min-width: 220px;
}

.sos-donations-col-2 {
    flex: 1 1 260px;
}

.sos-donations-col-other-amount {
    max-width: 260px;
}

/* Labels that wrap fields (structure only) */
.sos-donations-field-label {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

/* Other amount wrapper (for € alignment; not styling the input itself) */
.sos-donations-other-amount {
    display: inline-flex;
    align-items: center;
    position: relative;
}

.sos-donations-other-amount input::-webkit-outer-spin-button,
.sos-donations-other-amount input::-webkit-inner-spin-button {
    -webkit-appearance: none;
}
.sos-donations-other-amount input[type=number] {
    -moz-appearance:textfield;
}

.sos-donations-other-amount-currency {
    white-space: nowrap;
    position: absolute;
    right: 10px;
}

/* Radio groups */
.sos-donations-radio-group {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
}

.sos-donations-radio-option {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

/* Radio buttons look */
.sos-donations-radio-option input[type="radio"] {
    width: 16px;
    height: 16px;
}

/* Amount buttons (radio + label combo) */
.sos-donations-amount-options {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.sos-donations-amount-option {
    position: relative;
    display: inline-flex;
    align-items: center;
}

/* Hide native radio, keep it accessible */
.sos-donations-amount-option input[type="radio"] {
    position: absolute;
    opacity: 0;
}

/* Visual amount block */
.sos-donations-amount-option span {
    display: inline-block;
    padding: 0 1.75rem;
    border-radius: 4px;
    border: 1px solid #ddd;
    cursor: pointer;
    line-height: var(--inputs-height, 2em);
}

/* Selected amount */
.sos-donations-amount-option input[type="radio"]:checked + span {
    border-color: #83ac8c;
    background: #83ac8c;
    color: #fff;
}

/* Checkboxes (structure only) */
.sos-donations-consents .sos-donations-checkbox {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.sos-donations-consents .sos-donations-checkbox input[type="checkbox"] {
    margin-top: 3px;
}

/* Submit button */
.sos-donations-submit-group {
    text-align: left;
}

.sos-donations-submit {
    padding: 0.9rem 2.5rem;
    border: none;
    cursor: pointer;
    font-weight: 600;
    text-transform: uppercase;
    background: #83ac8c;
    color: #fff;
}

/* Note */
.sos-donations-note {
    font-size: 0.85rem;
    opacity: 0.8;
}

.sos-donations-messages {
    margin: 15px 0;
}
.sos-donations-messages--error {
    color: #ad0000;
}
.sos-donations-messages--success {
    color: #008652;
}

.sos-donations-radio-option span {
    display: flex;
    gap: 10px 5px;
    align-items: center;
}

.sos-donations-payment-logo-stripe {
    width: 35px;
    max-height: 35px;
}
.sos-donations-payment-logo-stripe img {
    width: 100%;
}
.sos-donations-payment-logo-montonio {
    width: 60px;
    max-height: 35px;
}
.sos-donations-payment-logo-montonio img {
    width: 100%;
}
/* Responsive */
@media (max-width: 600px) {
    .sos-donations-form {
        padding: 1.5rem 1rem;
    }
}
