﻿:root {
    /* Brand primary */
    --bs-primary: #2b2b2b !important; /*#1B1B6F;*/
    --bs-primary-rgb: 38, 38, 255;
    /* Bootstrap reboot link tokens (the important part) */
    --bs-link-color-rgb: 38, 38, 255;
    --bs-link-hover-color-rgb: 38, 38, 111;
    --bs-link-opacity: 1;
    --bs-border-color: rgba(255, 255, 255, 0.2);
}

@font-face {
    font-family: 'circular-std-book';
    src: url('../content/fonts/circular/circularstd-book 1 1.otf') format('truetype');
}

@font-face {
    font-family: 'circular-std-bold';
    src: url('../content/fonts/circular/CircularStd-Bold 1 1.otf') format('truetype');
}

@font-face {
    font-family: 'circular-std-black';
    src: url('../content/fonts/circular/CircularStd-Black 1 1.otf') format('truetype');
}

@font-face {
    font-family: 'circular-std-medium';
    src: url('../content/fonts/circular/CircularStd-Medium 1 1.otf') format('truetype');
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'circular-std-book', Arial, sans-serif;
}

body {
    background-image: url('/content/images/mrrk_pattern_2_rgb_25052.png');
    background-repeat: no-repeat;
    background-size: cover;
    /*background-position: center top;*/
    background-position: 25% 75%;
    background-attachment: fixed;
}

.environment-stripe {
    position: fixed;
    height: 22px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    text-transform: uppercase;
    color: white;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    isolation: isolate;
}

body {
    position: relative; /* required for overlay layering */
}

    /* bottom fade overlay */
    body::after {
        content: "";
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        height: 281px;
        pointer-events: none;
        z-index: 0;
        background: linear-gradient(to bottom, rgba(21, 13, 80, 0) 0%, rgba(21, 13, 80, 1) 45%, rgba(21, 13, 80, 1) 80%);
    }

.top-bar::after {
    content: "";
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    height: 281px;
    pointer-events: none;
    z-index: -1;
    background: linear-gradient(180deg, rgb(21, 13, 80, 1) 21%, rgba(21, 13, 80, 0) 59%);
}

header,
main,
footer {
    position: relative;
    z-index: 1000;
}

header {
    height: 100px;
}

.footer .container {
    padding-top: 10px;
    padding-bottom: 10px;
}

.entryLargeText sup {
    font-size: 25px;
}

.bigBorder {
    background: #fff;
    padding: 32px 55px;
    border-radius: 12px;
    max-width: 775px;
    margin: auto;
    color: #2B2B2B;
}

.getStartedText {
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-size: 32px;
    line-height: 40px;
    color: #150d50;
    margin-bottom: 10px;
}

.getStartedTextTwo {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 18px;
    line-height: 26px;
    margin-bottom: 20px;
}

.getStartedTextThree {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 16px;
    line-height: 26px;
    margin-bottom: 15px;
}

.numberRequiredText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 12px;
    line-height: 18px;
    color: #777
}

.paperlessOptInText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 18px;
    line-height: 26px;
    color: #000;
}

.paperlessEnrollText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 12px;
    line-height: 18px;
}

#allPhoneFieldsMessage {
    color: #DA1222;
    font-size: 12px;
}

#allDobFieldsMessage {
    color: #DA1222;
    font-size: 12px;
    font-weight: unset;
}

.reviewLink:link {
    color: #2626FF;
}

.reviewLink:visited {
    color: #2626FF;
}

.reviewLink {
    color: #2626FF;
    font-weight: 450;
    font-size: 14px;
    line-height: 22px;
    text-align: right;
    text-decoration: underline;
    text-decoration-style: solid;
    text-decoration-thickness: 10%;
    cursor: pointer;
}
/*#ssn-error {
    color: #DA1222;
    font-size: 12px;
    font-weight: 700;
    position: relative;
    top: -8px;
}*/
.errorMessageInputs {
    font-family: 'circular-std-book', Arial, sans-serif;
    color: #DA1222;
    font-size: 12px;
}

#phoneInputRow {
    margin-bottom: 10px;
}

.containerCardReview {
    background-color: #FFF6EF;
    /*   background-color: #bda28d;*/
    border-radius: 8px;
    width: 100%;
    padding: 32px 24px;
    position: relative;
    margin-bottom: 16px;
}

#containerPrescreen {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
}

.fieldContainerPreview {
    margin: auto;
    width: 80px;
    position: relative;
    top: 10px;
}

.cardPreview1, .cardPreview2, .cardPreview3, .cardPreview4, .cardPreview5 {
    display: inline-flex;
    height: 133px;
}

.cardPreviewSelectedText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 12px;
    line-height: 18px;
}

.cardPreviewSelectedLeft {
    width: 20%;
    float: left;
}

.cardPreviewSelectedName {
    margin-bottom: 5px;
}


.review-profile-card {
    max-width: 820px;
    background: #fff6ef;
    border-radius: 14px;
    padding: 28px 32px;
    font-family: system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    color: #1f2937;
}

.review-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
}

    .review-card-header h3 {
        margin: 0;
        font-size: 13px;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        color: #6b7280;
    }

.edit-link {
    font-size: 14px;
    color: #2563eb;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 6px;
}

.card-body {
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.reviewField label {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 12px;
    color: #2B2B2B;
    line-height: 18px;
}

.reviewField .reviewValue {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 16px;
    line-height: 24px;
    color: #2B2B2B;
}

.reviewField .valueFullName {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 22px;
    line-height: 34px;
    color: #2B2B2B;
}

.review-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px 48px;
}

@media (max-width: 640px) {
    .review-grid-2 {
        grid-template-columns: 1fr;
        gap: 20px;
    }
}




/*Paperless opt in radio set -------------------------------------------------*/
.radioPaperlessGroup {
    display: flex;
    width: 100%;
    gap: 24px;
    /* justify-content: space-between;*/
}

.radioPaperless {
    flex: 1;
    position: relative;
    cursor: pointer;
}

    .radioPaperless input {
        position: absolute;
        opacity: 0;
        pointer-events: none;
    }

.paperlessContent {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 11px;
    /*min-width: 260px;*/
    border-radius: 4px;
    border: 1px solid #ccc;
    background: #ffffff;
    font-size: 15px;
    font-weight: 500;
    color: #1c1c1c;
    transition: all 0.2s ease;
    height: 44px;
}

/* Check icon (hidden by default) */
.paperlessCheck {
    display: none;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: #ffffff;
    color: #1b0f4b;
    font-size: 14px;
    font-weight: bold;
    align-items: center;
    justify-content: center;
}

/* Checked state */
.radioPaperless input:checked + .paperlessContent {
    background: #150D50;
    border-color: #150D50;
    color: #ffffff;
}

    .radioPaperless input:checked + .paperlessContent .paperlessCheck {
        display: inline-flex;
    }

/* Hover */
.radioPaperless:hover .paperlessContent {
    border-color: #140b3f;
}

/* Keyboard focus */
.radioPaperless input:focus-visible + .paperlessContent {
    outline: 2px solid #6b5cff;
    outline-offset: 2px;
}

.paperlessRadioText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 100;
    font-size: 14px;
    line-height: 22px;
    vertical-align: middle;
}

.PPPEligibilityLink {
    text-decoration: underline;
    cursor: pointer;
    color: #2626FF !important;
}

