:root{
    --srl_diagonal_radius: 4px;
    --bodyfont : 'Titillium Web', sans-serif;
    --headerfont: 'Titillium Web', sans-serif;
    --border-radius-small: 3px;
}
.srl_form {
    font-family: var(--bodyfont);
    max-width: 100%;
    margin: 0px;
    position: relative;
    padding: 0px 0px;
}

.srl_form .srl_form_fields {
    display: flex;
    flex-direction: column;
    gap: 20px;
    max-width: 600px;
}

.srl_form .srl_form_fields .srl_form_field {
    display: flex;
    flex-direction: column;
    gap: 8px;
    position: relative;
    align-items: flex-start;
    max-width: 750px;
}

.srl_form .srl_form_fields .srl_form_field .srl_form_field_message {
    font-size: 14px;
    color: #666;
    font-family: var(--bodyfont);
    line-height: 1.4;
    position: absolute;
    right: 0;
    top: -12px;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    padding: 0px 14px;
}

.srl_form .srl_form_fields .srl_form_field .srl_form_field_el {
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%;
    border-radius: 4px;
    overflow: visible;
    align-items: stretch;
}

.srl_form .srl_form_fields .srl_form_field .srl_form_field_error_indicator {
    color: #d32f2f;
    font-size: 14px;
    font-weight: 600;
    position: absolute;
    bottom: 6px;
    height: 4px;
    width: calc(100% - 40px);
    background-color: #d32f2f;
    left: 20px;
    border-radius: 0;
    /* background-color: #e5e5f7; */
    /* background-size: 10px 10px; */
    /* background-image: repeating-linear-gradient(45deg, #d32f2f 0, #d32f2f 3px, white 0, white 50%); */
}

.srl_form .srl_form_fields .srl_form_field .srl_form_field_error {
    background-color: #ffebee;
    background-color: #b93f3f;
    padding: 5px 8px;
    border-radius: 0p;
    font-size: 14px;
    /* border-left: 5px solid #d32f2f; */
    border-radius: 2px!important;
    color: white;
    font-weight: 700;
}

.srl_form .srl_form_fields .srl_form_field .srl_form_field_input {
    padding: 13px 13px;
    border: 1px solid #D3DDDE;
    border-radius: var(--border-radius-small)!important;
    font-family: var(--bodyfont);
    font-size: 16px;
    transition: all 0.3s ease;
    background-color: #fff;
    width: 100%;
}
.srl_form_field_el select::placeholder,
.srl_form .srl_form_fields .srl_form_field .srl_form_field_input::placeholder{
    color: var(--text);
    font-size: 17px;
}

.srl_form .srl_form_fields .srl_form_field .srl_form_field_input:focus {
    outline: none;
    border-color: var(--secondary);
    box-shadow: var(--shadow-md);
}

.srl_form .srl_form_fields .srl_form_field .srl_btn.srl_btn_primary {
    background-color: var(--secondary);
    color: #FFFFFF;
    padding: 11px 20px;
    border: none;
    border-radius: var(--srl_diagonal_radius);
    font-family: var(--headerfont);
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: var(--shadow-md);
    margin: 0px;
}

.srl_form .srl_form_fields .srl_form_field .srl_btn.srl_btn_primary:hover {
    transform: translateY(-2px);
    box-shadow: rgba(0, 0, 0, 0.15) 0px 6px 20px;
}

.srl_form .srl_form_fields .srl_form_field .srl_btn.srl_btn_primary:active {
    transform: translateY(0px);
    box-shadow: var(--shadow-md);
}

.srl_form .srl_form_fields .srl_form_field .srl_btn.srl_btn_primary:focus {
    outline: 3px solid rgba(0, 0, 0, 0.1);
    outline-offset: 2px;
}

.srl_form .srl_form_fields .srl_form_field .srl_btn.srl_btn_primary span {
    display: inline-block;
}

.srl_form .srl_form_field_loader {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    position: absolute;
    left: 0px;
    top: 0px;
    width: 100%;
    height: 100%;
    background-color: var(--secondary);
}

