@charset "UTF-8";

html {
scroll-behavior: smooth;
}

body {
font-family: "Noto Serif JP", serif;
font-weight: 300;
font-size: 14px;
line-height: 1.7;
color: #6D8059;
background: #fff;
margin-bottom: 12%;
}

h1,h2,h3,h4,h5,h6 {
font-weight: 300;
}

.inner {
padding-left: 16px;
padding-right: 16px;
}

@media (max-width: 767px){
.hidden-sp {display: none;}
section#youtube{ width: 350px; height:196.875px; margin: 60px auto 0; padding-bottom:10px;}
}
@media (min-width: 768px) {
.hidden-pc {display: none;}
section#youtube{ width: 700px; height:393.75px; margin: 0 auto; padding-bottom:60px;}
}

.section__title {
font-size: 20px;
text-align: center;
margin-top: -50%;
padding-top: 40px;
}

@media (min-width: 768px) {
.section__title {
font-size: 32px;
}
}

/* header */
.header {
padding-block: 16px;
position: sticky;
top: 0;
z-index: 30;
background: #fff;
}

.header__inner {
display: flex;
justify-content: space-between;
}

.header__logo a img{
width: 91px;
display: block;
}

.header__nav-sp {
display: flex;
gap: 24px;
}

.header__button-sp {
font-size: 11px;
border: 1px solid #6D8059;
background: #6D8059;
color: #fff; 
width: 135px;
height: 24px;
text-align: center;
display: grid;
place-content: center;
text-decoration: none;
padding: 0 3px;
transition: opacity 0.3s;
}

.header__button-sp:hover {
opacity: 0.7;
}

.drawer-icon {
width: 30px;
height: 24px;
position: relative;
z-index: 50;
border: none;
background: transparent;
}

.drawer-icon.is-checked .drawer-icon__bar {
background: #fff;
}

.drawer-icon.is-checked .drawer-icon__bar:nth-last-of-type(1) {
top: 12px;
transform: rotate(45deg);
color: #fff;
}

.drawer-icon.is-checked .drawer-icon__bar:nth-last-of-type(2) {
display: none;
}

.drawer-icon.is-checked .drawer-icon__bar:nth-last-of-type(3) {
top: 12px;
transform: rotate(-45deg);
color: #fff;
}

.drawer-icon__bar {
width: 30px;
height: 1px;
border-radius: 3px;
background: #6D8059;
position: absolute;
left: 0;
}

.drawer-icon__bar:nth-last-of-type(1) {
top: 0;
}

.drawer-icon__bar:nth-last-of-type(2) {
top: 12px;
}

.drawer-icon__bar:nth-last-of-type(3) {
top: 24px;
}

.header__nav {
display: none;
}

.header__link:hover {
opacity: 0.7;
}

.drawer-content {
position: fixed;
top: 0;
left: 0;
background: #6D8059;
width: 100%;
height: 100%;
z-index: 40;
transform: translateX(100%);
transition: transform 0.3s linear;
}

.drawer-content.is-checked {
transform: translateX(0);
}

.drawer-content__menu {
padding-top: 48px;
display: flex;
flex-direction: column;
}

.drawer-content__link {
text-align: center;
font-size: 18px;
color: #fff;
padding: 8px;
margin-top: 32px;
text-decoration: none;
}

.drawer-content__link:hover {
opacity: 0.7;
}

.drawer-content__button {
text-decoration: none;
font-size: 15px;
font-weight: 600;
border: 1px solid #fff;
background: #fff;
color: #6D8059; 
width: 200px;
height: 24px;
display: grid;
place-content: center;
margin-top: 40px;
align-self: center;
padding: 3px;
transition: opacity 0.3s;
}

.drawer-content__button:hover {
opacity: 0.7;
}

@media (min-width: 768px) {
.header {
max-width: 100%;
margin-left: auto;
margin-right: auto;
padding-inline: 35px;
}

.header__logo a img{
width: 144px;
}

.header__button-sp {
display: none;
}

.header__nav {
display: flex;
gap: 20px;
align-items: center;
}

.header__open {
display: none;
}

.header__link {
font-size: 15px;
color: #6D8059;
text-decoration: none;
}

.header__button {
font-size: 13px;
border: 1px solid #6D8059;
background: #6D8059;
color: #fff; 
width: 166px;
height: 38px;
text-align: center;
display: grid;
place-content: center;
text-decoration: none;
transition: opacity 0.3s;
}

.header__button:hover {
opacity: 0.7;
}
}

