@font-face {
    font-family: 'notosans-regular';
    font-weight: 400;
    font-style: normal;
    font-display: swap;
    font-optical-sizing: auto;
    src: url("../fonts/notosansjp/NotoSansJP-Regular.woff2") format("woff2"),
        url("../fonts/notosansjp/NotoSansJP-Regular.woff") format("woff");
}

@font-face {
    font-family: 'notosans-bold';
    font-weight: 700;
    font-style: normal;
    font-display: swap;
    font-optical-sizing: auto;
    src: url("../fonts/notosansjp/NotoSansJP-Bold.woff2") format("woff2"),
        url("../fonts/notosansjp/NotoSansJP-Bold.woff") format("woff");
}

@font-face {
    font-family: 'din-2014';
    font-style: normal;
    font-display: swap;
    font-optical-sizing: auto;
    src: url("../fonts/din-2014.woff") format("woff");
}

@font-face {
    font-family: 'roboto';
    font-style: normal;
    font-display: swap;
    font-optical-sizing: auto;
    src: url("../fonts/roboto.ttf") format("ttf");
}

:root {
    --font-notosans-regular: "notosans-regular";
    --font-notosans-bold: "notosans-bold";
    --font-din-2014: "din-2014";
    --font-roboto: "roboto";
    --primary-bgcolor: rgba(238, 242, 246, 1);
    --primary-color: rgba(168, 183, 205, 1);
    --secondary-color: rgba(215, 190, 136, 1);
    --third-color: rgba(225, 138, 106, 1);
    --text-color: rgba(74, 81, 91, 1);
}

html {
    overflow-x: hidden;
}

body {
    overflow-x: hidden;
}

.w-1000px {
    max-width: 976px;
    margin: 0 auto;
}

.container {
    max-width: 1200px;
}

/****************************** Header ******************************/
#header {
    background-color: var(--primary-bgcolor);
}

#header.fixed {
    position: fixed !important;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9999;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    background-color: #ffffff !important;
}

#header.fixed #header-main {
    background-color: #ffffff !important;
}

#header-main {
    height: 60px;
}

#header-main #nav-primary {
    list-style: none;
    display: flex;
    padding: 0;
    margin: 0;
}

#header-main #nav-primary li {
    margin-left: 20px;
}

#header-main #nav-primary li a {
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    font-size: 15px;
    color: var(--text-color);
    letter-spacing: 0.75px;
}

#header-top {
    padding: 23px 0 0 0;
}

#header-top,
#header-main {
    width: calc(100% - 25px);
    margin: 0 auto;
}

#header-top .top-contact .text {
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 13px;
    color: var(--text-color);
    letter-spacing: 1.3px;
    line-height: 18.2px;
}

#header-top .tel {
    font-family: var(--font-din-2014);
    font-weight: 600;
    font-size: 25px;
    letter-spacing: 1px;
}

#header .mobile-menu {
    background-color: rgb(74 81 91 / 95%);
    color: white;
    padding: 20px 0;
    position: absolute;
    z-index: 9999;
    width: 100%;
    overflow: hidden;
    transition: all 0.3s ease;
    flex-direction: column;
    justify-content: space-between;
    display: none;
    top: 60px !important;
    height: calc(100vh - 60px);
}

.logo-sticky {
    display: none;
}

.logo-sticky svg {
    width: 150px;
}

.home #header .mobile-menu {
    top: -100vh;
}

.home .header.menu-open {
    background-color: #ffffff !important;
}

#header .mobile-menu a .arrow {
    float: right;
}

#header .mobile-contact {
    text-align: center;
    margin-top: 20px;
    padding: 0 40px;
}

#header .mobile-contact .phone {
    background-color: white;
    border-radius: 30px;
    margin-bottom: 20px;
    height: 60px;
    padding: 0 20px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

#header .mobile-contact .phone a {
    color: var(--text-color);
    padding: 0;
    font-family: var(--font-din-2014);
    font-size: 23px;
    letter-spacing: 1px;
    font-weight: 600;
}

#header .mobile-contact .inquiry {
    background-color: var(--third-color);
    color: white;
    border-radius: 30px;
    margin-bottom: 15px;
    font-weight: 500;
    height: 60px;
    padding: 0 20px;
    width: 100%;
    display: flex;
    align-items: center;
    font-family: var(--font-notosans-regular);
    font-size: 17px;
    letter-spacing: 1.7px;
    justify-content: center;
}

#header .mobile-contact .inquiry svg {
    margin-right: 4px;
}

.mobile-menu #nav-primary {
    list-style: none;
    padding: 0;
    margin: 0;
}

.mobile-menu #nav-primary li {
    margin: 0;
}

#header .mobile-menu a {
    color: white;
    text-decoration: none;
    display: block;
    padding: 25px 40px;
}

#header .mobile-menu a svg {
    margin-left: 10px;
}

.mobile-contact .top-contact .text {
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 13px;
    color: #ffffff;
    letter-spacing: 1.3px;
    line-height: 18.2px;
}

#header .mobile-nav-button .navbar-brand svg {
    width: 150px;
}

#header .mobile-nav-button {
    padding: 0 15px;
}

#header .mobile-nav-button .toggle-mobile-menu {
    padding: 5px 8px;
}

#header .mobile-nav-button .toggle-mobile-menu svg {
    width: 15px;
    height: 12px;
    margin-top: -2px;
}

#header .mobile-nav-button a.btn {
    padding: 5px 8px;
}

#header .mobile-nav-button a.btn svg {
    width: 20px;
    height: 20px;
    margin-top: -1px;
}

/****************************** Footer ******************************/
.section-contact-2 {
    padding: 120px 0 70px;
    background: url('../img/contact.webp') lightgray 50% / cover no-repeat;
}

.section-title {
    font-size: 80px;
    font-style: normal;
    font-weight: 700;
    line-height: 80px;
    letter-spacing: 5.6px;
    margin-bottom: 10px;
    font-family: var(--font-din-2014);
}

.section-subtitle {
    font-size: 25px;
    font-weight: 500;
    letter-spacing: 2.5px;
    margin-bottom: 10px;
    font-family: var(--font-notosans-regular);
}

.section-description {
    font-family: var(--font-notosans-regular);
    font-size: 15px;
    font-weight: 400;
    letter-spacing: 1px;
}

.section-contact-2 .row.g-0 {
    display: flex;
    align-items: center;
    justify-content: center;
}

.section-contact-2 .row.g-0 .col-12 {
    height: 183px;
    cursor: pointer;
}

