﻿@import url('https://fonts.googleapis.com/css2?family=Cormorant:wght@600&family=Zen+Old+Mincho:wght@400;700&display=swap');

body, .font_sans-serif{
    font-family: 'Zen Old Mincho', "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
}

.shop_link, .more, #header_menu, .top_cms_box .cms_title h2, #bottom_menu, #copyright, #page_title, .cate_list::before, .foot_link a, .con_no{
    font-family: 'Cormorant', 'Zen Old Mincho', "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
    font-weight: normal;
}

/*** fade ***/

.fadein, .fadein .fade_box{
    opacity: 0;
    transform: translateY(20px);
    transition: 1s;
    transition-property: opacity, transform;
}
.fadein.trans, .fadein .fade_box.active{
    opacity: 1;
    transform: none;
}

/*** other ***/

html, body{
    line-height: 2;
    font-size: 14px;
    letter-spacing: 2px;
}

h2, h3, h4, h5, h6{
    line-height: 1.5;
}

.square_img2, .square_img3{
    position: relative;
}
.square_img2 img, .square_img3 img{
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
}

.cate img, .cate_box img{
    box-shadow: none;
}

#wrap{
    min-width: 1000px;
}

#wrap, #info .info_box{
    background-color: #e2e2e2;
}

.svg_box, .svg_box2{
    display: none!important;
}

header{
    padding-top: 30px;
    padding-bottom: 30px;
    background-color: transparent!important;
}
header::before{
    position: absolute;
    content: "";
    z-index: -1;
    width: 100%;
    height: 120%;
    background-image: url('./Dup/img/gradation.png');
    background-size: auto 100%;
    background-repeat: repeat-x;
    pointer-events: none;
    opacity: 0.8;
    top: 0;
    left: 0;
    transition: 0.3s;
    transition-property: opacity;
}
header.transform::before{
    opacity: 1;
}
header #header{
    align-items: center;
}
header #logo{
    padding-top: 0;
    width: 250px!important;
}
header #logo .logo{
    width: 100%;
}
header #header #header_menu li{
    width: auto!important;
    padding: 0 15px;
    letter-spacing: 3px;
}
header #header #header_menu li a{
    display: block;
    position: relative;
    color: #1a1a1a;
}
header #header #header_menu li:not(:last-child) a::before{
    position: absolute;
    content: "";
    width: 0;
    height: 1px;
    left: 0;
    right: 0;
    bottom: -10px;
    margin: auto;
    background-color: currentColor;
    transition: 0.3s;
}
header #header #header_menu li:not(:last-child) a:hover::before{
    width: 50px;
}
header #header #header_menu li a span, header #header #header_menu li a:hover span{
    color: #1a1a1a;
}
header #header #header_menu li:last-child a span{
    border: none;
    padding: 10px 20px;
    background-color: #1a1a1a;
    color: #fff;
}
header #header #header_menu li:last-child a:hover span{
    background-color: #999999;
}

#main_img{
    height: 100vh;
}

#top_cms_h, #top_cms{
    padding: 0;
    max-width: 100%;
}
.top_cms_box{
    padding: 100px 30px;
    max-width: 1280px;
    width: 100%!important;
    margin: 0 auto!important;
    box-sizing: border-box;
}
#top_cms .top_cms_box:first-child{
    max-width: 100%;
    background-color: #eaeaea;
}
#top_cms .top_cms_box:first-child .cms_wrap{
    padding: 0 30px;
    max-width: 1280px;
    box-sizing: border-box;
    margin: 0 auto!important;
}
#top_cms .top_cms_box:first-child .more{
    margin-top: 50px;
}
.top_cms_box .cms_title{
    text-align: center;
    margin-bottom: 100px;
}
.top_cms_box .cms_title h2{
    padding: 0;
    margin: 0;
    color: #1a1a1a;
    font-size: 30px;
    letter-spacing: 3px;
    display: inline-block;
    padding-bottom: 10px;
    border-bottom: solid 2px;
    font-style: italic;
}

.con_no{
    font-style: italic;
}

#contents_h .box{
    margin-top: -50px;
}
#contents_h .con_no::before{
    position: absolute;
    content: "";
    width: 30px;
    height: 1px;
    left: 0;
    top: -1px;
    background-color: currentColor;
}

.cms_1-a .cate_box a:hover{
    background-color: #f2f2f2;
}

.more{
    text-align: center;
    width: 100%;
    margin-top: 0;
}
.more a{
    display: inline-block;
    padding: 5px 20px;
    border: none;
    background-color: #999999;
    color: #fff;
    letter-spacing: 3px;
}
.more a:hover{
    background-color: #1a1a1a;
}
.more a::after{
    content: "─";
    display: inline-block;
    margin-left: 10px;
}

#page_title{
    margin-bottom: 100px;
    background-image: none!important;
}
#page_title #filter_white{
    background-color: transparent!important;
    padding-bottom: 0!important;
}
#page_title h2{
    font-size: 40px;
    letter-spacing: 5px;
}
#page_title h2 span{
    padding: 0;
    background-color: transparent;
    color: #1a1a1a;
}