/* fv */
.fv__inner {
position: relative;
margin-top: 70px;
margin-left: auto;
margin-right: auto;
}

.fv__images img{
display: block;
}

.fv__image-photo img {
width: 350px;
margin-left: auto;
margin-right: auto;
}

.fv__image-logo img {
width: 286px;
position: absolute;
top: 320px;
left: 50%;
transform: translateX(-50%);
}

.fv__content {
position: absolute;
top: 10px;
left: 50%;
transform: translateX(-50%);
display: flex;
justify-content: space-between;
gap: 180px;
}

.fv__text-left,
.fv__text-right {
font-size: 12px;
writing-mode: vertical-rl;
color: #000;
letter-spacing: 4px;
}

.fv__text-left {
margin-top: 80px;
margin-left: -15px;
}

@media(min-width: 768px) {
.fv__inner {
margin-top: 130px;
padding-bottom: 62px;
}

.fv__image-photo img {
width: 600px;
}

.fv__image-logo {
width: calc(820px / 1920px * 100%);
}

.fv__image-logo img {
width: 550px;
}

.fv__image-logo img {
position: absolute;
top: 520px;
left: 50%;
transform: translateX(-50%);
}

.fv__content {
gap: 430px;
top: 0px;
}

.fv__text-left,
.fv__text-right {
font-size: 16px;
letter-spacing: 8px;
}

.fv__text-left {
margin-top: 130px;
}
}

/* concept */
.concept__reef img{
width: 100%;
margin-left: -17px;
position: relative;
z-index: -1;
}

.concept__content-first {
text-align: center;
line-height: 25px;
margin-top: 32px;
}

.concept__content-first img {
width: 172px;
margin-top: 24px;
}

.concept__text-top + .concept__text-top {
margin-top: 16px;
}

.concept__content-second {
display: flex;
justify-content: space-between;
align-items: center;
margin-right: -16px;
margin-top: 5%;
}

.concept__text-bottom{
font-size: 13px;
line-height: 2;
}

.concept__content-second img {
width: 30%;
object-fit: cover;
}

.concept__content-second div {
width: 10%;
}

@media(min-width: 768px) {
.concept{
margin-top: -50px;
}

.concept__content-first {
line-height: 35px;
margin-top: 56px;
}

.concept__content-first img {
width: 594px;
margin-top: 56px;
}

.concept__text-top {
font-size: 18px;
}

.concept__text-top + .concept__text-top {
margin-top: 48px;
}

.concept__content-second {
font-size: 18px;
line-height: 35px;
}

.concept__text-bottom{
margin-top: 6%;
font-size: 16px;
text-align: center;
line-height: 55px;
}

.concept__content-second div {
width: 5%;
}

.concept__content-second {
margin-top: -30px;
}
}

@media(min-width: 1200px) {
.concept__text-bottom{
font-size: 18px;
}

.concept__content-second div {
width: 23%;
}

.concept__content-second img {
width: 25%;
object-fit: cover;
}

.concept__content-second {
margin-top: -80px;
}
}

/* menu */
.menu {
margin-top: 60%;
background-image: url(../img/menu-bg.png),url(../img/wood.jpg);
clip-path: polygon(0 0, 100% 8%, 100% 100%, 0% 100%);
background-repeat: no-repeat,round;
background-size: cover,130px;
color: #674E3B;
}

.menu__inner {
max-width: 450px;
margin-inline: auto;
}

.menu__inner h2 {
padding-top: 100px;
}

.menu__item-big {
display: flex;
gap: 24px;
margin-top: 40px;
width: 340px;
margin-inline: auto;
}

.menu__item-big-photo img,
.menu__item img {
width: 140px;
border-radius: 25px;
box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.2);
transition: 0.2s;
}

.menu__item-big-photo img:hover,
.menu__item img:hover {
transform: scale(105%);
transition: transform 0.2s linear;
}