.srl_form .srl_form_field_loader .srl_form_field_spinner {
    width: 34px;
    height: 34px;
    border: 6px solid #D3DDDE;
    border-top-color: var(--primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

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

.srl_form .srl_form_field_loader p {
    font-family: var(--headerfont);
    font-size: 30px;
    color: white;
    margin: 0;
}

.srl_form_field_submit{
    position: relative;
}
.srl_form_field_submit,
.srl_form_field_submit > button{
    width: 218px;
    border-radius: var(--border-radius-small)!important;
    /* font-size: 24px!important; */
}


/* modal fields */
.srl_form_field_modal {
    position: fixed;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    background-color: #171717a8;
    z-index: 999999999999999999999999999999!important;
}
.srl_form_field_modal .srl_form_field_modal_content {
    width: 350px;
    height: 350px;
    background-color: #ffffff;
    border-radius: 12px;
    padding: 20px;
}
.srl_form_field_modal_content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 20px;
    text-align: center;
}

.srl_form_field_modal_content .srl_sent_confirmation_img {
    width: 100px;
    height: 100px;
}

.srl_form_field_modal_content .srl_sent_confirmation_img img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.srl_form_field_modal_content .srl_sent_confirmation_content {
    display: flex;
    flex-direction: column;
    gap: 15px;
    align-items: center;
}

.srl_form_field_modal_content .srl_sent_confirmation_content .srl_btn.srl_btn_primary.srl_form_field_modal_close {
    background-color: var(--primary);
    color: #FFFFFF;
    padding: 11px 30px;
    border: none;
    border-radius: var(--srl_diagonal_radius);
    font-family: var(--headerfont);
    font-size: 18px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: var(--shadow-md);
}

.srl_form_field_modal_content .srl_sent_confirmation_content .srl_btn.srl_btn_primary.srl_form_field_modal_close span {
    display: inline-block;
}

.srl_consent {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 15px 0;
}

.srl_consent #srl_consent_checkbox {
    margin-top: 4px;
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: var(--primary);
}

.srl_consent .srl_text.srl_txt_light {
    font-size: 14px;
    line-height: 1.6;
    color: #333333;
    font-family: var(--bodyfont);
}

.srl_consent .srl_text.srl_txt_light .srl_text.srl_txt_primary {
    color: var(--accent);
    text-decoration: underline;
    cursor: pointer;
    transition: all 0.3s ease;
}

.srl_consent .srl_text.srl_txt_light .srl_text.srl_txt_primary:hover {
    color: var(--secondary);
    text-decoration: none;
}

.srl_consent .srl_text.srl_txt_light .srl_text.srl_txt_primary:active {
    transform: translateY(1px);
}

.srl_consent .srl_text.srl_txt_light .srl_text.srl_txt_primary:focus {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
    border-radius: 2px;
}

#srl_contactform .srl_consent .srl_text.srl_txt_light {
    color: #ffffff;
}

.srl_section_header {
    color: var(--primary);
    font-size: 14px;
    font-weight: 600;
    font-family: var(--bodyfont);
    width: 100%;
}

.srl_form_submit_note {
    font-size: 13px;
    color: #777777;
    font-family: var(--bodyfont);
    margin: 0;
    font-style: italic;
}



/* Ninja Forms styles */

.nf-form-layout {
    font-family: var(--bodyfont);
}

/* Custom element display fixes */
.nf-form-layout nf-rows-wrap {
    display: flex;
    flex-direction: column;
    gap: 0px;
}

.nf-form-layout nf-row {
    display: block;
}

.nf-form-layout nf-cells {
    display: flex;
    flex-direction: row;
    gap: 20px;
    align-items: flex-start;
}

.nf-form-layout nf-fields,
.nf-form-layout nf-field,
.nf-form-layout nf-section {
    display: block;
}

/* Cell sizing */
.nf-form-layout .nf-cell {
    box-sizing: border-box;
    min-width: 0;
}

/* Field wrap: label above input */
.nf-form-layout .field-wrap {
    display: flex;
    flex-direction: column;
    gap: 0px;
}

/* Label */
.nf-form-layout .nf-field-label label {
    font-family: var(--bodyfont);
    font-size: 16px;
    font-weight: 600;
    color: var(--gcid-body-color);
    line-height: 1.4;
}

/* Required symbol */
.nf-form-layout .ninja-forms-req-symbol {
    color: #d32f2f;
}

