/*====================================================================
body
====================================================================*/
body{font-family: "MSゴシック","Noto Sans JP","游ゴシック体", "YuGothic", "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Sawarabi Mincho";}
*{
    min-width: 0;
    min-height: 0;
    }
/*====================================================================
all
====================================================================*/
.text_align_c{
	text-align: center;
}
.wrapper {
    overflow: hidden;
}
.article_wrap{
    margin: 0 auto;
    max-width: 1100px;
}
.yugo{
    font-family: "游ゴシック体";}
.sawarabi_g{
    font-family: "Sawarabi Gothic";
    font-weight: bold;
}
.tsume{
    font-family: "Noto Sans JP";
    font-weight: bold;
    padding-top:0.2em;
    letter-spacing: -0.2em;
}
.choonpu,.tsu{
    font-family: "MSゴシック","Noto Sans JP","游ゴシック体";
}
/*====================================================================
PC表示
====================================================================*/
.sp{
    display: none;
}

/*====================================================================
header
====================================================================*/
header{
    background-color: #fff;
margin-bottom:38em;
position:relative;
z-index:60;
}
.header{
	width: 100%;
    display: flex;
}
.slider_area{
    flex-basis: 80%;
    position:relative;
}
.abs_title {
    display: block;
    position: absolute;
    right: 18px;
    bottom: 20px;
    width: auto;
    height: 48%;
}
.nav_area{
    flex-shrink: 0;
    flex-basis: 300px;
}
nav {
    margin: 65px 10px 0 0;
    max-width: 100%;
    text-align: center;
}
.main_logo {
    max-width: 130px;
    padding-bottom: 4em;
    width: 80%;
}
.menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-flow: column;
    height: 180px;
    margin: 0 0 1em;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.menu li {
    width: 100%;
    padding-left: 2em;
    padding-bottom: 5.5em;
    text-align: left;
    margin:0.5em;
}
.menu img {
    width: auto;
    height: 27px;
}
.menu p {
    display: inline;
    font-size: 1.5vmin;
    font-weight: bold;
    margin-left: 0.8em;
    padding-bottom: 0.3em;
    border-bottom: 1px solid #666;
}


/*ハンバーガーメニュー*/
.anchor {
    display: block;

}
.anchor {
    display: block;
}
.anchor2 {
    display: block;
    padding-top: 50px;
    margin-top: -50px;
}
.drawer-wrap{
    position: absolute;
    top: 0;
    right: 0;
    z-index: 40;
}
.drawer-label{
    position: fixed;
    top: 50px;
    right: 19px;
    font-size: 10px;
    z-index: 100;
}
#drawer-content {
    overflow: auto;
    position: fixed;
    top: 0;
    right: 0;
    padding: 30px;
    z-index: 40;
    text-align: right;
    /* width: 30vw; */
    /* min-width: 30vw; */
    height: 100%;
    opacity: 0.9;
    background: #fff;
    transition: all 0.3s ease-in-out 0s;
    transform: translateX(100%);
}
#drawer-content .menu img {
    width: 100%;
    height:auto;
}
#drawer-checkbox:checked ~ #drawer-content {
  transform: translateX(0);
  box-shadow: 6px 0 24px rgba(0, 0, 0, 0.16);
}
#drawer-close {
  display: none;
  position: fixed;
  z-index: 39;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0;
  transition: all 0.3s ease-in-out 0s;
}
#drawer-checkbox:checked ~ #drawer-close {
  display: block;
  opacity: 0.3;
}
#drawer-checkbox {
  display: none;
}
#drawer-icon {
	cursor: pointer;
	display: inline-block;
	height: 50px;
	position: fixed;
	width: 50px;
	right: 17px;
	top: 14px;
    z-index: 100;
}
#drawer-icon span {
    background: #333;
    display: block;
    height: 1px;
    left: 50%;
    margin: -8% 0 0 -42%;
    position: absolute;
    top: 46%;
    transition: all 0.3s ease-in-out 0s;
    width: 84%;
}
#drawer-icon span::before,
#drawer-icon span::after {
  -webkit-transform: rotate(0);
    background: #333;
    content: "";
    display: block;
    height: 100%;
    left: 50%;
    margin: -8% 0 0 -50%;
    position: absolute;
    top: 50%;
    transform: rotate(0);
    transition: all 0.3s ease-in-out;
    width: 100%;
}
#drawer-icon span::before {
  margin-top: -13px;
}
#drawer-icon span::after {
  margin-top: 12px;
}
#drawer-checkbox:checked ~ #drawer-icon span {
  background: rgba(51, 51, 51, 0);
}
#drawer-checkbox:checked ~ #drawer-icon span::before,
#drawer-checkbox:checked ~ #drawer-icon span::after {
  content: "";
  display: block;
  height: 100%;
  left: 50%;
  margin: -8% 0 0 -42%;
  position: absolute;
  top: 50%;
  width: 100%;
}
#drawer-checkbox:checked ~ #drawer-icon span::before {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
#drawer-checkbox:checked ~ #drawer-icon span::after {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}


