@import "tct2026constant.css";
@import "partials/layout.css";
@import "partials/default.css";
@import "tct2026-menu.css";
@import url("https://use.typekit.net/tuf3veg.css");
@import url("https://use.typekit.net/owl3kcp.css");

/*
@import "partials/navbar.css";
@import "partials/table.css";
@import "partials/home-faculty.css";
@import "partials/social-footer.css";
@import "partials/program-at-a-glance.css";
@import "tct2025-header.css";
@import url("https://use.typekit.net/owl3kcp.css");
*/

/* nav */
@media screen and (max-width: 1200px) {
    .megaMenu__centerPanel h4 {
        display: none;
    }
}

/*utility styles*/

.font-zekton {
    font-family: "zekton", sans-serif;
    font-weight: 500;
    font-style: normal;
}

.font-kallisto {
    font-family: "kallisto", sans-serif;
    font-weight: 500;
    font-style: normal;
}

.body h2 {
    font-size: 26px;
    line-height: 30px;
}

.darkblue {
    color: #040883 !important
}


.lime, a.lime {
    color: #C8FF4E !important;
}

.blue {
    color: #04A6E2 !important;
}

.blue2 {
    color: #0E6FBC !important
}

.pink {
    color: #E30083 !important
}

.body a {
    text-decoration: underline;
}

.body a.white {
    color: white !important;
}

/*other font sizes*/
.body h1.large {
    font-size: 46px;
    line-height: 44px;
}

main h3 {
    font-size: 22px !important;
    line-height: 28px;
}

/*home page styles*/
.signup-container button {
    background: #edf2f7;
    color: #666666;
}

.bg-darkblue {
    background: #070A36;
}