@media (max-width: 768px) {
    .radioPaperlessGroup {
        flex-direction: column;
        gap: 16px;
    }

    .paperlessContent {
        width: 100%;
        min-width: unset;
        font-family: 'circular-std-bold', Arial, sans-serif;
        font-weight: 700;
        font-size: 14px;
        line-height: 22px;
        vertical-align: middle;
    }

    .container, .container-md, .container-sm {
        max-width: unset;
    }
}

/*--Payment-Protection-Radio-Set---------------------------*/

.radioPaymentGroup {
    /*display: flex;*/
    width: 100%;
    /*gap: 24px;*/
    /* justify-content: space-between;*/
}

.radioPayment {
    flex: 1;
    position: relative;
    cursor: pointer;
    width: 100%;
}

.paymentYesBold {
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-size: 14px;
    line-height: 16px;
    vertical-align: middle;
}

.paymentRadioTextYes {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 13px;
    line-height: 16px;
    vertical-align: middle;
    position: relative;
    right: 8px;
}

.paymentCheckX {
    position: absolute;
    top: 10px;
}

.paymentRadioTextYesAll {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 13px;
    line-height: 16px;
    vertical-align: middle;
    position: absolute;
    top: 12px;
    left: 41px;
    padding-right: 40px;
}

.paymentRadioText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
    vertical-align: middle;
}

.radioPayment input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.paymentContent {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 11px;
    /*min-width: 260px;*/
    border-radius: 4px;
    border: 1px solid #ccc;
    background: #ffffff;
    font-size: 15px;
    font-weight: 500;
    color: #1c1c1c;
    transition: all 0.2s ease;
    height: 44px;
}

#paymentContentYes {
    height: 100px;
}

/* Check icon (hidden by default) */
.paymentCheck {
    display: none;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: #ffffff;
    color: #1b0f4b;
    font-size: 14px;
    font-weight: bold;
    align-items: center;
    justify-content: center;
}

/* Checked state */
.radioPayment input:checked + .paymentContent {
    background: #150D50;
    border-color: #150D50;
    color: #ffffff;
}

    .radioPayment input:checked + .paymentContent .paymentCheck {
        display: inline-flex;
    }

/* Hover */
.radioPayment:hover .paymentContent {
    border-color: #140b3f;
}

/* Keyboard focus */
.radioPayment input:focus-visible + .paymentContent {
    outline: 2px solid #6b5cff;
    outline-offset: 2px;
}

@media (max-width: 992px) {
    #paymentContentYes {
        height: 130px;
    }
}

@media (max-width: 768px) {

    #paymentContentYes {
        height: 116px;
    }

    .radioPaymentGroup {
        flex-direction: column;
        gap: 16px;
    }

    .paymentContent {
        width: 100%;
        min-width: unset;
        font-family: 'circular-std-bold', Arial, sans-serif;
        font-size: 14px;
        line-height: 22px;
        vertical-align: middle;
    }

    .container, .container-md, .container-sm {
        max-width: unset;
    }
}

@media (max-width: 650px) {
    #paymentContentYes {
        height: 150px;
    }
}

@media (max-width: 400px) {
    #paymentContentYes {
        height: 177px;
    }
}

@media (max-width: 720px) {
    .pppCardBox {
        flex: 1;
        display: flex;
        align-items: flex-start;
        gap: 11px;
        margin-bottom: 27px;
    }

        .pppCardBox svg {
            flex: 0 0 60px;
        }
}

.inputCell input {
    height: 50px;
}

.inputCell {
    vertical-align: top;
}
/* Personal page – make focus border match other pages */
.inputRow .form-control:focus {
    border: solid 3px #2b2b2b !important;
    box-shadow: none; /* optional if you don't want glow */
}
hr {
    display: block;
    -webkit-margin-before: 0.5em;
    -webkit-margin-after: 0.8em;
    -webkit-margin-start: auto;
    -webkit-margin-end: auto;
    border-style: solid;
    border-width: 0px;
    height: 1px;
    background-color: #000;
    color: #CCCCCC;
}

.stepNumberHeader {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 16px;
    line-height: 20px;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 21px;
    margin-top: 20px;
    color: #777777;
}

.labelSectionTop {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 18px;
    line-height: 26px;
}

.cardSelectedBelowText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
    width: fit-content;
    color: #2B2B2B;
    margin: auto;
}

.reviewScrollText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
    width: fit-content;
    color: #2B2B2B;
    margin: auto;
}

.grayButton {
    opacity: 50%;
}


.cardColorText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 22px;
    line-height: 34px;
    width: fit-content;
    color: #2B2B2B;
    margin: auto;
}


/*--------------------------------------- Sidebar*/
.sidebar {
    color: #fff;
    max-width: 317px;
}

.cards-img {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-bottom: -10px;
}

.benefits {
    list-style: none;
    margin-top: 40px;
}

.centering {
    max-width: 1400px;
    width: 100%;
    display: grid;
    grid-template-columns: 1.1fr 0.5fr;
    gap: 40px;
    margin: auto;
}

/*--------------------------------------------------- 02 Step header circles command cards*/

.progress {
    all: unset;
    -webkit-touch-callout: none; /* iOS Safari */
    -webkit-user-select: none; /* Chrome, Safari, Opera */
    -khtml-user-select: none; /* Konqueror (historical) */
    -moz-user-select: none; /* Firefox */
    -ms-user-select: none; /* Internet Explorer/Edge */
    user-select: none; /* Standard property */
}

.app-header {
    margin-bottom: 35px;
}

.stepp-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 700px;
    width: 100%;
    margin: auto;
}

.stepp {
    width: 32px;
    height: 32px;
    border: 2px solid #777777;
    color: #777777;
    border-radius: 50%;
    background-color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    font-size: 12px;
    flex-shrink: 0;
}

    .stepp.currentStep {
        border: 2px solid #2626FF;
        color: #2626FF;
    }

    .stepp.previousStep {
        border: 2px solid #02836D;
        background-color: #02836D;
        color: transparent; /* hide number */
        position: relative;
    }

/*        .stepp.previousStep::before {
            content: "✓";
            color: #ffffff;
            font-size: 16px;
            font-weight: 300;
            line-height: 1;
        }
*/

.disclosureContainer {
    border: 1px solid #CCCCCC;
    border-radius: 8px;
    padding: 17px;
}

.disclosureScroll {
    overflow: auto;
    max-height: 1082px;
    padding: 10px;
    scrollbar-width: thin;
    scrollbar-color: #888 #f0f0f0;
    min-height: 1050px;
}

.disclosureText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 14px;
    line-height: 22px;
}

.ppOptional {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 18px;
    line-height: 26px;
    position: relative;
    top: -14px;
}

.pppCardContainer {
    display: flex;
    gap: 16px;
}

.pppCardBox {
    flex: 1;
}

.pppCardBoxHeader {
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 10px;
}

.pppCardBoxText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
}

.pppCardBoxTextBold {
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-size: 14px;
    line-height: 24px;
}

.pppMainTextBold {
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-size: 16px;
    line-height: 24px;
}

.pppMainText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 16px;
    line-height: 24px;
}

.PPPBenefitsLink, .PPPAgreementLink {
    text-decoration: underline;
    cursor: pointer;
    color: #0000ee !important;
}



/*---PPP Modal--------------------------------*/
body.no-scroll {
    /*overflow: hidden;*/
    height: 100%;
}

.modal-container-ppp {
}

/*, .exclusionsPop*/
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    overflow: auto;
    overscroll-behavior-y: contain;
}

