@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans&family=Noto+Sans+JP:wght@300;400;500;600&family=Noto+Serif+JP:wght@300;400;500;600&family=Sorts+Mill+Goudy&family=BIZ+UDPGothic:wght@400;700&display=swap');

/* Reset */
html {font-size: 62.5%; -webkit-font-feature-settings: 'palt' 1; font-feature-settings: 'palt' 1;}
body {color: #000; line-height: 1.6; word-spacing: 0; font-size: 1.6rem; font-family: 'Sorts Mill Goudy', sans-serif; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; -moz-text-size-adjust: 100%;}

*{margin: 0; padding: 0; box-sizing: border-box; border: 0;}
h1, h2, h3, h4, h5, h6{font-size: 100%; font-weight: normal;}
ol, ul{list-style: none;}
table{border-collapse: collapse; border-spacing: 0;}
th{text-align: left; font-weight: normal;}
a{color: inherit; text-decoration: none; transition: all 0.2s;}
img{vertical-align: bottom; max-width: 100%; height: auto;}

.imgFull {width: 100%;}
.container{margin: 0 auto; max-width: 1000px; width: calc(100% - 40px);}
.dFlex {display: flex; flex-wrap: wrap; justify-content: space-between;}
.fontSortsMill {font-family: 'Sorts Mill Goudy', sans-serif;}
.fontMincho {font-family: 'Noto Serif JP', sans-serif;}
.fontBizUdp {font-family: 'BIZ UDPGothic', sans-serif;}


@media (min-width: 768px){
    a[href^="tel:"]{pointer-events: none;}
    .sp{display: none !important;}
}

@media (max-width: 767px){
    .pc{display: none !important;}
    body{font-size: 1.4rem;}
}

@media print {
    body{color-adjust: exact; -webkit-print-color-adjust: exact; print-color-adjust: exact;}
}

body {padding-right: 73px;}
header {position: fixed; right: 0; top: 0; width: 73px; height: 100%; background: #073755; z-index: 9; transition: all 0.5s;}
header.is-open {width: 100%;}
header .gradientSp {display: none;}


#btn-menu {position: absolute; top: 50%; transform: translateY(-50%); -webkit-transform: translateY(-50%); right: 18.5px;; height: 36px; width: 36px; z-index: 996; cursor: pointer; display: block;}
#btn-menu span{display: block; position: absolute; left: 0; width: 100%; height: 2px; background: #fff; transition: transform .3s;}
#btn-menu span:nth-of-type(1){top: 3px;}
#btn-menu span:nth-of-type(2){top: 17px;}
#btn-menu span:nth-of-type(3){top: 31px;}

#btn-menu.is-open span:nth-of-type(1){top: 17px; transform: rotate(45deg);}
#btn-menu.is-open span:nth-of-type(2){opacity: 0;}
#btn-menu.is-open span:nth-of-type(3){top: 17px; transform: rotate(-45deg);}


.menu {position: fixed; top: 0; width: 100%; height: 100%; transition: 0.5s; color: #fff; margin: 0; padding: 0; display: flex; flex-wrap: wrap; justify-content: space-around; align-items: center; text-align: center; z-index: 9;}
.menu li {text-align: center; margin-bottom: 20px; font-size: 2.4rem;}
.menu a.active {color: #e86336; pointer-events: none;}
.menu a:hover {color: #e86336;}
.menu .btnPurchase {display: block; max-width: 460px; width: calc(100% - 40px); line-height: 1; letter-spacing: 0.1em; padding: 20px 0; background: #e86336 !important; color: #fff !important; margin: 6rem auto 0; font-size: 1.9rem; font-weight: bold; text-align: center; transition: all 0.2s;}
.menu .btnPurchase:hover {color: #525252 !important; background: #fff !important;}



footer {padding: 10rem 0 6rem; background: #000; color: #fff;}
footer .logo {font-size: 2.6rem; font-weight: bold; text-align: center; margin-bottom: 3rem; letter-spacing: 0.1em;}
footer .logo span {display: block; margin-bottom: 2rem;}
footer .fMenu {text-align: center; margin-bottom: 60px;}
footer .fMenu li {display: inline-block; padding: 0 30px; line-height: 1; border-right: 1px solid #fff;}
footer .fMenu li:last-of-type {border-right: 0;}
footer .fMenu li a {display: block; font-size: 1.4rem; letter-spacing: 0.1em; transition: all 0.2s;}
footer .fMenu li a:hover {color: #e86336;}
footer .btnContact {display: block; max-width: 460px; width: calc(100% - 40px); line-height: 1; letter-spacing: 0.1em; padding: 20px 0; background: #fff; margin: 0 auto 7rem; font-size: 1.9rem; font-weight: bold; color: #525252; text-align: center; transition: all 0.2s;}
footer .btnContact:hover {background: #e86336; color: #fff;}
footer .social {margin: 80px 0;}
footer .copy {text-align: center; font-size: 1rem; letter-spacing: 0.1em;}

#pagetop{position: fixed; bottom: 10px; right: 83px; width: 50px; height: 50px; background: #073755; z-index: 8; cursor: pointer;}
#pagetop:after{content: ''; border: solid #fff; border-width: 0 1px 1px 0; display: inline-block; padding: 10px; transform: rotate(-135deg); -webkit-transform: rotate(-135deg); margin: 20px 0 0 14px;}

.social {text-align: center;}
.social li {display: inline-block; margin-right: 10px;}
.social li a {display: block;}
.social li a:hover {opacity: 0.6;}

@media (max-width: 1600px) and (min-width: 769px){
    body {padding-right: 53px;}
    header {width: 53px;}
    #btn-menu {width: 30px; height: 30px; right: 11.5px;}
}

@media (max-width: 1200px) and (min-width: 768px){
    body {padding-right: 43px;}
    header {width: 43px;}
    #btn-menu {width: 30px; height: 30px; right: 6.5px;}
}


@media (max-width: 767px){
    body {padding-right: 0;}
    header {background: none; left: 0; width: 100%; height: 70px; display: flex; align-items: center; justify-content: space-around; z-index: 9; line-height: 1;}
    /* header .gradientSp {display: block; height: 200px; background: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0) ); position: fixed; top: 0; left: 0; width: 100%; z-index: 2;}*/
    
    
    #btn-menu {left: auto; right: 1rem; background: #073755;}
    #btn-menu span {width: calc(100% - 12px); left: 0; right: 0; margin: 0 auto;}
    #btn-menu span:nth-of-type(1) {top: 7px;}
    #btn-menu span:nth-of-type(3) {top: 27px;}

    .menu {display: block; position: fixed; top: 0; left: 0; width: 100%; height: 100%; overflow: auto; background: #fff; opacity: 0; visibility: hidden; pointer-events: none; transition: .3s; display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center;}
    .menu > div {width: 100%;}
    .menu-wrap {padding: 0; width: 100%;}
    .menu li{text-align: center; margin: 0 0 20px; overflow: hidden;}
    .menu a {padding: 10px 20px; font-size: 1.7rem; letter-spacing: 0.1em; display: block; transform: translateY(100%); -webkit-transform: translateY(100%); transition: 1s ease .3s; color: #000;}
    .menu a.is-active{color: #de6600;}
    .menu.is-open {opacity: 1; visibility: visible; pointer-events: auto;}
    .menu.is-open a{transform: translateY(0); -webkit-transform: translateY(0);}
    .menu .btnPurchase {background: #073755 !important; color: #fff !important; padding: 15px; width: 80%; transition: 1s ease .3s; margin-top: 4rem;} 

    footer {padding: 6rem 0 3rem;}
    footer .logo {margin-bottom: 10%; font-size: min(2.2rem, 5vw);}
    footer .fMenu {margin-bottom: 0;}
    footer .fMenu li {display: block; border-right: 0; margin-bottom: 5%;}
    footer .fMenu li:last-of-type {margin-bottom: 0;}    
    footer .btnContact {margin: 3rem auto;}
    footer .social {margin: 60px 0;}
    footer .social img {width: 30px; height: 30px;}
    footer .copy {margin-top: 0;}


    #pagetop{bottom: 0; right: 0; width: 40px; height: 40px;}
    #pagetop:after{margin: 15px 0 0 10px;}

    .social li {margin-right: 10px;}
    .social li a {padding: 0;}
}











/* Animate */
.fade-in{opacity: 0; transition: opacity 1.5s ease;}
.fade-in.is-view{opacity: 1;}

.fade-up{opacity: 0; transform: translateY(40px); -webkit-transform: translateY(40px); filter: blur(5px) brightness(105%); transition: opacity 1s ease, transform 1s ease, filter 1s ease;}
.fade-up.is-view{opacity: 1; transform: translateY(0); -webkit-transform: translateY(0); filter: blur(0) brightness(100%);}

.fade-down{opacity: 0; transform: translateY(-40px); -webkit-transform: translateY(-40px); filter: blur(5px) brightness(105%); transition: opacity 1s ease, transform 1s ease, filter 1s ease;}
.fade-down.is-view{opacity: 1; transform: translateY(0); -webkit-transform: translateY(0); filter: blur(0) brightness(100%);}

.fade-left{opacity: 0; transform: translateX(-40px); -webkit-transform: translateX(-40px); filter: blur(5px) brightness(105%); transition: opacity 1s ease, transform 1s ease, filter 1s ease;}
.fade-left.is-view{opacity: 1; transform: translateY(0); -webkit-transform: translateY(0); filter: blur(0) brightness(100%);}

.fade-right{opacity: 0; transform: translateX(40px); -webkit-transform: translateX(40px); filter: blur(5px) brightness(105%); transition: opacity 1s ease, transform 1s ease, filter 1s ease;}
.fade-right.is-view{opacity: 1; transform: translateY(0); -webkit-transform: translateY(0); filter: blur(0) brightness(100%);}

.zoom-in{opacity: 0; overflow: hidden; transform: scale(0.7,0.7); -webkit-transform: scale(0.7,0.7); transition: opacity 1s ease, transform 1s ease;}
.zoom-in.is-view{opacity: 1; transform: scale(1,1); -webkit-transform: scale(1,1);}

.zoom-out{opacity: 0; overflow: hidden; transform: scale(1.3,1.3); -webkit-transform: scale(1.3,1.3); transition: opacity 1s ease, transform 1s ease;}
.zoom-out.is-view{opacity: 1; transform: scale(1,1); -webkit-transform: scale(1,1);}

.roll-left{position: relative; overflow: hidden;}
.roll-left img{opacity: 0; transition: opacity 1.2s ease .7s;}
.roll-left:after{content: ''; position: absolute; top: 0; bottom: 0; background: #de6600; opacity: .4;}
.roll-left.is-view img{opacity: 1;}
.roll-left.is-view:after{animation: rollLeft 1s ease;}

@keyframes rollLeft{
    0%{left: 0; right: 100%;}
    50%{left: 0; right: 0;}
    100%{left: 100%; right: 0;}
}

.roll-right{position: relative; overflow: hidden;}
.roll-right img{opacity: 0; transition: opacity 1.2s ease .7s;}
.roll-right:after{content: ''; position: absolute; top: 0; bottom: 0; background: #de6600; opacity: .4;}
.roll-right.is-view img{opacity: 1;}
.roll-right.is-view:after{animation: rollRight 1s ease;}

@keyframes rollRight{
    0%{right: 0; left: 100%;}
    50%{right: 0; left: 0;}
    100%{right: 100%; left: 0;}
}

.delay1{transition-delay: .2s;}
.delay2{transition-delay: .4s;}
.delay3{transition-delay: .6s;}
.delay4{transition-delay: .8s;}
.delay5{transition-delay: 1s;}
.delay6{transition-delay: 1.2s;}

.btnFixPurchase {
    height: 50px;
    padding: 0 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 8;
    position: fixed;
    bottom: 10px;
    right: 150px;
    line-height: 1; 
    letter-spacing: 0.1em; 
    font-size: 1.6rem; 
    font-weight: bold; 
    transition: all 0.2s;
    background: #e86336 !important; 
    color: #fff !important;
}

.btnFixPurchase:hover {
    color: #525252 !important; 
    background: #fff !important;
}

@media (max-width: 767px){
    .btnFixPurchase {
        height: 40px;
        bottom: 0;
        right: 50px;
        font-size: 1.4rem;
    }
}