.menu__container {
display: flex;
flex-direction: column;
gap: 40px;
margin-top: 24px;
}

.menu__item {
display: flex;
align-items: center;
gap: 16px;
width: 340px;
margin-inline: auto;
}

.menu__item:nth-of-type(2n+1) {
display: flex;
flex-direction: row-reverse;
gap: 16px;
align-items: center;
}

.menu__title-ja {
font-size: 18px;
}

.menu__text {
font-size: 12px;
flex: 1;
}

.menu__content a {
color: #674E3B;
font-size: 12px;
}

@media(min-width: 768px) {
.menu {
margin-top: 50%;
}

.menu__inner h2 {
padding-top: 150px;
}

.menu__inner {
max-width: none;
}

.menu__container {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 30px;
}

.menu__item-big-photo img,
.menu__container img {
width: 350px;
}

.menu__item-big {
display: block;
width: 350px;
gap: 37.6px;
text-align: center;
}

.menu__container {
margin-top: 32px;
width: 730px;
margin-inline: auto;
}

.menu__item,
.menu__item:nth-of-type(2n+1) {
display: block;
width: 350px;
gap: 37.6px;
text-align: center;
} 

.menu__title-ja {
font-size: 24px;
}

.menu__title-en {
font-size: 10px;
}

.menu__text {
font-size: 15px;
padding: 0 20px 15px;
}

.menu__content a {
font-size: 14px;
}
}

@media(min-width: 1330px) {
.menu__container {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 60px;
}

.menu__item-big-photo img,
.menu__container img {
width: 495px;
}

.menu__item-big {
display: block;
width: 495px;
gap: 37.6px;
text-align: center;
margin-inline: auto;
}

.menu__container {
margin-top: 50px;
width: 1025px;
margin-inline: auto;
}

.menu__item,
.menu__item:nth-of-type(2n+1) {
display: block;
width: 495px;
gap: 37.6px;
text-align: center;
}

.menu__item-big-photo img:hover,
.menu__item img:hover {
transform: scale(103%);
}

.menu__title-ja {
font-size: 24px;
}

.menu__title-en {
font-size: 10px;
}

.menu__text {
font-size: 14px;
padding: 20px 40px;
}

.menu__content a {
font-size: 16px;
}
}

/* eat-in */
.swiper {
width: 350px;
height: 200px;
}

.eat-in {
padding-top: 56px;
background-image: url(../img/wood.jpg);
background-repeat: round;
background-size: 130px;
margin-top: -5px;
color: #674E3B;
}

.eat-in__inner {
display: flex;
flex-direction: column;
gap: 24px;
align-items: center;
}

.eat-in__slide {
display: flex;
align-items: center;  
justify-content: center;  
}

.eat-in__slide img {
width: 300px;
border-radius: 30px;
}

.eat-in__title {
font-size: 17px;
}

.eat-in__content {
font-size: 12px;
padding-bottom: 16px;
width: 300px;
}

.swiper-pagination-bullet-active{
background-color: #674E3B;
}

@media(min-width: 768px)  {
.swiper {
width: 350px;
height: 310px;
}

.eat-in__inner {
display: grid;
grid-template-columns: repeat(2,2fr);
max-width: 680px;
margin-inline: auto;
text-align: center;
}

.eat-in__slide img {
width: 320px;
border-radius: 30px;
}

.eat-in__slider {
grid-column:1/2; 
grid-row:1/3;
}

.eat-in__title{
text-align-last: left;
font-size: 16px;
margin-top: 0px;
}

.eat-in__content {
text-align-last: left;
margin-top: -100px;
}

}


@media(min-width: 1330px)  {

.swiper {
width: 600px;
height: 400px;
}

.eat-in__slide img {
width: 505px;
}

.eat-in__inner {
margin-left: 8%;
max-width: 1100px;
margin-inline: auto;
}

.eat-in__title{
font-size: 18px;
}

.eat-in__content {
font-size: 14px;
margin-top: -130px;
}
}

/* online store */
.onlinestore{
color: #674E3B;
background-image: url(../img/wood.jpg);
background-repeat: round;
background-size: 130px;
padding: 80px 0;
margin-top: -10px;
margin-bottom: -20px;
}

.on_butter{
display: flex;
justify-content: flex-end;
width: 375px;
margin: 0 auto;
}

