:root{
    --cldr_orange: #FF6633;
}

/******************************************* typography */

@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter-Italic.woff2') format('woff2'),
        url('../fonts/Inter-Italic.woff') format('woff');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('../fonts/Inter-Regular.woff2') format('woff2'),
        url('../fonts/Inter-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

h1, h2, h3, h4, h5, h6, p, ul, a {
    font-family: 'Inter', sans-serif !important;
}

h1 {
    font-size: 36px !important;
}

h2 {
    font-size: 22px !important;
}

label, p, a {
    font-size: 14px !important;
}

/******************************************* general styles */

.bold {
    font-weight: 700;
}

.italic {
    font-style: italic;
}

a {
    color: #000 !important;
}

/******************************************* header */

#header {
    background-image: url(../images/header-image.jpg);
    background-size: cover;
    background-repeat: no-repeat;
}

#header-nav {
    background-color: #f6821f96;
    padding: 20px;
    text-align: right;
}

#header-nav .container {
    max-width: 94% !important;
}

#header-banner {
    color: #fff;
    padding: 75px;
    text-align: center;
}

#header-banner h1 span {
    display: block;
}

#header-banner p {
    margin-bottom: 0;
    font-size: 18px !important;
    width: 52%;
    max-width: 840px;
    margin-right: auto;
    margin-left: auto;
}

#header-banner p span {
    display: block;
}

#header-nav img {
    width: 30%;
    margin-left: 0;
    margin-right: auto;
    display: block;
    text-align: left;
}

#header-nav a {
    color: #ffffff !important;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
    border-bottom: 1px solid #fff;
}

#header-nav a:hover {
    color: #0F006B !important;
    border-bottom: 1px solid #0F006B !important;
}

.text-link {
    border-bottom: 1px solid #000;
}

.text-link:hover {
    border-bottom: 1px solid #0F006B !important;
}

a {
    text-decoration: initial !important;
}

#contact-nav-desktop {
    display: inline;
}

#contact-nav-mobile {
    display: none;
}

/******************************************* sidebar  */

#sidebar-wrapper {
    height: 100vh;
    background-color: #ffffff;
    width: 25%;
    display: inline-block;
    vertical-align: top;
    position: sticky;
    position: -webkit-sticky;
    top: 0;
    padding: 3% 3.5% 3% 3.5%;
}

#sidebar {
    color: #000000;
}

#sidebar-wrapper h1 {
    background: linear-gradient(to right, #fbad41, #f63);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 28px !important;
    margin-bottom: 20px;
}

#sidebar-wrapper h1 span {
    display: block;
}

#sidebar-wrapper h2 {
    color: #000000;
    font-size: 18px !important;
    margin-bottom: 0;
}

#search_name {
    background-color: #fffffff5;
    color: #000000;
    padding-left: 14px;
    height: 40px;
    line-height: 40px;
    border: 1px solid #807C7B40;
    font-size: 14px;
    width: 100%;
    border-radius: 5px;
}

#search_name::placeholder {
    color: #747474;
}

#partner-name-label, #search-country-label {
    margin-top: 15px;
    margin-bottom: 5px;
}

#search-country-select-container {
    border: 1px solid #807C7B40;
    border-radius: 5px;
    background-color: #fffffff5;
    color: #000000;
    padding-left: 10px;
    height: 40px;
    line-height: 40px;
    font-size: 14px;
    width: 100%;
}

#search_country {
    width: 100%;
    border-left: initial;
    border-top: initial;
    border-bottom: initial;
    border-right: 16px solid transparent;
    background-color: transparent !important;
}

#search_country:has(option:disabled:checked) {
  color: #747474 !important;
}

#search-control-container {
    margin-top: 20px;
}

#search-divider {
    width: 100%;
    height: 1px;
    background-color: #747474;
    margin-top: 40px;
    margin-bottom: 40px;
}

#search_partner, #reset_search {
    background-color: initial;
    border: 1px solid #FF6633;
    color: #000;
    font-size: 14px;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
}

#search_partner:hover, #reset_search:hover {
    background-color: #0F006B;
    border: 1px solid #0F006B;
    color: #fff;
}

#search_partner {
    background-color: #FF6633;
    margin-right: 13px;
}

#search_partner:hover {
    background-color: #0F006B;
    border: 1px solid #0F006B;
}

#search_country:focus, #search_country:focus-visible {
    outline: none;
}

/******************************************* dashboard  */

#main-content {
    display: flex;
    justify-content: center;
    vertical-align: top;
}

#partner-wrappers {
    width: 75%;
    background-color: #E8E8E8;
    display: inline-block;
    padding: 3% 3.5% 3% 3.5%;
}

.partner_card {
/*    min-height: 445px;*/
    background-color: #FFFFFF;
    border-radius: 10px;
    margin-bottom: 10px;
}

.partner_card .logo_wrapper {
    height: 130px;
    border-bottom: 1px solid #DFDFDF;
    display: flex;
    align-items: center;
    justify-content: center;
}

.partner_card .logo_wrapper img {
    max-width: 135px;
    max-height: 56px;
    margin: auto;
    display: block;
}

.partner_info_wrapper {
    min-height: 230px !important;
    display: flex;
    justify-content: space-around;
    flex-direction: column;
    padding: 5px 20px;
    line-height: 14px;
}

.partner_info_wrapper p {
    color: #000;
    font-weight: 300;
}

.partner_links_wrapper a {
    white-space: pre-wrap;
    white-space: -moz-pre-wrap;
    white-space: -pre-wrap;
    white-space: -o-pre-wrap;
    word-wrap: break-word;
}

