/* Match form-control-lg height */
.select2-container--default .select2-selection--single {
    height: 40px !important;
    min-height: 45px !important;
    border: 1px solid #d9dee3 !important;
    border-radius: 0.375rem !important;
}

.select2-container--default
    .select2-selection--single
    .select2-selection__rendered {
    line-height: 48px !important;
    padding-left: 12px !important;
}

.select2-container--default
    .select2-selection--single
    .select2-selection__arrow {
    height: 48px !important;
    right: 8px !important;
}

/* Focus state similar to Vuexy */
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
    border-color: #696cff !important;
}

/* Full width */
.select2-container {
    width: 100% !important;
    max-width: 100%;
}

/* Long option labels stay inside the dropdown panel */
.select2-results__option {
    white-space: normal;
    overflow-wrap: anywhere;
}

.logo-box img {
    height: 35px;
    width: auto;
    max-width: 90%;
    display: block;
    object-fit: contain;
}
.logo-footer img{
height: 45px;
}
.section-header {
    background: linear-gradient(90deg, #c1123f 0%, #213f9a 100%);
    color: #fff;
    font-weight: 700;
    padding: 14px 20px;
    border-radius: 8px;
    letter-spacing: 0.4px;
    font-size: 16px;
}

.form-label {
    margin-bottom: 6px;
}

.card {
    border-radius: 12px;
}

.form-control,
.form-select {
    min-height: 46px;
}

.input-group-text {
    font-weight: 600;
}

@media (max-width: 768px) {
    .card-body {
        padding: 1rem !important;
    }

    .section-header {
        font-size: 14px;
        padding: 12px 15px;
    }

    h2 {
        font-size: 1.3rem;
    }
}

.photo-box {
   border: 1.5px solid #444;
    width: 38mm;
    min-height: 45mm;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    padding: 6px 4px 5px;
    background: #fafafa;
}

.photo-placeholder {
      font-size: 7px;
    color: #bbb;
    text-align: center;
    line-height: 1.4;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}

.photo-sign-area {
font-size: 8px;
    font-weight: 700;
    color: #333;
    text-align: center;
    border-top: 1px solid #ccc;
    width: 100%;
    padding-top: 4px;
    line-height: 1.3;
    word-break: break-word;
}

@media (max-width: 768px) {
    .photo-box {
        width: 100%;
        max-width: 140px;
        margin: auto;
    }
}

#applicationForm .invalid-feedback:empty,
#applicationForm .fv-plugins-message-container:empty {
    display: none !important;
}

/* Vuexy inline validation */
#applicationForm .is-invalid ~ .invalid-feedback,
#applicationForm .is-invalid ~ .err,
#applicationForm .was-validated .form-control:invalid ~ .invalid-feedback {
    display: block;
}

#applicationForm .err {
    display: none;
    width: 100%;
    margin-top: 0.25rem;
    font-size: 0.875em;
    color: var(--bs-form-invalid-color, #ff3e1d);
}

#applicationForm .err.d-block,
#applicationForm .err[style*="display: block"],
#applicationForm .err[style*="display:block"] {
    display: block !important;
}

#applicationForm .select2-container.is-invalid .select2-selection {
    border-color: var(--bs-form-invalid-border-color, #ff3e1d) !important;
}

#applicationForm .form-control.is-invalid,
#applicationForm .form-select.is-invalid {
    border-color: var(--bs-form-invalid-border-color, #ff3e1d) !important;
}

#applicationForm .select2-container.is-valid .select2-selection {
    border-color: var(--bs-form-valid-border-color, #71dd37) !important;
    border-width: 2px !important;
}

/* Use only the static .invalid-feedback below each input — hide FV duplicate */
#applicationForm .fv-plugins-message-container {
    display: none !important;
}

