@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100;300;400;500;700;900&display=swap');
/* css捲軸 */
html {
    scroll-behavior: smooth;
}

/* *{
font-family: Arial,
"Noto Sans TC",
"Microsoft JhengHei",
微軟正黑體,
Helvetica,
sans-serif;
font-size: 1rem;
margin: 0;
padding: 0;
color: #222222 !important;
} */
/* 需要在 bootstrap.css 之後呼叫 */
/*  15px for iPhone Start */
.row {
    margin: 0;
}

.col-1,
.col-2,
.col-3,
.col-4,
.col-5,
.col-6,
.col-7,
.col-8,
.col-9,
.col-10,
.col-11,
.col-12,
.col,
.col-auto,
.col-sm-1,
.col-sm-2,
.col-sm-3,
.col-sm-4,
.col-sm-5,
.col-sm-6,
.col-sm-7,
.col-sm-8,
.col-sm-9,
.col-sm-10,
.col-sm-11,
.col-sm-12,
.col-sm,
.col-sm-auto,
.col-md-1,
.col-md-2,
.col-md-3,
.col-md-4,
.col-md-5,
.col-md-6,
.col-md-7,
.col-md-8,
.col-md-9,
.col-md-10,
.col-md-11,
.col-md-12,
.col-md,
.col-md-auto,
.col-lg-1,
.col-lg-2,
.col-lg-3,
.col-lg-4,
.col-lg-5,
.col-lg-6,
.col-lg-7,
.col-lg-8,
.col-lg-9,
.col-lg-10,
.col-lg-11,
.col-lg-12,
.col-lg,
.col-lg-auto,
.col-xl-1,
.col-xl-2,
.col-xl-3,
.col-xl-4,
.col-xl-5,
.col-xl-6,
.col-xl-7,
.col-xl-8,
.col-xl-9,
.col-xl-10,
.col-xl-11,
.col-xl-12,
.col-xl,
.col-xl-auto {
    padding: 0 ;
}





/*  15px for iPhone Over */

.vs-img{
margin-top: 80px;
/* max-width: 285px; */
}

.vs-ttl {
    font-size: 22px;
    font-weight: 900;
    font-family: Arial,
    "Noto Sans TC",
    "Microsoft JhengHei",
    Helvetica,
    sans-serif;
    padding: 10px 0;
}


.vs-txt {
    font-size: 16px;
    font-family: Arial,
    "Noto Sans TC",
    "Microsoft JhengHei",
    Helvetica,
    sans-serif;
    line-height: 1.5;
    padding: 10px 0;
    text-align: justify;
    font-weight: 400;
}

.pdf-ttl {
    font-size: 22px;
    font-weight: 900;
    font-family: Arial,
        "Noto Sans TC",
        "Microsoft JhengHei",
        Helvetica,
        sans-serif;
    padding: 10px 0;
}


.pdf-txt {
    font-size: 16px;
    color: #222222;
    font-family: Arial,
        "Noto Sans TC",
        "Microsoft JhengHei",
        微軟正黑體,
        Helvetica,
        sans-serif;
    text-align: left !important;
    font-weight: normal;
    line-height: 1.8;
    margin-bottom: 20px;
}



/* =====================

  remodal

===================== */
.fixed {
    position: relative;
    top:0;
    bottom: 0;
    right: 0;
    left: 0;
}

html.remodal-is-locked {
    touch-action: none;
}

.remodal-overlay {
    display: none;
    background: rgba(255, 255, 255, 0.8);
}

/* Close button */
.remodal-close {
    content: "";
    top: 20px;
    right: 30px;
    left: initial;
    left: auto;
    width: 25px;
    height: 25px;
    z-index: 100;
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2249px%22%20height%3D%2249px%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20fill%3D%22rgb(102%2C%20102%2C%20102)%22%20d%3D%22M48.541%2C47.116%20L47.127%2C48.531%20L24.499%2C25.904%20L1.872%2C48.531%20L0.457%2C47.116%20L23.085%2C24.490%20L0.457%2C1.862%20L1.872%2C0.451%20L24.499%2C23.077%20L47.127%2C0.451%20L48.541%2C1.862%20L25.913%2C24.490%20L48.541%2C47.116%20Z%22%2F%3E%3C%2Fsvg%3E');
    background-color: rgba(255, 255, 255, 0);
    background-size: cover;
    color: #95979c;
   
}

