body {
    height: 100%;
    margin: 0;
    font-feature-settings: 'palt';
	-webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
	color: #ff7c40;
	font-family: "yu-gothic-pr6n", sans-serif;
	font-weight: 400;
	font-style: normal;
	background: #f9f9f9;
}
a{
	color: #ff7c40;
	text-decoration: none;
}

/* js_ani */
.img-opa {
	opacity: 0;
	transition: opacity 0.3s ease-out;
}
.img-opa img {
	display: block;
	width: 100%;
	height: auto;
}




/* 
font-family: "itc-avant-garde-gothic-pro", sans-serif;
font-weight: 700;
font-style: normal;
 */

/* font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif; */


/* 

font-family: "baskerville-urw", serif;
font-weight: 400;
font-style: normal;

font-family: garamond-premier-pro, serif;
font-weight: 400;

Didot LT Pro Headline
font-family: "linotype-didot-headline", serif;
font-weight: 400;
font-style: normal;

*/

/*imac*/
@media screen and (min-width: 2560px) and (max-width: 5120px) {
	.sp-on{
		display: none !important;
	}
	.pad-on {
		display: none !important;
	}

	/* pagetop */
	.page-top{
		width: 12px;
		line-height: 0;
		position: fixed;
		right: 30px;
		bottom: 20px;
	}
	.page-top:hover {
		transform: scale(1) translateY(-4px);
		animation: elastic-pull 0.6s ease-out;
	}
	@keyframes elastic-pull {
		0% {
			transform: scale(1) translateY(0);
		}
		50% {
			transform: scale(1.15) translateY(-6px);
		}
		100% {
			transform: scale(1.05) translateY(-4px);
		}
	}

	/* load */
	.load{
		width: 100%;
		height: 100vh;
		position: fixed;
		z-index: 9999;
		background: #fff;
	}
	.icon-list{
		width: 80%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.icon-list li{
		width: 16%;
		box-sizing: border-box;
		padding: 2% 2%;
	}
	.icon-list li:nth-child(n+7):nth-child(-n+12){
		margin-top: 5%;
		margin-bottom: 5%;
	}

	.load .logo{
		width: 17%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 99999;
	}

	/* header */
	header{
		width: 100%;
		height: 100vh;
		position: relative;
		margin: 0 0 5% 0;
	}
	.header_logo{
		width: 10%;
		display: flex;
		justify-content: space-between;
		position: absolute;
		bottom: 8%;
		right: 2%;
	}
	.header_logo li{
		width: 40%;
	}
	.header_logo li a{
		width: 100%;
		display: block;
		position: relative;
		line-height: 0;
	}
	.header_logo li a .on{
		width: 100%;
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		line-height: 0;
		clip-path: inset(0 100% 0% 0%);
		transition: .3s;
	}
	.header_logo li a:hover .on{
		clip-path: inset(0 0% 0% 0%);
		transition: .3s;
	}

	.mv-logo{
		width: 25%;
		position: absolute;
		left: 0;
		right: 0;
		bottom: 7%;
		margin: 0 auto;
		z-index: 999;
	}

	.wrapper{
		width: 70%;
		position: relative;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		margin: 0 auto;
	}
	.swiper{
		text-align: center;
		width: 100%;
	}
	.bar{
		position: relative;
		width: 100%;
		height: 3px;
		background: #fff;
		overflow: hidden;
		z-index: 999;
	}
	.bar span{
		display: inline-block;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		z-index: 2;
		background: #ff7c40;
		border-radius: 10px;
		transform: scaleX(0);
		transform-origin: left center;
		transition-timing-function: linear;
	}
	.swiper-slide {
		overflow: hidden;
	}
	.swiper-slide img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		transition: transform 10000ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
	}
	.swiper-slide-active img {
		transform: scale(1.07);
	}

	/* reservation */
	.reservation {
		width: 120px;
		height: 120px;
		display: block;
		background: #fff;
		position: fixed;
		top: 3%;
		right: 1.5%;
		font-weight: bold;
		text-decoration: none;
		overflow: hidden;
		cursor: pointer;
		transition: color 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
		z-index: 999;
		border-radius: 1000px;
	}
	.reservation .txt{
		width: 100%;
		font-size: 12px;
		letter-spacing: 5px;
		line-height: 1em;
		text-align: center;
		font-weight: bold;
		text-decoration: none;
		color: #ff7c40;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 3px;
		z-index: 9999;
	}
	.reservation:hover .txt{
		color: #fff;
	}
	.reservation::before {
		content: '';
		position: absolute;
		width: 0;
		height: 0;
		background: radial-gradient(circle, 
			rgba(255,124,64,0.9) 0%, 
			rgba(255,124,64,0.7) 50%, 
			rgba(255,124,64,0.5) 80%, 
			rgba(255,124,64,0) 100%);
		border-radius: 50%;
		transition: all 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
		z-index: 1;
		transform: translate(-50%, -50%);
		opacity: 0;
		left: var(--mouse-x, 50%);
		top: var(--mouse-y, 50%);
	}
	.reservation:hover::before {
		width: 500px;
		height: 500px;
		opacity: 1;
	}
	.reservation:hover {
		color: white;
	}
	.reservation span {
		width: 10px;
		display: block;
		line-height: 0;
		margin: 0% auto 0 auto;
		position: absolute;
		z-index: 2;
		left: -3px;
		right: 0;
		top: 30px;
		opacity: 0;
		transform: translateY(20px);
		transition: .5s;
	}
	.reservation span img {
		width: 100%;
		filter: brightness(0) saturate(100%) invert(53%) sepia(91%) saturate(2878%) hue-rotate(346deg) brightness(104%) contrast(97%);
		transition: filter 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	}
	.reservation:hover span img {
		filter: brightness(0) invert(1);
	}
	.reservation:hover span {
		transform: translateY(0px);
		opacity: 1;
		transition: .3s;
	}

	/* fix-nav */
	.fix-nav{
		width: max-content;
		position: fixed;
		z-index: 99;
		top: 40%;
		-webkit-transform: translateY(-40%); /* Safari用 */
		transform: translateY(-40%);
		left: 3%;
	}
	.fix-nav li{
		margin: 0 0 70% 0;
	}
	.fix-nav li:last-child{
		margin: 0 0 0% 0;
	}
	.fix-nav li a{
		display: block;
		font-size: 12px;
		letter-spacing: 1px;
		font-weight: bold;
		position: relative;
	}
	.fix-nav li a .on01{
		width: 140%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on01{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on02{
		width: 90%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on02{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on03{
		width: 140%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on03{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on04{
		width: 105%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on04{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	/* sns-nav */
	.sns-nav{
		width: 100px;
		position: fixed;
		z-index: 99;
		bottom: 8%;
		left: 3%;
		display: flex;
		justify-content: space-between;
	}
	.sns-nav li{
		width: 20%;
	}
	.sns-nav li a{
		display: block;
	}

	.screen-fix{
		width: 100%;
		position: fixed;
		top: 50%;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.8s ease-in-out, visibility 0.8s ease-in-out;
	}
	.screen-fix.show {
		opacity: 1;
		visibility: visible;
	}
	.icon-list-screen{
		width: 90%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.icon-list-screen li{
		width: 16%;
		box-sizing: border-box;
		padding: 2% 3%;
	}
	.icon-list-screen li:nth-child(n+7):nth-child(-n+12){
		margin-top: 4%;
		margin-bottom: 4%;
	}

	/* main-fix */
	.main-fix{
		width: 15%;
		position: fixed;
		left: 0;
		right: 0;
		margin: 0 auto;
		top: 3%;
		line-height: 0;
		z-index: 99;
		transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	}
	.main-fix.hidden {
		opacity: 0;
		transform: translateY(-30px) scale(0.95);
		pointer-events: none;
	}
	.main-fix.visible {
		opacity: 1;
		transform: translateY(0) scale(1);
		pointer-events: auto;
	}

	.rever{
		flex-direction: row-reverse;
	}
	.all-wrap{
		width: 100%;
		position: relative;
		display: flex;
		justify-content: space-between;
		margin: 0 0 10% 0;
	}
	.fix-box{
		width: 50%;
		position: relative;
	}
	.cont{
		width: 50%;
		overflow: hidden;
		padding: 0 0 10% 0;
	}

	.col3{
		width: 70%;
		display: flex;
		justify-content: space-between;
		margin: 0 auto 10% auto;
	}
	.col3_end{
		margin: 0 auto 5% auto !important;
	}
	.col3 .img{
		width: 30%;
	}

	/* cont01 */
	.fix-box .fix-img01{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/01-01.jpg) no-repeat;
		background-size: cover;
	}
	.cont01 .txt{
		width: 75%;
		font-size: 16px;
		line-height: 3em;
		letter-spacing: 5px;
		box-sizing: border-box;
		margin: 0 auto 10% auto;
		padding: 15% 0 0 0;
	}
	.img01-01{
		width: 50%;
		margin: 0 auto 15% auto;
	}
	.img01-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img01-03{
		width: 45%;
		margin: 0 0 0 20%;
	}

	/* cont02 */
	.fix-box .fix-img02{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/02-02.jpg) no-repeat;
		background-size: cover;
	}
	.cont02 .title{
		width: 170px;
		background: #ff7c40;
		margin: 0 auto 10% auto;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.cont02 .title .txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
	}
	.cont02 .img01{
		width: 60%;
		position: relative;
		margin: 0 auto 15% auto;
	}
	.cont02 .img01 .point{
		width: max-content;
		position: absolute;
		bottom: 0;
		right: 7%;
	}
	.cont02 .img01 .point li{
		font-size: 12px;
        letter-spacing: 2px;
        line-height: 1.8em;
	}
	.cont02 .img02{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.img02-01{
		width: 50%;
		margin: 0 auto 15% auto;
		padding: 10% 0 0 0;
	}
	.img02-02{
		width: 70%;
		margin: 0 0 15% 0%;
	}
	.img02-03{
		width: 45%;
		margin: 0 0 0 40%;
	}

	/* cont03 */
	.fix-box .fix-img03{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/03-01.jpg) no-repeat;
		background-size: cover;
	}
	.img03-01{
		width: 50%;
		margin: 0 auto 15% auto;
	}
	.img03-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img03-03{
		width: 45%;
		margin: 0 0 0 20%;
	}

	/* price_data */
	.price_data{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.price_data .title{
		width: 170px;
		background: #ff7c40;
		margin: 0 0 5% 0;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.price_data .title .txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
	}
	.price_data .pr-txt00{
		width: 100%;
		font-size: 14px;
        letter-spacing: 2px;
		text-align: justify;
		line-height: 2.5em;
		margin: 0 0 7% 0;
	}
	.pr-list{
		width: 100%;
		margin: 0 auto 5% auto;
	}
	.pr-list li{
		width: 100%;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		flex-wrap: wrap;
		border-bottom: 1px solid #ff7c40;
		padding: 3% 0;
	}
	.pr-list li .pr-txt01{
		width: 30%;
		font-size: 16px;
        letter-spacing: 2px;
		margin: 0 5% 0 0;
	}
	.pr-list li .icon{
		width: 10%;
		margin: 0 5% 0 0;
	}
	.pr-list li .pr-txt02{
		width: 20%;
		text-align: left;
		font-size: 16px;
        letter-spacing: 2px;
	}
	.pr-list li .pr-txt03{
		width: 30%;
		text-align: left;
		font-size: 12px;
        letter-spacing: 2px;
	}
	.pr-list li .pr-txt04{
		width: 50%;
		text-align: left;
		font-size: 12px;
        letter-spacing: 2px;
		margin: 2% 0 0 50%;
	}

	.price_data .cou{
		width: 100%;
		margin: 0 auto 10% auto;
	}
	.price_data .cou li{
		width: 100%;
		text-align: justify;
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-indent: -.7em;
		padding-left: .7em;
	}
	.p-txt-box{
		width: 100%;
		margin: 0 0 7% 0;
	}
	.p-txt-box .line{
		width: 100%;
		height: 1px;
		background: #ff7c40;
		margin: 0 0 3% 0;
	}
	.p-txt-box .p-title{
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		margin: 0 0 1% 0;
	}
	.p-txt-box .p-txt{
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: justify;
	}
	.p-txt-box .tell{
		width: max-content;
		display: block;
		background: #ff7c40;
		color: #fff;
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		padding: 2px 10px 0 12px;
	}
	.p-txt-box .tell span{
		font-size: 10px;
		letter-spacing: 2px;
		margin: 0 10px 0 0;
		position: relative;
		top: -1px;
	}
	
	.tell-time{
		width: max-content;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		margin: 5% 0 7% 0;
	}
	.tell-time li:nth-child(1){
		margin: 0 40px 0 0;
	}
	.tell-time li:nth-child(2){
		margin: 0 10px 0 0;
		font-size: 12px;
		letter-spacing: 2px;
	}
	.tell-time li:nth-child(3){
		margin: 0 10px 0 0;
		height: 20px;
		width: .5px;
		background: #ff7c40;
	}
	.tell-time li:nth-child(4){
		font-size: 12px;
		letter-spacing: 2px;
	}

	/* cont04 */
	.fix-box .fix-img04{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/04-02.jpg) no-repeat;
		background-size: cover;
	}
	.cont04 .img01{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.img04-01{
		width: 70%;
		margin: 0 0 15% 0;
		padding: 15% 0 0 0;
	}
	.img04-02{
		width: 50%;
		margin: 0 auto 15% auto;
	}
	.img04-03{
		width: 45%;
		margin: 0 0 0 40%;
	}

	/* cont05 */
	.fix-box .fix-img05{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/05-01.jpg) no-repeat;
		background-size: cover;
		background-position: top center;
	}
	.img05-01{
		width: 50%;
		margin: 0 auto 15% auto;
		padding: 15% 0 0 0;
	}
	.img05-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img05-03{
		width: 60%;
		margin: 0 auto 0 auto;
	}

	/* cont06 */
	.fix-box .fix-img06{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/06-02.jpg) no-repeat;
		background-size: cover;
	}
	.cont06 .img01{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.img06-01{
		width: 70%;
		margin: 0 0 15% 0;
		padding: 15% 0 0 0;
	}
	.img06-02{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img06-03{
		width: 50%;
		margin: 0 0 0 35%;
	}

	/* staff */
	.staff{
		width: 100%;
		margin: 0 auto 10% auto;
	}
	.staff .staff_list{
		width: 100%;
	}
	.staff .staff_list li{
		width: 100%;
		font-family: "droid-serif", serif;
		font-weight: 400;
		font-style: italic;
		font-size: 12px;
		letter-spacing: 2px;
		text-align: center;
		line-height: 2em;
		margin: 0 0 2% 0;
	}

	/* f_nav */
	.f_nav{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.f_nav_list{
		width: 100%;
		margin: 0 auto;
	}
	.f_nav_list li{
		width: 100%;
		margin: 0 auto 7% auto;
	}
	.f_nav_list li:last-child{
		width: 100%;
		margin: 0 auto 0% auto;
	}
	.f_nav_list li a{
		width: 100%;
		display: block;
		text-decoration: none;
		color: #ff7c40;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.f_nav_list li a .img{
		width: 45%;
		overflow: hidden;
		border-radius: 15px;
		transition: .3s;
	}
	.f_nav_list li a .img img{
		transform: scale(1);
		transition: .3s;
	}
	.f_nav_list li a:hover .img{
		width: 45%;
		overflow: hidden;
		border-radius: 30px;
		transition: .3s;
	}
	.f_nav_list li a:hover .img img{
		transform: scale(1.1);
		transition: .3s;
	}
	.f_nav_list li a .data{
		width: 45%;
	}
	.f_nav_list li a .data .txt01{
		font-size: 16px;
		letter-spacing: 5px;
		line-height: 2em;
		margin: 0 0 2% 0;
	}
	.f_nav_list li a .data .txt02{
		font-size: 20px;
		letter-spacing: 5px;
		line-height: 2em;
		font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
		margin: 0 0 10% 0;
	}
	.f_nav_list li a .data .txt03{
		width: 80%;
		line-height: 0;
		display: block;
	}

	/* footer */
	footer{
		width: 100%;
		padding: 0 0 3% 0;
	}
	footer .f-logo{
		width: 10%;
		margin: 0 auto 2% auto;
	}
	footer .f-txt{
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 2em;
		text-align: center;
		margin: 0 auto 2% auto;
	}
	footer a{
		display: block;
        position: relative;
        font-size: 13px;
        letter-spacing: 2px;
        text-align: center;
		color: #ff7c40;
        text-decoration: none;
		text-align: center;
		margin: 0 auto 2% auto;
    }
	footer .copy {
        width: 10%;
		line-height: 0;
        margin: 0 auto;
    }

	/* leagal */
	.content-leagal{
		width: 60%;
		margin: 0 auto 10% auto;
		padding: 10% 0 0 0;
	}
	.leagal-title{
		width: 170px;
		background: #ff7c40;
		margin: 0 auto 2% auto;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.leagal-title .leagal-txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
		padding: 2px 0 0 0;
	}
	.leagal-sub-title{
		width: 100%;
		text-align: center;
		font-size: 13px;
		letter-spacing: 2px;
		line-height: 1.8em;
		margin: 0 auto 10% auto;
	}
	.leagal-box .leagal-list{
		width: 100%;
		margin: 0 0 5% 0;
	}
	.leagal-box .leagal-list li{
		width: 98.8%;
		font-size: 13px;
		line-height: 2em;
		letter-spacing: 2px;
		text-align: justify;
		text-indent: -1.2%;
		padding-left: 1.2%;
	}
	.leagal-box .leagal-list li .icon{
		width: 2px;
		height: 2px;
		border-radius: 1px;
		background: #ff7c40;
		display: inline-block;
		position: relative;
		top: -4px;
		margin: 0 10px 0 0;
	}
	.leagal-box .leagal-list li a{
		text-decoration: none;
		color: #ff7c40;
		border-bottom: 1px solid #ff7c40;
	}

}

/*pc*/
@media screen and (min-width: 1281px) and (max-width: 2559px) {
    .sp-on{
		display: none !important;
	}
	.pad-on {
		display: none !important;
	}

	/* pagetop */
	.page-top{
		width: 12px;
		line-height: 0;
		position: fixed;
		right: 30px;
		bottom: 20px;
	}
	.page-top:hover {
		transform: scale(1) translateY(-4px);
		animation: elastic-pull 0.6s ease-out;
	}
	@keyframes elastic-pull {
		0% {
			transform: scale(1) translateY(0);
		}
		50% {
			transform: scale(1.15) translateY(-6px);
		}
		100% {
			transform: scale(1.05) translateY(-4px);
		}
	}

	/* load */
	.load{
		width: 100%;
		height: 100vh;
		position: fixed;
		z-index: 9999;
		background: #fff;
	}
	.icon-list{
		width: 80%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.icon-list li{
		width: 16%;
		box-sizing: border-box;
		padding: 2% 2%;
	}
	.icon-list li:nth-child(n+7):nth-child(-n+12){
		margin-top: 5%;
		margin-bottom: 5%;
	}

	.load .logo{
		width: 17%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 99999;
	}

	/* header */
	header{
		width: 100%;
		height: 100vh;
		position: relative;
		margin: 0 0 5% 0;
	}
	.header_logo{
		width: 10%;
		display: flex;
		justify-content: space-between;
		position: absolute;
		bottom: 8%;
		right: 2%;
	}
	.header_logo li{
		width: 40%;
	}
	.header_logo li a{
		width: 100%;
		display: block;
		position: relative;
		line-height: 0;
	}
	.header_logo li a .on{
		width: 100%;
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		line-height: 0;
		clip-path: inset(0 100% 0% 0%);
		transition: .3s;
	}
	.header_logo li a:hover .on{
		clip-path: inset(0 0% 0% 0%);
		transition: .3s;
	}

	.mv-logo{
		width: 25%;
		position: absolute;
		left: 0;
		right: 0;
		bottom: 7%;
		margin: 0 auto;
		z-index: 999;
	}

	.wrapper{
		width: 70%;
		position: relative;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		margin: 0 auto;
	}
	.swiper{
		text-align: center;
		width: 100%;
	}
	.bar{
		position: relative;
		width: 100%;
		height: 3px;
		background: #fff;
		overflow: hidden;
		z-index: 999;
	}
	.bar span{
		display: inline-block;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		z-index: 2;
		background: #ff7c40;
		border-radius: 10px;
		transform: scaleX(0);
		transform-origin: left center;
		transition-timing-function: linear;
	}
	.swiper-slide {
		overflow: hidden;
	}
	.swiper-slide img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		transition: transform 10000ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
	}
	.swiper-slide-active img {
		transform: scale(1.07);
	}

	/* reservation */
	.reservation {
		width: 120px;
		height: 120px;
		display: block;
		background: #fff;
		position: fixed;
		top: 3%;
		right: 1.5%;
		font-weight: bold;
		text-decoration: none;
		overflow: hidden;
		cursor: pointer;
		transition: color 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
		z-index: 999;
		border-radius: 1000px;
	}
	.reservation .txt{
		width: 100%;
		font-size: 12px;
		letter-spacing: 5px;
		line-height: 1em;
		text-align: center;
		font-weight: bold;
		text-decoration: none;
		color: #ff7c40;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 3px;
		z-index: 9999;
	}
	.reservation:hover .txt{
		color: #fff;
	}
	.reservation::before {
		content: '';
		position: absolute;
		width: 0;
		height: 0;
		background: radial-gradient(circle, 
			rgba(255,124,64,0.9) 0%, 
			rgba(255,124,64,0.7) 50%, 
			rgba(255,124,64,0.5) 80%, 
			rgba(255,124,64,0) 100%);
		border-radius: 50%;
		transition: all 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
		z-index: 1;
		transform: translate(-50%, -50%);
		opacity: 0;
		left: var(--mouse-x, 50%);
		top: var(--mouse-y, 50%);
	}
	.reservation:hover::before {
		width: 500px;
		height: 500px;
		opacity: 1;
	}
	.reservation:hover {
		color: white;
	}
	.reservation span {
		width: 10px;
		display: block;
		line-height: 0;
		margin: 0% auto 0 auto;
		position: absolute;
		z-index: 2;
		left: -3px;
		right: 0;
		top: 30px;
		opacity: 0;
		transform: translateY(20px);
		transition: .5s;
	}
	.reservation span img {
		width: 100%;
		filter: brightness(0) saturate(100%) invert(53%) sepia(91%) saturate(2878%) hue-rotate(346deg) brightness(104%) contrast(97%);
		transition: filter 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	}
	.reservation:hover span img {
		filter: brightness(0) invert(1);
	}
	.reservation:hover span {
		transform: translateY(0px);
		opacity: 1;
		transition: .3s;
	}

	/* fix-nav */
	.fix-nav{
		width: max-content;
		position: fixed;
		z-index: 99;
		top: 40%;
		-webkit-transform: translateY(-40%); /* Safari用 */
		transform: translateY(-40%);
		left: 3%;
	}
	.fix-nav li{
		margin: 0 0 70% 0;
	}
	.fix-nav li:last-child{
		margin: 0 0 0% 0;
	}
	.fix-nav li a{
		display: block;
		font-size: 12px;
		letter-spacing: 1px;
		font-weight: bold;
		position: relative;
	}
	.fix-nav li a .on01{
		width: 140%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on01{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on02{
		width: 90%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on02{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on03{
		width: 140%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on03{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on04{
		width: 105%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on04{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	/* sns-nav */
	.sns-nav{
		width: 100px;
		position: fixed;
		z-index: 99;
		bottom: 8%;
		left: 3%;
		display: flex;
		justify-content: space-between;
	}
	.sns-nav li{
		width: 20%;
	}
	.sns-nav li a{
		display: block;
	}

	.screen-fix{
		width: 100%;
		position: fixed;
		top: 50%;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.8s ease-in-out, visibility 0.8s ease-in-out;
	}
	.screen-fix.show {
		opacity: 1;
		visibility: visible;
	}
	.icon-list-screen{
		width: 90%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.icon-list-screen li{
		width: 16%;
		box-sizing: border-box;
		padding: 2% 3%;
	}
	.icon-list-screen li:nth-child(n+7):nth-child(-n+12){
		margin-top: 4%;
		margin-bottom: 4%;
	}

	/* main-fix */
	.main-fix{
		width: 15%;
		position: fixed;
		left: 0;
		right: 0;
		margin: 0 auto;
		top: 3%;
		line-height: 0;
		z-index: 99;
		transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	}
	.main-fix.hidden {
		opacity: 0;
		transform: translateY(-30px) scale(0.95);
		pointer-events: none;
	}
	.main-fix.visible {
		opacity: 1;
		transform: translateY(0) scale(1);
		pointer-events: auto;
	}

	.rever{
		flex-direction: row-reverse;
	}
	.all-wrap{
		width: 100%;
		position: relative;
		display: flex;
		justify-content: space-between;
		margin: 0 0 10% 0;
	}
	.fix-box{
		width: 50%;
		position: relative;
	}
	.cont{
		width: 50%;
		overflow: hidden;
		padding: 0 0 10% 0;
	}

	.col3{
		width: 70%;
		display: flex;
		justify-content: space-between;
		margin: 0 auto 10% auto;
	}
	.col3_end{
		margin: 0 auto 5% auto !important;
	}
	.col3 .img{
		width: 30%;
	}

	/* cont01 */
	.fix-box .fix-img01{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/01-01.jpg) no-repeat;
		background-size: cover;
	}
	.cont01 .txt{
		width: 75%;
		font-size: 16px;
		line-height: 3em;
		letter-spacing: 5px;
		box-sizing: border-box;
		margin: 0 auto 10% auto;
		padding: 15% 0 0 0;
	}
	.img01-01{
		width: 50%;
		margin: 0 auto 15% auto;
	}
	.img01-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img01-03{
		width: 45%;
		margin: 0 0 0 20%;
	}

	/* cont02 */
	.fix-box .fix-img02{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/02-02.jpg) no-repeat;
		background-size: cover;
	}
	.cont02 .title{
		width: 170px;
		background: #ff7c40;
		margin: 0 auto 10% auto;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.cont02 .title .txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
	}
	.cont02 .img01{
		width: 60%;
		position: relative;
		margin: 0 auto 15% auto;
	}
	.cont02 .img01 .point{
		width: max-content;
		position: absolute;
		bottom: 0;
		right: 7%;
	}
	.cont02 .img01 .point li{
		font-size: 12px;
        letter-spacing: 2px;
        line-height: 1.8em;
	}
	.cont02 .img02{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.img02-01{
		width: 50%;
		margin: 0 auto 15% auto;
		padding: 10% 0 0 0;
	}
	.img02-02{
		width: 70%;
		margin: 0 0 15% 0%;
	}
	.img02-03{
		width: 45%;
		margin: 0 0 0 40%;
	}

	/* cont03 */
	.fix-box .fix-img03{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/03-01.jpg) no-repeat;
		background-size: cover;
	}
	.img03-01{
		width: 50%;
		margin: 0 auto 15% auto;
	}
	.img03-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img03-03{
		width: 45%;
		margin: 0 0 0 20%;
	}

	/* price_data */
	.price_data{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.price_data .title{
		width: 170px;
		background: #ff7c40;
		margin: 0 0 5% 0;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.price_data .title .txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
	}
	.price_data .pr-txt00{
		width: 100%;
		font-size: 14px;
        letter-spacing: 2px;
		text-align: justify;
		line-height: 2.5em;
		margin: 0 0 7% 0;
	}
	.pr-list{
		width: 100%;
		margin: 0 auto 5% auto;
	}
	.pr-list li{
		width: 100%;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		flex-wrap: wrap;
		border-bottom: 1px solid #ff7c40;
		padding: 3% 0;
	}
	.pr-list li .pr-txt01{
		width: 30%;
		font-size: 16px;
        letter-spacing: 2px;
		margin: 0 5% 0 0;
	}
	.pr-list li .icon{
		width: 10%;
		margin: 0 5% 0 0;
	}
	.pr-list li .pr-txt02{
		width: 20%;
		text-align: left;
		font-size: 16px;
        letter-spacing: 2px;
	}
	.pr-list li .pr-txt03{
		width: 30%;
		text-align: left;
		font-size: 12px;
        letter-spacing: 2px;
	}
	.pr-list li .pr-txt04{
		width: 50%;
		text-align: left;
		font-size: 12px;
        letter-spacing: 2px;
		margin: 2% 0 0 50%;
	}

	.price_data .cou{
		width: 100%;
		margin: 0 auto 10% auto;
	}
	.price_data .cou li{
		width: 100%;
		text-align: justify;
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-indent: -.7em;
		padding-left: .7em;
	}
	.p-txt-box{
		width: 100%;
		margin: 0 0 7% 0;
	}
	.p-txt-box .line{
		width: 100%;
		height: 1px;
		background: #ff7c40;
		margin: 0 0 3% 0;
	}
	.p-txt-box .p-title{
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		margin: 0 0 1% 0;
	}
	.p-txt-box .p-txt{
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: justify;
	}
	.p-txt-box .tell{
		width: max-content;
		display: block;
		background: #ff7c40;
		color: #fff;
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		padding: 2px 10px 0 12px;
	}
	.p-txt-box .tell span{
		font-size: 10px;
		letter-spacing: 2px;
		margin: 0 10px 0 0;
		position: relative;
		top: -1px;
	}

	.tell-time{
		width: max-content;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		margin: 5% 0 7% 0;
	}
	.tell-time li:nth-child(1){
		margin: 0 40px 0 0;
	}
	.tell-time li:nth-child(2){
		margin: 0 10px 0 0;
		font-size: 12px;
		letter-spacing: 2px;
	}
	.tell-time li:nth-child(3){
		margin: 0 10px 0 0;
		height: 20px;
		width: .5px;
		background: #ff7c40;
	}
	.tell-time li:nth-child(4){
		font-size: 12px;
		letter-spacing: 2px;
	}

	/* cont04 */
	.fix-box .fix-img04{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/04-02.jpg) no-repeat;
		background-size: cover;
	}
	.cont04 .img01{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.img04-01{
		width: 70%;
		margin: 0 0 15% 0;
		padding: 15% 0 0 0;
	}
	.img04-02{
		width: 50%;
		margin: 0 auto 15% auto;
	}
	.img04-03{
		width: 45%;
		margin: 0 0 0 40%;
	}

	/* cont05 */
	.fix-box .fix-img05{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/05-01.jpg) no-repeat;
		background-size: cover;
		background-position: top center;
	}
	.img05-01{
		width: 50%;
		margin: 0 auto 15% auto;
		padding: 15% 0 0 0;
	}
	.img05-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img05-03{
		width: 60%;
		margin: 0 auto 0 auto;
	}

	/* cont06 */
	.fix-box .fix-img06{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/06-02.jpg) no-repeat;
		background-size: cover;
	}
	.cont06 .img01{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.img06-01{
		width: 70%;
		margin: 0 0 15% 0;
		padding: 15% 0 0 0;
	}
	.img06-02{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img06-03{
		width: 50%;
		margin: 0 0 0 35%;
	}

	/* staff */
	.staff{
		width: 100%;
		margin: 0 auto 10% auto;
	}
	.staff .staff_list{
		width: 100%;
	}
	.staff .staff_list li{
		width: 100%;
		font-family: "droid-serif", serif;
		font-weight: 400;
		font-style: italic;
		font-size: 12px;
		letter-spacing: 2px;
		text-align: center;
		line-height: 2em;
		margin: 0 0 2% 0;
	}

	/* f_nav */
	.f_nav{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.f_nav_list{
		width: 100%;
		margin: 0 auto;
	}
	.f_nav_list li{
		width: 100%;
		margin: 0 auto 7% auto;
	}
	.f_nav_list li:last-child{
		width: 100%;
		margin: 0 auto 0% auto;
	}
	.f_nav_list li a{
		width: 100%;
		display: block;
		text-decoration: none;
		color: #ff7c40;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.f_nav_list li a .img{
		width: 45%;
		overflow: hidden;
		border-radius: 15px;
		transition: .3s;
	}
	.f_nav_list li a .img img{
		transform: scale(1);
		transition: .3s;
	}
	.f_nav_list li a:hover .img{
		width: 45%;
		overflow: hidden;
		border-radius: 30px;
		transition: .3s;
	}
	.f_nav_list li a:hover .img img{
		transform: scale(1.1);
		transition: .3s;
	}
	.f_nav_list li a .data{
		width: 45%;
	}
	.f_nav_list li a .data .txt01{
		font-size: 16px;
		letter-spacing: 5px;
		line-height: 2em;
		margin: 0 0 2% 0;
	}
	.f_nav_list li a .data .txt02{
		font-size: 20px;
		letter-spacing: 5px;
		line-height: 2em;
		font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
		margin: 0 0 10% 0;
	}
	.f_nav_list li a .data .txt03{
		width: 80%;
		line-height: 0;
		display: block;
	}

	/* footer */
	footer{
		width: 100%;
		padding: 0 0 3% 0;
	}
	footer .f-logo{
		width: 10%;
		margin: 0 auto 2% auto;
	}
	footer .f-txt{
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 2em;
		text-align: center;
		margin: 0 auto 2% auto;
	}
	footer a{
		display: block;
        position: relative;
        font-size: 13px;
        letter-spacing: 2px;
        text-align: center;
		color: #ff7c40;
        text-decoration: none;
		text-align: center;
		margin: 0 auto 2% auto;
    }
	footer .copy {
        width: 10%;
		line-height: 0;
        margin: 0 auto;
    }

	/* leagal */
	.content-leagal{
		width: 60%;
		margin: 0 auto 10% auto;
		padding: 10% 0 0 0;
	}
	.leagal-title{
		width: 170px;
		background: #ff7c40;
		margin: 0 auto 2% auto;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.leagal-title .leagal-txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
		padding: 2px 0 0 0;
	}
	.leagal-sub-title{
		width: 100%;
		text-align: center;
		font-size: 13px;
		letter-spacing: 2px;
		line-height: 1.8em;
		margin: 0 auto 10% auto;
	}
	.leagal-box .leagal-list{
		width: 100%;
		margin: 0 0 5% 0;
	}
	.leagal-box .leagal-list li{
		width: 98.8%;
		font-size: 13px;
		line-height: 2em;
		letter-spacing: 2px;
		text-align: justify;
		text-indent: -1.2%;
		padding-left: 1.2%;
	}
	.leagal-box .leagal-list li .icon{
		width: 2px;
		height: 2px;
		border-radius: 1px;
		background: #ff7c40;
		display: inline-block;
		position: relative;
		top: -4px;
		margin: 0 10px 0 0;
	}
	.leagal-box .leagal-list li a{
		text-decoration: none;
		color: #ff7c40;
		border-bottom: 1px solid #ff7c40;
	}

	
}

/*note pc*/
@media screen and (min-width: 1025px) and (max-width: 1280px) {
    .sp-on{
		display: none !important;
	}
	.pad-on {
		display: none !important;
	}

	/* pagetop */
	.page-top{
		width: 12px;
		line-height: 0;
		position: fixed;
		right: 30px;
		bottom: 20px;
	}
	.page-top:hover {
		transform: scale(1) translateY(-4px);
		animation: elastic-pull 0.6s ease-out;
	}
	@keyframes elastic-pull {
		0% {
			transform: scale(1) translateY(0);
		}
		50% {
			transform: scale(1.15) translateY(-6px);
		}
		100% {
			transform: scale(1.05) translateY(-4px);
		}
	}

	/* load */
	.load{
		width: 100%;
		height: 100vh;
		position: fixed;
		z-index: 9999;
		background: #fff;
	}
	.icon-list{
		width: 80%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.icon-list li{
		width: 16%;
		box-sizing: border-box;
		padding: 2% 2%;
	}
	.icon-list li:nth-child(n+7):nth-child(-n+12){
		margin-top: 3%;
		margin-bottom: 3%;
	}
	.load .logo{
		width: 17%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 99999;
	}

	/* header */
	header{
		width: 100%;
		height: 100vh;
		position: relative;
		margin: 0 0 5% 0;
	}
	.header_logo{
		width: 10%;
		display: flex;
		justify-content: space-between;
		position: absolute;
		bottom: 9%;
		right: 2%;
	}
	.header_logo li{
		width: 40%;
	}
	.header_logo li a{
		width: 100%;
		display: block;
		position: relative;
		line-height: 0;
	}
	.header_logo li a .on{
		width: 100%;
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		line-height: 0;
		clip-path: inset(0 100% 0% 0%);
		transition: .3s;
	}
	.header_logo li a:hover .on{
		clip-path: inset(0 0% 0% 0%);
		transition: .3s;
	}

	.mv-logo{
		width: 25%;
		position: absolute;
		left: 0;
		right: 0;
		bottom: 7%;
		margin: 0 auto;
		z-index: 999;
	}

	.wrapper{
		width: 65%;
		position: relative;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		margin: 0 auto;
	}
	.swiper{
		text-align: center;
		width: 100%;
	}
	.bar{
		position: relative;
		width: 100%;
		height: 3px;
		background: #fff;
		overflow: hidden;
		z-index: 999;
	}
	.bar span{
		display: inline-block;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		z-index: 2;
		background: #ff7c40;
		border-radius: 10px;
		transform: scaleX(0);
		transform-origin: left center;
		transition-timing-function: linear;
	}
	.swiper-slide {
		overflow: hidden;
	}
	.swiper-slide img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		transition: transform 10000ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
	}
	.swiper-slide-active img {
		transform: scale(1.07);
	}

	/* reservation */
	.reservation {
		width: 120px;
		height: 120px;
		display: block;
		background: #fff;
		position: fixed;
		top: 3%;
		right: 1.5%;
		font-weight: bold;
		text-decoration: none;
		overflow: hidden;
		cursor: pointer;
		transition: color 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
		z-index: 999;
		border-radius: 1000px;
	}
	.reservation .txt{
		width: 100%;
		font-size: 12px;
		letter-spacing: 5px;
		line-height: 1em;
		text-align: center;
		font-weight: bold;
		text-decoration: none;
		color: #ff7c40;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 3px;
		z-index: 9999;
	}
	.reservation:hover .txt{
		color: #fff;
	}
	.reservation::before {
		content: '';
		position: absolute;
		width: 0;
		height: 0;
		background: radial-gradient(circle, 
			rgba(255,124,64,0.9) 0%, 
			rgba(255,124,64,0.7) 50%, 
			rgba(255,124,64,0.5) 80%, 
			rgba(255,124,64,0) 100%);
		border-radius: 50%;
		transition: all 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
		z-index: 1;
		transform: translate(-50%, -50%);
		opacity: 0;
		left: var(--mouse-x, 50%);
		top: var(--mouse-y, 50%);
	}
	.reservation:hover::before {
		width: 500px;
		height: 500px;
		opacity: 1;
	}
	.reservation:hover {
		color: white;
	}
	.reservation span {
		width: 10px;
		display: block;
		line-height: 0;
		margin: 0% auto 0 auto;
		position: absolute;
		z-index: 2;
		left: -3px;
		right: 0;
		top: 30px;
		opacity: 0;
		transform: translateY(20px);
		transition: .5s;
	}
	.reservation span img {
		width: 100%;
		filter: brightness(0) saturate(100%) invert(53%) sepia(91%) saturate(2878%) hue-rotate(346deg) brightness(104%) contrast(97%);
		transition: filter 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	}
	.reservation:hover span img {
		filter: brightness(0) invert(1);
	}
	.reservation:hover span {
		transform: translateY(0px);
		opacity: 1;
		transition: .3s;
	}

	/* fix-nav */
	.fix-nav{
		width: max-content;
		position: fixed;
		z-index: 99;
		top: 40%;
		-webkit-transform: translateY(-40%); /* Safari用 */
		transform: translateY(-40%);
		left: 3%;
	}
	.fix-nav li{
		margin: 0 0 30% 0;
	}
	.fix-nav li:last-child{
		margin: 0 0 0% 0;
	}
	.fix-nav li a{
		display: block;
		font-size: 11px;
		letter-spacing: 1px;
		font-weight: bold;
		position: relative;
	}
	.fix-nav li a .on01{
		width: 140%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on01{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on02{
		width: 90%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on02{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on03{
		width: 140%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on03{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on04{
		width: 105%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on04{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	/* sns-nav */
	.sns-nav{
		width: 100px;
		position: fixed;
		z-index: 99;
		bottom: 9%;
		left: 3%;
		display: flex;
		justify-content: space-between;
	}
	.sns-nav li{
		width: 20%;
	}
	.sns-nav li a{
		display: block;
		line-height: 0;
	}

	/* screen-fix */
	.screen-fix{
		width: 100%;
		position: fixed;
		top: 50%;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.8s ease-in-out, visibility 0.8s ease-in-out;
	}
	.screen-fix.show {
		opacity: 1;
		visibility: visible;
	}
	.icon-list-screen{
		width: 90%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.icon-list-screen li{
		width: 16%;
		box-sizing: border-box;
		padding: 2% 2%;
	}
	.icon-list-screen li:nth-child(n+7):nth-child(-n+12){
		margin-top: 2%;
		margin-bottom: 2%;
	}

	/* main-fix */
	.main-fix{
		width: 15%;
		position: fixed;
		left: 0;
		right: 0;
		margin: 0 auto;
		top: 3%;
		line-height: 0;
		z-index: 99;
		transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	}
	.main-fix.hidden {
		opacity: 0;
		transform: translateY(-30px) scale(0.95);
		pointer-events: none;
	}
	.main-fix.visible {
		opacity: 1;
		transform: translateY(0) scale(1);
		pointer-events: auto;
	}

	.rever{
		flex-direction: row-reverse;
	}
	.all-wrap{
		width: 100%;
		position: relative;
		display: flex;
		justify-content: space-between;
		margin: 0 0 10% 0;
	}
	.fix-box{
		width: 50%;
		position: relative;
	}
	.cont{
		width: 50%;
		overflow: hidden;
	}

	.col3{
		width: 90%;
		display: flex;
		justify-content: space-between;
		margin: 0 auto 10% auto;
	}
	.col3_end{
		margin: 0 auto 5% auto !important;
	}
	.col3 .img{
		width: 30%;
	}

	/* cont01 */
	.fix-box .fix-img01{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/01-01.jpg) no-repeat;
		background-size: cover;
	}
	.cont01 .txt{
		width: max-content;
		font-size: 13px;
		line-height: 3em;
		letter-spacing: 3px;
		box-sizing: border-box;
		margin: 0 auto 10% auto;
		padding: 15% 0 0 0;
	}
	.img01-01{
		width: 60%;
		margin: 0 auto 15% auto;
	}
	.img01-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img01-03{
		width: 60%;
		margin: 0 0 0 10%;
	}

	/* cont02 */
	.fix-box .fix-img02{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/02-02.jpg) no-repeat;
		background-size: cover;
	}
	.cont02 .title{
		width: 170px;
		background: #ff7c40;
		margin: 0 auto 5% auto;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.cont02 .title .txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
	}
	.cont02 .img01{
		width: 60%;
		position: relative;
		margin: 0 auto 10% auto;
	}
	.cont02 .img01 .point{
		width: max-content;
		position: absolute;
		bottom: 0;
		right: 7%;
	}
	.cont02 .img01 .point li{
		font-size: 12px;
        letter-spacing: 2px;
        line-height: 1.8em;
	}
	.cont02 .img02{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.img02-01{
		width: 60%;
		margin: 0 auto 15% auto;
		padding: 10% 0 0 0;
	}
	.img02-02{
		width: 70%;
		margin: 0 0 15% 0%;
	}
	.img02-03{
		width: 60%;
		margin: 0 0 0 30%;
	}

	/* cont03 */
	.fix-box .fix-img03{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/03-01.jpg) no-repeat;
		background-size: cover;
	}
	.img03-01{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img03-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img03-03{
		width: 60%;
		margin: 0 0 0 10%;
	}

	/* price_data */
	.price_data{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.price_data .title{
		width: 170px;
		background: #ff7c40;
		margin: 0 0 5% 0;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.price_data .title .txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
	}
	.price_data .pr-txt00{
		width: 100%;
		font-size: 13px;
        letter-spacing: 2px;
		text-align: justify;
		line-height: 2.5em;
		margin: 0 0 7% 0;
	}
	.pr-list{
		width: 100%;
		margin: 0 auto 5% auto;
	}
	.pr-list li{
		width: 100%;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		flex-wrap: wrap;
		border-bottom: 1px solid #ff7c40;
		padding: 3% 0;
	}
	.pr-list li .pr-txt01{
		width: 25%;
		font-size: 16px;
        letter-spacing: 2px;
		margin: 0 5% 0 0;
	}
	.pr-list li .icon{
		width: 10%;
		margin: 0 5% 0 0;
	}
	.pr-list li .pr-txt02{
		width: 20%;
		text-align: left;
		font-size: 16px;
        letter-spacing: 2px;
	}
	.pr-list li .pr-txt03{
		width: 35%;
		text-align: left;
		font-size: 11px;
        letter-spacing: 2px;
	}
	.pr-list li .pr-txt04{
		width: 50%;
		text-align: left;
		font-size: 11px;
        letter-spacing: 2px;
		margin: 2% 0 0 45%;
	}

	.price_data .cou{
		width: 100%;
		margin: 0 auto 10% auto;
	}
	.price_data .cou li{
		width: 100%;
		text-align: justify;
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-indent: -.7em;
		padding-left: .7em;
	}
	.p-txt-box{
		width: 100%;
		margin: 0 0 7% 0;
	}
	.p-txt-box .line{
		width: 100%;
		height: 1px;
		background: #ff7c40;
		margin: 0 0 3% 0;
	}
	.p-txt-box .p-title{
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		margin: 0 0 1% 0;
	}
	.p-txt-box .p-txt{
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: justify;
	}
	.p-txt-box .tell{
		width: max-content;
		display: block;
		background: #ff7c40;
		color: #fff;
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		padding: 0 10px 0 12px;
	}
	.p-txt-box .tell span{
		font-size: 10px;
		letter-spacing: 2px;
		margin: 0 10px 0 0;
		position: relative;
		top: -1px;
	}

	.tell-time{
		width: max-content;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		flex-wrap: wrap;
		margin: 5% 0 7% 0;
	}
	.tell-time li:nth-child(1){
		width: 100%;
		margin: 0 40px 2% 0;
	}
	.tell-time li:nth-child(2){
		margin: 0 10px 0 0;
		font-size: 12px;
		letter-spacing: 2px;
	}
	.tell-time li:nth-child(3){
		margin: 0 10px 0 0;
		height: 20px;
		width: .5px;
		background: #ff7c40;
	}
	.tell-time li:nth-child(4){
		font-size: 12px;
		letter-spacing: 2px;
	}

	/* cont04 */
	.fix-box .fix-img04{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/04-02.jpg) no-repeat;
		background-size: cover;
	}
	.cont04 .img01{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.img04-01{
		width: 70%;
		margin: 0 0 15% 0;
		padding: 15% 0 0 0;
	}
	.img04-02{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img04-03{
		width: 50%;
		margin: 0 0 0 35%;
	}

	/* cont05 */
	.fix-box .fix-img05{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/05-01.jpg) no-repeat;
		background-size: cover;
		background-position: top center;
	}
	.img05-01{
		width: 70%;
		margin: 0 auto 15% auto;
		padding: 15% 0 0 0;
	}
	.img05-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img05-03{
		width: 70%;
		margin: 0 auto 0 auto;
	}

	/* cont06 */
	.fix-box .fix-img06{
		width: 100%;
		height: 100vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/06-02.jpg) no-repeat;
		background-size: cover;
	}
	.cont06 .img01{
		width: 60%;
		margin: 0 auto 10% auto;
	}
	.img06-01{
		width: 70%;
		margin: 0 0 15% 0;
		padding: 15% 0 0 0;
	}
	.img06-02{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img06-03{
		width: 50%;
		margin: 0 0 0 35%;
	}

	/* staff */
	.staff{
		width: 100%;
		margin: 0 auto 5% auto;
	}
	.staff .staff_list{
		width: 100%;
	}
	.staff .staff_list li{
		width: 100%;
		font-family: "droid-serif", serif;
		font-weight: 400;
		font-style: italic;
		font-size: 12px;
		letter-spacing: 2px;
		text-align: center;
		line-height: 2em;
		margin: 0 0 2% 0;
	}

	/* f_nav */
	.f_nav{
		width: 60%;
		margin: 0 auto 5% auto;
	}
	.f_nav_list{
		width: 100%;
		margin: 0 auto;
	}
	.f_nav_list li{
		width: 100%;
		margin: 0 auto 7% auto;
	}
	.f_nav_list li:last-child{
		width: 100%;
		margin: 0 auto 0% auto;
	}
	.f_nav_list li a{
		width: 100%;
		display: block;
		text-decoration: none;
		color: #ff7c40;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.f_nav_list li a .img{
		width: 45%;
		overflow: hidden;
		border-radius: 15px;
		transition: .3s;
	}
	.f_nav_list li a .img img{
		transform: scale(1);
		transition: .3s;
	}
	.f_nav_list li a:hover .img{
		width: 45%;
		overflow: hidden;
		border-radius: 30px;
		transition: .3s;
	}
	.f_nav_list li a:hover .img img{
		transform: scale(1.1);
		transition: .3s;
	}
	.f_nav_list li a .data{
		width: 45%;
	}
	.f_nav_list li a .data .txt01{
		font-size: 14px;
		letter-spacing: 5px;
		line-height: 2em;
		margin: 0 0 2% 0;
	}
	.f_nav_list li a .data .txt02{
		font-size: 18px;
		letter-spacing: 5px;
		line-height: 2em;
		font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
		margin: 0 0 7% 0;
	}
	.f_nav_list li a .data .txt03{
		width: 70%;
		line-height: 0;
		display: block;
	}

	/* footer */
	footer{
		width: 100%;
		padding: 0 0 3% 0;
	}
	footer .f-logo{
		width: 10%;
		margin: 0 auto 2% auto;
	}
	footer .f-txt{
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 2em;
		text-align: center;
		margin: 0 auto 2% auto;
	}
	footer a{
		display: block;
        position: relative;
        font-size: 13px;
        letter-spacing: 2px;
        text-align: center;
		color: #ff7c40;
        text-decoration: none;
		text-align: center;
		margin: 0 auto 2% auto;
    }
	footer .copy {
        width: 10%;
		line-height: 0;
        margin: 0 auto;
    }

	/* leagal */
	.content-leagal{
		width: 60%;
		margin: 0 auto 10% auto;
		padding: 10% 0 0 0;
	}
	.leagal-title{
		width: 170px;
		background: #ff7c40;
		margin: 0 auto 2% auto;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.leagal-title .leagal-txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
		padding: 2px 0 0 0;
	}
	.leagal-sub-title{
		width: 100%;
		text-align: center;
		font-size: 13px;
		letter-spacing: 2px;
		line-height: 1.8em;
		margin: 0 auto 10% auto;
	}
	.leagal-box .leagal-list{
		width: 100%;
		margin: 0 0 5% 0;
	}
	.leagal-box .leagal-list li{
		width: 98.8%;
		font-size: 13px;
		line-height: 2em;
		letter-spacing: 2px;
		text-align: justify;
		text-indent: -1.2%;
		padding-left: 1.2%;
	}
	.leagal-box .leagal-list li .icon{
		width: 2px;
		height: 2px;
		border-radius: 1px;
		background: #ff7c40;
		display: inline-block;
		position: relative;
		top: -4px;
		margin: 0 10px 0 0;
	}
	.leagal-box .leagal-list li a{
		text-decoration: none;
		color: #ff7c40;
		border-bottom: 1px solid #ff7c40;
	}

}

/*pad*/
@media screen and (min-width: 767px) and (max-width: 1024px) {
	.sp-on{
		display: none !important;
	}
	.pad-off {
        display: none !important;
    }
    .pad-on {
        display: block;
    }

	/* pagetop */
	.page-top{
		width: 12px;
		line-height: 0;
		position: fixed;
		right: 30px;
		bottom: 20px;
	}
	.page-top:hover {
		transform: scale(1) translateY(-4px);
		animation: elastic-pull 0.6s ease-out;
	}
	@keyframes elastic-pull {
		0% {
			transform: scale(1) translateY(0);
		}
		50% {
			transform: scale(1.15) translateY(-6px);
		}
		100% {
			transform: scale(1.05) translateY(-4px);
		}
	}

	/* load */
	.load{
		width: 100%;
		height: 100vh;
		position: fixed;
		z-index: 9999;
		background: #fff;
	}
	.icon-list{
		width: 85%;
		position: absolute;
		top: 35%;
		-webkit-transform: translateY(-35%); /* Safari用 */
		transform: translateY(-35%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.icon-list li{
		width: 33%;
        box-sizing: border-box;
        padding: 0 9%;
		margin-top: 4%;
		margin-bottom: 4%;
	}

	.logo{
		width: 30%;
		position: absolute;
		top: 45%;
		-webkit-transform: translateY(-45%); /* Safari用 */
		transform: translateY(-45%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 99999;
	}

	/* header */
	header{
		width: 100%;
		height: 100vh;
		position: relative;
		margin: 0 0 0% 0;
	}
	.header_logo{
		width: 20%;
        position: absolute;
        bottom: 2%;
        right: 2%;
		z-index: 999;
		display: flex;
		justify-content: space-between;
	}
	.header_logo li{
		width: 42%;
	}
	.header_logo li a{
		width: 100%;
		display: block;
		position: relative;
		line-height: 0;
	}
	.header_logo li a .on{
		width: 100%;
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		line-height: 0;
		clip-path: inset(0 100% 0% 0%);
		transition: .3s;
	}
	.header_logo li a:hover .on{
		clip-path: inset(0 0% 0% 0%);
		transition: .3s;
	}

	.mv-logo{
		width: 30%;
        position: absolute;
        left: 0;
        right: 0;
        bottom: 15%;
        margin: 0 auto;
        z-index: 999;
	}

	.wrapper{
		width: 100%;
		height: 75vh;
		overflow: hidden;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
	}
	.swiper{
		text-align: center;
		width: 100%;
	}
	.bar{
		position: relative;
		width: 100%;
		height: 3px;
		background: #fff;
		overflow: hidden;
		z-index: 999;
	}
	.bar span{
		display: inline-block;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		z-index: 2;
		background: #ff7c40;
		border-radius: 10px;
		transform: scaleX(0);
		transform-origin: left center;
		transition-timing-function: linear;
	}
	.swiper-slide {
		overflow: hidden;
	}
	.swiper-slide img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		transition: transform 10000ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
	}
	.swiper-slide-active img {
		transform: scale(1.07);
	}

	/* reservation */
	.reservation {
		width: 110px;
		height: 110px;
		display: block;
		background: #fff;
		position: fixed;
		top: 2%;
		right: 1.5%;
		font-weight: bold;
		text-decoration: none;
		overflow: hidden;
		cursor: pointer;
		transition: color 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
		z-index: 999;
		border-radius: 1000px;
	}
	.reservation .txt{
		width: 100%;
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 1em;
		text-align: center;
		font-weight: bold;
		text-decoration: none;
		color: #ff7c40;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 3px;
		z-index: 9999;
	}
	.reservation:hover .txt{
		color: #fff;
	}
	.reservation::before {
		content: '';
		position: absolute;
		width: 0;
		height: 0;
		background: radial-gradient(circle, 
			rgba(255,124,64,0.9) 0%, 
			rgba(255,124,64,0.7) 50%, 
			rgba(255,124,64,0.5) 80%, 
			rgba(255,124,64,0) 100%);
		border-radius: 50%;
		transition: all 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
		z-index: 1;
		transform: translate(-50%, -50%);
		opacity: 0;
		left: var(--mouse-x, 50%);
		top: var(--mouse-y, 50%);
	}
	.reservation:hover::before {
		width: 500px;
		height: 500px;
		opacity: 1;
	}
	.reservation:hover {
		color: white;
	}
	.reservation span {
		width: 10px;
		display: block;
		line-height: 0;
		margin: 0% auto 0 auto;
		position: absolute;
		z-index: 2;
		left: -3px;
		right: 0;
		top: 30px;
		opacity: 0;
		transform: translateY(20px);
		transition: .5s;
	}
	.reservation span img {
		width: 100%;
		filter: brightness(0) saturate(100%) invert(53%) sepia(91%) saturate(2878%) hue-rotate(346deg) brightness(104%) contrast(97%);
		transition: filter 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	}
	.reservation:hover span img {
		filter: brightness(0) invert(1);
	}
	.reservation:hover span {
		transform: translateY(0px);
		opacity: 1;
		transition: .3s;
	}


	/* fix-nav */
	.fix-nav{
		width: max-content;
		position: fixed;
		z-index: 99;
		top: 17%;
		-webkit-transform: translateY(-17%); /* Safari用 */
		transform: translateY(-17%);
		left: 3%;
	}
	.fix-nav li{
		margin: 0 0 30% 0;
	}
	.fix-nav li:last-child{
		margin: 0 0 0% 0;
	}
	.fix-nav li a{
		display: block;
		font-size: 11px;
		letter-spacing: 1px;
		font-weight: bold;
		position: relative;
	}
	.fix-nav li a .on01{
		width: 140%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on01{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on02{
		width: 90%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on02{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on03{
		width: 140%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on03{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	.fix-nav li a .on04{
		width: 105%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}
	.fix-nav li a:hover .on04{
		-webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
		clip-path: polygon(0 0, 200% 0, 0 200%);
		transition: .7s;
	}

	/* sns-nav */
	.sns-nav{
		width: 100px;
		position: fixed;
		z-index: 99;
		top: 35%;
		left: 3%;
		display: flex;
		justify-content: space-between;
	}
	.sns-nav li{
		width: 20%;
	}
	.sns-nav li a{
		display: block;
		line-height: 0;
	}

	/* screen-fix */
	.screen-fix{
		width: 100%;
		position: fixed;
		top: 50%;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.8s ease-in-out, visibility 0.8s ease-in-out;
	}
	.screen-fix.show {
		opacity: 1;
		visibility: visible;
	}
	.icon-list-screen{
		width: 85%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.icon-list-screen li{
		width: 33%;
        box-sizing: border-box;
        padding: 0% 9%;
		margin-top: 4%;
		margin-bottom: 4%;
	}

	/* main-fix */
	.main-fix{
		width: 30%;
		position: fixed;
		left: 0;
		right: 0;
		margin: 0 auto;
		top: 3%;
		line-height: 0;
		z-index: 99;
		transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	}
	.main-fix.hidden {
		opacity: 0;
		transform: translateY(-30px) scale(0.95);
		pointer-events: none;
	}
	.main-fix.visible {
		opacity: 1;
		transform: translateY(0) scale(1);
		pointer-events: auto;
	}

	.rever{
		flex-direction: row-reverse;
	}
	.all-wrap{
		width: 100%;
		position: relative;
		margin: 0 0 10% 0;
	}
	.fix-box{
		width: 100%;
		position: relative;
		margin: 0 0 5% 0;
	}
	.cont{
		width: 75%;
		overflow: hidden;
		margin: 0 auto;
	}

	.col3{
		width: 100%;
		display: flex;
		justify-content: space-between;
		margin: 0 auto 20% auto;
	}
	.col3_end{
		margin: 0 auto 15% auto !important;
	}
	.col3 .img{
		width: 32%;
	}

	/* cont01 */
	.fix-box .fix-img01{
		width: 100%;
		height: 40vh;
		top: 0;
		left: 0;
		background: url(../img/01-01.jpg) no-repeat;
		background-size: cover;
		background-position: center center;
	}
	.cont01 .txt{
		width: max-content;
		font-size: 14px;
		line-height: 3em;
		letter-spacing: 3px;
		box-sizing: border-box;
		margin: 0 auto 10% auto;
		padding: 5% 0 0 0;
	}
	.img01-01{
		width: 60%;
		margin: 0 auto 15% auto;
	}
	.img01-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img01-03{
		width: 60%;
		margin: 0 0 0 10%;
	}

	/* cont02 */
	.fix-box .fix-img02{
		width: 100%;
		height: 40vh;
		top: 0;
		left: 0;
		background: url(../img/02-02.jpg) no-repeat;
		background-size: cover;
		background-position: center center;
	}
	.cont02 .title{
		width: 170px;
		background: #ff7c40;
		margin: 0 auto 5% auto;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.cont02 .title .txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
	}
	.cont02 .img01{
		width: 75%;
		position: relative;
		margin: 0 auto 10% auto;
	}
	.cont02 .img01 .point{
		width: max-content;
		position: absolute;
		bottom: 0;
		right: 7%;
	}
	.cont02 .img01 .point li{
		font-size: 12px;
        letter-spacing: 2px;
        line-height: 1.8em;
	}
	.cont02 .img02{
		width: 70%;
		margin: 0 auto 10% auto;
	}
	.img02-01{
		width: 60%;
		margin: 0 auto 15% auto;
		padding: 10% 0 0 0;
	}
	.img02-02{
		width: 70%;
		margin: 0 0 15% 5%;
	}
	.img02-03{
		width: 60%;
		margin: 0 0 0 30%;
	}

	/* cont03 */
	.fix-box .fix-img03{
		width: 100%;
		height: 40vh;
		top: 0;
		left: 0;
		background: url(../img/03-01.jpg) no-repeat;
		background-size: cover;
		background-position: center center;
	}
	.img03-01{
		width: 70%;
		margin: 10% auto 15% auto;
	}
	.img03-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img03-03{
		width: 60%;
		margin: 0 0 0 10%;
	}

	/* price_data */
	.price_data{
		width: 80%;
		margin: 0 auto 15% auto;
	}
	.price_data .title{
		width: 170px;
		background: #ff7c40;
		margin: 0 0 5% 0;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.price_data .title .txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
	}
	.price_data .pr-txt00{
		width: 100%;
		font-size: 15px;
        letter-spacing: 2px;
		text-align: justify;
		line-height: 2.5em;
		margin: 0 0 7% 0;
	}
	.pr-list{
		width: 100%;
		margin: 0 auto 5% auto;
	}
	.pr-list li{
		width: 100%;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		flex-wrap: wrap;
		border-bottom: 1px solid #ff7c40;
		padding: 3% 0;
	}
	.pr-list li .pr-txt01{
		width: 25%;
		font-size: 16px;
        letter-spacing: 2px;
		margin: 0 5% 0 0;
	}
	.pr-list li .icon{
		width: 10%;
		margin: 0 5% 0 0;
	}
	.pr-list li .pr-txt02{
		width: 20%;
		text-align: left;
		font-size: 16px;
        letter-spacing: 2px;
	}
	.pr-list li .pr-txt03{
		width: 35%;
		text-align: left;
		font-size: 11px;
        letter-spacing: 2px;
	}
	.pr-list li .pr-txt04{
		width: 50%;
		text-align: left;
		font-size: 11px;
        letter-spacing: 2px;
		margin: 2% 0 0 45%;
	}

	.price_data .cou{
		width: 100%;
		margin: 0 auto 10% auto;
	}
	.price_data .cou li{
		width: 100%;
		text-align: justify;
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-indent: -.7em;
		padding-left: .7em;
	}
	.p-txt-box{
		width: 100%;
		margin: 0 0 7% 0;
	}
	.p-txt-box .line{
		width: 100%;
		height: 1px;
		background: #ff7c40;
		margin: 0 0 3% 0;
	}
	.p-txt-box .p-title{
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		margin: 0 0 1% 0;
	}
	.p-txt-box .p-txt{
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: justify;
	}
	.p-txt-box .tell{
		width: max-content;
		display: block;
		background: #ff7c40;
		color: #fff;
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		padding: 0 10px 0 12px;
	}
	.p-txt-box .tell span{
		font-size: 10px;
		letter-spacing: 2px;
		margin: 0 10px 0 0;
		position: relative;
		top: -1px;
	}

	.tell-time{
		width: max-content;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		margin: 5% 0 7% 0;
	}
	.tell-time li:nth-child(1){
		margin: 0 40px 0 0;
	}
	.tell-time li:nth-child(2){
		margin: 0 10px 0 0;
		font-size: 12px;
		letter-spacing: 2px;
	}
	.tell-time li:nth-child(3){
		margin: 0 10px 0 0;
		height: 20px;
		width: .5px;
		background: #ff7c40;
	}
	.tell-time li:nth-child(4){
		font-size: 12px;
		letter-spacing: 2px;
	}

	/* cont04 */
	.fix-box .fix-img04{
		width: 100%;
		height: 40vh;
		top: 0;
		left: 0;
		background: url(../img/04-02.jpg) no-repeat;
		background-size: cover;
		background-position: center center;
	}
	.cont04 .img01{
		width: 65%;
		margin: 0 auto 10% auto;
	}
	.img04-01{
		width: 70%;
		margin: 0 0 15% 5%;
		padding: 15% 0 0 0;
	}
	.img04-02{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img04-03{
		width: 50%;
		margin: 0 0 0 50%;
	}

	/* cont05 */
	.fix-box .fix-img05{
		width: 100%;
		height: 40vh;
		top: 0;
		left: 0;
		background: url(../img/05-01.jpg) no-repeat;
		background-size: cover;
		background-position: center center;
	}
	.img05-01{
		width: 70%;
		margin: 0 auto 15% auto;
		padding: 15% 0 0 0;
	}
	.img05-02{
		width: 70%;
		margin: 0 0 15% 30%;
	}
	.img05-03{
		width: 70%;
		margin: 0 auto 0 auto;
	}

	/* cont06 */
	.fix-box .fix-img06{
		width: 100%;
		height: 40vh;
		position: sticky;
		top: 0;
		left: 0;
		background: url(../img/06-02.jpg) no-repeat;
		background-size: cover;
		background-position: center center;
	}
	.cont06 .img01{
		width: 65%;
		margin: 0 auto 10% auto;
	}
	.img06-01{
		width: 70%;
		margin: 0 0 15% 0;
		padding: 15% 0 0 0;
	}
	.img06-02{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img06-03{
		width: 50%;
		margin: 0 0 0 35%;
	}

	/* staff */
	.staff{
		width: 100%;
		margin: 0 auto 15% auto;
	}
	.staff .staff_list{
		width: 100%;
	}
	.staff .staff_list li{
		width: 100%;
		font-family: "droid-serif", serif;
		font-weight: 400;
		font-style: italic;
		font-size: 10px;
		letter-spacing: 2px;
		text-align: center;
		line-height: 2em;
		margin: 0 0 2% 0;
	}

	/* f_nav */
	.f_nav{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.f_nav_list{
		width: 100%;
		margin: 0 auto;
	}
	.f_nav_list li{
		width: 100%;
		margin: 0 auto 7% auto;
	}
	.f_nav_list li:last-child{
		width: 100%;
		margin: 0 auto 0% auto;
	}
	.f_nav_list li a{
		width: 100%;
		display: block;
		text-decoration: none;
		color: #ff7c40;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.f_nav_list li a .img{
		width: 50%;
		overflow: hidden;
		border-radius: 15px;
		transition: .3s;
	}
	.f_nav_list li a .img img{
		transform: scale(1);
		transition: .3s;
	}
	.f_nav_list li a:hover .img{
		overflow: hidden;
		border-radius: 30px;
		transition: .3s;
	}
	.f_nav_list li a:hover .img img{
		transform: scale(1.1);
		transition: .3s;
	}
	.f_nav_list li a .data{
		width: 45%;
	}
	.f_nav_list li a .data .txt01{
		font-size: 12px;
		letter-spacing: 5px;
		line-height: 2em;
		margin: 0 0 2% 0;
	}
	.f_nav_list li a .data .txt02{
		font-size: 16px;
		letter-spacing: 5px;
		line-height: 2em;
		font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
		margin: 0 0 7% 0;
	}
	.f_nav_list li a .data .txt03{
		width: 70%;
		line-height: 0;
		display: block;
	}

	/* footer */
	footer{
		width: 100%;
		position: relative;
		padding: 0 0 5% 0;
	}
	footer .f-logo{
		width: 15%;
		line-height: 0;
		margin: 0 auto 2% auto;
	}
	footer .f-txt{
		font-size: 12px;
		letter-spacing: 2px;
		line-height: 2em;
		text-align: center;
		margin: 0 auto 2% auto;
	}
	footer a{
		display: block;
        position: relative;
        font-size: 13px;
        letter-spacing: 2px;
        text-align: center;
		color: #ff7c40;
        text-decoration: none;
		text-align: center;
		margin: 0 auto 2% auto;
    }
	footer .copy {
        width: 20%;
		line-height: 0;
        margin: 0 auto;
    }

	/* leagal */
	.content-leagal{
		width: 60%;
		margin: 0 auto 10% auto;
		padding: 20% 0 0 0;
	}
	.leagal-title{
		width: 170px;
		background: #ff7c40;
		margin: 0 auto 2% auto;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.leagal-title .leagal-txt{
		color: #fff;
		font-size: 16px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
		padding: 2px 0 0 0;
	}
	.leagal-sub-title{
		width: 100%;
		text-align: center;
		font-size: 13px;
		letter-spacing: 2px;
		line-height: 1.8em;
		margin: 0 auto 10% auto;
	}
	.leagal-box .leagal-list{
		width: 100%;
		margin: 0 0 5% 0;
	}
	.leagal-box .leagal-list li{
		width: 98.8%;
		font-size: 13px;
		line-height: 2em;
		letter-spacing: 2px;
		text-align: justify;
		text-indent: -1.2%;
		padding-left: 1.2%;
	}
	.leagal-box .leagal-list li .icon{
		width: 2px;
		height: 2px;
		border-radius: 1px;
		background: #ff7c40;
		display: inline-block;
		position: relative;
		top: -4px;
		margin: 0 10px 0 0;
	}
	.leagal-box .leagal-list li a{
		text-decoration: none;
		color: #ff7c40;
		border-bottom: 1px solid #ff7c40;
	}

}

/*//////////////////////////////// for iphone ////////////////////////////*/
@media (min-width:0px) and ( max-width:766px) {
	.pc-on{
		display: none !important;
	}
	.pad-off,
	.pad-on {
		display: none !important;
	}

	/* pagetop */
	.page-top{
		width: 10px;
		line-height: 0;
		position: fixed;
		right: 15px;
		bottom: 10px;
	}
	.page-top:hover {
		transform: scale(1) translateY(-4px);
		animation: elastic-pull 0.6s ease-out;
	}
	@keyframes elastic-pull {
		0% {
			transform: scale(1) translateY(0);
		}
		50% {
			transform: scale(1.15) translateY(-6px);
		}
		100% {
			transform: scale(1.05) translateY(-4px);
		}
	}

	/* load */
	.load{
		width: 100%;
		height: 90vh;
		position: fixed;
		z-index: 99999;
		background: #fff;
	}
	.icon-list{
		width: 85%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.icon-list li{
		width: 30%;
		box-sizing: border-box;
		padding: 2% 2%;
		margin: 0 0 5% 0;
	}
	.icon-list li:nth-child(n+13):nth-child(-n+15) {
		margin: 0 0 0 0;
	}
	.load .logo{
		width: 50%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 99999;
	}

	/* header */
	header{
		width: 100%;
		position: relative;
		top: 0;
		left: 0;
	}
	.header_logo{
		width: 35%;
		display: flex;
		justify-content: space-between;
		position: absolute;
		bottom: 20%;
		right: 0%;
		left: 0;
		margin: 0 auto;
	}
	.header_logo li{
		width: 35%;
	}
	.header_logo li a{
		width: 100%;
		display: block;
		position: relative;
		line-height: 0;
	}
	.header_logo li a .on{
		width: 100%;
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		line-height: 0;
		clip-path: inset(0 100% 0% 0%);
		transition: .3s;
	}
	.header_logo li a:hover .on{
		clip-path: inset(0 0% 0% 0%);
		transition: .3s;
	}

	.mv-logo{
		width: 70%;
        position: absolute;
        left: 0;
        right: 0;
        bottom: 10%;
        margin: 0 auto;
        z-index: 99;
	}

	.sp-wrap{
		width: 100%;
		background: #fff;
		position: relative;
		z-index: 2;
	}
	.wrapper{
		width: 100%;
		position: relative;
		margin: 0 auto;
	}
	.swiper{
		text-align: center;
		width: 100%;
	}
	.bar{
		position: relative;
		width: 100%;
		height: 3px;
		background: #fff;
		overflow: hidden;
		z-index: 999;
	}
	.bar span{
		display: inline-block;
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		z-index: 2;
		background: #ff7c40;
		border-radius: 10px;
		transform: scaleX(0);
		transform-origin: left center;
		transition-timing-function: linear;
	}
	.swiper-slide {
		overflow: hidden;
	}
	.swiper-slide img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		transition: transform 10000ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
	}
	.swiper-slide-active img {
		transform: scale(1.1);
	}



	/* sp-nav */
	.sp-nav {
		position: fixed;
		top: 0;
		width: 100%;
		height: 100vh;
		z-index: 999;
		display: none;
		list-style:none;
		background: #f9f9f9;
	}
	.hamburger {
		position: fixed;
		top: 3%;
		right: 20px;
		cursor: pointer;
		width: 40px;
		height: 30px;
		z-index: 9999;
	}
	.hamburger span {
		transition: all .3s;
		position: absolute;
		height: 1px;
		background-color: #ff7c40;
		width:100%;
		z-index: 10;
	}
	.hamburger span:nth-of-type(1) {
		/*上の線の位置*/
		top: 12px;
	}
	.hamburger span:nth-of-type(2) {
		/*下の線の位置*/
		bottom: 12px;
	}
	.hamburger.open span:nth-of-type(1) {
		/*openのとき、上の線を右斜めにする*/
		top: 10px;
		transform: translateY(6px) rotate(-15deg);
	}
	.hamburger.open span:nth-of-type(2) {
		/*下の線を左斜めにする*/
		top: 22px;
		transform: translateY(-6px) rotate(15deg);
	}

	/* reservation */
	.reservation{
		width: 80%;
		display: block;
		background: #fff;
		margin: 0 auto;
		position: absolute;
		bottom: 10%;
		left: 0;
		right: 0;
		font-size: 14px;
		letter-spacing: 5px;
		line-height: 1em;
		text-align: center;
		padding: 4% 0;
		font-weight: bold;
	}
	.reservation span{
		width: 10px;
		line-height: 0;
		position: absolute;
		right: 10%;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
	}

	/* fix-nav */
	.fix-nav{
		width: max-content;
		position: fixed;
		z-index: 99;
		top: 20%;
		left: 25%;
	}
	.fix-nav li{
		margin: 0 0 30% 0;
	}
	.fix-nav li:last-child{
		margin: 0 0 0% 0;
	}
	.fix-nav li a{
		display: block;
		font-size: 13px;
		letter-spacing: 1px;
		font-weight: bold;
		position: relative;
	}
	.fix-nav li a .on01{
		width: 140%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}

	.fix-nav li a .on02{
		width: 90%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}

	.fix-nav li a .on03{
		width: 140%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}

	.fix-nav li a .on04{
		width: 105%;
		position: absolute;
		top: -10%;
		left: -20%;
		-webkit-clip-path: polygon(0 0, 0 0, 0 0);
		clip-path: polygon(0 0, 0 0, 0 0);
		transition: .5s;
	}

	/* sns-nav */
	.sns-nav{
		width: 100px;
		position: absolute;
		top: 55%;
		left: 25%;
		display: flex;
		justify-content: space-between;
	}
	.sns-nav li{
		width: 20%;
	}
	.sns-nav li a{
		display: block;
		line-height: 0;
	}

	/* screen-fix */
	.screen-fix{
		width: 100%;
		position: fixed;
		top: 50%;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.8s ease-in-out, visibility 0.8s ease-in-out;
	}
	.screen-fix.show {
		opacity: 1;
		visibility: visible;
	}
	.icon-list-screen{
		width: 85%;
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%); /* Safari用 */
		transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		z-index: 9999;
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}
	.icon-list-screen li{
		width: 30%;
		box-sizing: border-box;
		padding: 2% 2%;
		margin: 0 0 5% 0;
	}
	.icon-list-screen li:nth-child(n+13):nth-child(-n+15) {
		margin: 0 0 0 0;
	}

	/* main-fix */
	.main-fix{
		width: 50%;
		position: fixed;
		left: 0;
		right: 0;
		margin: 0 auto;
		top: 3%;
		line-height: 0;
		z-index: 9999;
		transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	}
	.main-fix.hidden {
		opacity: 0;
		transform: translateY(-30px) scale(0.95);
		pointer-events: none;
	}
	.main-fix.visible {
		opacity: 1;
		transform: translateY(0) scale(1);
		pointer-events: auto;
	}

	.rever{
		flex-direction: row-reverse;
	}
	.all-wrap{
		width: 100%;
		position: relative;
		margin: 0 0 15% 0;
	}
	.fix-box{
		width: 100%;
		position: relative;
	}
	.cont{
		width: 100%;
		overflow: hidden;
	}

	.col3{
		width: 100%;
		overflow: hidden;
		margin: 0 auto 20% auto;
	}
	.col3_end{
		margin: 0 auto 20% auto !important;
	}
	
	.swiper02 {
		width: 100%;
		overflow: visible; /* 左右の見切れを表示 */
		position: relative;
	}
	/* カスタムラッパー */
	.swiper-wrapper-sp {
		display: flex;
		align-items: center;
		transition-property: transform;
	}
	/* カスタムスライド */
	.swiper-slide-sp {
		flex-shrink: 0;
		width: 100%;
		position: relative;
		transition-property: transform;
		overflow: hidden;
	}
	/* 画像のスタイル */
	.swiper-slide-sp img {
		width: 100%;
		height: auto;
		display: block;
		object-fit: cover;
	}
	/* スライドのデフォルトスタイル */
	.swiper-slide-sp {
		opacity: 1;
		transform: none;
	}
	/* アクティブなスライドのスタイル */
	.swiper-slide-sp.swiper-slide-active {
		opacity: 1;
		transform: none !important;
	}
	.swiper-slide-sp.swiper-slide-active img{
		opacity: 1;
		transform: none !important;
	}

	/* cont01 */
	.fix-box .fix-img01{
		width: 100%;
		margin: 0 0 15% 0;
	}
	.cont01 .txt{
		width: 85%;
		font-size: 14px;
		line-height: 2.5em;
		letter-spacing: 2px;
		margin: 15% auto 15% auto;
		text-align: justify;
	}
	.img01-01{
		width: 60%;
		margin: 0 auto 15% auto;
	}
	.img01-02{
		width: 75%;
		margin: 0 auto 15% auto;
	}
	.img01-03{
		width: 60%;
		margin: 0 0 0 40%;
	}

	/* cont02 */
	.fix-box .fix-img02{
		width: 100%;
		margin: 0 0 15% 0;
	}
	.cont02 .title{
		width: 170px;
		background: #ff7c40;
		margin: 0 auto 20% auto;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.cont02 .title .txt{
		color: #fff;
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
	}
	.cont02 .img01{
		width: 100%;
		position: relative;
		margin: 0 auto 20% auto;
	}
	.cont02 .img01 img{
		width: 70%;
		display: block;
		margin: 0 auto 5% auto;
	}
	.cont02 .img01 .point{
		width: max-content;
		margin: 0 auto;
	}
	.cont02 .img01 .point li{
		font-size: 11px;
        letter-spacing: 2px;
        line-height: 1.8em;
	}
	.cont02 .img02{
		width: 85%;
		margin: 0 auto 10% auto;
	}
	.img02-01{
		width: 60%;
		margin: 0 auto 15% auto;
	}
	.img02-02{
		width: 75%;
		margin: 0 auto 15% auto;
	}
	.img02-03{
		width: 60%;
        margin: 0 0 0 0%;
	}

	/* cont03 */
	.fix-box .fix-img03{
		width: 100%;
		margin: 0 0 15% 0;
	}
	.img03-01{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img03-02{
		width: 75%;
		margin: 0 auto 15% auto;
	}
	.img03-03{
		width: 60%;
		margin: 0 0 0 40%;
	}

	/* price_data */
	.price_data{
		width: 85%;
		margin: 0 auto 15% auto;
	}
	.price_data .title{
		width: 170px;
        background: #ff7c40;
        margin: 0 auto 10% auto;
        box-sizing: border-box;
        padding: 0 0 0 2px;
	}
	.price_data .title .txt{
		color: #fff;
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
	}
	.price_data .pr-txt00{
		width: 100%;
		font-size: 13px;
        letter-spacing: 2px;
		text-align: justify;
		line-height: 2.5em;
		margin: 0 0 7% 0;
	}
	.pr-list{
		width: 100%;
		margin: 0 auto 5% auto;
	}
	.pr-list li{
		width: 100%;
		display: flex;
		justify-content: space-between;
		align-items: center;
		flex-wrap: wrap;
		border-bottom: 1px solid #ff7c40;
		padding: 5% 0;
	}
	.pr-list li .pr-txt01{
		width: 20%;
		font-size: 14px;
        letter-spacing: 2px;
		margin: 0 0% 0 0;
		white-space: nowrap;
	}
	.pr-list li .icon{
		width: 12%;
		margin: 0 0 0 0;
	}
	.pr-list li .pr-txt02{
		width: 20%;
		text-align: left;
		font-size: 14px;
        letter-spacing: 2px;
	}
	.pr-list li .pr-txt03{
		width: 35%;
		text-align: left;
		font-size: 9px;
        letter-spacing: 2px;
		white-space: nowrap;
	}
	.pr-list li .pr-txt04{
		width: 60%;
		text-align: left;
		font-size: 11px;
        letter-spacing: 2px;
		margin: 2% 0 0 40%;
		white-space: nowrap;
	}

	.price_data .cou{
		width: 100%;
		margin: 0 auto 10% auto;
	}
	.price_data .cou li{
		width: 100%;
		text-align: justify;
		font-size: 10px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-indent: -.7em;
		padding-left: .7em;
	}
	.p-txt-box{
		width: 100%;
		margin: 0 0 7% 0;
	}
	.p-txt-box .line{
		width: 100%;
		height: 1px;
		background: #ff7c40;
		margin: 0 0 3% 0;
	}
	.p-txt-box .p-title{
		font-size: 13px;
		letter-spacing: 1px;
		line-height: 1.8em;
		margin: 0 0 1% 0;
		white-space: nowrap;
	}
	.p-txt-box .p-txt{
		font-size: 11px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: justify;
	}
	.p-txt-box .tell{
		width: max-content;
		display: block;
		background: #ff7c40;
		color: #fff;
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		padding: 2px 10px 0 12px;
	}
	.p-txt-box .tell span{
		font-size: 10px;
		letter-spacing: 2px;
		margin: 0 10px 0 0;
		position: relative;
		top: -1px;
	}

	.tell-time{
		width: max-content;
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;
		align-items: center;
		margin: 5% 0 7% 0;
	}
	.tell-time li:nth-child(1){
		width: 100%;
		margin: 0 0 3% 0;
	}
	.tell-time li:nth-child(2){
		margin: 0 10px 0 0;
		font-size: 12px;
		letter-spacing: 2px;
	}
	.tell-time li:nth-child(3){
		margin: 0 10px 0 0;
		height: 20px;
		width: .5px;
		background: #ff7c40;
	}
	.tell-time li:nth-child(4){
		font-size: 12px;
		letter-spacing: 2px;
	}

	/* cont04 */
	.fix-box .fix-img04{
		width: 100%;
		margin: 0 0 15% 0;
	}
	.cont04 .img01{
		width: 85%;
		margin: 0 auto 10% auto;
	}
	.img04-01{
		width: 60%;
		margin: 0 0 15% 0;
	}
	.img04-02{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img04-03{
		width: 70%;
		margin: 0 0 0 30%;
	}

	/* cont05 */
	.fix-box .fix-img05{
		width: 100%;
		margin: 0 0 15% 0;
	}
	.img05-01{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img05-02{
		width: 60%;
		margin: 0 0 15% 40%;
	}
	.img05-03{
		width: 70%;
		margin: 0 auto 0 auto;
	}

	/* cont06 */
	.fix-box .fix-img06{
		width: 100%;
		margin: 0 0 15% 0;
	}
	.cont06 .img01{
		width: 85%;
		margin: 0 auto 10% auto;
	}
	.img06-01{
		width: 70%;
		margin: 0 0 15% 0;
		padding: 15% 0 0 0;
	}
	.img06-02{
		width: 70%;
		margin: 0 auto 15% auto;
	}
	.img06-03{
		width: 50%;
		margin: 0 0 0 35%;
	}

	/* staff */
	.staff{
		width: 100%;
		margin: 0 auto 20% auto;
	}
	.staff .staff_list{
		width: 100%;
	}
	.staff .staff_list li{
		width: 100%;
		font-family: "droid-serif", serif;
		font-weight: 400;
		font-style: italic;
		font-size: 10px;
		letter-spacing: 2px;
		text-align: center;
		line-height: 2em;
		margin: 0 0 5% 0;
	}

	/* f_nav */
	.f_nav{
		width: 80%;
		margin: 0 auto 25% auto;
	}
	.f_nav_list{
		width: 100%;
		margin: 0 auto;
	}
	.f_nav_list li{
		width: 100%;
		margin: 0 auto 20% auto;
	}
	.f_nav_list li:last-child{
		width: 100%;
		margin: 0 auto 0% auto;
	}
	.f_nav_list li a{
		width: 100%;
		display: block;
		text-decoration: none;
		color: #ff7c40;
	}
	.f_nav_list li a .img{
		width: 100%;
		overflow: hidden;
		border-radius: 15px;
		transition: .3s;
		margin: 0 0 5% 0;
	}
	.f_nav_list li a .img img{
		transform: scale(1);
		transition: .3s;
	}
	.f_nav_list li a:hover .img{
		width: 100%;
		overflow: hidden;
		border-radius: 30px;
		transition: .3s;
	}
	.f_nav_list li a:hover .img img{
		transform: scale(1.1);
		transition: .3s;
	}
	.f_nav_list li a .data{
		width: 100%;
	}
	.f_nav_list li a .data .txt01{
		font-size: 13px;
		letter-spacing: 2px;
		line-height: 1.5em;
		margin: 0 0 1% 0;
		white-space: nowrap;
		text-align: center;
	}
	.f_nav_list li a .data .txt02{
		font-size: 18px;
		letter-spacing: 5px;
		line-height: 2em;
		font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
		margin: 0 0 3% 0;
		text-align: center;
	}
	.f_nav_list li a .txt03{
		width: 90%;
		line-height: 0;
		display: block;
		margin: 0 auto 10% auto;
	}

	/* footer */
	footer{
		width: 100%;
		padding: 0 0 10% 0;
	}
	footer .f-logo{
		width: 30%;
		line-height: 0;
		margin: 0 auto 5% auto;
	}
	footer .f-txt{
		font-size: 10px;
		letter-spacing: 1px;
		line-height: 2em;
		text-align: center;
		margin: 0 auto 2% auto;
	}
	footer a{
		display: block;
        position: relative;
        font-size: 13px;
        letter-spacing: 2px;
        text-align: center;
		color: #ff7c40;
        text-decoration: none;
		text-align: center;
		margin: 0 auto 7% auto;
    }
	footer .copy {
        width: 40%;
		line-height: 0;
        margin: 0 auto;
    }



	/* leagal */
	.content-leagal{
		width: 85%;
		margin: 0 auto 15% auto;
		padding: 25% 0 0 0;
	}
	.leagal-title{
		width: 170px;
		background: #ff7c40;
		margin: 0 auto 2% auto;
		box-sizing: border-box;
		padding: 0 0 0 2px;
	}
	.leagal-title .leagal-txt{
		color: #fff;
		font-size: 14px;
		letter-spacing: 2px;
		line-height: 1.8em;
		text-align: center;
		padding: 2px 0 0 0;
	}
	.leagal-sub-title{
		width: 100%;
		text-align: center;
		font-size: 13px;
		letter-spacing: 2px;
		line-height: 1.8em;
		margin: 0 auto 10% auto;
	}
	.leagal-box .leagal-list{
		width: 100%;
		margin: 0 0 5% 0;
	}
	.leagal-box .leagal-list li{
		width: 98.8%;
		font-size: 12px;
		line-height: 2em;
		letter-spacing: 2px;
		text-align: justify;
		text-indent: -4%;
		padding-left: 1.8%;
	}
	.leagal-box .leagal-list li .icon{
		width: 2px;
		height: 2px;
		border-radius: 1px;
		background: #ff7c40;
		display: inline-block;
		position: relative;
		top: -4px;
		margin: 0 10px 0 0;
	}
	.leagal-box .leagal-list li a{
		text-decoration: none;
		color: #ff7c40;
		border-bottom: 1px solid #ff7c40;
	}

}