/* Text inputs and textarea */
.nf-form-layout input.ninja-forms-field:not([type="submit"]):not([type="checkbox"]):not([type="file"]),
.nf-form-layout textarea.ninja-forms-field {
    padding: 17px 20px;
    border-radius: var(--border-radius-small, 3px) !important;
    font-family: var(--bodyfont);
    font-size: 16px;
    transition: all 0.3s ease;
    background-color: #fff;
    width: 100%;
    box-sizing: border-box;
    border: 2px solid var(--gcid-xrsi82aml5);
}

.nf-form-layout input.ninja-forms-field:not([type="submit"]):not([type="checkbox"])::placeholder,
.nf-form-layout textarea.ninja-forms-field::placeholder {
    color: var(--text);
    font-size: 17px;
}

.nf-form-layout input.ninja-forms-field:not([type="submit"]):not([type="checkbox"]):not([type="file"]):focus,
.nf-form-layout textarea.ninja-forms-field:focus {
    outline: none;
    border-color: var(--secondary);
    box-shadow: var(--shadow-md);
}

/* Submit button */
.nf-form-layout input[type="submit"].ninja-forms-field {
    background-color: var(--secondary);
    color: #ffffff;
    padding: 7px 20px;
    border: none;
    border-radius: var(--srl_diagonal_radius, 4px);
    font-family: var(--headerfont);
    font-size: 18px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: var(--shadow-md);
    margin: 0;
}

.nf-form-layout input[type="submit"].ninja-forms-field:hover {
    transform: translateY(-2px);
    box-shadow: rgba(0, 0, 0, 0.15) 0px 6px 20px;
}

.nf-form-layout input[type="submit"].ninja-forms-field:active {
    transform: translateY(0px);
    box-shadow: var(--shadow-md);
}

.nf-form-layout input[type="submit"].ninja-forms-field:focus {
    outline: 3px solid rgba(0, 0, 0, 0.1);
    outline-offset: 2px;
}

/* File upload button */
.nf-form-layout .nf-fu-fileinput-button {
    background-color: var(--secondary);
    color: #ffffff;
    padding: 11px 30px;
    border: none;
    border-radius: var(--srl_diagonal_radius, 4px);
    font-family: var(--headerfont);
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: var(--shadow-md);
    margin: 0;
}

.nf-form-layout .nf-fu-fileinput-button:hover {
    transform: translateY(-2px);
    box-shadow: rgba(0, 0, 0, 0.15) 0px 6px 20px;
}

.nf-form-layout .nf-fu-fileinput-button:active {
    transform: translateY(0px);
    box-shadow: var(--shadow-md);
}

/* File cancel button */
.nf-form-layout .nf-fu-button-cancel {
    background: none;
    border: 1px solid #ccc;
    color: #666;
    padding: 6px 12px;
    border-radius: var(--border-radius-small, 3px);
    font-family: var(--bodyfont);
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s ease;
}

/* Checkbox field: reorder so input appears left, label right */
.nf-form-layout .checkbox-wrap {
    flex-direction: row;
    align-items: flex-start;
    gap: 12px;
    /* padding: 15px 0; */
}

.nf-form-layout .checkbox-wrap .nf-field-element {
    order: 1;
    flex-shrink: 0;
}

.nf-form-layout .checkbox-wrap .nf-field-label {
    order: 2;
}

.nf-form-layout input[type="checkbox"].ninja-forms-field {
    margin-top: 4px;
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: var(--primary);
}

/* Error messages */
.nf-form-layout .nf-error-wrap.nf-error:not(:empty) {
    background-color: var(--secondary);
    padding: 5px 8px;
    border-radius: 2px !important;
    font-size: 14px;
    color: white;
    font-weight: 700;
}
.nf-form-layout .nf-error-wrap.nf-error:not(:empty) > *{
    color: white;
}

/* "Required fields" notice */
.nf-form-layout .nf-form-fields-required {
    font-family: var(--bodyfont);
    font-size: 14px;
    color: #666;
    margin-bottom: 10px;
    display: none;
}


.nf-field-label > label > a{
    color: var(--secondary)!important;
}
div.field-wrap > div.nf-field-label > label::after {
    background-color: white!important;
    width: 25px!important;
    height: 25px!important;
    left: -30px!important;
    top: 0px!important;
}
.checkbox-container.label-right label:before {
    left: -29px!important;
    top: -4px!important;
}