.remodal-close::before {
    display: none;
}

.remodal-wrapper {
    overflow-y: hidden;
    overflow-x: hidden;
    padding: 0;
}

.remodal {
    overflow-y: hidden;
    position: relative;
    height: 100vh;
    max-width: initial;
    max-width: 100%;
    width: 100vw;
    padding: 0;
    outline: none;
    text-size-adjust: 100%;
    box-shadow: 0px 0px 10px #999;
    margin-bottom: 0;
}

.remodal-is-initialized {
    display: inline-block;
}

.clearfix::after {
    clear: both;
    content: '';
    display: block;
}

.remodal .sp-only {
    display: none;
}

.remodal .modal-content {
    padding: 0;
    background: #fff;
}

.remodal img {
    width: 100%;
    vertical-align: bottom;
}

.remodal a:link,
.remodal a:visited,
.remodal a:hover,
.remodal a:active,
.remodal a:focus {
    color: #000;
    text-decoration: none;
}

.remodal a:hover {
    opacity: 0.8;
}

.remodal {
     font-family: Arial,
     "Microsoft JhengHei",
     微軟正黑體,
     "Noto Sans TC",
     Helvetica,
     sans-serif;
}

.remodal p {
    text-align: left;
    font-size: 15px;
    /*    font-size: 14px;*/
    line-height: 1.8;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #585858;
}

.remodal .col__wrap {
    overflow: hidden;
}

.remodal .col__left,
.remodal .col__right {
    position: relative;
    /* overflow: hidden; */
    overflow-y: auto;
    width: 50%;
    height: 100vh;
}

.remodal .col__left {
    float: left;
    background: #fff;
}

.remodal .col__right {
    float: right;
    display: flex;
    align-items: center;
}

.remodal .col__left .movie-cover {
    cursor: pointer;
}

.video_wrap {
    z-index: -1;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 98%;
    margin: auto 1%;
}

.video_wrap .video_container {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
}

.video_wrap .video_container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.remodal .col__left .movie-cover>img {
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: 50%;
    vertical-align: bottom;
}

.remodal .icon__play {
    position: absolute;
    width: 75px;
    height: 75px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.remodal .col__right .col__right__inner {
    /* position: absolute;
  max-width: 590px;
  width: 80%;
  top: calc(15% - 50px);
  left: 10%; */
    /* transform: translate(-50%, -50%); */
    max-width: 590px;
    width: 82%;
    margin: 0 auto 60px;
}

.remodal .icon__country {
    /* position: relative;
  height: 100px;
  width: 100px; */
    margin: auto;
    font-family: "Gothic MB101 Bold", "MySansSerif", "YakuHanJP", sans-serif;
    font-size: 14px;
    /*    font-size: 12px;
    */
    font-weight: bold;
    line-height: 1.6;
    color: #000;
}

/* .remodal .icon__country.ae {background: url(/jp/feature/oriental-wisdom-culture/img/icon-myanmar-black.png); background-size: cover;}
.remodal .icon__country.jp {background: url(/jp/feature/oriental-wisdom-culture/img/icon-japan-black.png); background-size: cover;}
.remodal .icon__country.in {background: url(/jp/feature/oriental-wisdom-culture/img/icon-india-black.png); background-size: cover;}
.remodal .icon__country.cn {background: url(/jp/feature/oriental-wisdom-culture/img/icon-china-black.png); background-size: cover;}
.remodal .icon__country.th {background: url(/jp/feature/oriental-wisdom-culture/img/icon-thailand-black.png); background-size: cover;} */
.remodal .icon__country span {
    /* position: absolute; */
    display: block;
    width: 100%;
    /* top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); */
}

.remodal h2 {
    font-family:Arial,
    "Noto Sans TC",
    "Microsoft JhengHei",
    微軟正黑體,
   
    Helvetica,
    sans-serif;
    font-size: 28px;
    margin: 40px auto 20px;
    line-height: 1;
    font-weight: 900;
}

.remodal h2 span {
    display: block;
    font-size: 18px;
    margin-top: 10px;
    font-weight: normal;

}

.remodal .name,
.remodal .price,
.remodal .onsale-date {
    display: block;
    margin-top: 3px;
}

.remodal .name {
    font-size: 14px;
}

.remodal .price {
    font-size: 12px;
}

.remodal .price .num {
    font-family: "Helvetica", sans-serif;
    font-size: 20px;
    /*    font-size: 16px;*/
    font-weight: bold;
    margin: 0 3px;
}

.remodal .onsale-date {
    font-size: 12px;
    color: #999;
}

.remodal .col__right .link__section {
    position: absolute;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%);
}

