@charset "utf-8";

/*
關於CSS設定說明
CSS屬性是會繼承的，而且還是由上往下繼承。
同樣元素設定16px 後 12px 再 15px 最後會以最後設定的15px為準
但是有兩種情況除外:
1.絕對路徑命名. 如: .xx .yy .zz p {設定值;}
2.important.  如: .xx p {設定值 !important;}

CSS3選取器語法 :nth-child(n) 

*/
body {
    font-family: 'Figtree', 'Noto Serif TC';
}

.stellarnav>ul>li:nth-last-of-type(3)>ul>li:first-of-type {
    display: none;
}

/* = = = 分隔線 = = = = = = = = = == = = = = = = = = = = = = = = == = = */


/*上方選單解除滑動固定
.header_area.sticky { position:relative;}
*/

.main_header_area .container {
    max-width: 1600px;
    padding: 0 5%;
    transition: all 0.5s ease;
}

.sticky .main_header_area .container {
    max-width: 1700px;
}

.main_header_area {
    background: rgba(255, 255, 255, .8);
    transition: all 0.5s ease;
}

.sticky .main_header_area {
    backdrop-filter: blur(5px);
    box-shadow: 0 0 12px rgba(0, 0, 0, .09);
}

.header_area {
    padding: 0;
    transition: all 0.5s ease;
}

.header_area.sticky {
    position: fixed;
    padding: 20px;
}

.header_area,
.header_area.sticky {
    background: transparent;
}

.navigation {
    display: flex;
    align-items: center;
    gap: 40px;
}

.nav-header {
    max-width: 180px;
    padding: 8px 0 10px;
    transition: all 0.5s ease;
}

.sticky .nav-header {
    max-width: 160px;
}

.nav-brand,
.nav-brand img {
    display: block;
}

.me_tp_features,
.swiper-pagination {
    display: none;
}

.stellarnav ul {
    font-family: 'Figtree', 'Noto Serif TC';
}

.stellarnav li.has-sub>a:after {
    content: none;
}

.stellarnav>ul>li:after {
    width: 0;
    position: absolute;
    height: 2px;
    content: "";
    background: #00adf2;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    transition: all ease 0.3s;
}

.stellarnav>ul>li:hover:after {
    width: 100%;
}

.stellarnav>ul>li>a,
.stellarnav>ul>li.has-sub>a:not(.dd-toggle) {
    font-size: 16px;
    padding: 0 2px;
    color: #222;
    display: block;
    font-weight: bold;
    margin: 0 20px;
    text-transform: none;
    height: 100%;
    line-height: 86px;
    letter-spacing: 1px;
    transition: all ease 0.3s;
}

.sticky .stellarnav>ul>li>a,
.sticky .stellarnav>ul>li.has-sub>a:not(.dd-toggle) {
    line-height: 76px;
}

.stellarnav>ul>li:hover>a,
.stellarnav>ul>li.has-sub:hover>a:not(.dd-toggle) {
    color: #00adf2;
}

.stellarnav>ul>li:not(:first-of-type):before {
    content: '';
    display: block;
    width: 1px;
    height: 20px;
    transform: translate(-50%, -50%);
    position: absolute;
    left: -3px;
    top: calc(50% + 0px);
    background: rgba(0, 0, 0, .15);
}

/*次分類*/
.stellarnav ul ul {
    background: transparent;
    box-shadow: 0 0 12px rgba(0, 0, 0, .05);
}

.stellarnav>ul>li.drop-left>ul,
.stellarnav>ul>li>ul {
    right: auto;
    left: 50%;
    transform: translateX(-50%);
}

.stellarnav li li {
    background: #fff;
    border: none;
    border-bottom: 1px solid rgba(0, 0, 0, .075);
    margin-bottom: 0;
    text-align: center;
    transition: all ease .3s;
}

.stellarnav li li:hover {
    background: #0069b6;
}

.stellarnav li li:last-of-type {
    border: none;
}

.stellarnav li li a:not(.dd-toggle),
.stellarnav li li.has-sub>a:not(.dd-toggle),
.stellarnav li li.has-sub:hover li a:not(.dd-toggle) {
    color: #444;
    font-weight: 600;
    padding: 10px 12px;
    font-size: 15px;
    line-height: initial;
    height: auto;
    margin: 0;
    position: relative;
}

.stellarnav li li:hover a:not(.dd-toggle),
.stellarnav li li.has-sub:hover a:not(.dd-toggle),
.stellarnav li li.has-sub:hover li:hover a:not(.dd-toggle) {
    color: #fff;
}


