@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400..800;1,400..800&family=Shippori+Mincho&display=swap');


/* common
-------------------------------------------------*/
:root {
  font-size: 100px;
}
@media screen and (max-width: 1366px) and (min-width: 751px) {
:root {
    font-size: 7.320644216vw;
}
}
@media screen and (max-width: 750px) {
:root {
    font-size: 26.66666666666vw;
}
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
li,
dl,
dt,
dd,
table,
tr,
th,
td,
form,
figure,
picture {
	font-size: inherit;
	margin: 0;
	padding: 0;
}
a {
	color: inherit;
	text-decoration: none;
}
summary {
	display: block;
}
table {
	border-collapse: collapse;
	empty-cells: show;
}
th,
td {
	text-align: left;
	vertical-align: top;
}
ul li {
	list-style: none;
}
address {
	font-style: normal;
}
figure,
picture {
	display: block;
}
img {
	vertical-align: top;
    width: 100%;
    max-width: 100%;
	height: auto;
}
input,
textarea {
	color: inherit;
	font-family: inherit;
	-webkit-appearance: none;
	appearance: none;
}
textarea {
	form-sizing: content;
}
button {
	color: inherit;
	font-family: inherit;
}
input, select {
    vertical-align: middle;
}


/* module
------------------------------------------------- */
.pcon { display: block; }
.spon { display: none; }
@media screen and (max-width:750px){
.pcon { display: none; }
.spon { display: block; }
}


/* a
------------------------------------------------- */
a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
	text-decoration: none;
	outline: none;
    color: #000;
}
@media (hover: hover) and (min-width:751px) {
a {
    transition: 0.3s;
}
a.al:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
}
}
@media screen and (min-width:751px){
.telLink {
	pointer-events: none;
}
}


/* html
------------------------------------------------- */
html {
    font-size: 0.16rem;
    scroll-behavior: smooth;
    scrollbar-gutter: stable;
    overflow-x: hidden;
}


/* body, wrapper
------------------------------------------------- */
body {
    background-color: #EEE7D9;
    min-height: 100vh;
    font-family: "Shippori Mincho", serif;
    font-weight: 400;
    font-style: normal;
	font-size: 0.16rem;
	line-height: 1.785;
	color: #000;
	-webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    position: relative;
}
body::before,
body::after {
    content: '';
    width: 0.1rem;
    height: 100%;
    background-color: #fff;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 2;
}
body::after {
    left: auto;
    right: 0;
}
.eng {
    font-family: "EB Garamond", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
}


/* layout
------------------------------------------------- */
.inner {
    max-width: 13.46rem;
    margin: 0 auto;
    position: relative;
}
.d-flex {
    display: flex;
}
.f-wrap {
    flex-wrap: wrap;
}
.f-rev {
    flex-direction: row-reverse;
}
.just-center {
    justify-content: center;
}
.just-between {
    justify-content: space-between;
}
.just-end {
    justify-content: flex-end;
}
.align-center {
    align-items: center;
}
.align-start {
    align-items: flex-start;
}
.align-end {
    align-items: flex-end;
}
@media screen and (max-width:750px){
.inner {
    width: 92%;
}
.d-flex {
    display: block;
}
}


