html {
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}
body {
    font-family: var(--font-family);
    font-size: var(--font-size);
    line-height: var(--line-height);
    color:  var(--theme-color-3);
    overflow-x: hidden;
}
a {
    color: inherit;
}
.body {
    overflow-x: hidden;
}
.center {
    text-align: center;
}
.medium {
    font-weight: 500;
}
.semibold {
    font-weight: 600;
}
.bold {
    font-weight: 700;
}
.italic {
    font-style: italic;
}
.hidden {
    display: none;
}
.inline {
    display: inline-block;
}
.note {
    font-size: var(--font-size-sm);
}
@media screen and (min-width: 768px) {
    .md-visible { display: block; }
}
@media screen and (min-width: 1200px) {
    .lg-visible { display: block; }
}
@media screen and (min-width: 1366px) {
    .ml-visible { display: block; }
}
@media screen and (min-width: 1600px) {
    .xl-visible { display: block; }
}
@media screen and (max-width: 1599px) {
    .ml-hidden { display: none; }
}
@media screen and (max-width: 1365px) {
    .lg-hidden { display: none; }
}
@media screen and (max-width: 1199px) {
    .md-hidden { display: none; }
}
@media screen and (max-width: 767px) {
    .sm-hidden { display: none; }
}

/*** HEADER ***/
.header {
    width: 100%;
    background-color: var(--header-bg-color);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}