.section-contact-2 .row.g-0 .col-12:hover {
    background-color: var(--secondary-color) !important;
}

.section-contact-2 .row.g-0 .col-12:nth-of-type(1) {
    background-image: url('../img/home-page/contact-bg.webp');
    position: relative;
    z-index: 2;
}

.section-contact-2 .row.g-0 .col-12:nth-of-type(1)::after {
    content: "";
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: rgb(215 190 136 / 31%);
    position: absolute;
    z-index: -1;
    display: none;
}

.section-contact-2 .row.g-0 .col-12:nth-of-type(1):hover::after {
    display: block;
}

.section-contact-2 .row.g-0 .col-12 p,.section-contact-2 .row.g-0 .col-12 .contact-link  {
    font-family: var(--font-notosans-regular);
    font-weight: 700;
    color: #ffffff;
    font-size: 25px;
    letter-spacing: 1px;
    margin-bottom: 0;
}
.section-contact-2 .row.g-0 .col-12 .contact-link {
    width: 100%;
    height: 100%;
}
.section-contact-2 .row.g-0 .col-12 .tel {
    font-family: var(--font-din-2014);
    font-weight: 600;
    font-size: 25px;
    letter-spacing: 1px;
    color: #ffffff;
}

.section-contact-2 .row.g-0 .col-12:nth-of-type(2) {
    background-color: var(--text-color);
}

.section-map-2 {
    padding: 110px 0;
}

.section-map-2 iframe {
    height: 300px;
}

.section-working-hours .w-1000px {
    border-radius: 20px;
    box-shadow: 4px 4px 20px 0px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    background-color: #ffffff;
}

.section-working-hours .col-md-6.row {
    background-color: var(--primary-color);
    padding: 25px 25px 25px 35px;
    align-items: center;
}

.section-working-hours .col-right {
    padding: 36px;
}

.col-head p {
    color: var(--text-color);
    font-weight: 400;
    font-family: var(--font-notosans-regular);
    font-size: 13px;
    letter-spacing: 0.39px;
}

.col-head p:nth-of-type(1) {
    color: var(--text-color);
    font-weight: 700;
    font-family: var(--font-notosans-bold);
    font-size: 15px;
    letter-spacing: 0.45px;
}


.schedule-table table {
    width: 100%;
    position: relative;
}

.schedule-table table thead {
    border-bottom: 1px solid rgba(228, 227, 227, 1);
}

.schedule-table td {
    text-align: center;
    padding: 10px 0px 10px 5px;
    font-size: 14px;
    border-bottom: 1px solid rgba(228, 227, 227, 1);
}

.schedule-table tbody tr td:nth-of-type(1){
    padding: 14px 0px 10px 5px;
}

.schedule-table th {
    font-family: var(--font-notosans);
    color: rgba(58, 58, 58, 1);
    font-weight: 500;
    text-align: center;
    padding: 8px;
    font-size: 15px;
}

.schedule-note {
    font-size: 11px;
    color: var(--text-color);
    font-weight: 400;
    line-height: 1.5;
    margin-top: 10px;
    font-family: var(--font-notosans-regular);
}

.circle-check {
    color: #5c9795;
    font-size: 0.8rem;
}

.circle-x {
    color: #999;
    font-size: 0.8rem;
}

.triangle-warn {
    color: #ddd;
    font-size: 0.8rem;
}

.schedule-section {
    background-color: rgba(250, 246, 243, 1);
}

.schedule-circle {
    width: 12px;
    height: 12px;
    background-color: var(--text-color);
    margin-left: 10px;
    border-radius: 50%;
    margin-top: 10px;
}

.schedule-triangle {
    margin-top: 3px;
}

.schedule-table .saturday {
    color: rgba(94, 161, 190, 1);
}

.schedule-table .saturday span {
    line-height: 8.8px;
    font-size: 11px;
    font-family: var(--font-notosans-regular);
    font-weight: 400;
}

.schedule-table .sunday {
    color: rgba(221, 102, 104, 1);
}

.section-working-hours {
    position: relative;
    z-index: 2;
}

.footer-section {
    height: 622px;
    background-image: url("../img/footer.webp");
    position: relative;
    z-index: 1;
    margin-top: -180px;
}

.footer-section::after {
    content: "";
    background-color: rgb(255 255 255 / 40%);
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.footer-section .footer-main {
    z-index: 2;
    height: 285px;
    background-color: rgb(255 255 255 / 70%);
}

.logo-text {
    width: 246px;
    height: 100px;
    background-color: var(--text-color);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.footer-section .tel {
    width: 246px;
}

.footer-section .tel span {
    color: var(--text-color);
    font-family: var(--font-din-2014);
    font-weight: 700;
    font-size: 20px;
}

.logo-text p:nth-of-type(1) {
    color: #ffffff;
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 23px;
    margin-bottom: 0;
    line-height: 23px;
}

.logo-text p:nth-of-type(2) {
    color: #ffffff;
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 15px;
    margin-bottom: 0;
    letter-spacing: 1.5px;
}

.footer-section #footer-nav li a, .footer-section #second-footer-nav li a{
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    font-size: 15px;
    color: var(--text-color);
    letter-spacing: 0.75px;
}

.footer-section #footer-nav li, .footer-section #second-footer-nav li{
    margin-left: 20px;
    margin-top: 10px;
}

.footer-section #footer-nav, .footer-section #second-footer-nav{
    list-style: none;
    display: flex;
    padding: 0;
    margin: 0;
}
.footer-section #second-footer-nav {
    flex-wrap: wrap;
    justify-content: center;
}

.btn-mail {
    background-color: var(--third-color);
    border: none;
    color: #ffffff;
    height: 50px;
    text-align: center;
    padding: 0 25px;
    font-size: 17px;
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    letter-spacing: 1.7px;
}

.footer-main .text-mail {
    color: var(--text-color);
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    letter-spacing: 1px;
    font-size: 15px;
}

.all-rights {
    border-top: 1px solid rgba(218, 224, 234, 1);
    margin: 30px 0 0 0;
    padding: 8px 0;
}

/****************************** Home Page ******************************/
.home .hero-section {
    height: 700px;
    background-color: var(--primary-bgcolor);
}

.home .hero-section::after {
    width: calc(100% - 220px);
    left: 220px;
}

.home .hero-section .box-content {
    margin-left: 120px;
    width: calc(100% - 120px);
    z-index: 1;
    position: relative;
}

.home .hero-section::before {
    width: calc(100% - 220px);
    left: 220px;
    background: linear-gradient(270deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 30%) 100%);
}