.modal {
    /*        background: #fff;
        width: 100%;
        max-width: 660px;
        max-height: 310px;
        padding: 26px;
        position: absolute;
        box-shadow: 0 20px 60px rgba(0,0,0,.3);
        display: block;
        pointer-events: none;
        top: 112px;*/
    background: #fff;
    width: 95%;
    max-height: 333px;
    padding: 26px;
    position: absolute;
    box-shadow: 0 20px 60px rgba(0, 0, 0, .3);
    display: block;
    /*pointer-events: none;*/
    top: 112px;
    margin: 0 20px;
}

/*ggggggggggg*/
@media (max-width: 650px) {
    .modal {
        position: absolute;
        height: 600px;
        top: 100px;
        margin: 0;
        width: 100%;
        max-height: unset;
    }
}


#exclusionsPopOverlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 100;
    overflow: auto;
    /*  overscroll-behavior-y: contain;*/
}

.exclusionsPop {
    background: #fff;
    width: 100%;
    max-width: 660px;
    padding: 0px 15px 15px 15px;
    position: relative;
    box-shadow: 0 20px 60px rgba(0,0,0,.3);
    display: block;
    pointer-events: unset;
    top: 130px;
    max-height: unset;
    position: absolute;
    z-index: 200;
    overflow-y: scroll;
}

@media (max-width: 650px) {
    .exclusionsPop {
        left: 0;
    }
}

.exclusionsTable {
    color: #150D50;
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
    vertical-align: middle;
}

    .exclusionsTable td {
        padding: 5px;
    }

#exclusionsPopHeader {
    padding: 8px;
    text-align: center;
    background: #150D50;
    color: #ffffff;
    font-family: 'circular-std-medium', Arial, sans-serif;
    font-weight: unset;
    font-size: 14px;
    line-height: 20px;
    letter-spacing: 2px;
    text-align: center;
    vertical-align: middle;
    text-transform: uppercase;
}

.exclusionsTable td:nth-child(1) {
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-weight: 700;
    font-size: 14px;
    line-height: 22px;
    vertical-align: middle;
    width: 130px;
    width: 80px;
}

.exclusionsTable tr:nth-child(even) {
    background-color: #FFFFFF;
}

.exclusionsTable tr:nth-child(odd) {
    background: #F4F4F4;
}


.exclusionsPopContent {
    max-height: fit-content;
}

#timeoutWarningModal {
    display: none;
}

.modal-content {
    pointer-events: none;
}



.modal-close {
    position: absolute;
    top: 16px;
    right: 16px;
    background: none;
    border: none;
    cursor: pointer;
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
    letter-spacing: 0%;
    vertical-align: middle;
}

.modalPPPsidebarHolder {
    max-width: 470px;
    width: 100%;
}


@media (max-width: 1400px) {
    .modalPPPsidebarHolder {
        max-width: 450px;
        width: 100%;
    }
}

@media (max-width: 720px) {
    .modalPPPsidebarHolder {
        max-width: 450px;
        width: 100%;
    }
}

.benefits-table {
    width: 100%;
    border-collapse: collapse;
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 14px;
    line-height: 22px;
    vertical-align: middle;
    position: relative;
    top: 32px;
    margin-bottom: 18px;
}

    .benefits-table thead {
        background: #150d50;
        color: #fff;
    }

    .benefits-table th {
        text-align: left;
        padding: 3px 10px;
        font-size: 13px;
        letter-spacing: 1px;
        font-family: 'circular-std-medium', Arial, sans-serif;
        font-size: 14px;
        line-height: 20px;
        letter-spacing: 2px;
        vertical-align: middle;
        text-transform: uppercase;
        font-weight: unset;
    }

    .benefits-table td {
        padding: 3px 10px;
        font-size: 14px;
        color: #1a1a4b;
    }

    .benefits-table tbody tr:nth-child(even) {
        background: #f4f4f4;
    }

    .benefits-table th:first-child,
    .benefits-table td:first-child {
        width: 133px;
        white-space: normal;
    }







@media (max-width: 720px) {
    .pppCardContainer {
        flex-direction: column;
    }

    .modal {
        padding-bottom: 60px;
        /*max-height: fit-content;*/
    }
}

.benefitsPop {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 200;
    left: 0;
    top: -100px;
    border-radius: 10px;
    /* display: none; */
    background-color: #ffffff;
    max-width: 780px;
    margin: auto;
    overflow: scroll;
    border-radius: 0px;
    display: none;
}

/*----------------------------------------------------*/
















/*---------------------------------------------------*/

/*.disclosureContainer {
    max-height: 400px;
    overflow-y: scroll;
    scrollbar-width: thin;
    -ms-overflow-style: none;
    overflow-x: hidden;
}*/
/*  -----------------------------------------------*/
/*.disclosureContainer {
    max-height: 400px;
    border: 1px solid #ccc;
    padding: 10px;
    overflow-y: scroll;*/
/* Firefox scrollbar style */
/*scrollbar-width: thin;*/ /* options: auto, thin, none */
/*scrollbar-color: #888 #f0f0f0;*/ /* thumb color, track color */
/*}*/
/* --- WebKit browsers (Chrome, Safari, Edge) --- */
/* Scrollbar track */
/*.disclosureContainer::-webkit-scrollbar {
        width: 10px;
        height: 10px;
    }*/
/* Track background */
/*.disclosureContainer::-webkit-scrollbar-track {
        background: #f0f0f0;
        border-radius: 5px;
    }*/
/* Scrollbar thumb */
/*.disclosureContainer::-webkit-scrollbar-thumb {
        background-color: #888;
        border-radius: 5px;
        border: 2px solid #f0f0f0;*/ /* optional padding for flat look */
/*}*/
/* Remove arrows */
/*.disclosureContainer::-webkit-scrollbar-button {
        display: none;
    }*/
/* Thumb hover effect */
/*.disclosureContainer::-webkit-scrollbar-thumb:hover {
        background-color: #555;
    }*/
.scrollArea {
    max-height: 400px;
    overflow: auto;
    border: 1px solid #ccc;
    padding: 10px;
    /* Firefox */
    scrollbar-width: thin;
    scrollbar-color: #888 #f0f0f0;
    border: none;
}

    /* WebKit browsers */
    .scrollArea::-webkit-scrollbar {
        width: 10px;
        height: 10px;
    }

    /* Track */
    .scrollArea::-webkit-scrollbar-track {
        background: #f0f0f0;
        border-radius: 5px;
    }

    /* Thumb */
    .scrollArea::-webkit-scrollbar-thumb {
        background-color: #888;
        border-radius: 5px;
        border: 2px solid #f0f0f0;
    }

    /* Remove all scrollbar buttons/arrows */
    .scrollArea::-webkit-scrollbar-button {
        width: 0;
        height: 0;
        display: none; /* optional, but 0 size ensures no arrows */
        background: transparent;
    }

    /* Thumb hover */
    .scrollArea::-webkit-scrollbar-thumb:hover {
        background-color: #555;
    }


    /*  -------------------------------------------------*/

    .scrollArea::after {
        content: '';
        position: sticky;
        bottom: -11px;
        left: 0;
        width: 100%;
        height: 90px;
        pointer-events: none;
        background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, #ffffff 100%);
        z-index: 20000;
        display: block;
    }

/* =========================
   AGREE CONTAINER CHECKBOX
   ========================= */
.agreeContainerCard,
.agreeContainerCardReview {
    border-radius: 8px;
    background: #FFF6EF;
    padding: 9px 13px;
    position: relative;
}