.on_butter img{
width: 110px;
margin-bottom: -50px;
z-index: 2;
}

.on_tiramisu{
display: flex;
justify-content: start;
width: 375px;
margin: 0 auto;
}

.on_tiramisu img{
width: 110px;
margin-top: -50px;
position: absolute;
}

.on_text{
background-color: rgba(255, 255, 255, .6);
width: 343px;
text-align: center;
margin: 0 auto;
border-radius: 0px;
padding: 10px 0;
outline: 2px solid #674E3B;
outline-offset: -10px;
padding-bottom: 30px;
position: relative;
}


.on_text h2{
font-size: 17px;
font-weight: 500;
margin: 20px 0 10px 0;
}

.on_text p{
font-size: 14px;
font-weight: normal;
line-height: 2;
padding-bottom: 8px;
}

.on_bigflex{
display: flex;
justify-content: center;
}

.on_textin h3{
writing-mode: vertical-rl;
margin: 15px;
font-size: 17px;
}

.on_textin{
margin-top: 50px;
text-indent: -150px;
}

.on_flex{
display: flex;
justify-content: space-between;
margin: 12px 16px 0 0;
text-align: left;
gap: 18px;
}

.on_textinner{
writing-mode: vertical-rl;
font-size: 14px;
}

.on_button {
margin-top: 20px;
display: grid;
place-content: center;
width: 200px;
text-align: center;
margin: 0 auto;
transition: opacity 0.3s;
}

.on_button:hover {
opacity: 0.7;
}

.on_text a{
background-color: rgba(103, 78, 59, .9);
border-radius: 25px;
padding: 8px 15px;
color: #ffffff;
text-decoration: none;
box-shadow: 0px 3px 5px 3px rgba(0,0,0,0.15);
transition: opacity 0.3s;
}

.on_text a:hover{
box-shadow: 0px 0px 5px 0px rgba(0,0,0,0.3);
}

@media (min-width: 768px) {
.onlinestore{
padding: 120px 0;
}

.on_text{
width: 600px;
}

.on_butter{
width: 700px;
}

.on_butter img{
width:220px;
margin-bottom: -120px;
}

.on_tiramisu{
width: 670px;
}

.on_tiramisu img{
width:210px;
margin-top: -100px;
}

.on_text h2{
font-size: 18px;
}

.on_text p{
font-size: 13px;
}

.on_textin h3{
font-size: 19px;
}

.on_text a{
padding: 8px 15px 12px 15px;
}

.on_button{
margin-top: 20px;
}
}

/* commitment */
.commitment {
padding-top: 55%;
color: #674E3B;
background-image: url(../img/commitment-bg.png),url(../img/wood.jpg);
clip-path: polygon(0 0, 100% 0%, 100% 92%, 0% 100%);
background-repeat: no-repeat,round;
background-size: cover,130px;
padding-bottom: 150px;
}

.commitment__inner {
padding-inline: 10px;
}

.commitment__top {
text-align: center;
margin-top: 32px;
}

.commitment__top img {
width: 226px;
border-radius: 30px;
}

.commitment__top-text {
margin-top: 24px;
font-size: 13px;
line-height: 2.1;
}

.commitment__bottom {
display: flex;
justify-content: space-between;
align-items: flex-end;
margin-top: 20px;
width: 355px;
margin-inline: auto;
}

.commitment__bottom-content {
display: flex;
flex-direction: column;
align-items: center;
width: 110px;
}

.commitment__bottom-content img {
width: 80px;
border-radius: 56px;
}

.commitment__bottom-name {
height: 70px;
text-align: center;
font-size: 14px;
writing-mode: vertical-rl;
letter-spacing: 5px;
}

.commitment__bottom-text {
font-size: 10px;
text-align: center;
margin-top: 10px;
}

@media (min-width: 768px) {
.commitment__top img {
width: 495px;
border-radius: 30px;
}

.commitment__top-text {
font-size: 16px;
}

.commitment__bottom {
width: 600px;
margin-top: 50px;
}

.commitment__bottom-content {
width: 250px;
}

.commitment__bottom-content img {
width: 130px;
border-radius: 65px;
}

.commitment__bottom-name {
height: 100px;
font-size: 19px;
}

.commitment__bottom-text {
font-size: 14px;
margin-top: 20px;
}
}