/*slider*/
.slider{
    min-width: 300px;
    max-width: 2000px;
}


/*====================================================================
main
====================================================================*/
/*menu01*/
#menu_01{
    margin-bottom: 230px;
    position: relative;
}
.menu_abs_box{
    position:relative;
}
.abs_menu01_l {
    display: block;
    position: absolute;
    right: 3em;
    top: -28em;
    width: 40px;
    height: auto;
}
.abs_menu01_item {
    width: 14%;
    position: absolute;
    top: 55%;
    right: 6%;
    z-index: -10;
}
#menu_01 .flex_01{
    align-items:flex-start;
    justify-content: center;
}
.menu_01_inbox:first-child {
    flex-basis: 600px;
}
.menu_01_inbox:last-child {
    flex-basis: 42%;
    padding-left: 22px;
    padding-right: 60px;
}
.menu_01_inbox:last-child img {
    width: 300px;
    padding-top:25px;
    padding-bottom: 40px;
}
.menu_01_inbox p {
    font-size: 16px;
    line-height: 1.4em;
    letter-spacing: 0.1em;
}
/*menu02*/
#menu_02 {
    margin-bottom: 200px;
}
.abs_menu02_l {
    display: block;
    position: absolute;
    right: 3em;
    top: 0;
    width: 95px;
    height: auto;
}
#menu_02 .flex_01:first-child{
    justify-content: center;
    height: 312px;
    width: auto;
    margin-left: 20px;
    align-items: flex-start;
}
.menu_02_inbox:first-child{
    height: 425px;
    padding-right: 1em;
}
.menu_02_center{
    justify-content: center;
    padding-left: 80px;
}
.menu_02_inbox:last-child img{
    max-width: 600px;
    border-radius: 10px;
}
.menu_02_inbox p {
    writing-mode: vertical-rl;
    text-orientation: upright;
    font-size: 13px;
    line-height: 1.5em;
    letter-spacing: 0.1em;
}
.menu_02_under {
    width: 700px;
    margin: 50px 0 0px 33%;
    align-items: center;
}
.menu_02_under img{
    margin: 0px 20px 0 0;
    height: 122px;
    width: auto;
}
.menu_02_under_text{
    flex-basis: 436px;
}
.menu_02_under_text p {
    font-size: 16px;
    line-height: 1.5em;
    /* padding-left: 1em; */
}
.menu_02_relative{
    display: block;
    position: relative;
    margin:0 auto;
}
.menu_02_abs {
    width: 14%;
    position: absolute;
    top: 350px;
    left: 6%;
    z-index: -1;
}
/*menu03 gallery*/
#menu_03{
    padding-top:160px;
    padding-bottom: 90px;
    background-image:url(../img/bg_left.png),
    url(../img/bg_right.png);
background-color: #FFF6E9;
	background-repeat:repeat-y,
    repeat-y;
	background-position:left top,
	right top;
    background-size: 14%,14%;
}
.menu_03_heading{
    display: block;
    height: 40px;
    width: auto;
    margin:0 auto 40px;
    text-align: center;
}
.flexwrap {
    justify-content: space-between;
    display: flex;
    flex-wrap: wrap;
    width: 900px;
    margin: 0 auto;
}
.item {
    margin: 28px 0;
    text-align: center;
}
.item img{
    width: 410px;
    height: auto;
    border-radius: 10px;
}
.item p {
    writing-mode: vertical-rl;
    text-orientation: upright;
    text-align: start;
    padding-left: 0.6em;
    font-size: 1.5em;
    letter-spacing: 0em;
    height: 410px;
}

.button {
    text-align: center;
    padding: 15px;
    color: #fff;
    background: #F6AC19;
    border-radius: 10px;
    width: 300px;
    margin: 40px auto;
    font-size: 16px;
    letter-spacing: 0.2em;
}
.close {
    background:#666;
}