/* contact
------------------------------------------------- */
#contact {
    width: 0.8rem;
    height: 0.365rem;
    position: fixed;
    right: 0.29rem;
    top: 0.45rem;
    cursor: pointer;
    z-index: 98;
}
#contact a {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
}
#contact a::before {
    content: '';
    width: 1rem;
    height: 1rem;
    background-color: #E6DBC4;
    border-radius: 50%;
    position: absolute;
    left: 50%;
    top: 50%;
    margin: -0.5rem 0 0 -0.5rem;
    z-index: 1;
    opacity: 0;
    transition: 0.3s;
}
#contact a::after {
    content: 'CONTACT';
    width: 100%;
    font-size: 0.14rem;
    line-height: 1.285;
    letter-spacing: normal;
    text-align: center;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    transition: 0.3s;
    z-index: 2;
}
#contact a span {
    display: block;
    width: 100%;
    height: 0.01rem;
    background-color: #000;
    position: absolute;
    left: 0;
    top: 0;
    transition: 0.3s ease-in-out;
    z-index: 2;
}
#contact a span:nth-child(2) {
    top: 0.11rem;
}
@media (hover: hover) and (min-width:751px) {
#contact a:hover::before {
    opacity: 1;
}
}
@media screen and (max-width:750px){
#contact {
    width: 0.5rem;
    height: 0.3rem;
    right: 0.2rem;
    top: 0.3rem;
}
#contact a::after {
    font-size: 0.1rem;
}
#contact a span:nth-child(2) {
    top: 0.09rem;
}
}


/* headline
------------------------------------------------- */
.headline {
    font-size: 1.02rem;
    font-weight: 400;
    line-height: 1.3;
    letter-spacing: 0.1em;
    color: rgba(255,255,255,0.39);
    margin-left: -0.1rem;
    position: relative;
}
.headline::before {
    content: '';
    width: 0.36rem;
    height: 0.36rem;
    background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2236.707%22%20height%3D%2236.707%22%20viewBox%3D%220%200%2036.707%2036.707%22%3E%20%3Cline%20id%3D%22%E7%B7%9A_5%22%20data-name%3D%22%E7%B7%9A%205%22%20x2%3D%2236%22%20y2%3D%2236%22%20transform%3D%22translate(0.354%200.354)%22%20fill%3D%22none%22%20stroke%3D%22%23ba0053%22%20stroke-width%3D%221%22%2F%3E%3C%2Fsvg%3E') center center no-repeat;
    background-size: 100% auto;
    position: absolute;
    left: -0.05rem;
    bottom: 0;
}
@media screen and (max-width:750px){
.headline {
    font-size: 0.43rem;
}
.headline::before {
    width: 0.2rem;
    height: 0.2rem;
}
}


/* main
------------------------------------------------- */
.main {
    position: relative;
}
.main::before {
    content: '';
    width: 100%;
    height: 0.1rem;
    background-color: #fff;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 2;
}


/* mainvisual
------------------------------------------------- */
.mainvisual {
    width: 100%;
    height: 7.7rem;
    background: url("../img/top/main_img.jpg") 0.1rem 0.1rem no-repeat;
    background-size: 13.46rem auto;
    position: relative;
    z-index: 2;
}
.mainvisual h1 {
    width: 4.92rem;
    position: absolute;
    left: 1rem;
    top: 1.66rem;
}
.mainvisual .txt {
    font-size: 0.12rem;
    font-weight: 400;
    line-height: 1.33;
    letter-spacing: 0.12em;
    text-align: center;
    position: absolute;
    right: 0.58rem;
    top: 2.8rem;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    white-space: pre;
}
.mainvisual .scroll {
    width: 0.31rem;
    height: 2.04rem;
    background: url("../img/top/main_scroll.svg") left top no-repeat;
    background-size: 100% auto;
    position: absolute;
    left: 0.35rem;
    bottom: 0;
}
.mainvisual .scroll span {
    width: 0.01rem;
    height: 1.34rem;
    background-color: #707070;
    position: absolute;
    left: 50%;
    top: 0.73rem;
    z-index: -1;
    animation: scroll 2.5s ease-in-out 0s infinite;
}
@keyframes scroll {
    0% {
        height: 0;
        top: 0.7rem;
        opacity: 1;
    }
    30% {
        height: 1.34rem;
        top: 0.7rem;
        opacity: 1;
    }
    50% {
        height: 1.34rem;
        top: auto;
        bottom: 0;
        opacity: 1;
    }
    80% {
        height: 0;
        top: auto;
        bottom: 0;
        opacity: 1;
    }
    100% {
        height: 0;
        top: 0.7rem;
        opacity: 0;
    }
}
@media screen and (max-width:750px){
.mainvisual {
    height: 4.5rem;
    background-size: 130% auto;
}
.mainvisual h1 {
    width: 60vw;
    left: 10vw;
    top: 1rem;
}
.mainvisual .txt {
    font-size: 0.1rem;
    right: 0.3rem;
    top: 1.8rem;
}
.mainvisual .scroll {
    transform: scale(0.8);
    left: 5vw;
    bottom: 0;
}
.mainvisual .scroll span {
    height: 1.34rem;
    background-color: #707070;
    position: absolute;
    left: 50%;
    top: 0.73rem;
    z-index: -1;
    animation: scroll 2.5s ease-in-out 0s infinite;
}
}