/* = = = 分隔線 = = = = = = = = = == = = = = = = = = = = = = = = == = = */

.show_content {
    padding: 0;
}

.path {
    display: none;
}

.main_part {
    width: 90%;
    max-width: 1500px;
    padding: 100px 0;
}

.animated-arrow {
    background: #0069b6;
}

/*預設解除背景輪播*/
#content_main {
    margin: 0;
}

.bannerindex {
    position: relative;
    height: auto;
}

.swiper-banner {
    position: static;
    margin: 0;
    height: auto;
}

/* .swiper-slide img { height:auto;} */
@media screen and (max-width: 768px) {
    .bannerindex {
        padding: 0;
        margin: 0;
    }
}


/* = = = 分隔線 = = = = = = = = = == = = = = = = = = = = = = = = == = = */


/*內頁BANNER 設定*/
.banner {
    padding: 0;
    display: flex;
    align-items: center;
    width: 100%;
    height: auto;
    aspect-ratio: 40/7;
    position: relative;
    background: #00376e;
    overflow: hidden;
}

.banner:after {
    content: "";
    position: absolute;
    width: 102%;
    height: 102%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: url(https://pic03.eapple.com.tw/eivon/banner.jpg) center/cover no-repeat;
    opacity: .75;
    filter: blur(5px);
}

.banner h5 {
    line-height: 185%;
    color: #222;
    font-size: 34px;
}

.banner h5 {
    line-height: 220%;
    color: #fff;
    font-size: 36px;
    font-weight: bold;
    font-family: 'Noto Serif TC';
    letter-spacing: 4px;
    z-index: 9;
    text-shadow: 0 0 25px rgba(0, 0, 0, .75);
    filter: drop-shadow(0 0 25px rgba(0, 0, 0, .75));
}

.banner h5:after {
    content: 'EIVON IN YOUR LIFE';
    font-family: 'Arial';
    font-size: 18px;
    display: block;
    opacity: .5;
    line-height: 1;
    letter-spacing: 1px;
}

/* = = = 分隔線 = = = = = = = = = == = = = = = = = = = = = = = = == = = */


/*文章設定*/
.blog_page h4.blog_category_title {
    display: none;
}

.blog_box,
.blog_le {
    padding: 0;
}

.blog_ri {
    padding: 0 0 0 60px;
}

.blog_subbox {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
}

.blog_subbox:before {
    content: none;
}

.subbox_item {
    width: 100%;
    margin: 0;
    border-bottom: none;
    background: #fff;
    padding: 15px;
    box-shadow: 0 0 10px rgba(0, 0, 0, .075);
}

.subbox_item a {
    display: flex;
    flex-flow: column wrap;
    gap: 0;
}

.blog_list_le {
    height: auto;
    aspect-ratio: 4/3;
    overflow: hidden;
    position: relative;
}

.blog_list_le:after {
    content: 'VIEW MORE +';
    font-size: 16px;
    font-weight: 500;
    width: 102%;
    height: 102%;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 8;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    background: rgba(0, 105, 183, .9);
    opacity: 0;
    transition: all .4s;

}

.subbox_item a:hover .blog_list_le:after {
    opacity: 1;
}

.blog_list_le img {
    min-width: 100%;
    margin: 0 auto;
    object-position: center;
    transition: 1s ease;
}

.subbox_item a:hover .blog_list_le img {
    transform: scale(1.1);
}

.blog_list_ri {
    display: flex;
    flex-flow: column wrap;
    padding: 15px 10px 7px;
    position: relative;
    justify-content: center;
}

.blog_list_ri h5,
.i_blog_ri h5 {
    font-size: 22px;
    color: #0069b7;
    font-family: 'Noto Serif TC';
    font-weight: bold;
}

.blog_list_ri em {
    font-weight: 400;
    margin: 8px 0 10px;
}

.blog_list_ri p,
.i_blog_ri p {
    line-height: 160%;
    -webkit-line-clamp: 2;
    margin-top: 0;
}

.subbox_item a:before,
.subbox_item a:after {
    content: none;
}

h5.blog_le_t {
    display: none;
}

.blog_le .accordion {
    border-radius: 0;
}

.accordion li .link a {
    color: #444;
    font-weight: bold;
    font-size: 15px;
    padding: 12px;
}

.accordion li .link {
    border-bottom: none;
}

.accordion li {
    transition: all 0.2s ease;
}

.blog_le .accordion>li:hover,
.blog_le .accordion>li.open:hover,
.blog_le .accordion>li.on_this_category:hover {
    background: #0069b6 !important;
}

.blog_le .accordion>li.open,
.blog_le .accordion>li.on_this_category {
    background: #00aaef !important;
}

.blog_le .accordion>li.open .link a,
.blog_le .accordion>li.open .link i {
    color: #fff !important;
}

.submenu {
    background: #fff;
    font-size: 14px;
}

.submenu a {
    font-family: 'Noto Serif TC';
    color: #444;
    letter-spacing: 0px;
    font-weight: 600;
    padding: 12px 12px 12px 36px;
    border-left: #f8fcfd 0 solid;
    transition: all .15s;
}

.submenu li.on_this_category a,
.submenu a:hover {
    background: #f8fcfd;
    color: #222;
}

.submenu a i {
    left: 12px;
    font-weight: var(--fa-style, 900);
    font-family: var(--fa-style-family, "Font Awesome 6 Free");
}

.submenu a:hover {
    border-left-width: 4px;
}

.blog_search input[type=search] {
    background: #fff;
    font-size: 13px;
    border-radius: 0;
    padding: 10px 36px 10px 12px;
}

.blog_search input[type=submit] {
    filter: grayscale(20);
}

.blog_le .accordion li .link i {
    transition: none;
}

/*內頁*/
.articel_mainPic,
.blog_shareData {
    display: none;
}

h4.blog_category_title {
    padding: 0;
    margin-bottom: 0;
    font-size: 26px;
    color: #222;
    font-family: 'Noto Serif TC';
}

.blog_box_edit {
    color: #444;
    font-size: 16px;
}

.blog_box_edit * {
    line-height: 170%;
}

.blog_back {
    width: 100%;
    margin: 0 auto;
    grid-gap: 10px;
    justify-content: center;
}

.blog_back a {
    width: 100%;
    font-weight: 500 !important;
}

.blog_back a:hover {
    color: #fff !important;
    background: #0069b7 !important;
}

.blog_back a.article_btn_next,
.blog_back a.article_btn_prev,
.blog_back a.article_btn_back {
    background: transparent;
    color: #0069b7;
    border: 1px solid #0069b7;
    transition: all .3s ease;
}

.news_related {
    padding: 48px 0;
    background: #f8fcfd;
}

.news_related_list {
    max-width: 1500px;
    width: 90%;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
}

.news_related_list li {
    width: calc((100% - 60px) / 4);
}

.news_related_list li a {
    box-shadow: 0 0 10px rgba(0, 0, 0, .1);
}

.lastPage {
    background: #0069b7;
    margin: 40px auto 20px;
}

.news_related h6 span:before {
    color: #666;
    font-family: 'Noto Serif TC';
}

.news_related_list li a p {
    margin: 6px auto 4px;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    color: #666;
}

/*首頁*/
.module_i_news {
    padding: 100px 5%;
    background: #f8fcfd;
}

.module_i_news section {
    max-width: 1500px;
}

.module_i_news .title_i_box h4 {
    color: #0069b6;
    letter-spacing: 1px;
    font-family: 'Figtree', 'Noto Serif TC';
    font-size: 36px;
    font-weight: bold;
}

.module_i_news .title_i_box h4:before {
    content: 'LATEST NEWS';
    display: block;
    line-height: 1.7;
    font-size: 20px;
    font-weight: bold;
    color: #444;
    letter-spacing: 1px;
}

.module_i_news ul {
    grid-template-columns: repeat(2, 1fr);
}

.module_i_news li {
    width: 100%;
    margin: 0;
    background: #fff;
    box-shadow: 0 0 10px rgba(0, 0, 0, .075);
    border-bottom: none;
    transition: all 0.6s ease;
}

.module_i_news li:hover {
    transform: translateY(-6px);
}

.module_i_news li a {
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    gap: 0;
}

.i_blog_le {
    width: 240px;
    padding: 0;
    height: auto;
    aspect-ratio: 1/1;
    overflow: hidden;
    position: relative;
}

.i_blog_le img {
    min-width: 100%;
    display: block;
    width: 100%;
    margin: 0 auto;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.i_blog_ri {
    display: flex;
    flex-flow: column wrap;
    justify-content: center;
    padding: 36px;
    width: calc(100% - 240px);
    position: relative;
}

.i_blog_ri em:after {
    content: '＋ 繼續閱讀';
    letter-spacing: 1px;
    color: #999;
    font-weight: 600;
    position: absolute;
    top: 0;
    right: 0;
    transition: all 0.6s ease;
}

.module_i_news li:hover .i_blog_ri em:after {
    color: #0069b6;
}

.module_i_news li a:after,
.module_i_news li a:before {
    content: none;
}

.module_i_news .title_i_box {
    margin: 0 auto;
}

.i_blog_ri em {
    position: relative;
    order: 1;
    margin: 0;
}

.i_blog_ri p {
    margin: 15px 0;
}

.module_i_news_list {
    padding: 40px 0;
}


/* = = = 分隔線 = = = = = = = = = == = = = = = = = = = = = = = = == = = */


/*相簿*/
.show-list .show_name {
    color: #444;
    -webkit-line-clamp: 1;
    font-weight: 500;
    letter-spacing: 1px;
}

.show-list .item:hover .show_name {
    color: #0069b7;
}

.subalbum-menu {
    margin: 0;
    padding: 0;
}

.other_subalbum li a p {
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin: 10px 0 0;
}

.subalbum-menu h2 {
    color: #0069b7;
}

.other_album_choice li {
    background: linear-gradient(to bottom, #0069b6, #00aaef);
}

.other_album_choice li a {
    font-weight: 600;
    letter-spacing: 1px;
}

/* = = = 分隔線 = = = = = = = = = == = = = = = = = = = = = = = = == = = */


/*購物車*/
/*modify*/
.products-list .more {
    border-color: #0069b6;
    color: #0069b6;
    background: #fff;
}

.products-list .item a:hover .more {
    background: #0069b6;
}

.products-list .name {
    -webkit-line-clamp: 1;
    height: 22px;
    margin: 13px 0 15px;
    font-weight: 600;
    font-size: 18px;
}

.products-list .price {
    margin: 7px 0 17PX;
    display: none;
}

.products-list .price * {
    margin: 0;
}

.products-list .price b {
    color: #00aaef;
}

/*預設*/
.product_page .show_content,
.product_info_page .show_content {
    width: 100%;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-start;
    align-content: flex-start;
}

.product_page .product_menu_list {
    position: relative;
    width: 220px;
    letter-spacing: 1px;
    border-right: 1px solid #ccc;
    min-height: 45vw;
}

.product_page .products-list {
    width: calc(100% - 280px);
    grid-gap: 20px;
}

ul.page {
    width: 100%;
}

.product-layer-two li ul {
    position: static;
    margin: 0;
    width: 100%;
    background: #e3f0f87F;
}

.product-layer-two li:hover ul {
    border: none !important;
    /*display:block !important;*/
}

.product-layer-two>li {
    width: 100%;
    max-width: 100%;
    text-align: left;
    border-bottom: 1px dotted #ccc;
    padding: 5px 5px 5px 0;
}

.product-layer-two li i {
    right: 15px;
    top: 18px;
    width: 20px;
    height: 20px;
    font-size: 20px;
    color: #444;
    transition: all ease .3s;
}

.product-layer-two>li:hover i,
.product-layer-two>li.active i {
    color: white;
}

.product_info_page .product_menu_list {
    display: none;
}

.product-wrapper {
    width: 100%;
}

.product-layer-two li li>a:before {
    content: "";
    position: absolute;
    width: 12px;
    height: 8px;
    background: transparent;
    left: 0;
    margin-left: -22px;
    top: 50%;
    margin-top: -4px;
    clip-path: polygon(0 0, 100% 50%, 0 100%);
}

/*預設結束*/
.product-layer-two li li {
    display: block;
    background: none;
    border: none;
    padding: 0 22px;
    margin: 10px 0 0;
    transition: all ease .3s;
}

.product-layer-two li li:hover {
    padding-left: 46px;
}

.product-layer-two>li>ul li+li {
    margin-top: 0;
}

.product-layer-two>li>ul li:last-of-type {
    margin-bottom: 5px;
}

.product-layer-two li.active li {
    display: block;
}

.product-layer-two li li a,
.product-layer-two li.active li a {
    background: none;
    padding: 0;
    color: #666;
}

.product-layer-two li li:hover>a {
    color: #222;
    border: none;
}

.product-layer-two li li:hover>a:before {
    background: #222;
}

.product-layer-two li:hover>a:before,
.product-layer-two li.active>a:before {
    background: white;
    color: #0069b6;
}

.product-layer-two li a {
    padding: 10px 48px 10px 22px;
    color: #444;
    letter-spacing: 0px;
    border: none;
    font-weight: bold !important;
    background: transparent;
    transition: all 0.3s;
    line-height: 160%;
    font-size: 15px;
    transition: all 0.3s;
}

.product-layer-two li li a {
    font-weight: 500 !important;
}

.product-layer-two>li:hover>a,
.product-layer-two li.active>a {
    background: #0069b6;
    border: none;
    color: #fff;
}

.product-layer-two ul {
    grid-gap: 10px;
}

.sidebarBtn {
    padding: 0 0 0 30px;
    border: none;
    background: none;
}

.product_info li span {
    font-family: 'Noto Serif TC';
    font-size: 13px;
    color: #666;
    font-weight: 600;
}

/*內頁*/
.product_info_page .main_part {
    max-width: 1200px;
}

.product_main {
    padding: 0;
}

.proImgSwiper li {
    align-items: flex-start;
}

.pd_tabInner_contain {
    padding-top: 0;
}

.prod_related {
    padding: 48px 0;
    background: #e3f0f87f;
}

.prod_related h6 span:before {
    color: #666;
}

.related_list li a p {
    margin: 6px auto 4px;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.related_list {
    max-width: 1200px;
    width: 90%;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
}

.related_list li {
    width: calc((100% - 60px) / 4);
}

.related_list li a {
    box-shadow: 0 0 10px rgba(0, 0, 0, .1);
}

.pd_tabTitle li.activeTab a {
    font-size: 24px;
    font-weight: bold;
    color: #0069b6;
}

.pd_tabTitle li.activeTab::after {
    height: 2px;
    background: #0069b6;
}

.pd_tabTitle li {
    border: none;
}

.product-wrapper .edit {
    color: #444;
    font-size: 16px;
    line-height: 170%;
    letter-spacing: .5px;
    padding: 20px 0 0;
}

.sidebarBtn .price span {
    font-size: 20px;
}

.inquiry_a1 {
    background: #fef100;
    color: #000;
    font-weight: bold;
}

.inquiry_a2 {
    background: #00adf2;
    font-weight: bold;
}

.inquiry_a1:hover,
.inquiry_a2:hover {
    background: #0069b7;
    color: #fff;
}

/*首頁*/
.prod_part {
    padding: 100px 5%;
    background: #f8fcfd;
}

.prod_part section {
    max-width: 1500px;
}

.prod_part .products-list .item:nth-of-type(n+5) {
    display: none;
}

.i_prod_tit span {
    color: #0069b6;
    letter-spacing: 1px;
    font-family: 'Figtree', 'Noto Serif TC';
    font-size: 36px;
    font-weight: bold;
}

.i_prod_tit span:before {
    content: 'OUR PRODUCT';
    display: block;
    line-height: 1.7;
    font-size: 20px;
    font-weight: bold;
    color: #444;
    letter-spacing: 1px;
}

.pageIndex .productsListBox {
    padding: 40px 0;
}



/* = = = 分隔線 = = = = = = = = = == = = = = = = = = = = = = = = == = = */


/*聯絡*/
.contact_page .main_part {
    width: 100%;
    max-width: 100%;
    padding: 0;
}

.contact_content,
.contact_editbox {
    padding: 0;
}

.contact_editbox {
    background: #f8fcfd;
}

.contact_content {
    background: #e3f0f8;
}

.contact_content .information_left {
    display: none;
}

.contact_content .information_right {
    width: 100%;
    padding: 0;
}

.contact_content>form {
    max-width: calc(1200px + 10%);
    margin: 0 auto;
    padding: 100px 5%;
}

.contact_form {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    grid-gap: 20px;
    margin: 0;
    color: #222;
}

.contact_form li:not(:nth-last-of-type(3)) {
    width: calc(50% - 10px);
}

.contact_form li.last {
    margin-top: auto;
    margin-bottom: 0;
}

.contact_form li input.noborder,
.contact_form li textarea.noborder {
    background: #fff;
    padding: 8px;
    border: none;
    border-bottom: 1px solid rgba(0, 0, 0, .25);
}

.contact_form li {
    width: 100%;
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-content: flex-start;
    padding: 0;
    border-bottom: none;
    grid-gap: 8px;
}

.contact_form li .form__label {
    display: flex;
    flex-flow: row wrap;
    width: 100%;
    text-align: left;
    max-width: 100%;
    letter-spacing: .5px;
    font-weight: 500;
    padding: 0;
    background: none;
}

.star {
    order: 1;
    height: 18px;
}

.contact_form li .form__insert {
    line-height: 165%;
}

.contact_form li.last blockquote {
    color: #0069b6;
    border-color: #0069b6;
    background: #fff;
    font-weight: bold;
}

.contact_form li.last cite {
    background: #0069b6;
    border-color: #0069b6;
    font-weight: bold;
}

.contact_form li .form__label {
    color: #222;
}

.blank_letter {
    padding-top: 0;
    color: #0069b6;
    letter-spacing: 1px;
    font-family: 'Figtree', 'Noto Serif TC';
    font-size: 36px;
    font-weight: bold;
    margin-bottom: 30px;
}

.blank_letter:before {
    content: 'CONTACT FORM';
    display: block;
    line-height: 1.7;
    font-size: 20px;
    font-weight: bold;
    color: #444;
    letter-spacing: 1px;
}

/* = = = 分隔線 = = = = = = = = = == = = = = = = = = = = = = = = == = = */


/*footer*/
.footer {
    padding: 80px 0 0;
    background: #fff;
    font-family: 'Figtree', 'Noto Serif TC';
    box-shadow: 0 0 12px rgba(0, 0, 0, .08);
}

.footer .center {
    max-width: 1280px;
    padding: 0 5%;
}

.footer_logo {
    width: 100%;
    max-width: 400px;
    background: url(https://pic03.eapple.com.tw/eivon/row_logo.svg) center no-repeat;
    height: 100%;
    aspect-ratio: 15/2;
    background-size: cover;
}

.footer_logo a {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 15/2;
}

.footer_logo img {
    display: none;
}

.footer_info {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    gap: 0;
}

.footer_info,
.footer_info li {
    padding: 0;
}

.footer_info ul {
    letter-spacing: 0;
    display: flex;
    flex-flow: row wrap;
    width: calc(100% - 400px);
    margin-bottom: 80px;
    padding-left: calc(50% - 440px);
}

.footer_info li:before {
    color: #000;
    font-size: 20px;
    line-height: 1.2;
    letter-spacing: 1px;
    text-transform: uppercase;
    font-weight: 700;
    padding-bottom: 36px;
    display: block;
    font-family: 'Figtree', 'Noto Serif TC';
}

.footer_info li:nth-child(1):before {
    content: "CONTACT DETAILS";
    grid-column: 1 / -1;
}

.footer_info li:nth-child(2):before {
    content: "NAVIGATION";
    left: 0;
    position: absolute;
}

.footer_info li:nth-child(1) {
    width: calc(100% - 250px);
    display: flex;
    flex-flow: column wrap;
}

.footer_info li p {
    letter-spacing: .3px;
    color: #000;
    line-height: 175%;
    display: block;
    margin-bottom: 5.5px;
    font-weight: 400;
}

.footer_info li p a {
    color: #000;
    width: max-content;
}

.footer_info li p:before {
    color: #000;
    font-weight: 400;
}

.footer_info li:nth-child(2) {
    width: 250px;
    position: relative;
}

.footer_menu {
    margin-top: 62px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 15px 60px;
}

.footer_menu a {
    padding: 0;
    border: none;
    color: rgba(0, 0, 0, .7);
    background: transparent;
    width: max-content;
    text-align: left;
    margin: 0;
    line-height: 175%;
    transition: all 0.3s;
}

.footer_menu a:hover {
    background: transparent;
    color: #000;
}

.footer_menu a:first-of-type {
    display: none;
}

.copy,
.copy a,
.copy a:hover {
    color: #fff;
}

.privacyLinks a+a {
    border-color: #fff;
}

.copy {
    font-size: 13px;
    white-space: inherit;
    padding: 24px 0;
    border-top: none;
    background: #00adf2;
}

.box_link,
.footer_info li p.line,
.footer_info li p.phone {
    display: none;
}

.footer_info li p.taxid {
    order: 1;
}

.footer_info li p.tel {
    order: 2;
}

.footer_info li p.mail {
    order: 3;
}

.footer_info li p.add {
    order: 4;
}

.footer_info li p.add2 {
    order: 5;
}

.footer_info li p.tel:before {
    content: '市話：';
}

.footer_info li p.add:before {
    content: '店家地址：';
}

.footer_info li p.add2:before {
    content: '服務時間：';
}

@media screen and (max-width: 768px) {
    #bottom_menu li:nth-of-type(n+2) {
        display: none;
    }

    .footer.with_shopping_mode {
        padding: 40px 0;
    }

    #to_top {
        bottom: 68px;
    }
}