html {
    scroll-behavior: smooth;
}
a {
    transition: none;
}
.banner__img {
    height: auto;
}
button {
    box-shadow: none;
}

.editBtn {
    color: var(--primary-color);
    border-radius: 0;
    border: none;
    padding: 0;
    background: none;
}
.editBtn:hover {
    background: none;
    box-shadow: none;
}

.breadcrumb {
    padding-left: 0;
}

.main-content {
    margin-top: 2rem;
}

.nav-tabs .tab-link {
    margin: 1.5rem;
    padding: 0.5rem 1.5rem;
    border: 3px #fff solid;
    border-radius: 47px;
    font-size: 16px;
    font-weight: 400;
    color: #2A2A2A;
}
.nav-tabs .tab-link:hover,
.nav-tabs .tab-link:focus {
    color: #2A2A2A;
    border-color: #2A2A2A;
}
.nav-tabs .tab-link.active {
    border-color: #2A2A2A;
}
.tab-container {
    top: 6rem;
    height: calc(100vh - 6rem);
    overflow-y: auto;
    overflow-x: hidden;
}

.tab-side-content {
    display: flex;
    flex-flow: column;
    max-width: 320px;
    padding: 21px 47px 35px 46px;
    border-radius: 25px;
    border: 1px solid #42c0f9;
    background: #e8f3fd;
}
.tab-icon {
    width: 81px;
    height: 81px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.tab-side-content h5 {
    font-size: 28px;
    line-height: 1.6;
    color: #4f4f4f;
}

.tab-side-content ol {
    padding-left: 0;
    list-style-position: inside;
}

.tab-side-content ol li {
    font-size: 16px !important;
    font-weight: normal;
    font-style: normal;
    line-height: 2;
    letter-spacing: normal;
    color: #4f4f4f;
}
.tab-side-content a:hover {
    color: #009fe8;
}

.store {
    margin-bottom: 100px;
}

.store_step-text {
    font-size: 18px;
    color: #5199FF;
    font-weight: 700;
    line-height: 22px;
    white-space: nowrap;
}

.store_step-title{
    font-weight: 500;
    font-size: 20px;
}

.store p {
    padding: 1.5rem 0 1.5rem 0;
    margin: 0;
    font-size: 1rem;
    color: #4f4f4f;
}

.store .swiper {
    padding: 16px 0 6px 10px;
}
.store .carousel-item img {
    border-radius: 20px;
}

.store .fqa__list-text{
    padding:50px 10px;
}

.qa-footer .fqa_list {
    border-bottom: solid 1px #d6d6d6;
}
.text-lightblue {
    color: #009fe8;
}

.fqa_list-head,
.fqa_list-text {
    padding: 17px 27.4px 19px 28px;
    cursor: pointer;
}

.fqa_list-head.collapsed .fa-chevron-down {
    transform: rotate(-90deg);
}

.fqa_list-head {
    font-size: 20px;
    font-weight: 500;
    color: #009fe8;
    position: relative;
    display: flex;
    align-items: center;
    font-size: 18px;
    border: solid 1px #d1e7fc;
    border-radius: 10px;
}

.fqa_list-head .fa-chevron-down {
    position: absolute;
    right: 10px;
}

.fqa_list-head img {
    width: 40px;
    height: 40px;
    margin-right: 8px;
    border-radius: 20px;
}

.fqa_list-text {
    color: #4e4e4e;
}

.carousel-item img {
    place-self: center;
    object-fit: contain;
}

.description {
    width: 100%;
    padding: 16px 28px;
    margin: 12px 0 28px 0;
    border-left: 1px solid #009fe8;
    background: #ebf8ff;
}

.description h6 {
    font-size: 16px;
    font-weight: 500;
    color: #2f2f2f;
}

.description .description_text {
    font-size: 14px;
    color: #2f2f2f;
    line-height: normal;
    letter-spacing: normal;
    padding-bottom: 1rem;
}

.laundryGuideSwiperPackage,
.laundryGuideSwiperPro {
    width: 100%;
    /* max-width: 1200px; */
    max-height: 500px;
}

.laundryGuideSwiperPackage .card,
.laundryGuideSwiperPro .card {
    border-radius: 22px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    width: 100%;
}
.laundryGuideSwiperPackage .card-body,
.laundryGuideSwiperPro .card-body {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.laundryGuideSwiperPackage .card-title,
.laundryGuideSwiperPro .card-title {
    font-size: 20px;
    margin-top: 12px;
    color: #2f2f2f;
}
.laundryGuideSwiperPackage .card-text,
.laundryGuideSwiperPro .card-text {
    font-weight: 400;
    font-size: 18px;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    min-height: 90px;
}

.card-list {
    height: 455px;
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    gap: 20px;
    padding: 0;
    scroll-behavior: smooth;
}

#step-4 .card-list .card {
    flex: 0 0 265px;
}
.card-list .card-body {
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    align-items: center;
    height: 445px;
}
.card-body .hollow-text {
    height: 99px;
    -webkit-text-stroke: 2px #d9d9d9;
    font-family: Roboto, sans-serif;
    font-size: 75px;
    font-weight: bold;
    font-stretch: normal;
    font-style: normal;
    line-height: normal;
    letter-spacing: normal;
    text-align: left;
    color: #fff;
}
.card-list .card-title {
    font-size: 1rem;
    margin-bottom: 28px !important;
}
.card-list .card-text {
    text-align: center;
    font-size: 16px !important;
    color: #4f4f4f !important;
    line-height: 1.88;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

#step-4 .card-body .card-subtitle {
    min-width: 200px;
}

.je-button {
    display: block;
    margin: 0 auto;
    border-radius: 48px;
    box-shadow: 3px 3px 8px 0 rgba(0, 0, 0, 0.16);
    border: solid 0.8px #dcdddd;
    background-color: #fff;
}
.line-button {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 350px;
    max-width: 90%;
    height: 96px;
    cursor: pointer;
}
.je-button.line-button:hover {
    border: solid 2px #02b902;
}
.line-button .line-text {
    padding: 0 6.4px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.5;
    color: #2f2f2f;
}

.appoint-button {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-left: 40px;
    width: 358px;
    height: 96px;
    color: #fff;
    background-color: #009fe8;
    cursor: pointer;
    transition: none;
}
.appoint-button:hover {
    color: #009fe8;
    background-color: #fff;
    border: 1px solid #009fe8;
}

.appoint-button:hover .calendar path,
.appoint-button:hover .arrow path {
    fill: #009fe8;
}
.download-app {
    display: flex;
    justify-content: center;
    padding: 30px 0;
    background-color: #f2f2f2;
}
.download-app .download-app-text {
    display: flex;
}
.download-app .download-app-text span {
    font-size: 30px;
    font-weight: 600;
    color: #2f2f2f;
}

.download-app .download-app-text span:last-child {
    font-weight: 300;
}

.store-machine {
    padding-top: 1rem;
}
.store-type {
    display: inline-flex;
    align-items: center;
    height: 44px;
    padding: 3px 17px;
    border-radius: 22px;
    background-color: #e9e9e9;
}
.store-type img {
    width: 38px;
}
.store-type .title {
    padding: 0 8px;
    font-size: 20px;
    font-weight: 500;
    font-stretch: normal;
    font-style: normal;
    line-height: normal;
    letter-spacing: normal;
    text-align: left;
    color: #4f4f4f;
    font-family: "Noto Sans TC", sans-serif !important;
}
.store-machine p {
    padding: 14px 0;
    font-size: 0.875rem !important;
    font-weight: normal;
    font-stretch: normal;
    font-style: normal;
    line-height: 2.19;
    letter-spacing: normal;
    text-align: left;
    color: #4f4f4f;
}

.coupon {
    padding: 20px 0px 48px;
    display: flex;
    align-items: start;
}

.send-step {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 400px;
    height: 41px;
    margin: 16px 24px 0;
    padding: 3px 20px 6px 20px;
    border-radius: 20.5px;
    background-color: #42c0f9;
    font-style: normal;
    line-height: normal;
    letter-spacing: normal;
    text-align: center;
    color: #fff;
    font-size: 22px;
    font-weight: 500;
}

.carousel-store-item img {
    width: 100%;
    height: auto;
    min-height: 460px;
    max-height: 643px;
    object-fit: contain;
}

.swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}
.laundryGuideSwiper .swiper-slide img,
.laundryGuideSwiperKioskGuide .swiper-slide img {
    width: 100%;
    height: auto;
    max-height: 643px;
    object-fit: contain;
}
.swiper-button-prev,
.swiper-button-next {
    width: 8%;
}
.swiper-button-prev:after,
.swiper-button-next:after {
    content: none;
}
.swiper-button-prev img {
    transform: rotate(180deg);
}
.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
    opacity: 0;
}