.agreeContainerCardReview {
    padding: 9px 54px;
}

    /* anchor + positioning only inside agree cards */
    .agreeContainerCard .custom-checkbox,
    .agreeContainerCardReview .custom-checkbox {
        position: absolute;
        left: 2px;
        top: 6px;
        z-index: 1;
    }

        /* hide the real checkbox only inside agree cards */
        .agreeContainerCard .custom-checkbox input,
        .agreeContainerCardReview .custom-checkbox input {
            display: none;
        }

        /* the visible box (your old span) only inside agree cards */
        .agreeContainerCard .custom-checkbox span,
        .agreeContainerCardReview .custom-checkbox span {
            display: inline-block;
            width: 20px;
            height: 20px;
            border: 1px solid #777;
            background-color: #fff6ef;
            position: absolute;
            cursor: pointer;
            transition: all 0.2s ease;
            top: 15px;
            left: 15px;
        }

        .agreeContainerCard .custom-checkbox input:checked + span,
        .agreeContainerCardReview .custom-checkbox input:checked + span {
            background-color: #150d50;
        }

            .agreeContainerCard .custom-checkbox input:checked + span::after,
            .agreeContainerCardReview .custom-checkbox input:checked + span::after {
                content: '';
                position: absolute;
                left: 7px;
                top: 3px;
                width: 5px;
                height: 10px;
                border: solid #fff;
                border-width: 0 2px 2px 0;
                transform: rotate(45deg);
            }

        .agreeContainerCard .custom-checkbox span:hover,
        .agreeContainerCardReview .custom-checkbox span:hover {
            border-color: #888;
        }
.ms-2F {
    margin: 8px 0 0 20px;
}

/*.custom-checkbox input {
    display: none;
}

.custom-checkbox span {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 1px solid #777;
    background-color: #fff6ef;
    position: absolute;
    cursor: pointer;
    transition: all 0.2s ease;
    top: 15px;
    left: 15px;
}

.custom-checkbox input:checked + span {
    background-color: #150d50;
}

    .custom-checkbox input:checked + span::after {
        content: '';
        position: absolute;
        left: 7px;
        top: 3px;
        width: 5px;
        height: 10px;
        border: solid #fff;*/ /*color of checkmark*/
        /*border-width: 0 2px 2px 0;
        transform: rotate(45deg);
    }

.custom-checkbox span:hover {
    border-color: #888;
}*/


. /* Shared checkbox card styling for both nonTax + noIncome */
.softCheckCard {
    margin-top: .5rem;
}

.softCheckCard .custom-checkbox {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    cursor: pointer;
    line-height: 22px;
    font-size: 14px;
    position: relative;
}

    /* hide real checkbox but keep accessible */
    .softCheckCard .custom-checkbox input[type="checkbox"] {
        position: absolute;
        opacity: 0;
        width: 1px;
        height: 1px;
    }

    /* visual box */
    .softCheckCard .custom-checkbox .fake-box {
        width: 20px;
        height: 20px;
        border: 1px solid #777;
        border-radius: 3px;
        display: inline-block;
        flex: 0 0 20px;
        position: relative;
        transition: all .2s ease;
    }

    /* checked */
    .softCheckCard .custom-checkbox input[type="checkbox"]:checked + .fake-box {
        background-color: #150d50;
        border-color: #150d50;
    }

        .softCheckCard .custom-checkbox input[type="checkbox"]:checked + .fake-box::after {
            content: '';
            position: absolute;
            left: 7px;
            top: 3px;
            width: 5px;
            height: 10px;
            border: solid #fff;
            border-width: 0 2px 2px 0;
            transform: rotate(45deg);
        }

    /* optional focus ring when tabbing */
    .softCheckCard .custom-checkbox input[type="checkbox"]:focus + .fake-box {
        outline: 0;
        box-shadow: 0 0 0 .2rem rgba(21,13,80,.15);
        border-color: #150d50;
    }

.softCheckCard .softCheckText {
    font-size: .875rem;
    color: rgba(33,37,41,.75);
    margin: 0;
}
.bold {
    font-weight: bold;
}

#disclosureButton {
    max-width: 300px;
}

.solid-line {
    flex-grow: 0.9;
    height: 2px;
    margin: 0 12px;
    text-align: center;
    font-family: 'circular-std-book', Arial, sans-serif;
    border: 1px solid #2626ff;
    border-radius: 3px;
    width: 21px;
}

.linePrevious {
    flex-grow: 0.9;
    height: 2px;
    margin: 0 12px;
    text-align: center;
    font-family: 'circular-std-book', Arial, sans-serif;
    border: 1px solid #02836D;
    border-radius: 3px;
    width: 33px;
}

.dotted-line {
    flex-grow: 1;
    height: 2px;
    margin: 0 12px;
    text-align: center;
    font-family: 'circular-std-book', Arial, sans-serif;
    width: 34px;
    color: #777777;
    top: -5px;
    position: relative;
}

    .dotted-line::after {
        /*content: "••••";*/
        content: "\2022\2022\2022\2022\2022";
        color: #777777;
        font-size: 7px;
        letter-spacing: 6px;
        position: relative;
        top: -8px;
        /*right: -4px;*/
    }

.cardImageContainer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    width: 100%;
    margin: auto;
}

.cardImageBox {
    flex: 0 1 80px;
    position: relative;
    aspect-ratio: 80 / 127;
    background: #ffffff;
    border: 1px solid black;
    border-radius: 6px;
    z-index: 1;
}

/* .cardImageBox img{
    max-width: 80px;
} */

.cardImageOne {
    background-image:;
}

.selectedCard::before {
    content: "";
    position: absolute;
    top: -7px;
    left: -7px;
    right: -7px;
    bottom: -7px;
    border: 3px solid #2626FF;
    border-radius: 11px;
    pointer-events: none;
    z-index: -1;
}

#cardThumbs {
    display: flex;
    justify-content: space-between;
    max-width: 665px;
}

#cardThumbImage1 {
    background: url(../images/cardPreview1.png);
    background-size: 80px 127px;
}

.containerPersonalInfo {
    background-color: #FFF6EF;
    border-radius: 8px;
    width: 100%;
    height: 229px;
    padding: 32px 24px;
    position: relative;
}

.cardThumbImage {
    /*    height: unset;
    width: unset;
    cursor: pointer;
    margin: 0 auto;
    background-repeat: no-repeat;
    max-width: 80px;*/

    height: unset;
    width: unset;
    cursor: pointer;
    margin: 0 auto;
    background-repeat: no-repeat;
    max-width: 80px;
    object-fit: contain;
    max-width: 100%;
    height: auto;
    display: block;
}

.cardThumbContainer {
    width: unset;
    height: unset;
    max-width: 80px;
    max-height: 127px;
    aspect-ratio: 80 / 127;
    position: relative;
    margin: 0 5px;
}

.cardColorSelected::before {
    content: "";
    position: absolute;
    top: -7px;
    left: -7px;
    right: -7px;
    bottom: -7px;
    border: 3px solid #2626FF;
    border-radius: 11px;
    pointer-events: none;
    /*z-index: -1;*/
}

/*.cell50pct, .cell33pct, .cell40pct, .cell10pct {
    width: unset;
    display: unset;
}*/

.leftCell {
    margin-right: 20px;
}

.cell58pct {
    width: 58%;
    display: inline-block;
}

.cell37pct {
    width: 37%;
    display: inline-block;
}

.cell50pct {
    width: 48.1%;
    display: inline-block;
}

.cell40pct {
    width: 40%;
    display: inline-block;
}

.cell10pct {
    width: 10%;
    display: inline-block;
}

#suffix {
    width: 100%;
}