/*menu04*/
#menu_04{
    padding-top: 170px;
    padding-bottom: 90px;
}
.menu_04_heading{
    display: block;
    height: 40px;
    width: auto;
    margin:0 auto 70px;
    text-align: center;
}
.menu_04 p {
    font-size: 16px;
    line-height: 1.4em;
    letter-spacing: 0.1em;
}
.upperside,.lowerside{
align-items: center;
justify-content: center;
}
.left,.right{
    flex-basis: 530px;
}
.upperside .right img,.lowerside .left img{
    border-radius: 10px;
    width: 530px;
}
.upperside .left img,.lowerside .right img{
    height:auto;
    width: 100%;
    padding-bottom: 40px;
}
.upperside .left,.lowerside .right{
    padding: 20px;
}
/*====================================================================
landscape contact
====================================================================*/
/*landscape*/
.landscape_relative{
    display: block;
    position: relative;
    margin:0 auto;
}
.landscape_abs {
    width: 14%;
    position: absolute;
    top: -36%;
    left: 6%;
}

/*お問い合わせ*/
#menu_05{
    padding:100px 0 110px;
}
.map_box{
    text-align: center;
}
.map_box img{
    width: 250px;
    height: auto;
    margin-bottom: 30px;
}
.map_box div {
    display: block;
    font-size: 18px;
    line-height: 1.8em;
    font-weight: bold;
    letter-spacing: 0.1em;
}
.tel{
    margin-bottom:10px;
}
iframe{
    margin:42px auto;
}
.map_relative{
    display: block;
    position: relative;
    margin:0 auto;
}
.map_abs {
    width: 14%;
    position: absolute;
    top: 55%;
    right: 6%;
    z-index: -10;
}

/*====================================================================
footer
====================================================================*/
footer{
    text-align: center;
    background-color: #FFF6E9;
}
footer p{
    padding:100px 0 40px 0;
    color: #666;
    letter-spacing: 0.2em;
    font-size: 1.2em;
}


/*====================================================================
righside fixedtbutton to contact
====================================================================*/
/*fixedbutton*/
.fixedbutton{
    position: fixed;
    right: 0;
    width: 54px;
    height: auto;
    top: 40%;
    font-size: 50px;
    color: #fff;
    cursor: pointer;
    transition: .3s;
    /*デフォルトで非表示*/
    opacity: 0;
    visibility: hidden;
    z-index: 5;
    }
    /*このクラスが付与されると表示*/
    .active{
    opacity: 1;
    visibility: visible;
    }

/*====================================================================
1301-1850
====================================================================*/
@media ( max-width : 1850px ){
.menu img {
    height: 20px;
}
.nav_area {
    flex-basis: 340px;
}
.article_wrap {
    max-width: 1000px;
}
.menu_01_inbox:first-child {
    flex-basis: 550px;
}
.abs_menu01_l {
    /* display: block; */
    /* position: absolute;
    right: 3em;
    top: -28em; */
    width: 35px;
    /* height: auto; */
}
.menu_02_inbox:last-child img {
    max-width: 550px;
    /* border-radius: 10px; */
}
.menu_02_under_text {
    flex-basis: 420px;
}
.menu_02_under_text p {
    font-size: 16px;
    line-height: 1.5em;
    padding-left: 0.1em;
}
.abs_menu02_l {
    /* display: block;
    position: absolute;
    right: 3em;
    top: 0; */
    width: 80px;
    /* height: auto; */
}
.upperside .right img, .lowerside .left img {
    border-radius: 10px;
    width: 500px;
}

}