.home .hero-section .advertisement .text-1 {
    font-size: 100px;
    font-family: var(--font-notosans-bold);
    font-weight: 700;
}

.home .hero-section .advertisement .text-2 {
    font-size: 50px;
    font-family: var(--font-notosans-bold);
    font-weight: 90px;
}

.home .hero-section .advertisement .text-3 {
    font-size: 25px;
    font-family: var(--font-notosans-bold);
    font-weight: 700;
}

.home .hero-section .station {
    background-color: var(--text-color);
    color: white;
    font-size: 17px;
    border-radius: 20px;
    padding: 5px 10px;
    display: inline-flex;
    align-items: center;
}

.home .hero-section .station svg {
    margin-right: 5px;
}

.hero-section .schedule-table {
    width: 400px;
    position: absolute;
    right: 0;
    bottom: 50px;
    background-color: #ffffff;
    z-index: 1;
    padding: 20px;
}

.calendar-right-sticky .schedule-table {
    width: 400px;
    position: fixed;
    right: -400px;
    background-color: #ffffff;
    z-index: 999;
    padding: 20px;
    top: calc(23% + 130px);
    height: max-content;
    transition: right 0.4s ease-in-out;
}

.hero-section .calendar-badge {
    position: absolute;
    left: -104px;
    top: 30px;
    transform: rotate(90deg);
    background-color: #ffffff;
    padding: 5px 20px;
}

.calendar-right-sticky .calendar-badge {
    position: absolute;
    left: -115px;
    height: 50px;
    top: 28px;
    transform: rotate(90deg);
    background-color: #ffffff;
    padding: 0 20px;
    line-height: 50px;
    cursor: pointer;
    border: none;
}

.calendar-right-sticky .calendar-badge svg {
    margin: -1px 5px 0 0;
}

.hero-section .calendar-badge span,
.calendar-right-sticky .calendar-badge span {
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    color: var(--text-color);
    font-size: 17px;
}

.hero-section .schedule-note,
.calendar-right-sticky .schedule-note {
    font-size: 13px;
    letter-spacing: 0.39px;
}

.hero-section .schedule-note p:nth-of-type(2),
.calendar-right-sticky .schedule-note p:nth-of-type(2) {
    font-weight: 700;
    font-size: 15px;
    font-family: var(--font-notosans-bold);
    letter-spacing: 0.45px;
}
iframe.g-cal {
    border-radius: 8%;
}
.introduce-section {
    padding: 100px 0;
    position: relative;
}

.introduce-section::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 40%;
    width: 100%;
    background-color: var(--primary-bgcolor);
}

.introduce-section .col-md-8 {
    padding-right: 50px;
}

.introduce-section .col-md-4 {
    padding-right: 65px;
}

.introduce-section .image-intro-1,
.introduce-section .image-intro-2 {
    width: 100%;
}

.introduce-section .box-text {
    backdrop-filter: blur(30px);
    background-color: rgb(255 255 255 / 80%);
    padding: 40px;
    position: absolute;
    max-width: 814px;
    left: 39%;
    top: 78%;
    z-index: 1;
}

.introduce-section .box-text .text-1 {
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 25px;
    letter-spacing: 2.5px;
    color: var(--text-color);
    line-height: 37.5px;
}

.introduce-section .box-text .text-2 {
    font-size: 15px;
    letter-spacing: 0.75px;
    font-family: var(--font-notosans-regular);
    font-weight: 400;
}

.promise-section {
    padding: 80px 0;
}

.promise-section .section-subtitle span {
    font-family: var(--font-din-2014);
    font-size: 40px;
    font-weight: 600;
}


.promise-section .img {
    margin-bottom: 30px;
}

.promise-section .img img {
    width: 100%;
}

.promise-section .promise-order {
    display: flex;
    align-items: center;
    height: 40px;
    margin-bottom: 30px;
}

.promise-section .number {
    color: #FFF;
    text-align: center;
    font-size: 36px;
    font-style: normal;
    font-weight: 600;
    line-height: 150%;
    letter-spacing: 2px;
    display: flex;
    width: 40px;
    height: 40px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background: var(--text-color);
    margin-right: 10px;
    font-family: var(--font-din-2014);
}

.promise-section .name {
    font-size: 23px;
    font-style: normal;
    font-weight: 700;
    line-height: 120%;
    letter-spacing: 2.3px;
    margin-bottom: 0;
    width: calc(100% - 50px);
}

.promise-section .content {
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 180%;
    /* 27px */
    letter-spacing: 0.75px;
}

.promise-section .promise-item-next {
    position: relative;
    height: 100%;
    background: url('../img/promise-6.webp') lightgray 50% / cover no-repeat;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    cursor: pointer;
}

.promise-section .promise-item-next:hover {
    background: url('../img/promise-6.webp') rgb(215, 190, 136, 1) 50% / cover no-repeat;
}

.promise-section .promise-item-next .text {
    position: absolute;
    left: 50%;
    transform: translate(-50%);
    bottom: 50px;
    color: #ffffff;
    font-family: var(--font-notosans-regular);
    font-weight: 700;
    font-size: 30px;
    width: max-content;
    letter-spacing: 3px;
}

.home .infor-service-section .w-1000px {
    max-width: 1020px;
}

.faq-section .accordion-item {
    background-color: unset;
    border-radius: 0;
    border: none;
    border-bottom: 1px solid rgba(208, 205, 205, 1);
}

.accordion-item:first-of-type {
    border-top: 1px solid rgba(208, 205, 205, 1);
}

#faqAccordion {
    padding: 40px;
}

.accordion-button {
    font-size: 17px;
    font-family: var(--font-notosans-regular);
    color: rgba(58, 58, 58, 1);
    font-weight: 400;
    background-color: transparent;
    padding: 20px 15px;
}

.accordion-button:not(.collapsed) {
    color: #555;
    background-color: transparent;
    box-shadow: none;
}

.accordion-button:focus {
    box-shadow: none;
    border-color: transparent;
}

.accordion-button::before {
    content: "Q";
    color: var(--primary-color);
    font-weight: 400;
    margin-right: 10px;
    font-family: var(--font-din-2014);
    font-size: 27px;
}