.personalEditLink {
    position: absolute;
    top: 32px;
    right: 24px;
    color: #2626FF;
    font-weight: 450;
    font-size: 14px;
    line-height: 22px;
    text-align: right;
    text-decoration: underline;
    text-decoration-style: solid;
    text-decoration-thickness: 10%;
    cursor: pointer;
}

.nameFullContainer {
    display: none;
}


@media (max-width: 600px) {
    .step-container {
        flex-wrap: wrap;
        justify-content: center;
        gap: 10px;
    }

    .solid-line {
        margin: 0 12px;
        width: 9px;
    }

    .dotted-line {
        margin: 0px;
    }
}



@media (max-width: 800px) {
    .dotted-line::after {
        content: "\2022\2022\2022\2022\2022";
    }
}

@media (max-width: 750px) {
    .dotted-line::after {
        content: "\2022\2022\2022";
    }
}

@media (max-width: 660px) {
    .dotted-line::after {
        content: "\2022\2022";
        left: 3px;
    }
}

@media (max-width: 1350px) {

    .centering {
        grid-template-columns: 1fr 0fr;
        display: block;
    }

    .sidebar {
        display: none;
    }

    .modalPPPsidebarHolder {
        display: none;
    }
}






/* HEADER ------------------------------------------------------ */
.top-bar {
    max-width: 1360px;
    height: 100px;
    margin: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* .inputText{
    height: 50px;
    width: 433px;
} */

.input-validation-error {
    background-color: #fff !important;
    border: 1px solid #DA1222 !important;
}

.formInputText:focus {
    box-shadow: none;
    outline: none;
    background: none;
    background-repeat: no-repeat;
    background-position: -21px -1px;
    background-color: #ffffff;
}

.secure-text {
    font-size: 14px;
    color: white;
}

.entryLargeText {
    color: #150D50;
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-size: 34px;
    margin: 17px 0 0 0;
    font-weight: 700;
    font-size: 42px;
    line-height: 50px;
}

.largeTextOffer {
    line-height: 50px;
}

.offerCreditLineText {
    font-family: 'circular-std-medium';
    font-weight: 500;
    font-size: 24px;
    line-height: 32px;
}

.partTwoText {
    font-family: 'circular-std-medium';
    font-weight: 500;
    font-size: 24px;
    line-height: 32px;
}

.offerSubText {
    font-family: 'circular-std-book';
    font-size: 16px;
    line-height: 24px;
}

.offerH3 {
    font-family: 'circular-std-bold';
    font-weight: 700;
    font-size: 64px;
    line-height: 64px;
}

section {
    z-index: 500;
    position: relative;
}

/* OFFER SECTION ------------------------------------------------------ */

.offer-container {
    background: white;
    margin: auto;
    padding: 54px 40px;
    width: 100%;
    max-width: 1166px;
    border-radius: 8px;
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.offer-left {
    flex: 1;
    min-width: 280px;
    max-width: 550px;
}

.offer-right {
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: center;
}

.offer-right-found {
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: center;
}

.cards-img {
    max-width: 670px;
    width: 100%;
}

.entryLabel {
    color: #150D50;
    font-size: 14px;
    font-family: 'circular-std-medium', Arial, sans-serif;
    font-weight: 500;
    line-height: 20px;
    letter-spacing: 2px;
    text-transform: uppercase;
}

h1 {
    font-size: 32px;
    margin: 10px 0 20px;
    color: #150D50;
}

.lookup-field-validation-error {
    color: #DA1222;
    font-size: 12px;
    display: block;
    margin-top: .25rem; /* tweak */
    margin-bottom: 0; /* so it doesn't push the next section down */
}

.highlight {
    color: red;
}

.personalCardAddress {
    font-family: circular-std-book, Arial, sans-serif;
    font-weight: 450;
    font-size: 16px;
    line-height: 24px;
}

.personalCardLabel {
    font-weight: 450;
    font-size: 12px;
    line-height: 18px;
    color: #2B2B2B;
}

.personalCardHeader {
    font-family: 'circular-std-medium', Arial, sans-serif;
    font-weight: 500;
    font-size: 14px;
    line-height: 20px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #777777;
}

.personalCardFullName {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 22px;
    line-height: 34px;
    color: #2B2B2B;
}

.description {
    font-family: 'circular-std-book', Arial, sans-serif;
    margin: 16px 0px;
    line-height: 1.4;
    font-weight: 450;
    font-size: 18px;
    line-height: 26px;
}

.subHeaderText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 500;
    font-size: 14px;
    line-height: 20px;
    letter-spacing: 2px;
    text-align: center;
    text-transform: uppercase;
    margin: auto;
}

.offer-form-found {
    margin: 30px 0 0 0;
    background: #FFF6EF;
    border-radius: 10px;
    padding: 32px;
    max-width: 443px;
}

.offer-form {
    margin: 30px 0 0 0;
}

    .offer-form label, #personalForm label {
        display: block;
        font-size: 14px;
        margin-bottom: 2px;
    }


    .offer-form input:not(.entryButton):not(.pill-radio), #personalForm input[type="text"], #personalForm input[type="password"], #personalForm select {
        width: 100%;
        /*max-width: 433px;*/
        padding: 12px;
        border-radius: 5px;
        border: 1px solid #ccc;
        margin-top: 4px;
        margin-bottom: 16px;
        height: 50px;
        font-size: 14px;
        color: #2B2B2B;
        font-family: 'circular-std-book', Arial, sans-serif;
        font-weight: 450;
        line-height: 22px;
    }

.visible-icon {
    position: relative;
}

    .visible-icon input {
        width: 100%;
        padding: 10px 40px 10px 12px; /* space for icon */
        font-size: 14px;
        box-sizing: border-box;
    }

    .visible-icon i {
        position: absolute;
        right: 12px;
        top: 43%;
        transform: translateY(-50%);
        color: #999;
        /* pointer-events: none;  */
        cursor: pointer;
    }

.step-pages-field-validation-error {
    font-family: 'circular-std-book', Arial, sans-serif;
    /*font-weight: 450;*/
    font-size: 12px;
    line-height: 18px;
    color: #DA1222;
    position: relative;
    top: -15px;
}

.field-validation-error {
    font-family: 'circular-std-book', Arial, sans-serif;
    /*font-weight: 450;*/
    font-size: 12px;
    line-height: 18px;
    color: #DA1222;
    position: relative;
    top: -15px;
}

.V2radio {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-family: Arial, sans-serif;
    font-size: 15px;
    color: #000;
}

.radiolabels2, .radiolabels {
    position: relative;
    top: -2px;
    left: 12px;
}

.V2radio input[type="radio"] {
    display: none;
}

.radio-mark {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: #0b2c6a; /* dark blue */
    display: flex;
    align-items: center;
    justify-content: center;
    float: left;
}

    /* Inner dot (shown when checked) */
    .radio-mark::after {
        content: "";
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: #fff;
        opacity: 0;
    }

#paperlessRadioCheckMarkNo {
    display: none;
}

.V2radio input[type="radio"] + .radio-mark {
    background: #fff;
    border: 1px solid #0b2c6a;
}

.V2radio input[type="radio"]:checked + .radio-mark {
    background: #0b2c6a;
    border: 1px solid #0b2c6a;
}


    /* Checked state */
    .V2radio input[type="radio"]:checked + .radio-mark::after {
        opacity: 1;
    }

/*.radioPaperless input:checked + .paperlessContent span svg .paperlessRadioCheckMark {
    opacity: 1;
}*/

.paperlessRadioCheckmark {
    opacity: 1;
}