.pager li{
    width: 60px!important;
    margin: 0 10px!important;
}
.pager li a{
    height: 60px!important;
    line-height: 60px!important;
    display: block;
    border: none;
    padding: 0;
    background-color: #1a1a1a;
    color: #fff;
}
.pager li a:hover{
    background-color: #999999;
}

.cate_list{
    justify-content: center;
    margin-bottom: 100px;
}
.cate_list::before{
    display: block;
    width: 100%;
    content: "Category";
    font-size: 18px;
    font-style: italic;
    color: #999999;
    text-align: center;
    margin-bottom: 10px;
    letter-spacing: 3px;
}
.cate_list li{
    margin: 0;
    padding: 5px;
}
.cate_list li a{
    padding: 10px 20px!important;
    background-color: #999999;
    color: #fff;
    font-size: 14px;
    line-height: 1.5;
}
.cate_list li a:hover{
    opacity: 1;
    background-color: #1a1a1a;
}

#cms_2-a .cate_box .box_title1::before{
    position: absolute;
    content: "";
    width: 30px;
    height: 1px;
    left: 0;
    bottom: 0;
    background-color: currentColor;
}
#cms_2-a .cate .cate_box:last-of-type{
    border-bottom: solid 1px #c8c8c8;
}

#cms_4-a .box_img1 a, .cms_4-a .box_img1 a{
    display: block;
    transition: 0.5s;
    transition-property: opacity;
}
#cms_4-a .box_img1:hover .hvr_img1, .cms_4-a .box_img1:hover .hvr_img1{
    opacity: 0;
}
#cms_4-a .box_img1 .hvr_img2, .cms_4-a .box_img1 .hvr_img2{
    pointer-events: none;
    opacity: 0;
}
#cms_4-a .box_img1:hover .hvr_img2, .cms_4-a .box_img1:hover .hvr_img2{
    opacity: 1;
}
#cms_4-a .box_title2, .cms_4-a .box_title2{
    transform: skewX(-10deg);
}
#cms_4-a .link_box a::before, .cms_4-a .link_box a::before{
    position: absolute;
    content: "";
    width: 20px;
    height: 1px;
    left: 0;
    top: 0;
    background-color: #1a1a1a;
}

#info_title_box{
    display: none;
}
#info .info_txt a{
    color: #1a1a1a;
}

#bottom_menu ul{
    justify-content: center;
}
#bottom_menu ul li{
    padding: 0 20px;
}

#logo2{
    width: 300px;
}

.insta_link a::before, .insta_link a::after{
    position: absolute;
    content: "";
    width: 20px;
    height: 1px;
    background-color: currentColor;
    top: 0;
    bottom: 0;
    left: 20px;
    margin: auto;
}
.insta_link a::after{
    transform: rotate(90deg);
}

.foot_link:hover .bg_img{
    transform: translate(-50%, -50%) scale(1.1);
}
.foot_link a{
    background-color: rgba(140,140,140,0.2);
    font-style: italic;
}
.foot_link:hover a{
    background-color: rgba(140,140,140,0.4);
}

#footer > .grid_12{
    text-align: center;
}
#footer > .grid_12 > ul{
    width: auto!important;
    display: inline-block;
    text-align: left;
}
footer .bg_color1{
    background-color: #eaeaea;
    padding-top: 50px;
    padding-bottom: 50px;
}
footer .bg-mask, #copyright{
    background-color: transparent;
}

#copyright{
    color: #1a1a1a;
    padding: 20px 0;
}

#page-top a{
    border-radius: 0;
    background-color: #dbdbdb;
    color: #1a1a1a;
}


/** tablet 780 **/
@media screen and (max-width: 768px){
#wrap{
    min-width: inherit;
}
header{
    padding-top: 20px;
    padding-bottom: 20px;
}
header #logo{
    margin-bottom: 0;
}
#header_menu{
    display: none;
}
header .menu_bt{
    display: block;
    margin-left: 0;
}
.drawer-hamburger{
    display: inline-block;
    padding-top: 10px;
    padding-bottom: 10px;
}
.drawer-hamburger-icon, .drawer-hamburger-icon:after, .drawer-hamburger-icon:before{
    height: 1px;
}
#main_img{
    height: 60vw;
}
#intro_h .intro_img{
    height: 70vw;
}
#contents_h .con_img{
    height: 60vw;
}
}

/** mobile 750 **/
@media screen and (max-width: 667px){
header{
    padding-top: 10px;
    padding-bottom: 10px;
}
header #logo {
    width: 200px!important;
}
.top_cms_box .cms_title h2{
    font-size: 26px;
}
.top_cms_box{
    padding: 100px 15px;
}
#top_cms .top_cms_box:first-child .cms_wrap{
    padding: 0 15px;
}
#page_title h2{
    font-size: 30px;
    letter-spacing: 3px;
}
}

/** IE **/
@media all and (-ms-high-contrast:none) {
.pager li a span{
    padding-top: 0!important;
}
}