.header .header-wrapper {
    width: min(100%, var(--max-width));
    height: var(--header-height);
    padding: 0 var(--main-padding);
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.header .header-logo-wrapper {
    flex-shrink: 0;
    line-height: 1;
}
.header .header-logo-wrapper a {
    display: flex;
    align-items: center;
    gap: 10px;
}
.header .header-logo-wrapper img {
    width: var(--header-logo-width);
}
.header .header-content-wrapper {
    display: flex;
    line-height: 1.8;
    font-size: var(--header-font-size);
    font-weight: var(--header-weight);
    color: var(--header-nav-color);
}
.header .top-nav {
    display: flex;
    gap: 10px;
}
.header .nav {
    position: relative;
    padding: 0 var(--nav-padding);
    cursor: pointer;
    height: calc(var(--header-font-size) + 45px);
}
.header .nav a {
    position: relative;
    display: inline-block;
    transition: 0.3s;
}
.header .nav-list {
    position: absolute;
    width: 240px;
    padding: 30px;
    margin-left: -30px;
    line-height: 1.4;
    font-size: var(--header-nav-size);
    top: 100%;
    background-color: var(--header-nav-bg-color);
    display: none;
}
.header .nav-list ul li {
    margin-bottom: 10px;
}
.header .lang-wrapper {
    display: flex;
    position: relative;
}
.header .lang-wrapper ul {
    display: flex;
    gap: 15px;
    margin: 0 20px;
}
.header .nav-btn {
    position: relative;
    width: 24px;
    height: 30px;
    cursor: pointer;
}
.header .nav-btn .line {
    display: block;
    width: 100%;
    height: 2px;
    background-color: var(--header-nav-color);
    position: relative;
    transition: 0.3s linear;
    transform-origin: right;
}
.header .nav-btn .line1 {
    top: 5px;
}
.header .nav-btn .line2 {
    top: 12px;
}
.header .nav-btn .line3 {
    top: 19px;
}
.header .nav-btn.act .line1 {
    transform: rotate(-45deg);
    top: 6px;
}
.header .nav-btn.act .line2 {
    opacity: 0;
}
.header .nav-btn.act .line3 {
    transform: rotate(45deg);
}
@media screen and (min-width: 1366px) {
    .header .header-content-wrapper {
        align-self: flex-end;
        flex-direction: row-reverse;
    }    
    .header .nav .nav-list {
        box-shadow: 0 8px 10px rgba(0, 0, 0, 0.2);
    }
    .header .nav:hover .nav-list {
        display: block;
    }
    .header .mobile-nav-btn-wrapper {
        display: none;
    }
    .header .lang-wrapper:before {
        content: '';
        width: 1px;
        height: 40%;
        background-color: var(--header-nav-color);
        position: absolute;
        left: 15px;
        top: 5px;
    }
    .header .lang-wrapper ul {
        gap: 20px;
        margin: 0 40px;
    }
}
@media screen and (min-width: 1600px) {
    .header .top-nav {
        gap: 40px;
    }
}
@media screen and (max-width: 1365px) {
    .header:has(.header-content-wrapper.act) .header-wrapper:before {
        content: '';
        width: 100%;
        height: calc(100dvh - var(--header-height));
        background-color: rgba(0, 0, 0, 0.5);
        position: fixed;
        top: var(--header-height);
        left: 0;
    }
    .header .header-wrapper {
        padding-right: calc(var(--main-padding) + 30px);
    }
    .header .mobile-nav-btn-wrapper {
        position: absolute;
        right: var(--main-padding);
    }
    .header .top-nav-wrapper {
        position: fixed;
        top: var(--header-height);
        left: 0;
        width: 100%;
        display: none;
        box-shadow: 0 10px 10px rgba(0, 0, 0, 0.2), inset 0 10px 10px -10px rgba(0, 0, 0, 0.2)
    }
    .header .header-content-wrapper.act .top-nav-wrapper {
        display: block;
    }
    .header .top-nav {
        display: block;
        background-color: var(--header-bg-color);
        padding: var(--main-padding);
    }
    .header .nav {
        height: auto;
        margin-bottom: 10px;
    }
    .header .nav-list {
        position: relative;
        margin-left: 0;
        width: 100%;
        padding: 10px 20px;
    }
    .header .nav.act .nav-list {
        display: block;
    }
}

/*** HEADER THEME 1 (header1) ***/
.header1 .nav.act .section-title a, .header1 .nav a:hover {
    color: var(--primary-color);
}
@media screen and (max-width: 1365px) {
    .header1 .header-content-wrapper.act .top-nav-wrapper {
        max-height: calc(100dvh - var(--header-height));
        overflow-y: auto;
        background-color: var(--header-pulldown-bg-color);
    }
    .header1 .top-nav {
        background-color: transparent;
    }
}

/*** HEADER THEME 2 (header2) ***/
.header2 .nav.act .section-title a, .header2 .nav a:hover {
    color: var(--primary-color);
}
@media screen and (max-width: 1365px) {
    .header2 .header-content-wrapper {
        position: fixed;
        top: var(--header-height);
        left: 0;
        width: 100%;
        background-color: var(--header-pulldown-bg-color);
        box-shadow: 0 10px 10px rgba(0, 0, 0, 0.2), inset 0 10px 10px -10px rgba(0, 0, 0, 0.2);
        max-height: calc(100dvh - var(--header-height));
        overflow-y: auto;
        padding-bottom: 20px;
        display: none;
    }
    .header2 .header-content-wrapper.act {
        display: block;
    }
    .header2 .top-nav-wrapper {
        position: relative;
        top: 0;
        box-shadow: none;
    }
    .header2 .top-nav, .header2 .nav-list {
        background: transparent;
    }
    .header2 .lang-wrapper {
        font-size: var(--header-font-size-sm);
        justify-content: flex-end;
        padding: 20px var(--main-padding) 10px;
    }
    .header2 .lang-wrapper:before {
        content: '';
        width: calc(100% - 20px - var(--main-padding)*2);
        height: 1px;
        background-color: var(--header-color);
        position: absolute;
        top: 100%;
        margin-right: 10px;
        opacity: 0.5;
    }
    .header2 .lang-wrapper ul {
        margin: 0 10px;
    }
}

/*** HEADER THEME 3 (header3) ***/
.header3 .nav.act .section-title a, .header3 .nav a:hover {
    color: var(--primary-color);
}
.header3 .lang-wrapper {
    font-size: var(--header-font-size-sm);
    color: var(--header-color);
    font-weight: initial;
}
.header3 .link-wrapper {
    position: relative;
    font-size: var(--header-font-size-sm);
    padding: var(--main-padding);
    color: var(--header-color);
    font-weight: initial;
}
.header3 .link-wrapper a {
    margin: 0 10px;
}
@media screen and (min-width: 1366px) {
    .header3 .header-wrapper {
        align-items: flex-end;
    }
    .header3 .header-logo-wrapper {
        padding-bottom: calc(var(--header-padding) + 8px);
    }
    .header3 .header-content-wrapper {
        flex-wrap: wrap;
        flex-direction: row;
        justify-content: flex-end;
        gap: 12px 10px;
        padding-right: 40px;
    }
    .header3 .top-nav-wrapper {
        width: 100%;
        order: 3;
    }
    .header3 .top-nav {
        justify-content: flex-end;
    }
    .header3 .nav {
        height: auto;
        padding-bottom: var(--header-padding);
    }
    .header3 .nav:last-child .nav-list {
        margin-left: 0;
        right: -30px;
    }
    .header3 .lang-wrapper {
        order: 2;
    }
    .header3 .lang-wrapper ul {
        margin-right: 10px;
        margin-left: 30px;
    }
    .header3 .lang-wrapper:before {
        height: 64%;
        left: 5px;
        top: 18%;
        background-color: var(--header-color);
    }
    .header3 .lang-wrapper.noline:before {
        display: none;
    }
    .header3 .link-wrapper {
        order: 1;
        padding: 0;
    }
    .header3 .link-wrapper ul {
        display: inline-flex;
    }
}
@media screen and (max-width: 1365px) {
    .header3 .header-content-wrapper {
        position: fixed;
        top: var(--header-height);
        left: 0;
        width: 100%;
        background-color: var(--header-pulldown-bg-color);
        -webkit-backdrop-filter: blur(5px);
        backdrop-filter: blur(5px);
        box-shadow: 0 10px 10px rgba(0, 0, 0, 0.2), inset 0 10px 10px -10px rgba(0, 0, 0, 0.2);
        max-height: calc(100dvh - var(--header-height));
        overflow-y: auto;
        padding-bottom: 20px;
        display: none;
    }
    .header3 .header-content-wrapper.act {
        display: block;
    }
    .header3 .top-nav-wrapper {
        position: relative;
        top: 0;
        box-shadow: none;
    }
    .header3 .top-nav, .header3 .nav-list {
        background: transparent;
    }
    .header3 .lang-wrapper {
        justify-content: flex-end;
        padding: 20px var(--main-padding) 10px;
    }
    .header3 .lang-wrapper:before {
        content: '';
        width: calc(100% - 20px - var(--main-padding)*2);
        height: 1px;
        background-color: var(--header-color);
        position: absolute;
        top: 100%;
        margin-right: 10px;
        opacity: 0.5;
    }
    .header3 .lang-wrapper ul {
        margin: 0 10px;
    }
    .header3 .link-wrapper:before {
        content: '';
        width: calc(100% - 20px - var(--main-padding)*2);
        height: 1px;
        background-color: var(--header-color);
        position: absolute;
        top: 0;
        margin-left: 10px;
        opacity: 0.5;
    }
    .header3 .link-wrapper ul li:not(:last-child) {
        margin-bottom: 5px;
    }
}

/*** HEADER THEME 4 (header4) ***/
.header4 .nav.act .section-title a, .header4 .nav a:hover {
    color: var(--primary-color);
}
.header4 .block-wrapper {
    position: relative;
    padding: var(--main-padding);
}
.header4 .stockquote-wrapper {
    max-width: 500px;
    height: 80px;
    padding: 0 10px;
}
.header4 .link-wrapper {
    position: relative;
    font-size: var(--header-font-size-sm);
    font-weight: initial;
}
.header4 .link-wrapper a {
    margin: 0 10px;
}
@media screen and (min-width: 768px) {
    .header4 .stockquote-wrapper {
        width: 100%;
        max-width: 600px;
        height: 26px;
        margin-left: auto;
    }
}
@media screen and (min-width: 1366px) {
    .header4 .header-wrapper {
        align-items: flex-end;
    }
    .header4 .header-logo-wrapper {
        padding-bottom: calc(var(--header-padding) + 8px);
    }
    .header4 .header-content-wrapper {
        flex-wrap: wrap;
        gap: 12px 10px;
    }
    .header4 .nav {
        height: auto;
        padding-bottom: var(--header-padding);
    }
    .header4 .block-wrapper {
        width: 100%;
        order: -1;
        padding: 0 30px 0 0;
        display: inline-flex;
    }
    .header4 .link-wrapper ul {
        display: inline-flex;
    }
}
@media screen and (max-width: 1365px) {
    .header4 .header-content-wrapper {
        position: fixed;
        top: var(--header-height);
        left: 0;
        width: 100%;
        background-color: var(--header-pulldown-bg-color);
        -webkit-backdrop-filter: blur(5px);
        backdrop-filter: blur(5px);
        box-shadow: 0 10px 10px rgba(0, 0, 0, 0.2), inset 0 10px 10px -10px rgba(0, 0, 0, 0.2);
        max-height: calc(100dvh - var(--header-height));
        overflow-y: auto;
        padding-bottom: 20px;
        display: none;
    }
    .header4 .header-content-wrapper.act {
        display: block;
    }
    .header4 .top-nav-wrapper {
        position: relative;
        top: 0;
        box-shadow: none;
    }
    .header4 .top-nav, .header4 .nav-list {
        background: transparent;
    }
    .header4 .lang-wrapper {
        font-size: var(--header-font-size-sm);
        justify-content: flex-end;
        padding: 20px var(--main-padding) 10px;
    }
    .header4 .lang-wrapper:before {
        content: '';
        width: calc(100% - 20px - var(--main-padding)*2);
        height: 1px;
        background-color: var(--header-color);
        position: absolute;
        top: 100%;
        margin-right: 10px;
        opacity: 0.5;
    }
    .header4 .lang-wrapper ul {
        margin: 0 10px;
    }
    .header4 .block-wrapper:before {
        content: '';
        width: calc(100% - 20px - var(--main-padding)*2);
        height: 1px;
        background-color: var(--header-color);
        position: absolute;
        top: 0;
        margin-left: 10px;
        opacity: 0.5;
    }
    .header4 .link-wrapper ul li:not(:last-child) {
        margin-bottom: 5px;
    }
}



/*** FOOTER ***/
.footer {
    width: 100%;
    background-color: var(--footer-bg-color);
    color: var(--footer-font-color);
    padding: var(--main-padding);
    font-size: var(--footer-font-size);
    border-top: var(--footer-border);
}
.footer .footer-wrapper {
    width: var(--footer-max-width);
    margin: 0 auto;
}
.footer .footer-top {
    display: grid;
    grid-template-columns: 30% 1fr;
    gap: 20px;
    padding-top: 40px;
}
.footer .footer-bottom {
    padding: 20px 0 40px;
    font-size: calc(var(--footer-font-size) * 0.875);
}
.footer .logo {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 40px;
}
.footer .logo img {
    width: var(--footer-logo-width);
}
.footer .contact {
    margin-bottom: 50px;
}
.footer .contact ul li {
    display: flex;
    align-items: flex-start;
    gap: 20px;
    margin-bottom: 15px;
    line-height: 1.6;
}
.footer .contact .icon {
    display: block;
    width: 30px;
    height: 30px;
    background-size: contain;
    background-repeat: no-repeat;
}
.footer .contact .icon-tel {
    background-image: url(../images/global/icon_tel.svg);
}
.footer .contact .icon-add {
    background-image: url(../images/global/icon_address.svg);
}
.footer .contact .icon-email {
    background-image: url(../images/global/icon_email.svg);
}
.footer .social-media ul {
    display: flex;
    gap: 15px;
    justify-content: left;
    margin-bottom: 20px;
}
.footer .social-media a {
    display: block;
    border-radius: 50%;
    overflow: hidden;
}
.footer .social-media .icon {
    display: block;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: #fff;
    background-size: 70%;
    background-position: center;
    background-repeat: no-repeat;
}
.footer .light .social-media .icon {
    border: 1px solid;
}
.footer .social-media .icon-fb {
    background-image: url(../images/global/icon_fb.svg);
}
.footer .social-media .icon-twitter {
    background-image: url(../images/global/icon_twitter.svg);
}
.footer .social-media .icon-linkedin {
    background-image: url(../images/global/icon_linkedin.svg);
}
.footer .social-media .icon-wechat {
    background-image: url(../images/global/icon_wechat.svg);
}
.footer .social-media .icon-weibo {
    background-image: url(../images/global/icon_weibo.svg);
}
.footer .selectWrapper {
    width: 250px;
    border-radius: 20px;
    border: 1px solid var(--theme-color-3);
    color: var(--theme-color-3);
    margin-bottom: 20px;
}
.footer .selectWrapper:after {
    border-color: var(--theme-color-3) transparent;
}
.footer .selectWrapper .dropdown {
    max-height: 200px;
    z-index: 1;
    left: -1px;
    border: 1px solid var(--theme-color-3);
    border-top: 0;
    box-sizing: content-box;
}
.footer .selectWrapper .dropdown a {
    padding: 10px 25px;
    transition: 0.3s;
}
.footer .selectWrapper .dropdown a:hover {
    color: var(--primary-color);
}
.footer .selectWrapper.act {
    border-radius: 20px 20px 0 0;
}
.footer .selectWrapper.act .dropdown {
    border-radius: 0 0 20px 20px;
}
.footer .sitemap {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 50px;
    padding-top: 10px;
}
.footer .sitemap .nav {
    margin-bottom: 80px;
}
.footer .sitemap .section-title {
    font-size: var(--footer-sitemap-title);
    font-weight: var(--footer-title-weight);
    color: var(--primary-color);
    margin-bottom: 25px;
}
.footer .sitemap ul li {
    line-height: 1.6;
    margin-bottom: 15px;
}
@media screen and (min-width: 1200px) {  
    .footer .social-media .icon {
        width: 30px;
        height: 30px;
    }
}
@media screen and (max-width: 1199px) {
    .footer .footer-wrapper {
        padding: 0 5px;
    }
    .footer .sitemap {
        display: none;
    }
    .footer .footer-top {
        display: flex;
        padding-top: 20px;
        margin-bottom: 20px;
    }
    .footer:has(.contact.md-hidden) .footer-top {
        justify-content: center;
        text-align: center;
    }
    .footer:has(.contact.md-hidden) .social-media ul {
        justify-content: center;
    }
    .footer .footer-bottom {
        padding: 20px 0;
    }
    .footer:has(.contact.md-hidden) .footer-bottom {
        text-align: center;
    }
    .footer .selectWrapper .dropdown {
        top: auto;
        bottom: 100%;
    }
    .footer .selectWrapper.act {
        border-radius: 0 0 20px 20px;
    }
    .footer .selectWrapper.act .dropdown {
        border-radius: 20px 20px 0 0;
        border-top: 1px solid var(--theme-color-3);
        border-bottom: 0;
    }
}
@media screen and (max-width: 767px) {
    .footer:has(.contact.sm-hidden) .footer-top {
        justify-content: center;
        text-align: center;
    }
    .footer:has(.contact.sm-hidden) .social-media ul {
        justify-content: center;
    }
    .footer:has(.contact.sm-hidden) .footer-bottom {
        text-align: center;
    }
}

/*** FOOTER THEME 1 (footer1) ***/
.footer1 .footer-bottom {
    text-align: center;
}
@media screen and (max-width: 1199px) {
    .footer1 .footer-bottom {
        text-align: left;
    }
}

/*** FOOTER THEME 2 (footer2) ***/
.footer2 .footer-bottom {
    position: relative;
}
.footer2 .footer-bottom:before {
    content: '';
    position: absolute;
    width: 100vw;
    height: 1px;
    background-color: var(--primary-color);
    top: -5px;
    left: 0;
}
@media screen and (max-width: 1199px) {
    .footer2:has(.contact.md-hidden) .social-media ul {
        margin-bottom: 0;
    }
    .footer2:has(.contact.md-hidden) .footer-bottom:before {
        display: none;
    }
}
@media screen and (max-width: 767px) {
    .footer2:has(.contact.sm-hidden) .social-media ul {
        margin-bottom: 0;
    }
    .footer2:has(.contact.sm-hidden) .footer-bottom:before {
        display: none;
    }
}



/*** SECTION BANNER ***/
.section-banner-wrapper {
    margin-top: var(--header-height);
}
.section-banner-wrapper .section-banner {
    position: relative;
    width: 100%;
    height: var(--section-banner-height);
    background-size: cover;
    background-position: center;
    background-color: #fff;
}
.section-banner-wrapper .section-banner.banner1 {
    background-image: url(../images/banner/section_banner1_m.jpg);
}
.section-banner-wrapper .section-banner.banner2 {
    background-image: url(../images/banner/section_banner2_m.jpg);
}
.section-banner-wrapper .section-banner.banner3 {
    background-image: url(../images/banner/section_banner3_m.jpg);
}
.section-banner-wrapper .section-banner.banner4 {
    background-image: url(../images/banner/section_banner4_m.jpg);
}
.section-banner-wrapper .section-banner.banner5 {
    background-image: url(../images/banner/section_banner5_m.jpg);
}
.section-banner-wrapper .section-banner.banner6 {
    background-image: url(../images/banner/section_banner6_m.jpg);
}
.section-banner-wrapper .section-banner.banner7 {
    background-image: url(../images/banner/section_banner7_m.jpg);
}
.section-banner-wrapper .section-banner.banner8 {
    background-image: url(../images/banner/section_banner8_m.jpg);
}
.section-banner-wrapper .section-banner.banner9 {
    background-image: url(../images/banner/section_banner9_m.jpg);
}
.section-banner-wrapper .section-banner.banner10 {
    background-image: url(../images/banner/section_banner10_m.jpg);
}
.section-banner-wrapper .section-banner-content {
    width: var(--container-width);
    margin: 0 auto;
    padding: var(--main-padding);
}
.section-banner-wrapper .breadcrumbs {
    display: flex;
    flex-wrap: wrap;
    font-size: var(--breadcrumb-size);
    font-weight: var(--breadcrumb-weight);
    position: relative;
    z-index: 1;
}
.section-banner-wrapper .breadcrumbs ul {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.section-banner-wrapper .breadcrumbs ul li {
    position: relative;
    margin-bottom: 5px;
    display: flex;
    align-items: center;
    padding-right: var(--breadcrumb-padding);
    margin-right: var(--breadcrumb-padding);
}
.section-banner-wrapper .breadcrumbs ul li:after {
    content: '';
    display: block;
    width: calc(var(--breadcrumb-size)/2 + 1px);
    height: calc(var(--breadcrumb-size)/2 + 1px);
    border-top: 1px solid;
    border-right: 1px solid;
    position: absolute;
    right: 1px;
    top: calc(50% - 1px);
    transform: rotate(45deg) translateY(-50%);
}
@media screen and (min-width: 768px) {    
    .section-banner-wrapper .section-banner.banner1 {
        background-image: url(../images/banner/section_banner1.jpg);
    }
    .section-banner-wrapper .section-banner.banner2 {
        background-image: url(../images/banner/section_banner2.jpg);
    }
    .section-banner-wrapper .section-banner.banner3 {
        background-image: url(../images/banner/section_banner3.jpg);
    }
    .section-banner-wrapper .section-banner.banner4 {
        background-image: url(../images/banner/section_banner4.jpg);
    }
    .section-banner-wrapper .section-banner.banner5 {
        background-image: url(../images/banner/section_banner5.jpg);
    }
    .section-banner-wrapper .section-banner.banner6 {
        background-image: url(../images/banner/section_banner6.jpg);
    }
    .section-banner-wrapper .section-banner.banner7 {
        background-image: url(../images/banner/section_banner7.jpg);
    }
    .section-banner-wrapper .section-banner.banner8 {
        background-image: url(../images/banner/section_banner8.jpg);
    }
    .section-banner-wrapper .section-banner.banner9 {
        background-image: url(../images/banner/section_banner9.jpg);
    }
    .section-banner-wrapper .section-banner.banner10 {
        background-image: url(../images/banner/section_banner10.jpg);
    }
}

/*** SECTION BANNER THEME 1 (section-banner1) ***/
.section-banner1 .section-banner {
    display: flex;
    align-items: end;
}
.section-banner1 .section-banner-content {
    background-color: var(--banner-content-bg);
    padding: 40px var(--main-padding);
}
.section-banner1 .breadcrumbs {
    width: var(--breadcrumb-width);
    margin: 0 auto;
}
.section-banner1 .breadcrumbs ul li:last-child:after {
    display: none;
}
.section-banner1 .breadcrumbs ul li a, .section-banner1 .breadcrumbs ul li span {
    color: var(--primary-color);
}
.section-banner1 + .mainWrapper .content-wrapper {
    margin-top: -60px;
}
@media screen and (min-width: 1200px) {
    .section-banner1 .section-banner-content {
        padding: 60px var(--main-padding);
    }
    .section-banner1 + .mainWrapper .content-wrapper {
        margin-top: -90px;
    }
}

/*** SECTION BANNER THEME 2 (section-banner2) ***/
.section-banner2 .section-banner-content {
    display: flex;
    height: 100%;
    justify-content: center;
    align-items: center;
    text-align: center;
}
.section-banner2 .breadcrumbs {
    flex-direction: column;
    align-items: center;
    color: var(--breadcrumb-color);
}
.section-banner2 .breadcrumbs ul {
    justify-content: center;
    padding: 9px 18px 4px 28px;
    background-color: var(--breadcrumb-bg-color);
    border-radius: 50px;
    margin-bottom: 8px;
}
.section-banner2 .breadcrumbs ul li {
    line-height: 1;
}
.section-banner2 .breadcrumbs ul li:after {
    border-width: 2px;
}
.section-banner2 .pageTitle {
    font-size: var(--banner-title);
    font-weight: var(--banner-title-weight);
    letter-spacing: -1px;
    line-height: 1.2;
}

/*** SECTION BANNER THEME 3 (section-banner3) ***/
.section-banner3 .section-banner {
    display: flex;
    align-items: end;
}
.section-banner3 .section-banner-content {
    padding: 0 var(--main-padding);
    margin-bottom: calc(var(--banner-title) * 1.5);
}
.section-banner3 .pageTitle {
    font-size: var(--banner-title);
    font-weight: var(--banner-title-weight);
    color: var(--breadcrumb-color);
    letter-spacing: -1px;
    text-align: center;
    line-height: 1.2;
    text-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
}
.section-banner3 .pageTitle.alignLeft {
    width: calc(var(--content-width) + 40px);
    padding: 0 20px;
    margin: 0 auto;
    text-align: left;
}
.section-banner3 .breadcrumbs-wrapper {
    padding: 30px var(--main-padding) 60px;
}
.section-banner3 .breadcrumbs {
    width: var(--breadcrumb-width);
    margin: 0 auto;
}
.section-banner3 .breadcrumbs ul li a {
    transition: 0.3s;
}
.section-banner3 .breadcrumbs ul li a:hover {
    color: var(--primary-color);
}
.section-banner3 .breadcrumbs ul li:last-child:after {
    display: none;
}
.section-banner3 + .mainWrapper .page-title-wrapper {
    margin-top: -60px;
}



/*** CONTENT ***/
.mainWrapper {
    width: min(100%, var(--max-width));
    margin: 0 auto;
}
.content-wrapper {
    width: var(--container-width);
    padding: 0 var(--main-padding);
    margin: 0 auto;
}
.page-content {
    position: relative;
    width: var(--content-width);
    margin: 0 auto;
    color: var(--content-color);
}
:nth-last-child(1 of .mainWrapper) .page-content {
    padding-bottom: 40px;
}
.page-content p {
    line-height: var(--line-height-p);
    margin-bottom: var(--margin-p);
}
.page-content .content {
    position: relative;
}
.page-content h2 {
    font-size: var(--font-size-h2);
    font-weight: var(--h2-weight);
    color: var(--h2-color);
    margin-bottom: 15px;
}
.page-content h3 {
    font-size: var(--font-size-h3);
    font-weight: var(--h3-weight);
    color: var(--h3-color);
    margin-bottom: 15px;
}
.page-content .subTitle {
    font-size: var(--font-size-ml);
    font-weight: var(--subtitle-weight);
    color: var(--subtitle-color);
    margin-bottom: 15px;
}
.page-content ul:not(.tab-links, .dropdown) li {
    position: relative; 
    padding-left: 30px;
    line-height: var(--line-height-p);
}
.page-content ul.listSquare > li:before { 
    content: "\220E"; 
    position: absolute; 
    top: -1px; 
    left: 4px; 
    transform: scale(0.6);
}
.page-content ul.listNum {
    counter-reset: num;
}
.page-content ul.listNum > li:before { 
    content: counter(num) "."; 
    counter-increment: num;
    position: absolute; 
    left: 0;
}
.page-content ul.listLetter {
    counter-reset: letter;
}
.page-content ul.listLetter > li:before { 
    content: "(" counter(letter, lower-alpha) ")"; 
    counter-increment: letter;
    position: absolute; 
    left: 0;
}
.page-content ul.para > li {
    margin-bottom: var(--margin-p);
}
.page-content a {
    color: var(--link-color);
}
.page-content a:hover {
    color: var(--link-hover-color);
}
.page-content .plainTable td {
    line-height: var(--line-height-p);
    padding: var(--plaintable-padding);
    border-width: var(--plaintable-border);
    border-color: var(--plaintable-border-color-2);
    border-style: solid;
}
.page-content .plainTable tr.borderTop td {
    border-top: 1px solid var(--plaintable-border-color-1);
}
.page-content .plainTable tr.borderBottom td {
    border-bottom: 1px solid var(--plaintable-border-color-1);
}
@media screen and (min-width: 768px) {
    :nth-last-child(1 of .mainWrapper) .page-content {
        padding-bottom: 60px;
    }
}



/*** PAGE TITLE ***/
.page-title-wrapper {
    position: relative;
    width: var(--content-width);
    padding-top: 60px;
    margin: 0 auto;
    color: var(--content-color);
}
.page-title-wrapper .page-title {
    position: relative;
    font-size: var(--font-size-title);
    font-weight: var(--title-weight);
    color: var(--title-color);
    margin-bottom: var(--title-margin);
}
/*** PAGE TITLE THEME 2 (pageTitle2) ***/
.pageTitle2 .page-title:after {
    content: '';
    width: 100%;
    height: 1px;
    background-color: var(--border-color-1);
    position: absolute;
    left: 0;
    bottom: calc(var(--title-margin) / -3);
}



/*** ARTICLE ***/
.article-img {
    margin-bottom: 25px;
}
.flexbox .img-wrapper {
    margin-bottom: 25px;
}
@media screen and (min-width: 768px) {
    .article-img.fright {
        margin-left: 30px;
    }
    .article-img.fleft {
        margin-right: 30px;
    }
    .flexbox {
        display: flex;
        gap: 40px;
    }
    .flexbox .img-wrapper {
        width: 35%;
        flex-shrink: 0;
    }
}
@media screen and (max-width: 767px) {
    .flexbox .img-wrapper.cover {
        width: min(100%, 300px);
        margin-left: auto;
        margin-right: auto;
    }
}

/*** ARTICLE THEME 1 (article1) ***/
.article1 .article-img {
    width: 100%;
}
.article1 .article-img img {
    width: 100%;
}
.article1 .fright.imgShadow {
    padding-right: 25px;
    padding-top: 25px;
}
.article1 .fright.imgShadow img {
    box-shadow: 25px -25px var(--primary-color);
}
.article1 .fleft.imgShadow {
    padding-left: 25px;
    padding-top: 25px;
}
.article1 .fleft.imgShadow img {
    box-shadow: -25px -25px var(--primary-color);
}
@media screen and (min-width: 768px) {
    .article1 .article-img {
        width: 49%;
    }
}
@media screen and (min-width: 1200px) {
    .article1 .feature-img {
        margin-top: calc(var(--title-margin) * -1);
    }
}

/*** ARTICLE THEME 2 (article2) ***/
.article2 .article-img {
    width: 100%;
}
.article2 .article-img img {
    width: 100%;
}
@media screen and (min-width: 768px) {
    .article2 .article-img {
        width: calc(min(100vw, var(--max-width)) / 2);
    }
    .article2 .fright.imgShadow {        
        margin-right: calc((min(100vw, var(--max-width)) - var(--content-width)) / -2);
        clip-path: polygon(15% 0, 0 100%, 100% 100%, 100% 0);
    }
    .article2 .fleft.imgShadow {        
        margin-left: calc((min(100vw, var(--max-width)) - var(--content-width)) / -2);
        clip-path: polygon(0 0, 0 100%, 100% 100%, 85% 0);
    }
    .article2 .feature-img {
        margin-top: calc((var(--title-margin) + var(--font-size-title)) * -1.1);
    }
}



/*** YEAR SELECTOR ***/
.yearWrapper {
    width: 100%;
    display: flex;
    gap: 20px;
    justify-content: space-between;
    align-items: center;
    padding: 30px 0;
    margin-bottom: 50px;
    border-bottom: 1px solid var(--border-color-1);
}
.yearWrapper .year {
    font-size: var(--font-size-xl);
    color: var(--theme-color-2);
    line-height: 1;
}
.selectWrapper {
    position: relative;
    padding: 10px 25px;
    font-size: var(--font-size-sm);    
    line-height: 1;
    cursor: pointer;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.selectWrapper:after {
    content: '';
    display: inline-block;
    border-width: 8px 6px 0;
    border-style: solid;
    border-color: var(--primary-color) transparent;
}
.selectWrapper .dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    max-height: 240px;
    overflow: auto;
    background-color: #fff;
    display: none;
}
.selectWrapper .dropdown a {
    display: block;
    padding: 12px 25px;
    color: inherit;
}
.selectWrapper.act .dropdown {
    display: block;
}



/*** TAB ***/
.tab-wrapper {
    position: relative;
    width: 100%;
    margin-bottom: 25px;
}
.tab-nav {
    text-align: center;
    overflow-y: hidden;
}
.tab-links {
    display: inline-flex;
    font-size: 20px;
}
.tab-links a {
    color: var(--theme-color-2);
}
.tab-links a:hover, .tab-links li.act a {
    color: var(--primary-color);
}
.tab-links li {
    padding: 0;
    flex-shrink: 0;
}
.tab-links li:not(:last-child) a {
    position: relative;
    margin-right: 30px;
}
.tab-links li:not(:last-child) a:after {
    content: '';
    width: 1px;
    height: 80%;
    background-color: var(--border-color-1);
    position: absolute;
    top: 10%;
    right: -15px;
}
@media screen and (min-width: 768px) {
    .tab-links li:not(:last-child) a {
        margin-right: 80px;
    }
    .tab-links li:not(:last-child) a:after {
        right: -40px;
    }
}
@media screen and (min-width:1200px) {
    .tab-links {
        font-size: 30px;
    }
}



/*** ACCORDION ***/
.accordion {
    border-bottom: 1px solid var(--border-color-1);
}
.accordion-wrapper {
    margin-bottom: var(--margin-p);
}
.accordion-title a {
    position: relative;
    display: block;
    color: inherit;
}
.accordion-title .name {
    display: block;
    font-size: 22px;
    color: var(--primary-color);
}
.accordion-title .title {
    display: block;
}
.accordion-title .text {
    font-size: 18px;
}
.accordion-content {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 0.3s;
}
.accordion-content .img-wrapper {
    width: min(100%, 250px);
    margin: 0 auto 30px;
}
.accordion-content .img-wrapper img {
    width: 100%;
}
.accordion-content .img-wrapper.img-sm {
    width: min(100%, 200px);
}
.accordion-content .img-wrapper.img-xs {
    width: min(100%, 150px);
}
.accordion-content > div {
    overflow: hidden;
    transition: 0.3s;
}
.accordion.act .accordion-content {
    grid-template-rows: 1fr;
}
@media screen and (min-width: 768px) {
    .accordion-title .name {
        font-size: 30px;
    }    
    .accordion-title .text {
        font-size: 20px;
    }
    .accordion-content .profile {
        display: flex;
        gap: 50px;
    }
    .accordion-content .img-wrapper {
        width: min(25%, 250px);
        flex-shrink: 0;
    }
    .accordion-content .img-wrapper.img-sm {
        width: min(20%, 200px);
        flex-shrink: 0;
    }
    .accordion-content .img-wrapper.img-xs {
        width: min(15%, 150px);
        flex-shrink: 0;
    }
    .accordion-content .text {
        flex-grow: 1;
    }
}

/*** ACCORDION THEME 1 (accordion1) ***/
.accordion1 .btn-wrapper {
    text-align: right;
    margin-bottom: 25px;
}
.accordion1 .btn-expand {
    position: relative;
    color: var(--primary-color);
    display: inline-block;
    line-height: 1;
    padding: 5px 10px;
    opacity: 0.8;
    cursor: pointer;
}
.accordion1 .btn-expand:before {
    content: '';
    display: inline-block;
    border-width: 10px 8px 0;
    border-style: solid;
    border-color: var(--primary-color) transparent;
    position: absolute;
    right: 100%;
    top: 50%;
    transform: translateY(-50%);
}
.accordion1 .btn-expand.act:before {
    transform: translateY(-50%) rotate(180deg);
}
.accordion1 .btn-expand:hover {
    opacity: 1;
}
.accordion1 .accordion {
    border-color: rgb(from var(--border-color-1) r g b / 0.4);
}
.accordion1 .accordion-title a {
    padding: 15px 40px 15px 20px;
    transition: 0.3s;
}
.accordion1 .accordion.act .accordion-title a, .accordion1 .accordion-title a:hover {
    background-color: var(--theme-color-4);
    color: inherit;
}
.accordion1 .accordion-title a:after {
    content: '';
    display: inline-block;
    border-width: 10px 8px 0;
    border-style: solid;
    border-color: var(--primary-color) transparent;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    transition: 0.3s;
}
.accordion1 .accordion.act .accordion-title a:after {
    transform: translateY(-50%) rotate(180deg);
}
.accordion1 .accordion-content > div {
    padding: 0 20px;
}
.accordion1 .accordion.act .accordion-content > div {
    padding-top: 30px;
    padding-bottom: 20px;
}
@media screen and (min-width: 768px) {
    .accordion1 .btn-expand:before {
        border-width: 12px 10px 0;
    }
    .accordion1 .accordion-title a {
        padding: 20px 50px 20px 30px;
    }
    .accordion1 .accordion-title a:after {
        border-width: 14px 12px 0;
        right: 20px;
    }
    .accordion1 .accordion-content > div {
        padding: 0 50px 0 30px;
    }
    .accordion1 .accordion.act .accordion-content > div {
        padding-top: 50px;
        padding-bottom: 30px;
    }
}

/*** ACCORDION THEME 2 (accordion2) ***/
.accordion2 .btn-wrapper {
    text-align: right;
    margin-bottom: 25px;
}
.accordion2 .btn-expand {
    position: relative;
    color: var(--primary-color);
    display: inline-block;
    line-height: 1;
    padding: 5px 10px;
    opacity: 0.8;
    cursor: pointer;
}
.accordion2 .btn-expand:before {
    content: '';
    display: inline-block;
    border-width: 10px 8px 0;
    border-style: solid;
    border-color: var(--primary-color) transparent;
    position: absolute;
    right: 100%;
    top: 50%;
    transform: translateY(-50%);
}
.accordion2 .btn-expand.act:before {
    transform: translateY(-50%) rotate(180deg);
}
.accordion2 .btn-expand:hover {
    opacity: 1;
}
.accordion2 .accordion {
    border: none;
    margin-bottom: 5px;
    background-color: rgb(from var(--theme-color-4) r g b / 0.3)
}
.accordion2 .striped .accordion:nth-child(even) { /* to remove even row background colour */
    background-color: transparent;
}
.accordion2 .accordion-title a {
    padding: 15px 40px 15px 20px;
    transition: 0.3s;
}
.accordion2 .accordion.act .accordion-title a, .accordion2 .accordion-title a:hover {
    background-color: var(--theme-color-4);
    color: inherit;
}
.accordion2 .accordion-title a:after {
    content: '';
    display: inline-block;
    border-width: 10px 8px 0;
    border-style: solid;
    border-color: var(--primary-color) transparent;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    transition: 0.3s;
}
.accordion2 .accordion.act .accordion-title a:after {
    transform: translateY(-50%) rotate(180deg);
}
.accordion2 .accordion-content > div {
    padding: 0 20px;
}
.accordion2 .accordion.act .accordion-content > div {
    padding-top: 30px;
    padding-bottom: 20px;
}
.accordion2.primary-color .accordion {
    background-color: #f2f2f2;
}
.accordion2.primary-color .accordion-title a {
    background-color: rgb(from var(--primary-color) r g b / 0.8);
    color: #fff;
}
.accordion2.primary-color .accordion-title .name {
    color: #fff;
}
.accordion2.primary-color .accordion.act .accordion-title a, .accordion2.primary-color .accordion-title a:hover {
    background-color: var(--primary-color);
    color: #fff;
}
.accordion2.primary-color .accordion-title a:after {
    border-color: #fff transparent;
}
.accordion2.secondary-color .accordion {
    background-color: #f2f2f2;
}
.accordion2.secondary-color .btn-expand {
    color: var(--secondary-color);
}
.accordion2.secondary-color .btn-expand:before {
    border-color: var(--secondary-color) transparent;
}
.accordion2.secondary-color .accordion-title a {
    background-color: rgb(from var(--secondary-color) r g b / 0.8);
    color: #fff;
}
.accordion2.secondary-color .accordion-title .name {
    color: #fff;
}
.accordion2.secondary-color .accordion.act .accordion-title a, .accordion2.secondary-color .accordion-title a:hover {
    background-color: var(--secondary-color);
    color: #fff;
}
.accordion2.secondary-color .accordion-title a:after {
    border-color: #fff transparent;
}

.accordion2.tertiary-color .accordion {
    background-color: #f2f2f2;
}
.accordion2.tertiary-color .btn-expand {
    color: var(--tertiary-color);
}
.accordion2.tertiary-color .btn-expand:before {
    border-color: var(--tertiary-color) transparent;
}
.accordion2.tertiary-color .accordion-title a {
    background-color: rgb(from var(--tertiary-color) r g b / 0.8);
    color: #fff;
}
.accordion2.tertiary-color .accordion-title .name {
    color: #fff;
}
.accordion2.tertiary-color .accordion.act .accordion-title a, .accordion2.tertiary-color .accordion-title a:hover {
    background-color: var(--tertiary-color);
    color: #fff;
}
.accordion2.tertiary-color .accordion-title a:after {
    border-color: #fff transparent;
}
@media screen and (min-width: 768px) {
    .accordion2 .btn-expand:before {
        border-width: 12px 10px 0;
    }
    .accordion2 .accordion-title a {
        padding: 20px 50px 20px 30px;
    }
    .accordion2 .accordion-title a:after {
        border-width: 14px 12px 0;
        right: 20px;
    }
    .accordion2 .accordion-content > div {
        padding: 0 50px 0 30px;
    }
    .accordion2 .accordion.act .accordion-content > div {
        padding-top: 50px;
        padding-bottom: 30px;
    }
}



/*** ANNOUNCEMENT ***/
.ann-wrapper .item {
    display: flex;
    align-items: center;
    width: 100%;
    gap: 20px;
    margin-bottom: 50px;
}
.ann-wrapper .date {
    flex-shrink: 0;
    width: 60px;
    aspect-ratio: 1;
    text-align: center;
    font-weight: var(--date-weight);
    line-height: 1;
    display: grid;
}
.ann-wrapper .month {
    font-size: 13px;
    text-transform: uppercase;
}
.ann-wrapper .day {
    font-size: 24px;
}
.ann-wrapper .title {
    line-height: var(--line-height-p);
}
.ann-wrapper .cat {
    font-weight: bold;
    margin-bottom: 5px;
}
.ann-wrapper .note {
    margin-top: 5px;
    color: #aaa;
}
.ann-wrapper a {
    color: inherit;
}
.ann-wrapper a:hover {
    color: var(--primary-color);
}
@media screen and (min-width: 768px) {
    .ann-wrapper .item {
        gap: 30px;
    }
    .ann-wrapper .date {
        width: 80px;
    }
    .ann-wrapper .month {
        font-size: 18px;
    }
    .ann-wrapper .day {
        font-size: 34px;
    }
}
@media screen and (min-width: 1200px) {
    .ann-wrapper .item {
        gap: 30px;
    }
    .ann-wrapper .date {
        width: 90px;
    }
    .ann-wrapper .month {
        font-size: 20px;
    }
    .ann-wrapper .day {
        font-size: 44px;
    }
}

/*** ANNOUNCEMENT THEME 1 (ann1) ***/
.ann1 .date {
    background-color: var(--primary-color);
    color: #fff;
    border-radius: 20px;
    place-content: center;
}
.ann1 .selectWrapper {
    min-width: 150px;
    background-color: var(--theme-color-4);
    border-radius: 20px;
}
.ann1 .selectWrapper.act {
    border-radius: 20px 20px 0 0;
}
.ann1 .selectWrapper.act .dropdown {
    background-color: var(--theme-color-4);
    border-radius: 0 0 20px 20px;
}
.ann1.secondary-color .date {
    background-color: var(--secondary-color);
}
.ann1.tertiary-color .date {
    background-color: var(--tertiary-color);
}

/*** ANNOUNCEMENT THEME 2 (ann2) ***/
.ann2 .date {
    background-color: var(--primary-color);
    color: #fff;
    border-radius: 100%;
    place-content: center;
}
.ann2 .selectWrapper {
    min-width: 150px;
    color: var(--primary-color);
    border: 1px solid var(--primary-color);
    border-radius: 20px;
}
.ann2 .selectWrapper.act {
    border-bottom-color: transparent;
    border-radius: 20px 20px 0 0;
}
.ann2 .selectWrapper.act .dropdown {
    left: -1px;
    border: 1px solid var(--primary-color);
    border-top: 0;
    border-radius: 0 0 20px 20px;
    box-sizing: content-box;
}
.ann2.secondary-color .date {
    background-color: var(--secondary-color);
}
.ann2.tertiary-color .date {
    background-color: var(--tertiary-color);
}

/*** ANNOUNCEMENT THEME 3 (ann3) ***/
.ann3 .yearWrapper {
    margin-bottom: 20px;
}
.ann3 .ann-wrapper {
    margin-bottom: 20px;
}
.ann3 .item {
    display: block;
    padding: 30px;
    margin-bottom: 0;
}
.ann3 .item:nth-child(even) {
    background-color: #eee;
}
.ann3 .date {
    width: auto;
    aspect-ratio: auto;
    font-weight: inherit;
    margin-bottom: 15px;
    text-align: left;
    color: var(--primary-color);
}
.ann3 .selectWrapper {
    min-width: 150px;
    background-color: var(--theme-color-4);
    border-radius: 20px;
}
.ann3 .selectWrapper.act {
    border-radius: 20px 20px 0 0;
}
.ann3 .selectWrapper.act .dropdown {
    background-color: var(--theme-color-4);
    border-radius: 0 0 20px 20px;
}

/*** ANNOUNCEMENT THEME 4 (ann4) ***/
.ann4 .yearWrapper {
    margin-bottom: 20px;
}
.ann4 .ann-wrapper {
    margin-bottom: 20px;
}
.ann4 .item {
    display: block;
    padding: 30px;
    margin-bottom: 0;
}
.ann4 .item:nth-child(even) {
    background-color: #eee;
}
.ann4 .date {
    width: auto;
    aspect-ratio: auto;
    font-weight: inherit;
    margin-bottom: 15px;
    text-align: left;
    color: var(--primary-color);
}
.ann4 .selectWrapper {
    min-width: 150px;
    color: var(--primary-color);
    border: 1px solid var(--primary-color);
    border-radius: 20px;
}
.ann4 .selectWrapper.act {
    border-bottom-color: transparent;
    border-radius: 20px 20px 0 0;
}
.ann4 .selectWrapper.act .dropdown {
    left: -1px;
    border: 1px solid var(--primary-color);
    border-top: 0;
    border-radius: 0 0 20px 20px;
    box-sizing: content-box;
}

/*** ANNOUNCEMENT THEME 0 (ann0) ***/
/* .ann0 .date {
    border: 3px solid #000;
    grid-template-rows: 35% 1fr;
}
.ann0 .month {
    display: grid;
    place-content: center;
    background-color: var(--theme-color-5);
    border-bottom: 3px solid #000;
}
.ann0 .day {
    display: grid;
    place-content: center;
}
.ann0 .selectWrapper {
    min-width: 150px;
    background-color: var(--theme-color-4);
    border-radius: 20px;
}
.ann0 .selectWrapper.act {
    border-radius: 20px 20px 0 0;
}
.ann0 .selectWrapper.act .dropdown {
    background-color: var(--theme-color-4);
    border-radius: 0 0 20px 20px;
} */



/*** REPORTS ***/
.report-wrapper .item {
    width: 100%;
}
.report-wrapper .cover {
    width: min(100%, 300px);
    margin-bottom: 40px;
}
.report-wrapper .cover.landscape {
    width: min(100%, 400px);
}
.report-wrapper .desc {
    width: 100%;
}
@media screen and (min-width: 1024px) {
    .report-wrapper .item {
        display: flex;
    }
    .report-wrapper .cover {
        width: min(40%, 300px);
        margin-bottom: 0;
    }
    .report-wrapper .cover.landscape {
        width: min(46%, 400px);
    }
    .report-wrapper .desc {
        width: 50%;
    }
}

/*** REPORT THEME 1 (report1) ***/
.report1 .selectWrapper {
    min-width: 150px;
    background-color: var(--theme-color-4);
    border-radius: 20px;
}
.report1 .selectWrapper.act {
    border-radius: 20px 20px 0 0;
}
.report1 .selectWrapper.act .dropdown {
    background-color: var(--theme-color-4);
    border-radius: 0 0 20px 20px;
}
.report1 .item {
    padding: 20px 10% 70px;
    margin-bottom: 50px;
    border-bottom: 1px solid var(--border-color-1);
    flex-direction: row-reverse;
    justify-content: space-between;
    gap: 20px;
}
.report1 .cover img {
    width: 100%;
    border: 1px solid #ccc;
}
.report1 .desc {
    align-self: flex-start;
}
.report1 .title {
    font-size: calc(var(--font-size-xl) * 1.15);
    color: var(--theme-color-2);
    line-height: 1.2;
    margin-bottom: 35px;
}
.report1 .links ul {
    display: flex;
    flex-wrap: wrap;
    font-size: 20px;
    margin-bottom: 40px;
}
.report1 .links ul li {
    margin-bottom: 10px;
}
.report1 .links ul li:after {
    content: '/';
    margin: 0 10px;
}
.report1 .links a {
    color: var(--primary-color);
}
.report1 .btn-wrapper a {
    display: inline-block;
    padding: 15px 20px;
    min-width: 180px;
    text-align: center;
    background-color: var(--primary-color);
    color: #fff;
    border-radius: 30px;
    font-size: 16px;
    line-height: 1;
}
@media screen and (min-width: 768px) {    
    .report1 .title {
        font-size: calc(var(--font-size-xl) * 1.5);    
    }
}
@media screen and (min-width: 1024px) {    
    .report1 .report-wrapper .desc {
        width: 43%;
    }
}
@media screen and (min-width: 1200px) {    
    .report1 .title {
        font-size: calc(var(--font-size-xl) * 1.25);
    }
}

/*** REPORT THEME 2 (report2) ***/
.report2 .selectWrapper {
    min-width: 150px;
    color: var(--primary-color);
    border: 1px solid var(--primary-color);
    border-radius: 20px;
}
.report2 .selectWrapper.act {
    border-bottom-color: transparent;
    border-radius: 20px 20px 0 0;
}
.report2 .selectWrapper.act .dropdown {
    left: -1px;
    border: 1px solid var(--primary-color);
    border-top: 0;
    border-radius: 0 0 20px 20px;
    box-sizing: content-box;
}
.report2 .item {
    padding: 20px 10% 70px;
    margin-bottom: 50px;
    border-bottom: 1px solid var(--border-color-1);
    flex-direction: row-reverse;
    justify-content: space-between;
    gap: 20px;
}
.report2 .cover img {
    width: 100%;
    border: 1px solid #ccc;
}
.report2 .desc {
    align-self: flex-start;
}
.report2 .title {
    font-size: calc(var(--font-size-xl) * 1.15);
    color: var(--theme-color-2);
    line-height: 1.2;
    margin-bottom: 35px;
}
.report2 .links ul {
    display: flex;
    flex-wrap: wrap;
    font-size: 20px;
    margin-bottom: 40px;
}
.report2 .links ul li {
    margin-bottom: 10px;
}
.report2 .links ul li:after {
    content: '/';
    margin: 0 10px;
}
.report2 .links a {
    color: var(--primary-color);
}
.report2 .btn-wrapper a {
    display: inline-block;
    padding: 15px 20px;
    min-width: 180px;
    text-align: center;
    background-color: var(--primary-color);
    color: #fff;
    border-radius: 30px;
    font-size: 16px;
    line-height: 1;
}
@media screen and (min-width: 768px) {    
    .report2 .title {
        font-size: calc(var(--font-size-xl) * 1.5);    
    }
}
@media screen and (min-width: 1024px) {    
    .report2 .report-wrapper .desc {
        width: 43%;
    }
}
@media screen and (min-width: 1200px) {    
    .report2 .title {
        font-size: calc(var(--font-size-xl) * 1.25);
    }
}

/*** REPORT THEME 3 (report3) ***/
.report3 .item {
    display: flex;
    align-items: center;
    margin-bottom: 40px;
}
.report3 .cover {
    flex-shrink: 0;
    width: min(50%, 300px);    
    margin-bottom: 0;
}
.report3 .desc {
    display: grid;
    justify-content: space-around;
    padding: 20px;
    margin-bottom: 15%;
}
.report3 .title {
    font-size: 20px;
    font-weight: 500;
    margin-bottom: 20px;
}
.report3 .btn-wrapper a {
    font-weight: 500;
    display: inline-block;
    text-align: center;
    padding: 15px;
    border-radius: 30px;
    background-color: var(--primary-color);
    color: #fff;
    min-width: 140px;
    font-size: 16px;
    line-height: 1;
}
@media screen and (min-width: 768px) {    
    .report3 .report-wrapper {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }   
}
@media screen and (min-width: 1200px) {  
    .report3 .title {
        font-size: 30px;
    }
    .report3 .btn-wrapper a {
        min-width: 160px;
    } 
}



/*** INFORMATION ***/
.info-wrapper {
    margin-bottom: var(--margin-p);
}
.info-wrapper .row {
    padding: 10px 0 30px;
    margin-bottom: 20px;
}
.info-wrapper .details > div:not(:last-child) {
    margin-bottom: 20px;
}
.info-wrapper .note {
    display: block;
    margin-top: 5px;
}

/*** INFORMATION THEME 1 (information1) ***/
.information1 .row {  
    font-size: calc(var(--font-size) * 1.125);
    border-bottom: 1px solid var(--theme-color-5);
}
.information1 .caption {
    font-weight: 600;
    margin-bottom: 30px;
}
.information1 .note {
    font-size: var(--font-size-sm);
}
@media screen and (min-width: 768px) {
    .information1 .row {
        display: flex;
        gap: 20px;
    }
    .information1 .caption {
        width: 30%;
        margin-bottom: 0;
    }
}

/*** INFORMATION THEME 2 (information2) ***/
.information2 .row {
    border-bottom: 1px solid var(--border-color-1);
}
.information2 .caption {
    font-weight: 600;
    margin-bottom: 5px;
    color: var(--primary-color);
}
.information2 .details {
    font-size: var(--font-size-lg);
    font-weight: 300;
}
.information2 .note {
    font-size: var(--font-size);
    font-weight: 400;
    color: var(--theme-color-2);
}
@media screen and (min-width: 768px) {
    .information2 .info-wrapper {
        display: flex;
        flex-wrap: wrap;
    }
    .information2 .row {
        padding-right: 20px;
        width: 50%;
        flex-grow: 1;
    }
}

/*** INFORMATION THEME 3 (information3) ***/
.information3 .row {  
    font-size: calc(var(--font-size) * 1.125);
    padding: 30px;
    margin-bottom: 0;
}
.information3 .row:first-child {
    padding-top: 10px;
}
.information3 .row:last-child {
    margin-bottom: 20px;
}
.information3 .row:nth-child(even) {
    background-color: #eee;
}
.information3 .caption {
    font-weight: 600;
    margin-bottom: 30px;
}
.information3 .note {
    font-size: var(--font-size-sm);
}
@media screen and (min-width: 768px) {
    .information3 .row {
        display: flex;
        gap: 20px;
    }
    .information3 .caption {
        width: 30%;
        margin-bottom: 0;
    }
}



/*** DIRECTORS ***/
.bio-wrapper .img {
    margin-bottom: 20px;
}

/*** DIRECTORS THEME 1 (director1) ***/
.director1 .profile {
    width: 100%;
    margin-bottom: 60px;
}
.director1 .img-wrapper {
    width: 40%;
}
.director1 .img {
    position: relative;
}
.director1 .img:before {
    content: '';
    display: block;
    width: calc(min(100vw, var(--max-width)) / 2);
    height: min(70%, 450px);
    background-image: url(../images/about/director_bg.png);
    background-repeat: no-repeat;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
}
.director1 .img img {
    max-width: 55%;
}
.director1 .name {
    font-size: 22px;
    font-weight: 500;
    color: var(--primary-color);
}
.director1 .title {
    font-weight: 500;
    color: var(--theme-color-2);
    margin: 10px 0 20px;
}
.director1 .item:nth-child(odd) img {
    margin-right: 0;
}
.director1 .item:nth-child(even) .img:before {
    left: auto;
    right: 0;
    transform: rotate(-180deg);
}
.director1 .item:nth-child(even) img {
    margin-left: 0;
}
.director1 .item:nth-child(odd) .img-wrapper {
    float: right;
    margin-left: 20px;
}
.director1 .item:nth-child(even) .img-wrapper {
    float: left;
    margin-right: 20px;
}
@media screen and (min-width: 768px) {
    .director1 .profile {
        display: flex;
    }
    .director1 .img-wrapper {
        flex-shrink: 0;
    }
    .director1 .name {
        font-size: 30px;
    }
    .director1 .item:nth-child(odd) .img-wrapper {
        order: 2;
        float: none;
    }
    .director1 .item:nth-child(even) .img-wrapper {
        float: none;
    }
}



/*** CONTACT ***/
.contact-wrapper .contact-info {
    margin-bottom: 40px;
}
.contact-wrapper .company {
    margin-bottom: 20px;
}
.contact-wrapper .address {
    margin-bottom: 35px;
}
.contact-wrapper .details > div {
    margin-bottom: 5px;
}
@media screen and (min-width: 768px) {
    .contact-wrapper:has(.img-wrapper) {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 20px;
    }
}

/*** CONTACT THEME 1 (contact 1) ***/
.contact1 .contact-wrapper {
    font-size: var(--font-size);
}
.contact1 .company {
    font-size: var(--font-size-lg);
    font-weight: 600;
}
.contact1 .details > div span {
    color: var(--primary-color);
}
.contact1 .details-table.para {
    line-height: var(--line-height-p);
}
.contact1 .details-table .row {
    margin-bottom: 10px;
}
.contact1 .details-table > div span {
    color: var(--primary-color);
}
.contact1 .img {
    padding-right: 25px;
    padding-top: 25px;
}
.contact1 .img img {
    box-shadow: 25px -25px 0 var(--primary-color);
}
@media screen and (min-width: 768px) {
    .contact1 .contact-wrapper {
        align-items: center;
    }
    .contact1 .details-table {
        display: grid;
        grid-template-columns: max-content 1fr;
    }
    .contact1 .details-table .row {
        display: grid;
        grid-template-columns: subgrid;
        grid-column: 1 / -1;
        margin-bottom: 5px;
    }
    .contact1 .details-table .row > div:only-child {
        grid-column: 1 / span 2;
    }
    .contact1 .details-table .row > div:first-child {
        padding-right: 20px;
    }
}

/*** CONTACT THEME 2 (contact 2) ***/
.contact2 .company {
    font-size: var(--font-size-lg);
    font-weight: 600;
}
.contact2 .details > div span {
    color: var(--primary-color);
}
.contact2 .details-table.para {
    line-height: var(--line-height-p);
}
.contact2 .details-table .row {
    margin-bottom: 10px;
}
.contact2 .details-table > div span {
    color: var(--primary-color);
}
@media screen and (min-width: 768px) {
    .contact2 .details-table {
        display: grid;
        grid-template-columns: max-content 1fr;
    }
    .contact2 .details-table .row {
        display: grid;
        grid-template-columns: subgrid;
        grid-column: 1 / -1;
        margin-bottom: 5px;
    }
    .contact2 .details-table .row > div:only-child {
        grid-column: 1 / span 2;
    }
    .contact2 .details-table .row > div:first-child {
        padding-right: 20px;
    }
    .contact2 .img-wrapper {
        width: calc(min(100vw, var(--max-width)) / 2);
        clip-path: polygon(15% 0, 0 100%, 100% 100%, 100% 0);
        margin-right: calc((min(100vw, var(--max-width)) - var(--content-width)) / -2);
    }
    .contact2 .img-wrapper.feature {
        margin-top: calc((var(--title-margin) + var(--font-size-title)) * -1.1);
    }
}



/*** FINANCIAL HIGHLIGHT ***/
.table-wrapper {
    overflow: auto;
}
.table-wrapper table {
    width: 100%;
    margin-bottom: var(--margin-p);
}
.finTable {
    text-align: right;
}
.finTable th {
    text-align: left;
}
.finTable thead tr {
    font-size: var(--font-thead);
}
.finTable tbody tr {
    background-color: var(--table-bg);
    font-size: var(--font-tbody);
}
.finTable.borderTable tbody th, .finTable.borderTable tbody td {
    border-bottom: 1px solid var(--table-bg-dark);
}

/*** FINANCIAL TABLE THEME 1 (finTable1) ***/
.finTable1 thead tr {
    background: var(--primary-color);
    color: #fff;
    font-size: var(--font-thead);
}
.finTable1 tr {
    background-color: var(--table-bg);
}
.finTable1 tbody:nth-of-type(even) tr {
    background-color: var(--table-bg-dark);
}
.finTable1 .collapsed tr:not(:first-child) th, .finTable1 .collapsed tr:not(:first-child) td {
    padding-top: 0;
}
.finTable1 td.table-highlight {
    background-color: rgb(from var(--primary-color) r g b / 0.2);
}
.finTable1.sticky thead th {
    background: var(--primary-color);
}
.finTable1.sticky tbody th {
    background-color: var(--table-bg);
}
.finTable1.sticky tbody:nth-of-type(even) th {
    background-color: var(--table-bg-dark);
}
.finTable1.sticky th {
    position: sticky;
    left: 0;
    z-index: 1;
    min-width: calc(var(--content-width) * 0.4);
}
.finTable1 th, .finTable1 td {
    padding: calc(var(--table-padding) * 2);
}
.finTable1.secondary-color thead tr {
    background: var(--secondary-color);
}
.finTable1.secondary td.table-highlight {
    background-color: rgb(from var(--secondary-color) r g b / 0.2);
}
.finTable1.tertiary-color thead tr {
    background: var(--tertiary-color);
}
.finTable1.tertiary td.table-highlight {
    background-color: rgb(from var(--tertiary-color) r g b / 0.2);
}
@media screen and (min-width: 768px) {
    .finTable1 th, .finTable1 td {
        padding: calc(var(--table-padding) * 1.2) calc(var(--table-padding) * 2);
    }
}



/*** FORM ***/
.form-group {
    display: grid;
    margin-bottom: 30px;
}
.form-group .form {
    margin-top: 20px;
}
.form-group.btn-group {
    margin-top: 50px;
    margin-bottom: 50px;
}
.form-group label {
    margin: 5px 0;
    font-weight: 500;
    color: var(--primary-color);
}
.form-group input[type="text"] {
    width: 100%;
    height: 40px;
    border: 1px solid var(--border-color-1);
    padding: 5px 10px 5px 10px;
    color: var(--content-color);
}
.form-group textarea {
    width: 100%;
    height: 120px;
    border: 1px solid var(--border-color-1);
    padding: 5px 10px;
    display: block;
}
.form-group .captcha-group {
    display: grid;
    grid-auto-flow: column;
    grid-template-columns: 1fr;
    align-items: center;
    gap: 20px;
}
.form-group .checkbox-group {
    display: flex;
    margin-top: 5px;
}
.form-group .checkbox-group input[type="checkbox"] {
    width: 20px;
    height: 20px;
    border: 1px solid var(--border-color-1);
    margin-right: 15px;
    flex-shrink: 0;
    display: grid;
    place-content: center;
}
.form-group .checkbox-group input[type="checkbox"]:before {
    content: '';
    width: 0.75em;
    height: 0.75em;
    box-shadow: inset 1em 1em var(--primary-color);
    transform-origin: bottom left;
    clip-path: polygon(14% 44%, 0 65%, 50% 100%, 100% 16%, 80% 0%, 43% 62%);
    opacity: 0;
}
.form-group .checkbox-group input[type="checkbox"]:checked:before {
    opacity: 1;
}
.form-group .checkbox-group span a {
    color: var(--primary-color);
}
.form-group .error_msg {
    line-height: 1.5;
    color: #ff0000;
}
.form-group .btn {
    width: 160px;
    font-weight: 500;
    line-height: 1;
    text-align: center;
    padding: 15px;
    border-radius: 30px;
    background-color: var(--primary-color);
    color: #fff;
    cursor: pointer;
}
@media screen and (max-width: 767px) {
    .form-wrapper .img-wrapper {
        display: none;
    }
}

/*** FORM THEME 1 (form1) ***/
.form1 .img {
    padding-right: 25px;
    padding-top: 25px;
}
.form1 .img img {
    box-shadow: 25px -25px 0 var(--primary-color);
}
@media screen and (min-width: 768px) {
    .form1 .form-wrapper {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 20px;
    }
    .form1 .form {
        width: 90%;
    }
}

/*** FORM THEME 2 (form2) ***/
@media screen and (min-width: 768px) {
    .form2 .form-wrapper {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 20px;
    }
    .form2 .form {
        width: 90%;
    }
    .form2 .img-wrapper {
        width: calc(min(100vw, var(--max-width)) / 2);
        clip-path: polygon(15% 0, 0 100%, 100% 100%, 100% 0);
        margin-right: calc((min(100vw, var(--max-width)) - var(--content-width)) / -2);
    }
    .form2 .img-wrapper.feature {
        margin-top: calc((var(--title-margin) + var(--font-size-title)) * -1.1);
    }
}



/*** CONTENT BLOCK ***/
.content-block-wrapper .item {
    width: 100%;
}
.content-block-wrapper .img {
    width: min(100%, 250px);
    margin: 0 auto 40px;
}
.content-block-wrapper .text {
    width: 100%;
}
@media screen and (min-width: 768px) {
    .content-block-wrapper .item {
        display: flex;
    }
    .content-block-wrapper .img {
        width: min(100%, 300px);
        margin-bottom: 0;
    }
}

/*** CONTENT BLOCK THEME 1 (content-block1) ***/
.content-block1 .selectWrapper {
    min-width: 150px;
    background-color: var(--theme-color-4);
    border-radius: 20px;
}
.content-block1 .selectWrapper.act {
    border-radius: 20px 20px 0 0;
}
.content-block1 .selectWrapper.act .dropdown {
    background-color: var(--theme-color-4);
    border-radius: 0 0 20px 20px;
}
.content-block1 .item {
    padding: 20px 40px 70px;
    margin-bottom: 50px;
    border-bottom: 1px solid var(--border-color-1);
    gap: 40px;
}
.content-block1 .title {
    font-size: var(--font-size-lg);
    color: var(--theme-color-2);
    font-weight: 700;
    margin-bottom: 20px;
}
.content-block1 .desc {
    margin-bottom: 20px;
}
.content-block1 ul.list li {
    padding-left: 0;
    line-height: var(--line-height);
    color: var(--primary-color);
}

/*** CONTENT BLOCK THEME 2 (content-block2) ***/
.content-block2 .selectWrapper {
    min-width: 150px;
    color: var(--primary-color);
    border: 1px solid var(--primary-color);
    border-radius: 20px;
}
.content-block2 .selectWrapper.act {
    border-bottom-color: transparent;
    border-radius: 20px 20px 0 0;
}
.content-block2 .selectWrapper.act .dropdown {
    left: -1px;
    border: 1px solid var(--primary-color);
    border-top: 0;
    border-radius: 0 0 20px 20px;
    box-sizing: content-box;
}
.content-block2 .item {
    padding: 20px 40px 70px;
    margin-bottom: 50px;
    border-bottom: 1px solid var(--border-color-1);
    gap: 40px;
}
.content-block2 .title {
    font-size: var(--font-size-lg);
    color: var(--theme-color-2);
    font-weight: 700;
    margin-bottom: 20px;
}
.content-block2 .desc {
    margin-bottom: 20px;
}
.content-block2 ul.list li {
    padding-left: 0;
    line-height: var(--line-height);
    color: var(--primary-color);
}



/*** BACK TO TOP ***/
a.btn-top {
    position: fixed;
    bottom: 40px;
    right: 20px;
    z-index: 10px;
    transition: 0.3s;
    opacity: 0;
    display: none;
}
a.btn-top.act {
    opacity: 0.6;
    display: block;
}
a.btn-top:hover {
    opacity: 1;
}
a.btn-top span.icon-back {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background-color: var(--primary-color);
    display: grid;
    place-content: center;
}
a.btn-top span.icon-back:before {
    content: '\279C';
    font-size: 24px;
    color: #fff;
    transform: rotate(-90deg);
}
@media screen and (min-width: 1200px) {
    a.btn-top span.icon-back {
        width: 50px;
        height: 50px;
    }
    a.btn-top span.icon-back:before {
        font-size: 30px;
    }
}