/* cont1
------------------------------------------------- */
.cont1 {
    height: 7.5rem;
    position: relative;
    z-index: 2;
}
.cont1 h2 {
    width: 3.08rem;
    position: absolute;
    left: 50%;
    margin-left: -1.22rem;
    top: -0.1rem;
}
.cont1 h3 {
    width: 0.2165rem;
    margin: 0 auto;
    padding-top: 4.04rem;
}
@media screen and (max-width:750px){
.cont1 {
    height: 6.5rem;
}
.cont1 h2 {
    width: 3rem;
    margin-left: -1.2rem;
    top: -1rem;
}
.cont1 h3 {
    width: 4vw;
    margin: 0 auto;
    padding-top: 3rem;
}
}


/* cont2
------------------------------------------------- */
.cont2 {
    height: 9.05rem;
    background: url("../img/top/cont2_bg.jpg") right top no-repeat;
    background-size: 13.44rem auto;
    padding-top: 1.07rem;
    position: relative;
    z-index: 2;
}
.cont2 p {
    font-size: 0.18rem;
    line-height: 3.33;
    letter-spacing: 0.12em;
    margin-left: 1.18rem;
    padding-top: 0.4rem;
}
@media screen and (max-width:750px){
.cont2 {
    height: 5rem;
    background-size: 90% auto;
    padding-top: 0;
}
.cont2 p {
    font-size: 0.14rem;
    line-height: 2;
    margin-left: 0.25rem;
    padding-top: 0.4rem;
}
}


/* cont3
------------------------------------------------- */
.cont3 {
    background: url("../img/top/cont3_bg2.jpg") center bottom 0.55rem no-repeat;
    background-size: 13.46rem auto;
    margin-top: -0.75rem;
    padding-bottom: 1.06rem;
    position: relative;
    z-index: 2;
}
.cont3::before {
    content: '';
    width: 10.08rem;
    height: 8.46rem;
    background: url("../img/top/cont3_bg1.png") center center no-repeat;
    background-size: cover;
    position: absolute;
    right: 50%;
    top: -1.65rem;
    margin-right: -3.24rem;
    z-index: 1;
}
.cont3 .headline {
    position: relative;
    z-index: 2;
}
.cont3 ul {
    padding-top: 0.92rem;
    position: relative;
    z-index: 2;
}
.cont3 ul li {
    width: 3.1rem;
    margin: 0 0.43rem 0.82rem;
}
@media screen and (max-width:750px){
.cont3 {
    background-position: center bottom 0.2rem;
    background-size: calc(100% - 0.2rem) auto;
    margin-top: -1rem;
    padding-bottom: 0.5rem;
}
.cont3::before {
    width: 100vw;
    height: 83.927vw;
    right: -10vw;
    top: -0.3rem;
    margin-right: 0;
}
.cont3 ul {
    display: flex;
    justify-content: space-between;
    padding-top: 0.5rem;
}
.cont3 ul li {
    width: 40vw;
    margin: 0 auto 0.25rem;
}
}