/* qa */
.qa {
margin-top: calc(20% - 120px);
padding-top: 120px;
}

.qa__inner {
position: relative;
}

.qa__title {
background: #fff;
width: 100px;
margin-inline: auto;
margin-bottom: -8px;
position: absolute;
left: 50%;
transform: translateX(-50%);
padding-inline: 10px;
top: -28px;
}

.qa__title-sub {
text-align: center;
font-size: 10px;
}

.qa-box{
border: 1px solid #6D8059;
padding-bottom: 20px;
margin-bottom: 20px;
width: 343px;
margin-inline: auto;
}

.qa-box__content-q {
display: flex;
gap: 10px;
padding-left: 20px;
align-items: center;
margin-top: 30px;
}

.qa-box__content-icon {
font-size: 11px;
color: #fff;
background: #6D8059;
border-radius: 50%;
padding: 10px;
}

.qa-box__content-a{
padding-top: 20px;
width: 280px;
margin-inline: auto;
font-size: 14px;
line-height: 1.4;
}

.qa-box__content {
margin-left: 0;
}

.border {
padding-block: 20px;
border-bottom: 1px solid #6D8059;
margin-inline: 10px;
}

.first{
margin-left: -10px;
}

.qa-box__content-image {
display: flex;
align-items: flex-end;
gap: 10px;
justify-content: flex-end;
}

@media (min-width: 768px) {
.qa {
margin-top: 10%;
}

.qa-box{
width: 700px;
margin-inline: auto;
padding-bottom: 20px;
margin-bottom: 20px;
}

.qa-box__content-a:nth-child(2n+1) {
padding: 300px 30px;
}

.qa-box__content-q {
gap: 20px;
padding-left: 20px;
margin-top: 50px;
}

.qa-box__content-text {
font-size: 18px;
}

.qa-box__content-a{
padding-top: 20px;
width: 550px;
margin-inline: auto;
font-size: 14px;
padding-bottom: 20px;
}

.qa-box__content-image {
gap: 20px;
margin-top: -40px;
margin-right: 20px;
}
}

/* access */
.access {
padding-top: 5px;
margin-top: -5px;
}

.access__inner {
margin-bottom: 30px;
}

.access__inner h2 {
margin-top: 72px;
}

.access__contents {
text-align: center;
margin-top: 32px;
}

.access__image img {
width: 227px;
}

.access__text {
font-size: 12px;
padding-top: 20px;
}

.access__sns {
display: flex;
gap: 20px;
justify-content: center;
align-items: center;
padding-top: 20px;
}

.access__sns a img {
width: 30px;
}

.youtube a img {
width: 80px;
}

@media (min-width: 768px) {
.access__inner {
margin-bottom: 60px;
}

.access__contents {
display: flex;
gap: 30px;
justify-content: center;
}

.access__image img {
width: 385px;
}

.access__content {
text-align: left;
}

.access__text {
font-size: 16px;
}

.access__text:nth-child(1) {
padding-top: 0;
}

.access__sns {
justify-content: flex-start;

}
}

/* footer */
.footer {
background: #6D8059;
box-sizing: border-box;
height: 204px;
padding: 32px;
}

.footer__inner {
text-align: center;
}

.footer__logo img{
width: 108px;
margin-top: 36px;
}

@media (min-width: 768px) {

.footer {
height: 204px;
padding: 32px;
}

.footer__inner {
display: flex;
gap: 40px;
flex-direction: row-reverse;
padding-left: 50px;
padding-bottom: 32px;
align-items: baseline;
justify-content: start;
max-width: 1760px;
margin-left: auto;
margin-right: auto;
}

.footer__logo img{
width: 164px;
}
}

.copylight {
color: #674E3B;
background: #fff;
font-size: 12px;
text-align: center;
}

@media (min-width: 768px) {
.copylight {
font-size: 14px;
}
}

/* line
-------------------------------------*/
p#line a{
width: 100%;
background: #00c300;
color: #fff;
text-align: center;
text-decoration: none;
display: block;
position: fixed;
bottom: -7px;
z-index: 9999;
}