/*unused elements from redesign ---------------------------------------------------*/

#sameAddressLabel {
    display: none;
}

#userAddBox {
    /*display: none;*/
}

#authAddText {
    /*display: none;*/
}

#fieldsetSameAddressBox {
    display: none;
}

#confirmEmailContainer {
    /*display: none;*/
}



/*Step 4 text box formatting -------------------------------------------------------------*/

.credit-line-card {
    border: 1px solid #cfcfcf;
    border-radius: 6px;
    overflow: hidden; /* ensures bottom radius stays clean */
    font-family: 'circular-std-book', Arial, sans-serif;
    background: #fff;
    max-width: 900px;
}

/* HEADER */
.credit-line-header {
    font-family: 'circular-std-bold', Arial, sans-serif;
    padding: 10px 14px;
    font-size: 13px;
    letter-spacing: 1px;
    border-bottom: 1px solid #cfcfcf;
    text-transform: uppercase;
}

/* EACH ROW */
.credit-line-row {
    display: grid;
    grid-template-columns: 180px 1fr;
}

@media (max-width: 720px) {

    .credit-line-row {
        grid-template-columns: 120px 1fr;
    }


    /*    .credit-line-left .bullet-line {
    padding-left: 2em;
    text-indent: -1em;
    }*/

    .credit-line-left:has(.feesBulletSVG) {
        padding-left: 2em;
        text-indent: -1em;
    }
}

/*vvvvvvvvvvvvvvv*/

/* LEFT COLUMN */
.credit-line-left {
    padding: 14px;
    font-size: 14px;
    border-right: 1px solid #cfcfcf;
    /*    white-space: nowrap;*/
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
}

/* RIGHT COLUMN */
.credit-line-right {
    padding: 14px;
    font-size: 14px;
    line-height: 1.4;
}

/* DIVIDER BETWEEN ROWS (NOT LAST) */
.credit-line-row:not(:last-child) {
    border-bottom: 1px solid #cfcfcf;
}


.schumerText {
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-size: 18px;
    line-height: 26px;
}

.feesBullet {
    position: relative;
    top: -1px;
    margin-right: 2px;
}

.feesBulletSVG {
    content: url("data:image/svg+xml, %3Csvg class='feesBullet' width='8' height='8' viewBox='0 0 8 8' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='1' y='1' width='6' height='6' rx='3' ry='3' /%3E%3C/svg%3E");
    display: inline-block;
    position: relative;
    top: -1px;
    margin-right: 2px;
    width: 8px;
    height: 8px;
}

.credit-line-left:has(.feesBulletSVG) {
    font-family: 'circular-std-book', Arial, sans-serif;
    padding-left: 22px;
}

.credit-line-left:has(.feesBullet) {
    font-family: 'circular-std-book', Arial, sans-serif;
    padding-left: 22px;
}

.credit-line-bold {
    font-family: 'circular-std-bold', Arial, sans-serif;
}
/*.credit-line-card {
    border: 1px solid #cfcfcf;
    border-radius: 6px;
    font-family: Arial, sans-serif;
    background: #fff;
    max-width: 900px;
}


.credit-line-header {
    padding: 10px 14px;
    font-weight: 700;
    letter-spacing: 1px;
    border-bottom: 1px solid #cfcfcf;
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 20px;
    letter-spacing: 2px;
    text-transform: uppercase;
}


.credit-line-body {
    display: grid;
    grid-template-columns: 180px 1fr;*/ /* LEFT NEVER SHRINKS */
/*border-bottom: 1px solid #cfcfcf;
}


.credit-line-left {
    padding: 14px;
    font-size: 14px;
    font-weight: 700;
    border-right: 1px solid #cfcfcf;
    white-space: nowrap;
    font-family: 'circular-std-book', Arial, sans-serif;
    line-height: 22px;
}


.credit-line-right {
    padding: 14px;
    font-size: 14px;
    line-height: 1.4;
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    line-height: 22px;
}*/

#feeTable {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
}

    #feeTable .bold {
        font-family: 'circular-std-bold', Arial, sans-serif;
        font-size: 14px;
        line-height: 22px;
    }

    #feeTable .smtext {
        font-family: 'circular-std-book', Arial, sans-serif;
        font-size: 14px;
        line-height: 22px;
    }

.textTerms {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
}

.feeInfoSpacer {
    height: 10px;
}

#feeTable p {
    margin-bottom: 12px;
}

.table {
    display: table;
    box-sizing: border-box;
    width: 100%;
    box-shadow: 1px 1px 0px 0px #2C6680;
    border-radius: 8px;
}

.tr {
    display: table-row;
    box-sizing: border-box;
}

.td {
    display: table-cell;
    box-sizing: border-box;
    padding: 8px;
    border: 1px solid red;
    border-bottom: none;
    border-right: none;
    background-color: #fff;
}






.primeRateNotice {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
    color: #fff;
    background: #150D50;
    margin-top: 0;
    border-radius: 4px;
    padding: 12px 15px;
}

.italic {
    font-style: italic
}

.textBlockBox {
    border: 1px solid #CCCCCC;
    border-radius: 8px;
    padding: 14px;
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 14px;
    line-height: 22px;
}

.radioImage {
    margin-bottom: 10px !important;
}

.rightContentHeader {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 500;
    font-size: 14px;
    line-height: 20px;
    letter-spacing: 2px;
    text-align: center;
    text-transform: uppercase;
}

.benefits {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 2 columns */
    grid-template-rows: repeat(3, auto); /* 3 rows */
    gap: 27px 0px;
}

.benefitsBox {
}

.benefitsBoxText {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 18px;
    line-height: 26px;
    align-items: center;
    display: flex;
    width: 250px;
}

.benefitsBoxIcon {
    width: 80px;
}

.benefits hr {
    grid-column: 1 / -1; /* span entire grid width */
    border: none;
    border-top: 1px solid #ccc;
    margin: 8px 0;
}

.rightContentText {
    display: inline;
}

.small-link {
    font-size: 12px;
    color: #3b5fff;
    display: block;
    margin: -5px 0 10px 0;
    position: relative;
    top: -2px;
}

.entryButton {
    width: 100%;
    height: 48px;
    max-width: 433px;
    padding: 14px;
    background: #2626FF;
    color: white;
    border: none;
    border-radius: 24px;
    font-size: 16px;
    cursor: pointer;
    margin-top: 7px;
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    line-height: 24px;
    letter-spacing: 0%;
}


#movedZipNo {
    display: none;
}

/* FEATURES SECTION ------------------------------------------------------ */
.features-section {
    margin: 104px 0 0 0;
    text-align: center;
    color: white;
}

    .features-section h2 {
        font-size: 28px;
        margin-bottom: 40px;
    }

.featuresHeaderText {
    font-family: 'circular-std-bold', Arial, sans-serif;
    font-size: 42px;
    padding: 0 20px;
}

.features-grid {
    display: grid;
    gap: 20px;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    width: 90%;
    max-width: 1360px;
    margin: 44px auto 0;
}

.feature-card {
    background: white;
    color: black;
    padding: 42px;
    border-radius: 4px;
    text-align: left;
}

.feature-card-header {
    font-family: 'circular-std-medium', Arial, sans-serif;
    font-weight: 500;
    font-size: 24px;
    line-height: 32px;
    letter-spacing: 0%;
}

.feature-card-text {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-weight: 450;
    font-size: 16px;
    line-height: 24px;
    letter-spacing: 0%;
    margin: 11px 0 0 0;
}