/* cont4
------------------------------------------------- */
.cont4 {
    width: 100%;
    height: 100vh;
    background: url("../img/top/cont4_bg1.jpg") center center no-repeat;
    background-size: cover;
    display: flex;
    align-items: center;
    color: #fff;
    position: relative;
    z-index: 3;
}
.cont4.con2 {
    background-image: url("../img/top/cont4_bg2.jpg");
}
.cont4.con3 {
    background-image: url("../img/top/cont4_bg3.jpg");
}
.cont4::after {
    content: '';
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.77);
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
}
.cont4 .inner {
    width: 100%;
    padding-left: 1.8rem;
    box-sizing: border-box;
    z-index: 2;
}
.cont4 h4,
.cont4 p {
    width: 100%;
    font-size: 0.18rem;
    font-weight: 400;
    line-height: 3.33;
    letter-spacing: 0.12em;
    padding: 0.3rem 0;
}
@media screen and (max-width:750px){
.cont4 {
    width: 100%;
    height: 100vh;
    background: url("../img/top/cont4_bg1.jpg") center center no-repeat;
    background-size: cover;
    display: flex;
    align-items: center;
    color: #fff;
    position: relative;
    z-index: 3;
}
.cont4.con2 {
    background-image: url("../img/top/cont4_bg2.jpg");
}
.cont4.con3 {
    background-image: url("../img/top/cont4_bg3.jpg");
}
.cont4::after {
    content: '';
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.77);
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
}
.cont4 .inner {
    padding: 0 0.2rem;
}
.cont4 h4,
.cont4 p {
    font-size: 0.14rem;
    line-height: 2;
    padding: 0.15rem 0;
}
}


/* cont5
------------------------------------------------- */
.cont5 {
    height: 12.92rem;
    background: url("../img/top/cont5_bg2.png") center bottom no-repeat;
    background-size: 100% auto;
    position: relative;
}
.cont5::after {
    content: '';
    width: 15rem;
    height: 15rem;
    background: url("../img/top/cont5_bg1.png") center center no-repeat;
    background-size: cover;
    position: absolute;
    left: 50%;
    top: -4.08rem;
    margin-left: -3.23rem;
    z-index: 1;
}
.cont5 h5 {
    width: 4rem;
    text-align: center;
    position: absolute;
    left: 50%;
    top: 5.14rem;
    margin-left: -2rem;
    z-index: 2;
}
.cont5 h5 span {
    display: block;
    font-size: 0.28rem;
    font-weight: 400;
    line-height: 1.285;
    letter-spacing: 0.12em;
    padding-top: 0.2rem;
}
@media screen and (max-width:750px){
.cont5 {
    height: 5rem;
}
.cont5::after {
    width: 160vw;
    height: 160vw;
    left: 50%;
    top: -1.5rem;
    margin-left: -50vw;
}
.cont5 h5 {
    width: 80vw;
    top: 2rem;
    margin-left: -40vw;
}
.cont5 h5 span {
    font-size: 0.2rem;
}
}


/* footer
------------------------------------------------- */
#footer {
    height: 1.97rem;
    background-color: #fff;
    text-align: center;
}
#footer h6 {
    font-size: 0.28rem;
    font-weight: 400;
    line-height: 1.285;
    letter-spacing: 0.12em;
    padding: 0.6rem 0 0.35rem;
}
#footer small {
    display: block;
    font-size: 0.12rem;
    font-weight: 400;
    line-height: 1.33;
    letter-spacing: 0.12em;
    color: #717171;
}
@media screen and (max-width:750px){
#footer {
    height: 1.8rem;
}
#footer h6 {
    font-size: 0.24rem;
    line-height: 1.35;
    padding: 0.5rem 0 0.25rem;
}
#footer small {
    font-size: 0.1rem;
}
}


/* animation
------------------------------------------------- */
.fadeUp {
    opacity: 0;
}
.fadeUp.isAnimate {
    animation: fadeUp 0.8s ease 0.2s 1 forwards;
}
@keyframes fadeUp {
    0% {
        opacity: 0;
        transform: translateY(0.2rem);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}