.accordion-button::after {
    background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2218%22%20height%3D%2219%22%20viewBox%3D%220%200%2018%2019%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cline%20y1%3D%229.25%22%20x2%3D%2218%22%20y2%3D%229.25%22%20stroke%3D%22%23A8B7CD%22%20stroke-width%3D%222%22%2F%3E%3Cline%20x1%3D%229.25%22%20y1%3D%220.5%22%20x2%3D%229.25%22%20y2%3D%2218.5%22%20stroke%3D%22%23A8B7CD%22%20stroke-width%3D%222%22%2F%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-size: contain;
    width: 20px;
    height: 20px;
    background-size: 20px;
    transform: rotate(0deg);
}

.accordion-button:not(.collapsed)::after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cline y1='12' x2='24' y2='12' stroke='%23A8B7CD' stroke-width='2'/%3E%3C/svg%3E");
    transform: rotate(0deg);
}


.accordion-body {
    font-size: 0.85rem;
    color: #666;
    line-height: 1.6;
    padding: 0 15px 20px 40px;
    position: relative;
}

.accordion-body::before {
    content: "A";
    color: #E34E6E;
    font-weight: 400;
    margin-right: 10px;
    font-family: var(--font-din-2014);
    font-size: 27px;
    position: absolute;
    left: 15px;
}

.faq-section {
    padding: 170px 0;
}

.faq-description {
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 15px;
    letter-spacing: 0.7px;
}

/****************************** About Page ******************************/

/*======= Hero Section =======*/
.hero-section {
    height: 250px;
    position: relative;
    display: flex;
    align-items: center;
    background-color: var(--primary-bgcolor);
}

.hero-section::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(270deg, rgba(255, 255, 255, 0) 0%, #FFFFFF 100%);
    z-index: 1;
}

.hero-section::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-size: cover;
}

.page-template-p_About .hero-section::after {
    width: 60%;
}

.hero-section .container {
    z-index: 2;
    position: relative;
}

.hero-section .breadcrumb {
    gap: 10px;
    align-items: center;
    text-transform: uppercase;
}

.hero-section .breadcrumb * {
    font-family: var(--font-notosans);
    color: var(--text-color);
    font-size: 13px;
    letter-spacing: 1.3px;
    font-weight: 700;
}

.hero-section .box-text {
    display: flex;
    align-items: center;
    gap: 20px;
}

.hero-section .hero-title {
    font-family: var(--font-notosans);
    color: var(--text-color);
    font-size: 40px;
    font-weight: 700;
    letter-spacing: 4px;
}

.hero-section .hero-subtitle {
    font-size: 13px;
    color: var(--text-color);
    font-weight: 600;
}

/*======= Intro Section =======*/
.intro-section {
    background-color: var(--primary-bgcolor);
    padding: 60px 0;
    position: relative;
}

.intro-section .box-intro {
    max-width: 1000px;
    background-color: rgba(255, 255, 255, 0.8);
    box-shadow: 3px 3px 30px 0px rgba(74, 81, 91, 0.1);
    margin: -100px auto 0;
    padding: 50px;
}

.intro-section .box-intro .intro-title {
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 25px;
    letter-spacing: 2.5px;
    color: var(--text-color);
}

.intro-section .box-intro .intro-text {
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 15px;
    color: var(--text-color);
    letter-spacing: 0.75px;
}

.intro-section .box-intro p:nth-last-child(1) {
    margin-bottom: 0;
}

.intro-section .intro-list {
    list-style: none;
    display: flex;
    gap: 15px;
    width: max-content;
    margin: 60px auto 0;
    padding: 0;
}

.intro-section .intro-list li {
    border: 1px solid rgba(168, 183, 205, 1);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 30px;
    font-size: 17px;
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    background-color: #ffffff;
    width: 200px;
    gap: 15px;
    height: 60px;
}

.intro-section .intro-list li a {
    color: var(--text-color);
}

.intro-section .intro-list li a span {
    margin-right: 10px;
}

.contact-right-sticky {
    position: fixed;
    z-index: 999;
    width: max-content;
    background-color: var(--third-color);
    height: 50px;
    line-height: 50px;
    padding: 0 20px;
    top: 23%;
    transform: rotate(90deg);
    right: -77px;
}

.contact-right-sticky:hover {
    background-color: var(--secondary-color);
}

.contact-right-sticky:hover svg rect,
.calendar-right-sticky .calendar-badge:hover svg path {
    fill: var(--secondary-color);
}

.calendar-right-sticky .calendar-badge:hover span {
    color: var(--secondary-color);
}

.contact-right-sticky a {
    font-size: 17px;
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    color: #ffffff;
}

.contact-right-sticky svg {
    margin: -1px 5px 0 0;
}

/*======= Services Section =======*/
.services-section {
    padding: 100px 0;
}

.section-title-left {
    position: relative;
    font-weight: 700;
    font-family: var(--font-notosans-bold);
    font-size: 25px;
    letter-spacing: 2.5px;
    color: var(--text-color);
    padding-left: 15px;
    margin-bottom: 30px;
}

.section-title-left::before {
    position: absolute;
    content: "";
    height: 100%;
    width: 5px;
    left: 0;
    top: 0;
    background-color: var(--text-color);
}

.section-title-center {
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 30px;
    letter-spacing: 3px;
    color: var(--text-color);
    line-height: 37.5px;
    text-align: center;
}

.page-template-p_About .services-section .section-title-center {
    font-size: 25px;
    letter-spacing: 2.5px;
}

.box-image-center .box-image {
    margin-bottom: 30px;
}

.box-image-center .box-image img {
    width: 100%;
}

.box-image-center .box-text .text-title {
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 23px;
    color: var(--text-color);
    letter-spacing: 2.3px;
    text-align: center;
    margin-bottom: 30px;
}

.box-image-center .box-text .text-description * {
    font-size: 14px;
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    letter-spacing: 0.75px;
    margin-bottom: 0;
}

.box-image-center .box-text .text-description ul {
    margin-bottom: 0;
    margin-top: 10px;
}

/*======= Information Section =======*/
.information-section {
    padding: 80px 0;
    background-color: var(--primary-bgcolor);
}

.section-des-center {
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 15px;
    letter-spacing: 1.5px;
}

.information-section .w-1000px .row {
    box-shadow: 3px 3px 30px 0px rgba(74, 81, 91, 0.1);
    background-color: #ffffff;
    height: 300px;
}

.information-section .w-1000px .row img {
    height: 100%;
}

.information-section .w-1000px .row .infor-title {
    position: relative;
    font-weight: 700;
    font-family: var(--font-notosans-bold);
    font-size: 23px;
    letter-spacing: 2.3px;
    color: var(--text-color);
    padding-left: 15px;
    margin-bottom: 30px;
}