.address-container div {
    display: inline-block;
}

.partner_country, .partner_phone, .program_tier {
    font-size: 14px;
}

.program_tier {
    background-color: #F5F5F5;
    padding: 8px 20px;
    border-radius: 10px 10px 0 0;
    font-size: 12px;
    color: #747474;
}

.partner_name {
    font-size: 16px;
    line-height: 22px;
}

.partner_country p {
    margin-bottom: 0px;
}

.partner_phone {
    margin-bottom: 5px;
}

.address-line {
    font-size: 10px !important;
    color: #747474 !important;
    margin-top: 5px;
    margin-bottom: 0;
}

.contact-container {
    margin-top: -30px;
}

.contact-container a {
    font-weight: 300;
}

.contact-container, .text-link {
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
}

.partner_links_wrapper a  {
    color: #000000 !important;
    border-bottom: 1px solid #000000 !important;
}

.contact-container a:hover, .text-link:hover, .partner_links_wrapper a:hover {
    color: #0F006B !important;
    border-bottom: 1px solid #0F006B !important;
}

.partner_phone a:hover {
    border-bottom: initial !important;
    color: #000 !important;
}

.partner_phone a {
    cursor: initial !important;
    pointer-events: none !important;
}

#partner-wrappers .my-3 {
    margin-top: initial !important;
    margin-bottom: initial !important;
}

#partner-wrappers .col-md-4 {
    margin-top: 15px;
}

/******************************************* footer  */

#footer-copyright {
    background-color: #000000;
    color: #ffffff3b;
    text-align: center;
    padding: 15px;
}

#footer-copyright p {
    margin-bottom: 0;
    font-size: 12px !important;
}

/******************************************* animations  */

.partner_card {
    opacity: 0;
}

.fadeInAnimationTop {
    animation: fadeInTop 1s ease-in-out;
    animation-fill-mode: both;
/*    animation-delay: .6s;*/
}

@keyframes fadeInTop {
    0% {
        opacity: 0;
        transform: translateY(200px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/******************************************* media queries  */

#error-page {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    min-height: 100vh;
    background-image: url(../images/error-page-bg.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    color: #fff;
    text-align: center;
}

#error-page h1 {
    margin-top: -75px;
}

#error-page .text-link {
    color: #fff !important;
    text-decoration: initial;
    border-bottom: 1px solid #fff;
    cursor: pointer; 
}

#error-page .text-link:hover {
    color: #0F006B !important;
    text-decoration: initial;
    border-bottom: 1px solid #0F006B !important;
    cursor: pointer; 
}

#main-other-pages-message {
    line-height: 24px;
}

#error-page-base #footer-copyright {
    background-color: #070033;
    color: #fff;
    text-align: center;
    padding: 15px;
    position: absolute;
    bottom: 0;
    width: 100%;
}

/******************************************* media queries  */

@media screen and (max-width: 992px) {
    .container {
        max-width: 100% !important;
    }
    #header-nav .col-lg-6 {
        width: 50%;
    }
    #header-nav img {
        width: 40%;
    }
    #main-content {
        display: initial;
    }
    #sidebar-wrapper {
        height: initial;
        width: 100%;
        display: block;
        position: sticky;
        position: -webkit-sticky;
        padding: 5% 5% 5.2% 5%;
        z-index: 3;
        border-bottom: 1px solid #FF6633;
    }
    #questions-tagline, #search-divider {
        display: none;
    }
    #sidebar-wrapper h1 span {
        display: inline;
    }
    #partner-wrappers {
        width: 100%;
    }
    #partner-search-container, #country-search-container {
        width: 49%;
        display: inline-block;
        vertical-align: top;
    }
    #country-search-container {
        margin-left: 1%;
    }
}

@media screen and (max-width: 800px) {
    #header-banner h1 span {
        display: initial;
    }
    #header-banner p {
        width: 100%;
        max-width: initial;
    }
}

@media screen and (max-width: 700px) {
    #header-banner p span {
        display: inline;
    }
}

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

    .partner_phone a {
        cursor: pointer !important;
        pointer-events: initial !important;
        border-bottom: 1px solid #000000 !important;
    }
    
    .partner_phone a:hover {
        color: #0F006B !important;
        border-bottom: 1px solid #0F006B !important;
    }

    #contact-nav-desktop {
        display: none;
    }

    #contact-nav-mobile {
        display: inline;
    }
    .partner_card .logo_wrapper img {
        max-width: 155px;
    }
    #header-nav img {
        width: 70%;
    }
    #partner-wrappers {
        padding: 3% 4.5% 3% 4.5%;
    }
    #sidebar-wrapper {
        padding: 7% 7% 7.2% 7%;
    }
    h1 {
        font-size: 22px !important;
    }
    #sidebar-wrapper h1 {
        font-size: 20px !important;
    }
    h2 {
        font-size: 18px !important;
        margin-bottom: 0 !important;
    }
    #sidebar-wrapper h2 {
        font-size: 14px !important;
        font-weight: 600;
    }
    #header-banner {
        padding: 8% 7%;
    }
    #header-banner p {
        font-size: 14px !important;
    }
}

@media screen and (max-width: 450px) {
    #header-banner h1 span {
        display: block;
    }
    #header-banner {
        padding: 10%;
    }
    #sidebar-wrapper {
        padding: 10%;
    }
    #partner-search-container, #country-search-container {
        width: 48%;
    }
    #country-search-container {
        margin-left: 2%;
    }
    #header-nav img {
        width: 95%;
    }
    #partner-name-label, #search-country-label, #search-country-select-container, #search_name {
        font-size: 12px !important;
    }
}