.remodal .col__right .link__section a {
    font-size: 14px;
    color: #585858;
}

@media only screen and (min-width: 1024px) and (max-height: 700px) {
    .remodal .col__right .col__right__inner {
        margin: 2% auto 0;
    }

    .remodal h2 {
        margin: 10px auto;
    }
}

@media only screen and (max-width: 1023px) {
    .remodal-wrapper {
        overflow-y: auto;
        padding: 0;
    }

    .remodal {
        /* overflow-y: initial; */
        overflow-y: auto;
    }

    .remodal .col__left,
    .remodal .col__right {
        height: auto;
        float: none;
    }

    .remodal .col__left {
        width: 100%;
        overflow: hidden;
        /* height: 56vw; */
    }

    .remodal .col__left>img,
    .remodal .col__left>.movie-cover>img {
        height: 56vw;
    }

    .remodal .icon__play {
        width: 15vw;
        height: 15vw;
    }

    .remodal h2 {
        text-align: left;
    }

    .remodal .col__right {
        position: relative;
    }

    .video_wrap {
        width: 100%;
        margin: auto 0;
    }

    .remodal .col__right {
        width: 650px;
        margin: 45px auto 0;
        flex-direction: column;
    }

    .remodal .col__right .col__right__inner,
    .remodal .col__right .link__section {
        position: static;
        max-width: 100%;
        width: 100%;
        transform: translate(0, 0);
    }

    .remodal .col__left__tab {
        width: 50%;
        float: left;
    }

    .remodal .col__right__tab {
        width: 50%;
        float: right;
        padding-left: 60px;
    }

    .remodal .col__right .link__section {
        margin-top: 40px;
        margin-bottom: 20px;
    }

    .remodal-close {
        background-size: 20px;
        background-repeat: no-repeat;
        background-position: 50%;
    }

}

/*  ---------------------
 remodal tablet
---------------------  */
@media only screen and (max-width: 1023px) {
    .remodal h2 {
        margin-top: 30px;
    }

}

/*  ---------------------
 remodal sp
---------------------  */
@media only screen and (max-width: 767px) {
    .remodal .sp-only {
        display: block;
    }

    .remodal .col__right {
        width: 100%;
        margin: 16vw auto 0;
        padding: 8vw 8vw 0;
    }

    .remodal .icon__country {
        /* height: 26vw;
    width: 26vw; */
        font-size: 4vw;
        /*        font-size: 3.2vw;*/
    }

    .remodal h2 {
        /* text-align: center; */
        font-size: 7.466vw;
        margin: 2.6667vw auto 7vw;
    }

    .remodal h2 span {
        font-size: 18px;
        /* font-size: 4.8vw; */
        margin-top: 4vw;
        line-height: 1.5;
    }

    .remodal p {
        font-size: 4.3vw;
        /*        font-size: 3.73vw;*/
    }

    .remodal .col__left,
    .remodal .col__left>img,
    .remodal .col__left>.movie-cover>img {
        /* height: 100vw; */
    }

    .remodal .col__left__tab,
    .remodal .col__right__tab {
        width: 100%;
        float: initial;
        padding-left: 0;
    }

    .remodal .name {
        font-size: 3.2vw;
        margin-top: 3.2vw;
    }

    .remodal .price {
        font-size: 2.667vw;
        line-height: 1;
        margin-top: 3.2vw;
    }

    .remodal .price .num {
        font-size: 4vw;
        margin: 0 .4rem;
    }

    .remodal .onsale-date {
        font-size: 3.2vw;
        margin-top: 3.2vw;
    }

    .remodal .col__right .link__section {
        margin-top: 13.3333vw;
        margin-bottom: 34vw;
    }

    .remodal .col__right .link__section a {
        font-size: 4vw;
    }

    .remodal-close {
        position: absolute;
        width: 20vw;
        top: 5vw;
        left: 5vw;
        padding: 0;
        border-top: none;
        height: 6vw;
        background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2218px%22%20height%3D%2236px%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20stroke%3D%22rgb(88%2C%2088%2C%2088)%22%20stroke-width%3D%222px%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20fill%3D%22none%22%20d%3D%22M14.998%2C2.993%20L2.000%2C18.012%20L14.998%2C32.992%20%22%2F%3E%3C%2Fsvg%3E');
        background-size: contain;
        background-position: left;
    }

    .remodal-close span {
        margin-top: 0vw;
        padding-left: 8vw;
        color: #585858;
        text-align: left;
        font-size: 5vw;
        font-weight: bold;
    }

    .remodal .col__right .col__right__inner {
        margin-bottom: 0;
    }
}