.information-section .w-1000px .row .infor-title::before {
    position: absolute;
    content: "";
    height: 100%;
    width: 5px;
    left: 0;
    top: 0;
    background-color: var(--text-color);
}

.information-section .w-1000px .row .infor-des {
    font-weight: 400;
    font-family: var(--font-notosans-regular);
    font-size: 15px;
    color: var(--text-color);
    letter-spacing: 1.5px;
}

.information-section .w-1000px .col-inner {
    padding: 30px;
}

/*======= Facility Section =======*/
.facility-section {
    padding: 80px 0;
    background-color: var(--primary-bgcolor);
}

.facility-section .box-image-center {
    background-color: #ffffff;
    box-shadow: 3px 3px 30px 0px rgba(74, 81, 91, 0.1);
}

.facility-section .box-text {
    padding: 0 20px 30px;
}

.facility-section .w-1000px>.row .col-md-6 {
    padding-bottom: 40px;
}

/*======= Introducing Section =======*/
.introducing-section {
    padding: 100px 0 50px 0;
}

.introducing-section .introducing-des {
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 15px;
    color: var(--text-color);
    letter-spacing: 0.6px;
}

.introducing-infor {
    margin-top: 40px;
}

.introducing-infor p {
    margin-bottom: 0;
    text-align: right;
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 15px;
    color: var(--text-color);
    letter-spacing: 0.6px;
}

.read-more {
    border: none;
    background-color: rgba(168, 183, 205, 1);
    border-radius: 25px;
    display: flex;
    padding: 10px 40px;
}

.read-more:hover {
    background-color: var(--secondary-color);
}

.read-more a {
    color: #ffffff;
    font-size: 17px;
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    letter-spacing: 0.85px;
}

.read-more a span {
    margin-right: 15px;
}

.read-more a svg {
    margin-top: -1px;
}

.about-page.section-7 {
    width: 100%;
    height: 600px;
    background-image: url("../img/about-page/bg-ss-7.webp");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: bottom;
}

.about-page.section-equipment .box-white {
    max-width: 1000px;
    background-color: rgba(255, 255, 255, 0.8);
    box-shadow: 3px 3px 30px 0px rgba(74, 81, 91, 0.1);
    margin: -150px auto 0;
    padding: 50px;
}

.about-page.section-equipment .box-white .box-title {
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 25px;
    letter-spacing: 2.5px;
    color: var(--text-color);
}

.about-page.section-equipment .box-white .box-text,
.about-page.section-equipment .box-white .box-text h3 {
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 15px;
    color: var(--text-color);
    letter-spacing: 0.75px;
}


.about-page.section-equipment .equipment-card {
    height: 384px;
    border: none;
    border-radius: 0;
    color: white;
    transition: transform 0.2s;
}

.about-page.section-equipment .equipment-card:hover {
    transform: translateY(-5px);
}

.about-page.section-equipment .card-body {
    padding: 15px;
    background-color: rgba(74, 81, 91, 1);
    height: 187px;
}

.about-page.section-equipment .card-title {
    font-size: 23px;
    font-weight: 700;
    font-family: var(--font-notosans-bold);
    letter-spacing: 2.3px;
    color: #ffffff;
    text-align: center;
}
.about-page.section-equipment .card-first .card-title {
    letter-spacing: 6.9px;
}
.about-page.section-equipment .card-text {
    font-size: 15px;
    font-weight: 400;
    font-family: var(--font-notosans-regular);
    letter-spacing: 0.75px;
    color: #ffffff;
}