/*====================================================================
1151-1300
====================================================================*/
@media ( max-width : 1300px ){
    .menu li {
        /* width: 100%;
        padding-left: 2em; */
        padding-bottom: 3.5em;
        /* text-align: left; */
        /* margin: 0.5em; */
    }
    .abs_title {
        height: 63%;
    }
    .article_wrap {
        max-width: 800px;
    }
    .menu_01_inbox p {
        font-size: 14px;
        /* line-height: 1.4em;
        letter-spacing: 0.1em; */
    }
    .menu_01_inbox:last-child {
        flex-basis: 60%;
    }
    .menu_01_inbox:last-child img {
        width: 255px;
        /* padding-top: 25px; */
        padding-bottom: 33px;
    }
    .menu_02_inbox:last-child img {
        max-width: 430px;
        /* border-radius: 10px; */
    }
    .abs_menu01_l {
        /* display: block; */
        position: absolute;
        right: 5em;
        top: -24em;
        width: 30px;
        /* height: auto; */
    }
    .abs_menu02_l {
        width: 74px;
        /* height: auto; */
    }
    .abs_menu02_l {
        /* display: block;
        position: absolute; */
        right: 5em;
        /* top: 0;
        width: 95px;
        height: auto; */
    }
    .menu_02_inbox:first-child {
        height: 345px;
        /* padding-right: 1em; */
    }
    .menu_02_inbox p {
        /* writing-mode: vertical-rl;
        text-orientation: upright; */
        font-size: 12px;
        /* line-height: 1.5em;
        letter-spacing: 0.1em; */
    }
    .menu_02_center {
        /* justify-content: center; */
        padding-left: 0px;
    }
    .menu_02_under {
        margin: 28px 0 0px 25%;
        align-items: center;
    }
    .menu_02_under img {
        margin: 0px 2px 0 0;
    }
    .menu_02_under_text {
        flex-basis: 380px;
    }
    .menu_02_under_text p {
        font-size: 14px;
        line-height: 1.2em;
        /* letter-spacing: 0.1em; */
        /* padding-left: 1em; */
    }
    .menu_03_heading {
        /* display: block; */
        height: 31px;
        /* width: auto;
        margin: 0 auto 40px;
        text-align: center; */
    }
    .flexwrap {
        /* justify-content: space-between;
        display: flex;
        flex-wrap: wrap; */
        width: 750px;
        /* margin: 0 auto; */
    }
    .item img {
        width: 340px;
        /* height: auto;
        border-radius: 10px; */
    }
    .item p {
        /* writing-mode: vertical-rl;
        text-orientation: upright;
        text-align: start;
        padding-left: 0.6em;
        font-size: 1.5em;
        letter-spacing: 0em; */
        height: auto;
    }
    #menu_04 {
        padding-bottom: 155px;
    }
    .menu_04 p {
        font-size: 14px;
        /* line-height: 1.4em; */
        /* letter-spacing: 0.1em; */
    }
    .menu_04_heading {
        /* display: block; */
        height: 31px;
        /* width: auto;
        margin: 0 auto 70px;
        text-align: center; */
    }
    .upperside .left img, .lowerside .right img {
        height: 130px;
        /* width: auto; */
        padding-bottom: 35px;
    }
    .left, .right {
        flex-basis: 380px;
    }
    .upperside .right img, .lowerside .left img {
        /* border-radius: 10px; */
        width: 377px;
    }
.map_box iframe{
    width: 80%;
}
    }


/*====================================================================
801-1150
====================================================================*/
@media ( max-width : 1150px ){
    .nav_area{
        flex-basis: 250px;
    }
    nav {
        margin: 10px 10px 0 0;
    }
    .anchor{
        display: block;
        padding-top: 60px;
        margin-top: -60px;
    }
    .anchor2 {
        display: block;
        padding-top: 100px;
        margin-top: -100px;
    }
    .main_logo {
        padding-bottom: 1.5em;
    }
    .map_abs {
        width: 14%;
        top: 21%;
    }
    .menu img {
        width: 100%;
        height: auto;
    }
    .abs_title {
        height: 63%;
    }

    }
/*PCnav補助px 800-1050*/
    @media ( max-width : 1050px ){
        .menu li {
            padding-bottom: 13%;
        }
        .menu img {
            width: 100%;
            height: auto;
        }
            }


/*====================================================================
SP表示
====================================================================*/
/* 800px under sp */
@media ( max-width : 800px ){
    .sp{display: block;}
    .pc{display: none;}
    .flex_01{
		display: block;
	}

    header {
    margin-bottom: 7em;
}
    .header{
    z-index: 1;
}
/*sp menu*/
.sp_menu{
    width: 100%;
    display: block;
    justify-content: space-between;
    position: fixed;
    top: 0;
    left: 0;
    background-color: #fff;
    padding:1.2em;
    z-index: 79;
}
.sp_logo {
    width: 200px;
}
.drawer-wrap {
    z-index: 80;
}
#drawer-content {
    height: 100%;
    opacity: 0.9;
    width: 100%;
}
.menu li {
    padding-bottom: 6%;
    padding-top: 7%;
}
.anchor1 {
    display: block;
    padding-top: 100px;
    margin-top: -100px;
}