/* =====================

  #product, #shop

===================== */
.product-list {
    margin-left: 4px;
}

.product-list__item {
    position: relative;
    width: calc(25% - 4px);
    width: calc(20% - 4px);
    margin: 4px 4px 0 0;
}

.product-list__item>a {
    display: block;
}

.product-list__item  {
    font-family: Arial,
    "Noto Sans TC",
    "Microsoft JhengHei",
    Helvetica,
    sans-serif;
    font-size: 22px;
    font-weight: 900;
    position: absolute;
    width: calc(100% - 40px);
    top: 20px;
    left: 30px;
    color: #fff;
}
.product-list__item span {
    font-family: Arial,
    "Noto Sans TC",
    "Microsoft JhengHei",
    Helvetica,
    sans-serif;
    display: block;
    font-size: 16px;
    margin-top: 3px;
    line-height: 1.4;
    color: #ffffff;
    font-weight: 400;
}

@media only screen and (max-width: 767px) {
.product-list__item {
    top: 10px;
    left: 15px;

}
}
/*-------------------------

.scroll

--------------------------- */
.scroll {
    position: absolute;
    padding-top: 76px;
    bottom: 30px;
    font-size: 12px;
    font-family: "Helvetica", sans-serif;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    right: 0;
    left: 0;
    margin: auto;
    color: #222;
    text-decoration: none;
    width: 120px;
}

.scroll span {
    color: #222;
margin-top: 20px;}

.scroll span::before {
    position: absolute;
    top: 10px;
    left: 50%;
    content: '';
    width: 1px;
    height: 60px;
    margin-left: -3px;
    background-color: #222;
    border-radius: 100%;
    -moz-animation: scrollStart 2s infinite;
    -webkit-animation: scrollStart 2s infinite;
    animation: scrollStart 2s infinite;
    animation-duration: 2s;
    box-sizing: border-box;
}

.scroll span+span::before {
    display: none;
}

@-webkit-keyframes scrollStart {
    0% {
        opacity: 0;
        height: 0;
    }

    20% {
        opacity: 1;
    }

    80% {
        opacity: 1;
    }

    100% {
        height: 60px;
        opacity: 0;
    }
}

@keyframes scrollStart {
    0% {
        opacity: 0;
        height: 0;
    }

    20% {
        opacity: 1;
    }

    80% {
        opacity: 1;
    }

    100% {
        height: 60px;
        opacity: 0;
    }
}

@media screen and (max-width: 1023px) {
    .scroll {
        bottom: 70px;
    }

    .scroll span::before {
        position: absolute;
        top: 10px;
        left: 50%;
        content: '';
        width: 1px;
        height: 60px;
    }
}

@media screen and (max-width: 767px) {
    .scroll {
        padding-top: 15vw;
        bottom: 5.33vw;
    }

    .scroll span::before {
        height: 2vw;
    }
}

/* ---- 展示文字 -----*/
.name-ttl{
font-size: 22px;
 font-family: Arial,
 "Noto Sans TC",
 sans-serif;
font-weight: 900;
line-height: 1.5;
}

.info-txt {
/* width: 70%; */
font-size: 16px;
font-weight: 600;
line-height: 1.5;
margin-top: 10px;
}

.middle {
position: relative;
   top: 50%;
   transform: translateY(-50%);
}