#step-3 .swiper-button-prev img {
    transform: translateY(-20px) rotate(180deg);
}
#step-3 .swiper-button-next img {
    transform: translateY(-20px);
}

.swiper-pagination-bullet-active {
    background-color: #42c0f9;
}

.qa-footer {
    padding: 60px 0 75px 0;
    background-color: #83DAB3;
}

.qa-footer .fqa__list{
    border-color:#2A2A2A;
}

.qa-footer__wrap {
    margin: auto;
    padding: 53px 40px 44px 40px;
}
.qa-footer h4 {
    font-size: 40px;
    font-weight: bold;
}

.qa_list-head {
    font-size: 16px;
    font-weight: 500;
    color: #4f4f4f;
    position: relative;
    display: flex;
    align-items: center;
}
.qa_list-text {
    padding: 24px 28px 24px 0;
    cursor: pointer;
}
.qa_list-head .fa-plus,
.qa_list-head .fa-minus {
    position: absolute;
    right: 10px;
}

.qa_list-head .fa-plus {
    display: none;
}
.qa_list-head.collapsed .fa-plus {
    display: block;
}
.qa_list-head .fa-minus {
    display: block;
}
.qa-content {
    width: 85%;
    padding-bottom: 24px;
    font-size: 14px;
    color: #4f4f4f;
    line-height: 2.14;
}