.section-header-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.removeBorrower {
    flex-shrink: 0;
}
.section-header .removeBorrower {
    background: rgba(255, 255, 255, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
}

.section-header .removeBorrower:hover {
    background: rgba(255, 255, 255, 0.28);
    color: #fff;
}

.decl-box {
    padding: 14px 16px;
    color: #333;
    border-radius: 3px;
    line-height: 1.6;
}

.signature-box {
flex: 0 0 175px;
    width: 175px;
    border: 1px solid #444;
    height: 105px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 8px;
    background: #fafafa;
    page-break-inside: avoid;
}

.signature-placeholder {
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #8592a3;
    font-size: 13px;
    border-bottom: 2px solid #d9dee3;
}


.signature-name {
   font-size: 7.5px;
    font-weight: 700;
    color: #333;
    border-top: 1px dashed #888;
    padding-top: 4px;
    text-align: center;
    line-height: 1.35;
    margin-top: auto;
    word-break: break-word;
}

.sig-box .signature-placeholder {
    height: 200px;
}


  .sig-entity-name {
        font-size: 9px;
        font-weight: 800;
        color: #1e448e;
        text-align: center;
        text-transform: uppercase;
        line-height: 1.3;
        word-break: break-word;
      }


      .applicant-date .form-control {
        width: 180px;
      }


      #applicationForm .is-invalid ~ .invalid-feedback,
#applicationForm .is-invalid ~ .err,
#applicationForm .was-validated .form-control:invalid ~ .invalid-feedback {
display: block;
}

#applicationForm .err {
display: none;
width: 100%;
margin-top: 0.25rem;
font-size: 0.875em;
color: var(--bs-form-invalid-color, #FF3E1D);
}

#applicationForm .err.d-block,
#applicationForm .err[style*="display: block"],
#applicationForm .err[style*="display:block"] {
display: block !important;
}

#applicationForm .select2-container.is-invalid .select2-selection {
border-color: var(--bs-form-invalid-border-color, #FF3E1D) !important;
border-width: 2px !important;
}

#applicationForm .select2-container.is-valid .select2-selection {
border-color: var(--bs-form-valid-border-color, #71DD37) !important;
}

/* Use only the static .invalid-feedback below each input — hide FV duplicate */
#applicationForm .fv-plugins-message-container {
display: none !important;
}

.val-disabled-bar {
    display: none;
    background: #fff3cd;
    color: #664d03;
    border: 1px solid #ffc107;
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 1.25rem;
    font-weight: 600;
    text-align: center;
    letter-spacing: 0.3px;
}

.val-disabled-bar.show {
    display: block;
    position: sticky;
    top: 0;
    z-index: 1050;
    margin: 0 0 1rem;
    border-radius: 0;
    border-left: none;
    border-right: none;
}

/* When validation is disabled (Ctrl+Alt+V) hide all error styling */
body.validation-off #applicationForm .form-control.is-invalid,
body.validation-off #applicationForm .form-control.is-valid,
body.validation-off #applicationForm .form-select.is-invalid,
body.validation-off #applicationForm .form-select.is-valid {
    border-color: #d9dee3 !important;
    background-image: none !important;
    box-shadow: none !important;
    padding-right: 0.9375rem !important;
}

body.validation-off #applicationForm .select2-container.is-invalid .select2-selection,
body.validation-off #applicationForm .select2-container.is-valid .select2-selection {
    border-color: #d9dee3 !important;
}

body.validation-off #applicationForm .invalid-feedback,
body.validation-off #applicationForm .err {
    display: none !important;
}

body.validation-off #applicationForm .invalid-wrap,
body.validation-off #applicationForm .valid-wrap {
    border-color: inherit !important;
}

.reset-icon {
    width: 90px;
    height: 90px;
    margin: 0 auto;
    border-radius: 50%;
    background: rgba(255, 159, 67, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
}

.reset-icon i {
    font-size: 3.5rem;
    color: #ff9f43;
}

#resetModal .modal-content {
    animation: modalPop .25s ease;
}

@keyframes modalPop {
    from {
        opacity: 0;
        transform: scale(.9);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

.sig-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
    align-items: flex-start
}


.sig-box {
    flex: 0 0 175px;
    width: 175px;
    border: 1px solid #444;
    height: 105px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 8px;
    background: #fafafa;
    page-break-inside: avoid
}


@media(max-width:820px) {

    .sig-box {
        flex: 0 0 150px;
        width: 150px;
        height: 90px
    }
}



@media print {
    body {
        background: #fff;
        padding: 0
    }

    .no-print {
        display: none !important
    }

    .draft-bar,
    .val-disabled-bar {
        display: none !important
    }

    .container {
        box-shadow: none;
        padding: 0;
        width: 100%;
        max-width: 210mm
    }

    .sig-row,
    .sig-box {
        page-break-inside: avoid
    }

    .collapsible-body.collapsed {
        max-height: none !important;
        overflow: visible !important
    }
}