/* article文章文字 */
.article-txt{
 font-size: 16px;
 color: #222222;
 font-family: Arial,
 "Noto Sans TC",
 "Microsoft JhengHei",
 微軟正黑體,
 Helvetica,
 sans-serif;
 text-align:left !important;
 font-weight: normal;
  line-height: 1.8;
margin-bottom:40px;}
.article-note{
font-size: 14px;
color: #666;
margin-top: -15px;
}

.article-txt-2 {
    
    font-size: 16px;
    color: #222222;
    font-family: Arial,
        "Noto Sans TC",
        "Microsoft JhengHei",
        微軟正黑體,
        Helvetica,
        sans-serif;
    text-align: left!important;
    font-weight: 700;
    margin: 15px 0 20px 0;
    line-height: 1.6;
}
.article-txt-2 span{
    font-weight: normal;

}



.article-icon{
    font-size: 16px;
    /* color: #222222; */
    font-family:
    Arial,
    "Noto Sans TC",
    "Microsoft JhengHei",
    微軟正黑體,
    Helvetica,
    sans-serif;
    text-align: left;
    background-color: #F8F3EC;
    /* background-color: #999; */
    padding: 10px 50px  ;
    font-weight: 700;
     line-height: 1.6;
}

.article-icon::after{
display: block;
position: absolute;
content:"";
background-image: url("../img/taspi-icon.png");
background-repeat: no-repeat;
background-size: 100%;
background-position:center;
vertical-align: middle;
top: 8px;
left: 10px;
width: 25px;
height: 29px;
    padding: 10px 0;
}
.article-icon-2 {
    font-size: 13px;
    line-height: 1.6;
    color: #222;
    font-family:
        Arial,
        "Noto Sans TC",
        sans-serif;
    text-align: left;
    background-color: #F8F3EC;
    padding: 10px 15px 10px 40px;
    text-align: justify;
    font-weight: 500;
    clip-path: inset(0.5% 0.5% 0.5% 0.5%);
    }

.article-icon-2::after {
    display: block;
    position: absolute;
    content: "";
    background-image: url("../img/taspi-icon.png");
    background-repeat: no-repeat;
    background-size: 100%;
    background-position: center;
    vertical-align: middle;
    top: 8px;
    left: 10px;
    width: 20px;
    height: 23px;
    padding: 10px 0;
}

.books_img {
margin-top: 200px;}


.br_pc{
    display: block;
}

@media screen and (max-width: 576px){
.br_pc {
    display: none;
}
.books_img {
    margin-top: 120px;
}
}

.btn-dl {
    color: #fff;
    background-color: #7f0019;
    font-weight: 900;
     font-family: Arial,
     "Noto Sans TC",
     "Microsoft JhengHei",
     微軟正黑體,
     Helvetica,
     sans-serif;
     width: 210px;
     height: 46px;
}

.btn-dl:hover {
    color: #7f0019;
    background-color: #FAF9F8;
    outline: none;
}
.btn-dl:focus {
outline: none;

}
.btn:hover,
.btn:focus {
    outline: none;
    box-shadow:none;
}

/* hover */
.bright {
    opacity: 1;
   
}

.bright:hover {
    opacity: 0.7;
    transition: 0.3s;
    transition: 0.3s ease-in-out;
     /* cursor: pointer !important; */
}

/* 顏色 */
.txt_red {
    color: #7f0019 !important;
}

.btn__top {
    display: block;
    width: 30px;
    height: 30px;
    /* border-radius: 50%; */
    padding: 5px;
    background-color: #d0d0d0;
    color: #222222;
    text-align: center;
    position: fixed;
    bottom: 45px;
    right: 30px;
    cursor: pointer;
    z-index: 100;
}

 .sp {
     display: none;
 }
@media screen and (max-width: 768px) {
    .mh_50 {
        max-height: 50vh;
    }

}

@media screen and (max-width: 576px) {
    .mh_40 {
        max-height: 40vh;
    }
    
    .sp {
        display: block;
    }
    .btn-dl{
        width: 140px;
        height: 40px;
        }

        .pdf-ttl {
            font-size: 27px;
          
        }
        .pdf-txt {
            font-size: 16px !important;
            line-height: 1.6!important;
        }

}