@media (max-width: 1400px) {
    .tab-side-content {
        padding: 21px 30px 35px 30px;
    }
}

@media (max-width: 768px) {
    .main-content {
        margin-top: 0.5rem;
    }

    .download-app {
        margin: 0 0 48px 0;
    }

    .download-app .download-app-text {
        flex-direction: column;
    }

    .download-app .download-app-img {
        display: none;
    }

    .download-app .taxiapp {
        width: 85px;
        object-fit: contain;
    }

    .download-app .download-app-text span {
        font-size: 24px;
    }

    .appoint-button,
    .line-button {
        place-self: center;
    }

    .store-machine p {
        padding: 0.5rem 0 0.75rem;
    }

    .coupon {
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

    .qa-content {
        width: 100%;
    }
}

@media (max-width: 576px) {
    .banner__img {
        max-height: 150px;
    }
    .breadcrumb {
        margin-bottom: 0;
    }

    .nav-tabs .tab-link {
        font-size: 1.625rem;
        padding: 16px 4px 8px 4px;
        margin: 0 32px 0 8px;
    }

    .laundryGuideSwiper .swiper-slide img {
        min-height: 310px;
    }

    .carousel-control-prev,
    .carousel-control-next {
        width: 15%;
    }

    .send-step {
        max-width: 300px;
        font-size: 16px;
    }

    .store p {
        padding: 1rem 0 1rem 0;
        margin: 0;
        font-size: 1rem;
        color: #4f4f4f;
    }

    .description .description_text {
        font-size: 12px;
    }

    #step-4 .card-list .card {
        flex: 0 0 320px;
    }
}


/* 1216 add */
.tww-main-bg {
    position: relative;
    overflow: hidden;
    background-color: var(--content-bg);
}
.tww-card-wrap {
    padding: 30px 30px 25px;
    background-color: #fff;
    border-radius: 20px;
    overflow: hidden;
}


@media (max-width: 576px) {
    .tww-card-wrap {
        padding: 15px 15px 22px;
    }
}