/*slider*/
.slider_area {
    padding-top: 65px;
}
.abs_title_sp {
    display: block;
    position: absolute;
    right: 10px;
    bottom: 10px;
    width: auto;
    height: 18%;
}
/*menu01*/
#menu_01 {
    margin-bottom: 60px;
}
.abs_menu01_sp {
    width: 50%;
    height: auto;
    margin: 0 auto;
}
.menu_01_inbox:first-child {
    /* flex-basis: 410px; */
    margin: 20px 20px 0px 40px;
}
.menu_01_inbox:last-child {
    text-align: center;
    padding: 30px;

}
.menu_01_inbox:last-child img {
    width: 300px;
    padding-top: 0px;
    padding-bottom: 40px;
}
.menu_01_inbox p {
    text-align:left;
    font-weight: normal;
    font-size:1.5em;
}

/*menu02*/
#menu_02 {
    padding: 30px 20px;
    margin-bottom: 60px;
}
.menu_02_l_sp {
    width: 400px;
    height: auto;
    margin: 0 auto;
}
.menu_02_inbox p {
    writing-mode: horizontal-tb;
    text-align: left;
    font-size: 1.5em;
    font-weight: normal;
    line-height: 1.5em;
    letter-spacing: 0.2em;
    padding-top: 2em;
    padding: 2em 0em 0.5em 0em;
    margin: 0 auto;
    width: 100%;
    max-width: 400px;
}
.menu_02_l_sp {
    width: 100%;
    height: auto;
    margin: 0 auto;
    padding: 0;
}
.menu_02_inbox{
    text-align: center;
}
.menu_02_inbox:first-child {
    height: 120px;
    padding-right: 1em;
}
.menu_02_inbox:last-child img {
    max-width: 450px;
    border-radius: 10px;
    width: 100%;
}
.menu_02_under {
    width: 100%;
    display: flex;
    margin: 0;
    align-items: flex-start;
    justify-content:center
}
.menu_02_under img {
    height: auto;
    width: 120px;
    /* max-width: 128px; */
}
.menu_02_under_text p {
    font-size: 1.5em;
    font-weight: normal;
    line-height: 1.5em;
    letter-spacing: 0.1em;
    padding-left: 0.5em;
}


/*menu03 gallery sp*/
.swipe_logo img{
    width: 29px;
    margin-top: 20px;
    margin-bottom: -7px;
    opacity: 70%;

}
#menu_03 {
    padding: 100px 20px;
    background-image: none;
}
.menu_03_heading {
    width: 100%;
    height: auto;
    margin: 0 auto;
    padding: 0;
}

/*menu04*/
#menu_04 {
    padding: 100px 20px 120px 20px;
}
.menu_04_heading {
    width: 100%;
    height: auto;
    margin: 0 auto;
    padding-bottom: 35px;
}
.upperside .left img, .lowerside .right img {
    width: 50%;
    /* max-width: 700px; */
    height: auto;
    margin: 20px auto 28px;
    padding: 0;
}
.upperside .left, .lowerside .right {
    text-align: left;
    padding: 16px;
}
.upperside .right img, .lowerside .left img {
    /* border-radius: 10px; */
    width: 100%;
}

/*menu05*/
#menu_05 {
    padding: 60px 0;
}
.map_box img {
    width: 200px;
    height: auto;
    margin:30px auto;
}
.map_box div {
    font-size: 1.8em;
    line-height: 1.5em;
    font-weight: normal;
}

}

/* 600px under sp */
@media ( max-width : 600px ){
.upperside .left img, .lowerside .right img {
    width: 95%;
    height: auto;
    padding: 0;
}}




/*spスワイプgallery*/

.scroll_table {
    max-width: 800px;
    overflow-x: auto;
}
.scroll_table table{
    margin-bottom: 15px;
}
.scroll_table img{
width: 90vw;
border-radius: 5px;
}
.scroll_table th{
padding-top: 20px;
padding-right:20px;
}
table {
white-space: nowrap;
margin: 25px 0 0 0;
font-size: 16px;
}

.scroll_table::-webkit-scrollbar {
height: 10px; /*スクロールバーの高さ*/
}

.scroll_table::-webkit-scrollbar-thumb {
background: #aaa; /*ツマミの色*/
}

.scroll_table::-webkit-scrollbar-track {
background: #ddd;  /*トラックの色*/
}

/* 販売場所追加 */
.sales_location {
    width: 100%;
    max-width: 560px;
    padding: 25px;
    border-radius: 12px;
    background-color: #FFF6E9;
}
.sales_location b {
    display: block;
    margin-bottom: 15px;
    font-size: 16px;
}
.sales_location ul {
    font-size: 14px;
    margin-left: 1.5em;
}
.sales_location ul li {
    margin-top: 10px;
    list-style: disc;
}
@media (max-width: 768px) {
    .sales_location {
        margin-top: 30px;
    }
}