.bg-darkblue-grad {
    background: linear-gradient(90deg, #070A36 0%, #0000FB 100%);
}

.bg-grad-blue {
    background-image: url("https://assets.crfconnect.com/meetings/tct2026/page-content/TCT2026_about_crf_meetings_banner.jpg");
    background-size: cover;
    background-position: center center;
}

.border-radius-sm {
    border-radius: 8px;
    overflow: hidden;
}

.body .btn, main .btn {
    width: auto;
    max-width: 350px;
    display: inline-block;
    padding: 5px 25px;
}

.event-box .btn {
    max-width: none;
    padding: 5px 25px;
    border-radius: 10px;
    width: auto;

}

.body .btn.btn-auto, main .btn.btn-auto {
    max-width: 270px;
    padding: 5px 30px;
}

.btn {
    border-radius: 5px;
}

.body .btn.btn-lime, main .btn.btn-lime {
    color: #070A36 !important;
    background-color: #C8FF4E !important;
}

@media screen and (max-width: 600px) {
    .mobile-btn-full {
        max-width: 100% !important;
        width: 100% !important;
    }

    .mobile-w-100 {
        width: 100%;
    }

    .mobile-ta-left {
        text-align: left;
    }
}

/*Upcoming Card*/
.upcoming-title {
    max-width: 800px;
    margin: 30px auto 40px auto;

}

.event-box {
    border-radius: 30px;
    color: white;
    border-color: white;

}


.cal-icon {
    border-radius: 30px;
    padding-left: 4px;
}

/*table styles*/
.body .table--borders.table-rounded {
    //border: 2px solid #EFF2F5 !important;
    box-shadow: none;
    border: 4px solid #EFF2F5 !important;
    border-radius: 10px !important;
    overflow: hidden;
    border-collapse: separate !important;
    border-spacing: initial !important;
}

.table--first tr th {
    padding: 20px;
}

.table--first tr th:first-child {
    width: 400px;
    border-right: solid 1px white;
}

.table tr td {
    vertical-align: middle;
}

.table--first tr:nth-child(even) td {
    background-color: #ECF4FC55;
}

.table--padding td, .table--padding th {
    padding: 10px 20px;
}

.table--center-exceptFirst td, .table--center-exceptFirst th {
    text-align: center;
}

.table--center-exceptFirst td:first-child, .table--center-exceptFirst th:first-child {
    text-align: left;
}

.table--row-colors tr:nth-child(even) td {
    background-color: #ECF4FC55;
}

.table--row-colors tr:nth-child(odd) td {
    background-color: white;
}

/* .body .table--borders thead tr*/


.table--borders th {
    border: solid 1px #EFF2F5;
}

.table-rounded tr th:first-child {
    border-top-left-radius: 7px;
}

.table-rounded tr th:first-child {
    border-top-right-radius: 7px;
}

@media screen and (max-width: 600px) {

    table.table.table--first {
        min-width: 0px;

        td, th {
            display: block !important;
            padding-left: 30px !important;
            padding-right: 30px !important;
            border-top: 0 !important;
            border-left: 1px solid var(--table-border-color) !important;
            border-right: 1px solid var(--table-border-color) !important;
            border-bottom: 0 !important;

            p {
                margin-top: 0;
            }

        }

        h2 {
            margin-top: 0px;
            margin-bottom: 0px;
        }

        thead:first-child tr:first-of-type th:last-of-type {
            border-top-right-radius: 0 !important;
        }

        tr {
            th:first-child, td:first-child {
                padding-top: 30px !important;
                border-right: solid 1px transparent !important;
            }

            th {
                border-right: solid 1px transparent !important;
            }

            td:first-child {
                border-top: solid 1px #EFF2F5 !important;

            }

            th:last-child, td:last-child {
                padding-top: 0 !important;
                padding-bottom: 30px !important;
            }
        }

        tr:last-of-type td:last-of-type {
            padding-bottom: 30px !important;
        }
    }

    table.table--borders-head-only {
        th:last-child {
            padding-bottom: 30px !important;
        }
    }


}


.table--first tr td:first-child {

    h2 {
        font-weight: bold;
        font-size: 26px;
    }

    p {
        font-weight: bold;
        font-size: 26px;
        line-height: 28px;
        color: #040883;

        strong {
            font-weight: 600;
        }
    }
}

.body .table--borders thead tr, .body .table--borders thead th, .body .table--borders tbody th {
    background: var(--table-header-bgcolor);
    color: var(--table-header-color, white);
    font-weight: 500 !important;
    border-color: white !important;
    text-align: left;


    strong {
        color: var(--table-header-color, white) !important;
    }

    p {
        color: var(--table-header-color, white) !important;
        //font-weight: 600 !important;
    }
}


.table--borders td {
    border-right: 1px solid #EFF2F5;
    border-bottom: 1px solid #EFF2F5;
    border-color: #EFF2F5;
}

.wrapperMatrixBlock.pl-0 .box-0 .body {
    padding-left: 5px;
}

@media screen and (max-width: 1231px) {
    .wrapperMatrixBlock.pl-0 .box-0 .body {
        padding-left: 15px;
    }

}

@media screen and (max-width: 800px) {

    .wrapperMatrixBlock.flex > div > div:first-child {
        flex-direction: column;
    }

    .wrapperMatrixBlock.mobile-gap-20 > div > div:first-child {
        gap: 20px;
    }
}

h4 + ul {
    margin-top: 10px !important;
}

body p {
    margin-top: 10px;
}

button[data-scope] {
    flex-direction: row-reverse;
}

//.faq-wrapper *:first-child, .faq-wrapper .box-0, .faq-wrapper .box-1 {
//    height: 100%;
//}

.faq .chakra-accordion__root {
    min-height: 290px;
    justify-content: space-between;
    display: flex;
    flex-direction: column;
}

@media screen and (max-width: 800px) {
    .faq .chakra-accordion__root {
        min-height: auto;
        justify-content: space-between;
        display: flex;
        flex-direction: column;
    }

}

.body ul.blue-bullets li::marker, ul.blue-bullets li::marker {
    color: #04A6E2 !important;
}

/*Row*/
.blue-hover {
    padding-top: 0px;
    padding-bottom: 0px;

}

.blue-hover p {
    line-height: 26px;
}

.blue-hover .pageWrapper__inner {
    transition: all 0.3s ease-in-out;
    padding: 20px;
    border-radius: 8px;
    overflow: hidden;
}

.blue-hover .pageWrapper__inner:hover {
    background-color: #D8F1FA;
}

@media screen and (max-width: 700px) {

    .mobile-maxW-65per {
        max-width: 65% !important;
    }
}

.body > .pageWrapper__inner {
    margin: 0 auto;
}

/*Blue Accordion*/
.blue-style h4.chakra-heading {
    background-color: #D8F1FA;
}

.blue-style h4.chakra-heading button {
    background-color: #D8F1FA;
    padding-left: 20px;
    padding-right: 10px;
}

.blue-style h4.chakra-heading button:is(:hover, :focus) {
    background-color: #D8F1FA;
}

.blue-style a {
    color: #04A6E2 !important;

}

.blue-style a:is(:hover, :focus) {
    color: #04A6E2 !important;
}

.blue-style {

}

.blue-style .chakra-accordion__root .chakra-accordion__item {
    margin-bottom: 5px;
    background-color: #EDF9FD;
    border-radius: 8px;
    overflow: hidden;
    border-color: transparent;
}

@media screen and (max-width: 600px) {
    input[name=email] {
        min-width: 200px;
    }
}

/*wire payment page*/
@media screen and (max-width: 600px) {
    .mobile-p-0 {
        padding: 0px;
    }

    .mobile-p-0 .notebox {
        border: transparent !important;
        padding-top: 0px !important;
        padding-bottom: 0px !important;
    }

    .mobile-p-0 .bg-darkblue {
        border-radius: 0px !important;
    }

    .mobile-p-0 h1 {
        font-size: 30px !important;
    }
}