.feature-card .icon {
    font-size: 28px;
    margin-bottom: 15px;
}

.feature-card h3 {
    margin-bottom: 12px;
}

.PPPSubmitDisabled {
    opacity: 0.5;
}

.PPPSubmitEnabled {
    opacity: 1;
}

#paymentRadioCheckMarkYes {
    display: none;
}

#paymentRadioCheckMarkNo {
    display: none;
}
/*  ToolTips ---------------------------------------------------*/
.form-group {
    position: relative;
    /*  margin: 30px; */
    font-family: Arial, sans-serif;
}

.field-label {
    /*                                     font-size: 14px;
                                    font-weight: 600; */
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* Info icon */
.info-icon {
    width: 16px;
    height: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    user-select: none;
}

/* Tooltip container */
.tooltip-wrapper {
    position: relative;
    margin-left: 10px;
    top: 3px;
}

/* Tooltip bubble */
.tooltip-box {
    position: absolute;
    top: 32px;
    left: -122px;
    width: 260px;
    background: #fff;
    color: #333;
    font-size: 13px;
    line-height: 1.4;
    padding: 12px 14px;
    border-radius: 8px;
    border: 1px solid #cccccc;
    /* box-shadow: 0 6px 18px rgba(0, 0, 0, 0.15); */
    -webkit-box-shadow: 0px 5px 3px -3px rgba(0,0,0,0.3);
    box-shadow: 0px 5px 3px -3px rgba(0,0,0,0.3);
    display: none;
    z-index: 1000;
    color: #2B2B2B;
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
    line-height: 22px;
}

    /* Tooltip arrow */
    .tooltip-box::before {
        content: "";
        position: absolute;
        top: -8px;
        left: 47%;
        width: 14px;
        height: 14px;
        background: #fff;
        transform: rotate(45deg);
        border-top: 1px solid #cccccc;
        border-left: 1px solid #cccccc;
        /* box-shadow: -3px -3px 6px rgba(0, 0, 0, 0.05); */
    }

/* Optional input styling */
.input-field {
    display: block;
    width: 400px;
    height: 36px;
    margin-top: 8px;
    padding: 6px 10px;
    border: 1px solid #ccc;
    border-radius: 4px;
}




/* FOOTER ------------------------------------------------------ */

.footer {
    /* padding: 0 40px; */
    text-align: left;
    color: white;
    font-size: 13px;
    line-height: 1.5;
    margin: 20px auto 40px;
    max-width: 1207px;
    border-top-color: rgba(255, 255, 255, 0.18);
    z-index: 100;
}

/*    .footer hr {
        opacity: 0.2;
    }
*/
.footer-text {
    margin: 34px 0px;
    padding-top: 25px;
    border-top: 1px solid rgba(255, 255, 255, 0.18);
}

/* Layout-02 footer links */
.footer .footer-link {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 16px;
    line-height: 22px;
    text-decoration: underline;
    text-decoration-style: solid;
    text-decoration-thickness: 1px;
    color: #fff;
    text-decoration: underline;
}

    .footer .footer-link:hover {
        color: #fff !important;
    }


.logo-left {
    width: 289px;
    height: 24px;
}

.iconLockSVG {
    position: relative;
    top: -2px;
}

.footerReLinks {
    display: flex;
    justify-content: space-between;
    width: 380px;
    font-size: 16px;
}

    .footerReLinks div {
        /* margin: 0 20px; */
        text-decoration: underline;
        cursor: pointer;
    }

.footerTextContainer {
    margin: 30px 0 0 0;
}

#footerMerrickLogo {
    vertical-align: top;
    margin: 0 30px 0 0;
}

.footer-text-rights {
    display: inline-block;
    max-width: 70%;
}

.zipChangedContainer {
    display: inline-flex; /* or flex if full width */
    align-items: center; /* vertical alignment */
    gap: 5px;
    cursor: pointer;
    white-space: nowrap;
}
    .zipChangedContainer svg {
        flex: 0 0 auto;
        margin-top: 0px; /* tiny tweak if needed */
    }

.zipChangedText {
    color: #2626FF;
    font-family: 'circular-std-book', Arial, sans-serif;
    font-size: 14px;
}
.zipChangedBlock {
    margin-top: .21rem; /* decrease to move closer */
    /* or even margin-top: 0; */
}
#plusIconZip {
    margin-right: 2px;
    vertical-align: middle;
    transform: translateY(-2px);
}
/* Decision icons etc ------------------------------------------------------ */
.icon-circle {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: #FFF38A;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* text sizing */
.decision-item-text {
    font-size: 12.5px;
    line-height: 1.45;
    color: #374151;
}

/* Desktop: constrain width so the 3 blocks look balanced */
@media (min-width: 720px) {
    .decision-item-text {
        max-width: 210px;
    }
}
/* Put the card in the same “band” vertically */
.pending02 {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    /* tweak this to move the card up/down */
    padding-top: 32px;
    padding-bottom: 200px;
}

/* Card size matches your screenshot proportions */
.pending02-card {
    background: #fff;
    border-radius: 4px;
    box-shadow: 0 12px 35px rgba(0,0,0,.28);
    /* key sizing */
    width: 760px; /* adjust 740-800 if needed */
    max-width: 100%;
    /* key spacing */
    padding: 56px 72px 34px;
    text-align: center;
    margin-bottom: 300px;
}

@media (max-width: 576px) {
    .pending02 {
        padding-top: 0; /* card starts right under header */
    }

    .cell37pct {
        width: 29%;
        display: inline-block;
    }

    .container {
        padding-left: 0;
        padding-right: 0;
    }
}

/* Title and copy */
.pending02-title {
    margin: 0 0 18px 0;
    font-weight: 800;
    font-size: 36px;
    line-height: 1.15;
    color: #1f2a44; /* or match your theme */
}

.pending02-body {
    margin: 0 auto 22px;
    max-width: 560px; /* keeps the paragraph line-length like screenshot */
    font-size: 13px;
    line-height: 1.6;
    color: #4f4f4f;
}

.pending02-thanks {
    margin: 0 auto 26px;
    font-size: 12px;
    color: #4f4f4f;
}

.pending02-divider {
    height: 1px;
    background: rgba(0,0,0,.10);
    width: 100%;
}

/* Mobile behavior like your earlier pending-mobile image */
@media (max-width: 576px) {
    .pending02 {
        padding-top: 0; /* starts right under header */
        padding-bottom: 0;
    }

    .pending02-card {
        width: 100%;
        padding: 26px 18px 18px;
        border-radius: 0; /* matches “full width” card look on mobile */
        box-shadow: none; /* optional, but matches many mobile comps */
    }

    .pending02-title {
        font-size: 20px;
        margin-bottom: 12px;
    }

    .pending02-body {
        max-width: none;
        font-size: 12px;
        margin-bottom: 14px;
    }

    .pending02-thanks {
        margin-bottom: 16px;
    }
}

/* LOADING ANIMATION ------------------------------------------------------ */

.loadingModal {
    display: none;
    width: 100%;
    height: 100%;
    background-color: #150d50b4;
    position: fixed;
    z-index: 1100;
}

.loadingModalBox {
    background-color: #fff;
    border-radius: 8px;
    max-width: 600px;
    height: 417px;
    margin: auto;
    top: 25%;
    position: relative;
}

.loadingCircleContainer {
    width: 180px;
    position: relative;
    margin: auto;
    top: 26%;
}

.landingLogoContainer {
    width: 80px;
}

.loadingLogoCenter {
    fill: #150d50;
}

.loadingLogo {
    position: absolute;
    top: 31%;
    left: 26%;
    width: 80px;
}

.circle {
    transform: rotate(-90deg);
}

.circleGray {
    fill: none;
    stroke: #cccccc;
    stroke-width: 6;
    stroke-linecap: round;
    /* stroke-dasharray: 509.5;
    stroke-dashoffset: 509.5;

    animation: draw-undraw 3s linear infinite;  */
}

.circleBlue {
    fill: none;
    stroke: #2626FF;
    stroke-width: 8;
    stroke-linecap: round;
    stroke-dasharray: 509.5;
    stroke-dashoffset: 509.5;
    animation: draw-undraw 3s linear infinite;
}

/* ALLOY-NOVA SECTION ------------------------------------------------------ */
/* Outer Box – Responsive */
.nova-center-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    max-width: 777px;
    padding: 6vw 5vw;
    gap: 40px;
    border-radius: 8px;
    background: #fff;
    text-align: center;
    box-sizing: border-box;
}