.about-page.section-equipment .img-container {
    height: 230px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.about-page.section-equipment .img-fluid {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

@media (min-width: 768px) {
    .facility-section .w-1000px>.row .col-md-6:nth-child(odd) {
        padding-left: 0 !important;
        padding-right: 20px !important;
    }

    .facility-section .w-1000px>.row .col-md-6:nth-child(even) {
        padding-left: 20px !important;
        padding-right: 0 !important;
    }
}

@media (max-width: 768px) {
    .home #header {
        position: absolute;
        z-index: 9999;
        width: 100%;
        background-color: unset;
    }

    /*======= Footer =======*/
    .section-title {
        font-size: 40px;
        line-height: 40px;
    }

    .section-contact-2 {
        position: relative;
        background-image: url('../img/home-page/contact-mobile-bg.webp');
        padding: 50px 25px;
    }

    .section-contact-2::after {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background: #ffffff73;
        z-index: 1;
    }

    .section-contact-2 .w-1000px {
        position: relative;
        z-index: 2;
    }

    .section-contact-2 .row.g-0 .col-12 p {
        font-size: 17px;
    }

    .section-contact-2 .row.g-0 .col-12 .tel {
        font-size: 27px;
        margin-top: 20px;
    }

    .section-contact-2 .row.g-0 .col-12:nth-of-type(1) {
        height: 160px;
    }

    .section-contact-2 .row.g-0 .col-12:nth-of-type(2) {
        height: 80px;
    }

    .section-contact-2 .row.g-0 .col-12:nth-of-type(1) {
        background-image: url('../img/home-page/contact-col-mobile.webp');
    }

    .section-contact-2 .row.g-0 .col-12:nth-of-type(2) svg {
        position: absolute;
        right: 30px;
        top: 39%;
    }

    .section-map-2 {
        padding: 0;
    }

    .section-map-2 .map-text {
        padding: 15px 25px;
    }

    .section-subtitle {
        font-size: 17px;
    }

    .section-description {
        font-size: 14px;
    }

    .section-description strong {
        font-size: 15px;
        font-weight: bold;
        color: var(--text-color);
        font-family: var(--font-notosans-bold);
        width: 95px;
    }

    .section-description svg {
        margin: 5px;
    }

    .section-working-hours {
        padding: 0 15px;
    }

    .section-working-hours .col-md-6.row {
        padding: 35px 58px;
        margin: 0;
    }

    .section-working-hours .col-md-6.row .col-md-6 {
        margin-bottom: 20px;
        text-align: center;
    }

    .section-working-hours .col-md-6.row .col-md-6:nth-of-type(2) {
        margin-bottom: 0;
    }

    .section-working-hours .col-md-6.row .col-md-6 img {
        width: 100%;
    }

    .footer-section {
        margin-top: -120px;
        height: 622px;
        background-image: url("../img/home-page/footer-mobile.webp");
    }

    .footer-main .col-md-4 {
        display: flex;
        flex-direction: column;
        align-items: center;
        margin-top: 30px;
    }

    .logo-text {
        margin-bottom: 25px;
    }

    .all-rights p {
        font-size: 11px;
        font-weight: 400;
        font-family: var(--font-din-2014);
    }

    /*======= Home Page =======*/
    .home .hero-section .advertisement .text-1 {
        font-size: 60px;
        line-height: 60px;
        margin: 10px 0;
    }

    .home .hero-section .advertisement .text-2 {
        font-size: 30px;
    }

    .home .hero-section .advertisement .text-3 {
        font-size: 20px;
        letter-spacing: 2px;
        line-height: 30px;
    }

    .home .hero-section .box-content {
        margin-left: 25px;
        margin-top: 100px;
        width: calc(100% - 50px);
    }

    .home .hero-section::before,
    .home .hero-section::after {
        width: 100%;
        left: 0;
    }

    .home .hero-section .hero-content {
        text-align: left !important;
    }

    .home .hero-section .station {
        padding: 0px 20px;
    }

    .hero-section .schedule-table .calendar-badge {
        display: none;
    }

    .hero-section .schedule-table {
        width: calc(100% - 30px);
        left: 15px;
        right: unset;
        bottom: -55px;
    }

    .home .hero-section {
        align-items: flex-start;
    }

    .introduce-section .col-md-8 {
        padding: 0 25px;
        margin: 0;
    }

    .introduce-section .box-text {
        position: unset;
        padding: 20px 10px;
    }

    .introduce-section .box-text .text-1 {
        font-size: 17px;
        letter-spacing: 1.7px;
        line-height: 25.5px;
    }

    .introduce-section .box-text .text-2 {
        font-size: 14px;
        line-height: 25.2px;
        letter-spacing: 0.7px;
    }

    .introduce-section::before {
        height: 80%;
    }

    .introduce-section .col-md-4 {
        padding: 0;
        margin-top: 24px;
    }

    .promise-section {
        padding: 0 0 70px 0;
    }

    .promise-section .container {
        padding: 0 25px;
    }

    .promise-section .section-subtitle {
        text-align: center;
    }

    .promise-section .section-subtitle span {
        font-size: 27px;
    }

    .promise-section .number {
        font-size: 27px;
    }

    .promise-section .name {
        font-size: 17px;
        letter-spacing: 1.7px;
    }

    .promise-section .content {
        font-size: 14px;
        letter-spacing: 0.7px;
    }

    .promise-section .promise-order {
        margin-bottom: 20px;
    }

    .promise-section .promise-item {
        margin-bottom: 50px;
    }

    .promise-section .promise-item-next {
        height: 80px;
        flex-direction: row-reverse;
        justify-content: space-between;
        padding: 0 28px;
    }

    .promise-section .promise-item-next .text {
        position: unset;
        font-size: 17px;
        letter-spacing: 1.7px;
        transform: unset;
    }

    .promise-section .promise-item-next svg {
        width: 40px;
    }

    .infor-service-section .container {
        padding: 0;
    }

    .accordion-button {
        font-size: 14px;
        padding: 15px 0;
    }

    .accordion-body::before {
        left: 2px;
    }

    .accordion-body {
        padding: 0 15px 20px 25px;
    }

    .faq-description {
        margin-top: 30px;
        padding: 0;
    }

    #faqAccordion {
        padding: 0;
    }

    .faq-section {
        padding: 70px 25px 40px 25px;
    }

    .faq-section .section-subtitle {
        margin-bottom: 40px;
    }

    .faq-description {
        font-size: 14px;
        letter-spacing: 0.56px;
    }

    .calendar-right-sticky {
        display: none !important;
    }

    /*======= Hero Section =======*/
    .hero-section::before {
        background: linear-gradient(270deg, rgba(255, 255, 255, 0) 0%, #FFFFFF 100%);
    }

    .hero-section::after {
        width: 100% !important;
    }

    .hero-section .breadcrumb {
        margin-bottom: 0;
    }

    .hero-section .box-text {
        gap: 0;
        flex-direction: column;
        align-items: flex-start;
    }

    .hero-section .hero-title {
        margin-bottom: 0;
        letter-spacing: 2px;
    }

    .contact-mobile-sticky {
        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        z-index: 999;
        height: 60px;
    }

    .contact-mobile-sticky .row .col-6,
    .contact-mobile-sticky .row {
        height: 100%;
    }

    .contact-mobile-sticky .row .col-6:nth-of-type(1) {
        background-color: var(--third-color);
    }

    .contact-mobile-sticky .row svg {
        margin: -2px 5px 0 0;
    }

    .contact-mobile-sticky .row a {
        color: #ffffff;
    }

    .contact-mobile-sticky .row .col-6:nth-of-type(2) {
        background-color: var(--text-color);
    }

    .contact-mobile-sticky .row .col-6:nth-of-type(2) p {
        color: #ffffff;
        font-size: 16px;
        line-height: 16px;
        font-family: var(--font-notosans-bold);
        font-weight: 700;
    }

    .contact-mobile-sticky .row .col-6:nth-of-type(2) p:nth-of-type(2) {
        margin-top: 7px;
        color: #ffffff;
        font-size: 16px;
        font-family: var(--font-din-2014);
    }

    /*======= Intro Section =======*/
    .intro-section {
        padding: 20px 0;
    }

    .intro-section .box-intro {
        background-color: unset;
        padding: 0;
        margin: 0;
        box-shadow: none;
    }

    .intro-section .box-intro .intro-title {
        font-size: 20px;
        letter-spacing: 1px;
    }

    .intro-section .box-intro .intro-text {
        font-size: 14px;
        letter-spacing: 0.28px;
    }

    .intro-section .intro-list {
        flex-direction: column;
        width: 100%;
        margin-top: 33px;
        gap: 10px;
    }

    .intro-section .intro-list li {
        width: 100%;
        height: 50px;
        justify-content: space-between;
        padding: 0 20px 0 30px;
    }

    .intro-section .intro-list li a {
        display: flex;
        justify-content: space-between;
        align-items: center;
        width: 100%;
    }

    /*======= Services Section =======*/
    .section-title-center {
        font-size: 25px;
    }

    .page-template-p_About .introducing-section .section-title-center {
        font-size: 20px;
        letter-spacing: 2px;
    }

    .services-section {
        padding: 30px 0 70px 0;
    }

    .services-section .container {
        padding: 0 25px;
    }

    .box-image-center .box-text .text-title {
        font-size: 20px;
        margin-bottom: 20px;
    }

    .box-image-center .box-text .text-description * {
        font-size: 14px;
    }

    /*======= Information Section =======*/
    .information-section {
        padding: 70px 0 20px 0;
    }

    .information-section .container {
        padding: 0 25px;
    }

    .information-section .w-1000px .row {
        height: 100%;
        margin-bottom: 20px !important;
    }

    .information-section .w-1000px .row .infor-title {
        font-size: 20px;
        letter-spacing: 2px;
        margin-bottom: 20px;
    }

    .information-section .w-1000px .row .infor-des {
        font-size: 14px;
        letter-spacing: 0.56px;
        margin-bottom: 0;
    }

    /*======= Facility Section =======*/
    .facility-section {
        padding: 30px 0;
    }

    .facility-section .container {
        padding: 0 25px;
    }

    .facility-section .w-1000px>.row .col-md-6 {
        padding-left: 0;
        padding-right: 0;
    }

    /*======= Introducing Section =======*/
    .introducing-section {
        padding: 70px 0 50px 0;
    }

    .section-title-left {
        font-size: 20px;
    }

    .about-page.section-7 {
        height: 480px;
    }

    /*======= Equipment Section =======*/
    .about-page.section-equipment .box-white {
        padding: 20px;
        margin: -150px 15px 0;
    }

    .about-page.section-equipment .box-white .box-title {
        font-size: 20px;
        letter-spacing: 2px;
    }

    .about-page.section-equipment .box-white .box-text {
        font-size: 14px;
        letter-spacing: 0.7px;
    }

    .about-page.section-equipment .card-body {
        height: unset;
    }

    .slide-right .section-title-left {
        margin: 0 25px;
    }

    .read-more {
        width: 100%;
        justify-content: center;
    }

    .equipment-container {
        padding: 0 25px;
    }

    .about-page.section-equipment .equipment-card {
        height: unset;
    }
}

/*======= Slide Section =======*/
.slide-right {
    padding: 40px 0;
}

.slide-right .slide-contain .slide-item img {
    width: 100%;
    height: 315px;
}

.home .slide-right .slide-contain .slide-item img {
    height: 216px;
}

.slide-right .slide-contain .slide-item .title {
    color: rgba(58, 58, 58, 1);
    font-family: var(--font-notosans-regular);
    font-size: 16px;
    font-weight: 500;
}

.slide-right .slide-contain .slide-item .position {
    background-color: rgba(168, 183, 205, 1);
    padding: 3px 10px;
    font-size: 13px;
    color: #fff;
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    width: max-content;
    letter-spacing: 3px;
    margin-bottom: 0;
}

.slide-right .slide-contain .slide-item .name {
    color: var(--text-color);
    font-family: var(--font-notosans-regular);
    font-size: 16px;
    font-weight: 500;
    margin-bottom: 0;
}

.slide-right .slide-contain .slick-dots {
    bottom: -35px;
}

.slide-right .slide-number {
    font-size: 15px;
    color: var(--text-color);
}

.slide-right .slide-control button {
    border: none;
    background: none;
}

.slide-right .slide-control {
    gap: 20px;
}

.slide-right {
    background-color: var(--primary-bgcolor);
}

.slide-right .slick-slide {
    box-shadow: 2px 0px 10px 2px rgba(74, 81, 91, 0.1);
    background-color: #ffffff;
}

.slide-right .slick-slide .content {
    padding: 20px;
}

.home .slide-right .slider .badge {
    position: absolute;
    right: 10px;
    bottom: 10px;
    background-color: #ffffff;
    border-radius: 2px;
    height: 26px;
    line-height: 26px;
    font-size: 12px;
    margin: 0;
    color: var(--primary-color);
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    padding: 0 10px;
}

.home .slide-right .slide-item .content p,
.home .slide-right .slide-item .content h3 {
    font-size: 15px;
    font-weight: 400;
    font-family: var(--font-notosans-regular);
}

@media (max-width: 480px) {
    .slide-contain .slider {
        margin-right: -250px;
        margin-left: 0;
    }

    .slide-contain .slick-dots {
        width: calc(100% - 250px);
    }

    .slide-contain {
        padding: 0 30px;
    }

}

@media (min-width: 1280px) {

    .slide-contain .slick-dots {
        width: 100%;
        max-width: 1010px;
    }

    .slide-right .slide-contain {
        width: 100%;
        overflow: hidden;
        position: relative;
    }

    .slide-right .slider {
        margin-left: calc((100% - 960px) / 2);
        padding-right: 0;
        width: calc(1500px + (100% - 960px) / 2);
        overflow-x: visible;
        display: flex;
    }

    .page-template-p_About .slide-right .slick-slide {
        width: 280px;
    }

    .home .slide-right .slider {
        margin-left: calc((100% - 1180px) / 2);
        width: calc(1500px + (100% - 1180px) / 2);
    }

    .home .slide-contain .slick-dots {
        width: 100%;
        max-width: 1190px;
    }
}

@media (min-width: 980px) and (max-width: 1500px) {
    .home .slide-right .slick-slide {
        width: 288px !important;
    }
}

/**************** Page Information ******************/
/*======= Processing Section =======*/
.w-1080px {
    max-width: 1104px;
    margin: 0 auto;
}

.processing-section {
    padding: 120px 0;
}

.processing-section .section-description-center {
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 15px;
    letter-spacing: 1.5px;
    text-align: center;
}

.processing-section .step-number {
    background-color: rgba(74, 81, 91, 1);
    color: white;
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    font-weight: 600;
    border-radius: 4px;
    margin-right: 8px;
}

.processing-section .step-title {
    font-weight: 500;
    font-size: 19px;
    margin-bottom: 20px;
    font-family: var(--font-notosans-regular);
    letter-spacing: 0.95px;
}

.processing-section .step-card {
    height: 100%;
}

.processing-section .step-image {
    height: 160px;
    overflow: hidden;
    margin-bottom: 20px;
}

.processing-section .step-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.processing-section .step-desc {
    font-size: 15px;
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    letter-spacing: 0.75px;
    line-height: 24px;
    color: var(--text-color);
}

.processing-section .step-desc strong {
    color: #000000;
}

.infor-service-section {
    padding: 100px 0;
    background-color: var(--primary-bgcolor);
}

.box-image-shade {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.box-image-shade .box-image {
    height: 250px;
    width: 100%;
}

.box-image-shade img {
    width: 100%;
    height: 100%;
}

.box-image-shade .box-text {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.box-image-shade .box-text .box-title {
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    font-size: 21px;
    color: var(--text-color);
    letter-spacing: 1.05px;
    text-align: center;
    margin-bottom: 15px;
}

.box-image-shade .overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 100%;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #FFFFFF 100%);
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.infor-price-section {
    padding: 80px 0;
    background-image: url("../img/information-page/price-bg.webp");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: bottom;
}

.infor-price-section .box-price {
    max-width: 1024px;
    margin: 0 auto;
    background-color: rgba(255, 255, 255, 0.9);
    padding: 100px 40px 40px 40px;
    backdrop-filter: blur(20px)
}

.infor-price-section .box-price .price-title {
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 19px;
    letter-spacing: 1.9px;
    color: var(--text-color);
}

.infor-price-section .box-price .price-card {
    padding: 15px;
    margin-bottom: 40px;
    border-bottom: 1px solid rgba(168, 183, 205, 1)
}

.infor-price-section .box-price .price-tag {
    font-family: var(--font-notosans-regular);
    font-weight: 500;
    font-size: 13px;
    color: #ffffff;
    letter-spacing: 2.6px;
    background-color: rgba(168, 183, 205, 1);
    padding: 0px 20px;
    border-radius: 20px;
    width: max-content;
}
.infor-price-section .box-price .price-tag.active {
    background-color: rgba(166, 138, 176, 1);
}
.infor-price-section .box-price .price-number .price-number-text {
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 13px;
    color: var(--text-color);
    letter-spacing: 0.56px;
}

.infor-price-section .box-price .price-number .price-number-text:nth-of-type(1) {
    font-family: var(--font-roboto);
    /* font-weight: 600; */
    font-size: 16px;
    color: var(--text-color);
    letter-spacing: 1px;

}

.infor-price-section .box-price .price-card .price-text {
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 15px;
    color: var(--text-color);
    letter-spacing: 0.6px;
    line-height: 22.5px;
}

.price-row {
    margin-bottom: 10px;
}
.price-before {
    font-size: 13px!important;
}
.price-number-text.onlay {
    font-size: 16px!important;
}

/*======= Payment Section =======*/
.payment-section {
    padding: 180px 0;
    background-image: url("../img/information-page/payment-bg.webp");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: bottom;
}

.payment-section .box-payment {
    max-width: 600px;
    margin: 0 auto;
}

.payment-section .box-payment .box-title {
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 21px;
    letter-spacing: 2.1px;
    color: #ffffff;
}

.payment-section .box-payment .box-text,
.payment-section .box-payment .box-text * {
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 15px;
    color: #ffffff;
    letter-spacing: 0.75px;
    margin-bottom: 0;
}

.payment-section .box-payment .box-head {
    padding-bottom: 50px;
    margin-bottom: 50px;
    position: relative;
}

.payment-section .box-payment .box-head::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 50%;
    max-width: 180px;
    height: 1px;
    background-color: rgba(255, 255, 255, 0.5);
}

.payment-section .section-title-center {
    color: #ffffff;
    margin-bottom: 100px;
}

.payment-section .box-payment .service-badge {
    display: inline-block;
    border-radius: 20px;
    padding: 0px 10px;
    margin: 0 10px 10px 0;
    font-family: var(--font-notosans-regular);
    font-weight: 400;
    font-size: 15px;
    color: #ffffff;
    letter-spacing: 0.75px;
    border: 1px solid rgba(168, 183, 205, 1);
}

.payment-section .box-payment .service-title {
    font-family: var(--font-notosans-bold);
    font-weight: 700;
    font-size: 17px;
    letter-spacing: 1.7px;
    color: #ffffff;
}

@media (max-width: 768px) {
    .processing-section {
        padding: 60px 25px;
    }

    .processing-section .step-title {
        font-size: 16px;
        letter-spacing: 0.8px;
    }

    .processing-section .step-title svg {
        transform: rotate(90deg);
    }

    .processing-section .step-desc {
        font-size: 14px;
        letter-spacing: 0.7px;
    }

    .infor-service-section {
        padding: 60px 25px;
    }

    .box-image-shade .box-image {
        height: 180px;
    }

    .box-image-shade .box-text .box-title {
        font-size: 14.6px;
        letter-spacing: 0.73px;
    }

    .infor-price-section .box-price {
        padding: 40px 15px;
    }

    .payment-section {
        padding: 70px 25px;
    }

    .payment-section .section-title-center {
        margin-bottom: 40px;
    }

    .payment-section .box-payment .service-badge {
        padding: 0px 15px;
    }

    .payment-section .box-payment .service-title {
        font-size: 16px;
        letter-spacing: 1.6px;
    }

    .payment-section .box-payment .box-title {
        font-size: 18px;
        letter-spacing: 1.8px;
    }

    .payment-section .box-payment .box-text,
    .payment-section .box-payment .box-text * {
        font-size: 14px;
        letter-spacing: 0.7px;
    }

    .payment-section .box-payment .box-head::after {
        display: none;
    }

    .payment-section .box-payment .box-head {
        padding-bottom: 40px;
        margin-bottom: 0;
    }

    .section-news .item {
        flex-direction: column;
        gap: 10px;
    }

    .section-des-center {
        font-size: 14px;
    }

    .fz-md-13 {
        font-size: 13px;
    }

    .introducing-section .introducing-des, .introducing-infor p {
        font-size: 14px;
        letter-spacing: 0.56px;
        line-height: 25.2px;
    }

    .equipment-card.card-first .card-title span:nth-of-type(1) {
        margin-right: -10px;
    }

    .about-page.section-equipment .card-title {
        font-size: 20px;
        letter-spacing: 2px;
    }

    .about-page.section-equipment .card-first .card-title {
        margin-bottom: 0;
        letter-spacing: 6px;
    }

    .about-page.section-equipment .card-text {
        font-size: 14px;
        letter-spacing: 0.42px;
    }
    .infor-price-section .box-price .price-card .price-text {
        font-size: 14px;
        letter-spacing: 0.56px;
    }
    .infor-price-section .box-price .price-title {
        font-size: 16px;
        letter-spacing: 1.6px;
    }

    .infor-price-section .box-price .price-number .price-number-text:nth-of-type(1) {
        font-size: 20px;
        letter-spacing: 0.8px;
    }

    .infor-price-section .box-price .price-number .price-number-text:nth-of-type(3) {
        font-size: 10px;
        /* margin-left: -10px; */
    }
    .price-number-text.onlay {
    font-size: 20px!important;
}
}

@media (max-width: 400px) {
    .section-des-center {
        font-size: 11px;
    }

    .hero-section .hero-title {
        font-size: 32px;
    }
}