/* Inner Box – Responsive */
.nova-inner-box {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 40px 5%;
    gap: 56px;
    border-radius: 5px;
    background: #ffffff;
    box-shadow: 0 0 8px rgba(0,0,0,0.05);
    box-sizing: border-box;
}

/* Continue Button – Responsive */
.nova-continue-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 343px;
    height: 48px;
    padding: 8px 24px;
    border: none;
    border-radius: 9999px;
    background: #2626FF;
    color: white;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
}

    .nova-continue-btn:hover {
        opacity: 0.85;
    }

.lookupOptOut {
    font-family: 'circular-std-book', Arial, sans-serif;
    font-style: italic;
    line-height: 1.2;
    font-size: 18px;
    margin: 40px 0 0 0;
    border: 1px solid;
    color: #2B2B2B;
    padding: 10px;
    border-radius: 4px;
    max-width: 433px;
}

/* Divider */
.nova-divider svg {
    width: 100%;
    height: 1px;
}

/* Link text only */
.nova-link-text {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 6px;
    color: #2626FF;
    font-size: 16px;
    cursor: pointer;
    text-decoration: underline;
}

    .nova-link-text svg {
        width: 16px;
        height: 16px;
    }

    .nova-link-text:hover {
        opacity: 0.85;
    }

/* Disclaimer text */
.nova-warning-text {
    align-self: stretch;
    color: #2B2B2B;
    text-align: center;
    font-family: "Circular Std", Arial, sans-serif;
    font-size: 16px;
    font-weight: 450;
    line-height: 24px;
}

.nova-centerbody {
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
}

@keyframes draw-undraw {
    0% {
        stroke-dashoffset: 509.5;
    }

    50% {
        stroke-dashoffset: 0;
    }

    100% {
        stroke-dashoffset: -509.5;
    }
}

@media all and (max-width: 510px) {

    .headerSecureText {
        display: none;
    }

    .logo-left {
        width: 177px;
        position: relative;
        top: 15px;
    }

    .top-bar {
        height: 75px;
    }

    .iconLockSVG {
        position: relative;
        top: 13px;
    }

    .cardThumbContainer {
        display: block;
        margin: 0 2px;
        max-width: 44px;
        max-height: 71px;
    }
}

@media all and (max-width: 660px) {
    .loadingModalBox {
        max-width: 90%;
    }



    .stepp {
        width: 24px;
        height: 24px;
    }
}

@media all and (max-width: 720px) {



    .cardColorSelected::before {
        content: "";
        position: absolute;
        top: -7px;
        left: -7px;
        right: -7px;
        bottom: -7px;
        border: 3px solid #2626FF;
        border-radius: 11px;
        pointer-events: none;
    }

    .bigBorder {
        margin: 0 0 0 0;
        border: none;
        width: auto;
        background-color: none;
        padding: 16px;
    }

    .features-section {
        margin: 40px 0 0 0;
    }

    .features-grid {
        margin: 20px auto 0;
    }

    .featuresHeaderText {
        padding: 10px;
        font-size: 32px;
    }

    .offer-container {
        padding: 30px 10px;
    }

    .offer-right {
        display: none;
    }

    .offer-left {
        margin: auto;
    }


    .offer-form input {
        max-width: unset;
    }

    .entryButton {
        max-width: unset;
    }

    .headerAppText {
        display: none;
    }
}


@media all and (max-width: 993px) {
    .offer-right-found {
        display: none;
    }

    .offer-form-found {
        max-width: unset;
    }

    .offer-left {
        max-width: unset;
    }
}

@media all and (max-width: 960px) {
    .features-grid {
        grid-template-columns: 1fr;
    }

    .feature-card {
        max-width: 550px;
        margin: auto;
    }



    .footerReLinks {
        display: block;
        justify-content: space-between;
        width: 100%;
        text-align: center;
    }

    .footerTextContainer {
        text-align: center;
        margin: 27px 0 0 0;
    }

    .footer-text-rights {
        max-width: unset;
        margin: 20px;
        font-size: 12px;
    }

    #footerMerrickLogo {
        vertical-align: top;
        margin: 0;
        width: 160px;
    }

    .footerReLinks div {
        margin: 27px 0 0 0;
    }
}

@media all and (min-width: 1400px) {

    /*.container size fix*/
    /*    .container {
        max-width: 1360px;
    }*/
}

@media (min-width: 992px) {
    /*.container size fix*/
    /*    .container, .container-lg, .container-md, .container-sm {
        max-width: unset;
    }*/
}

@media all and (max-width: 1400px) {
    .top-bar {
        padding: 30px;
    }
}

@media all and (max-width: 1505px) {

    .footer {
        max-width: unset;
        margin: 40px 30px;
    }
}

.renderComponent {
    position: relative;
    z-index: 99999;
}
/* Right panel background + padding */
.benefits-panel {
    height: 100%;
    border-radius: 0; /* square like example */
    padding: 28px 22px;
}

/* Optional: keep content nicely sized on wide screens */
.benefits-inner {
    max-width: 360px;
    margin: 0 auto;
}

/* Cards image spacing/sizing */
.benefits-cards {
    max-width: 320px; /* tune as needed */
}

/* Heading */
.benefits-title {
    font-weight: 700;
    letter-spacing: .08em;
    font-size: .75rem;
    opacity: .95;
}

/* Benefit row layout */
.benefit-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 0;
}

/* Icon “badge” – use your existing SVG but keep it centered */
.benefit-icon {
    flex: 0 0 54px;
    width: 54px;
    height: 54px;
    display: grid;
    place-items: center;
}

/* Text */
.benefit-text {
    font-size: .9rem;
    line-height: 1.2;
    font-weight: 600;
}

/* Divider lines */
.benefit-divider {
    height: 1px;
    background: rgba(255,255,255,.18);
}

/*.approved02-details {
    width: min(380px, 100%);
    margin: 0 auto 18px;
    background: #f6ece4;
    border-radius: 6px;
    padding: 16px 14px;
}
.approved02-hero {
    position: relative;
    width: 100%;
    max-width: 360px;
    height: 180px;
    margin: 0 auto 16px;
}*/

/* Confetti burst */
/*.approved02-confetti {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: contain;
    z-index: 1;
    pointer-events: none;
}*/

/* Selected card */
/*.approved02-cardimg {
    position: absolute;
    left: 50%;
    top: 20px;
    transform: translateX(-50%);
    height: 140px;
    width: auto;
    z-index: 2;
    filter: drop-shadow(0 14px 22px rgba(0,0,0,0.28));
}*/

