@charset "utf-8";
/* CSS Document */

/* base
-----------------------------------------------*/
/* ========== base style ========== */

/* common parts
-----------------------------------------------*/
/* ========== text ========== */
/* ========== border ========== */
/* ========== float ========== */
/* ========== display ========== */
/* ========== position ========== */
/* ========== overflow ========== */
/* ========== width ========== */
/* ========== margin ========== */
/* ========== background ========== */
/* ========== device displaying ========== */
/* ========== animation for ScrollTrigger.min.js  ========== */

/* other style
-----------------------------------------------*/



/* base
-----------------------------------------------*/
picture {
display: block;
}

/* ========== base style ========== */
.allwrapper,
.modal, .modal * {
color: #777;
font-family: classico-urw, sans-serif;
font-style: normal;
font-weight: 400;
line-height: 100%;
}
.allwrapper *,
.modal, .modal * {
box-sizing: border-box;
}
.allwrapper {
width: 100%;
min-height: 100vh;
padding-bottom: 0;
font-size: min(3.2vw, 12px);
background: #fff;
letter-spacing: 0.05em;
animation-delay: 0.75s;
}
@media (min-width:1100px){
	.allwrapper {
		font-size: 14px;
	}
}
.modal * {
font-size: 3.4666666666vw;
letter-spacing: 0.05em;
}
@media (min-width:768px){
	.modal * { font-size: 14px; }
}
.allwrapper a:link, .allwrapper a:visited, .allwrapper .acordion_btn,
.modal a:link, .modal a:visited, .modal .acordion_btn {
color: #777;
text-decoration: none;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease;
}
.allwrapper a:hover, .allwrapper button:hover,
.modal a:hover, .modal button:hover {
opacity: 0.65;
filter: alpha(opacity=65);
}
.allwrapper ol, .allwrapper ul,
.modal ol, .modal ul {
list-style:none;
}
.allwrapper img, .allwrapper video, .allwrapper button,
.modal img, .modal video, .modal button {
width: 100%;
height: auto;
display: block;
margin-left: auto;
margin-right: auto;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease;
}

/* common parts
-----------------------------------------------*/
/* ========== text ========== */
/* align */
.al_left { text-align: left; }
.al_center { text-align: center; }
.al_right { text-align: right; }

/* size */
.fs8 { font-size: 2.1333333333vw; }
.fs9 { font-size: 2.4vw; }
.fs10 { font-size: 2.6666666666vw; }
.fs11 { font-size: 2.9333333333vw; }
.fs12 { font-size: 3.2vw; }
.fs13 { font-size: 3.4666666666vw; }
.fs14 { font-size: 3.7333333333vw; }
.fs15 { font-size: 4vw; }
.fs16 { font-size: 4.2666666666vw; }
.fs17 { font-size: 4.5333333333vw; }
.fs18 { font-size: 4.8vw; }
@media (min-width:768px){
	.fs10 { font-size: 10px; }
	.fs11 { font-size: 11px; }
	.fs13 { font-size: 13px; }
	.fs15 { font-size: 15px; }
}

/* weight */
.fw200 { font-weight: 200 !important; }
.fw300 { font-weight: 300 !important; }
.fw400 { font-weight: 400 !important; }
.fw500 { font-weight: 500 !important; }
.fw600 { font-weight: 600 !important; }
.fw700 { font-weight: 700 !important; }

/* line height */
.lh120 { line-height: 120%; }
.lh130 { line-height: 130%; }
.lh140 { line-height: 140%; }
.lh150 { line-height: 150%; }
.lh160 { line-height: 160%; }
.lh170 { line-height: 170%; }
.lh180 { line-height: 180%; }
.lh190 { line-height: 190%; }
.lh200 { line-height: 200%; }
.lh210 { line-height: 210%; }

/* letter space */
.ltrspace0 { letter-spacing: 0; }
.ltrspace0025 { letter-spacing: 0.025em; }
.ltrspace005 { letter-spacing: 0.05em; }
.ltrspace0075 { letter-spacing: 0.075em; }
.ltrspace01 { letter-spacing: 0.1em; }
.ltrspace0125 { letter-spacing: 0.125em; }
.ltrspace015 { letter-spacing: 0.15em; }

/* decotarion */
.deco_line { text-decoration: underline; }


/* ========== float ========== */
/* clearfix */
.clearfix:before,
.clearfix:after {
display: table;
content: " ";
}
.clearfix:after { clear: both; }

/* float */
.float_left { float: left; }
.float_right { float: right; }


/* ========== display ========== */
.disp_block { display: block !important; }
.disp_iblock { display: inline-block !important; }
.disp_inline { display: inline !important; }
.disp_none { display: none; }
.disp_flex { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-start; }


/* ========== position ========== */
.posi_relative { position: relative !important; }
.posi_absolute { position: absolute !important; }
.posi_fixed { position: fixed !important; }


/* ========== overflow ========== */
.overflow_hidden { overflow: hidden !important; }


/* ========== margin ========== */
/* margin-auto */
.mx_auto { margin-left: auto; margin-right: auto; }


/* ========== device displaying ========== */
.sp_none{ display: none; }
img.sp_none{ display: none; }
.sp_only{ display: block; }
img.sp_only{ display: block; }
@media (min-width:600px){
	.sp_none{display: block;}
	img.sp_none{display: block;}
	.tab_none { display: none; }
	img.tab_none { display: none; }
	.sp_only{display: none;}
	img.sp_only{display: none;}
	.sp_only{display: none;}
	img.sp_only{display: none;}
}
.spc_none{ display: block; }
@media (min-width:1099px){.pc_none{display: block;}}
.pc_only{ display: none; }
@media (min-width:1100px){.pc_none{display: none;}
.pc_only{display: block;}
.tab_none{ display: block; }
}


/* ========== animation for ScrollTrigger.min.js  ========== */
.invisible {
transition: opacity 1s ease;
opacity: 0.0;
}
.visible {
transition: opacity 1s ease;
opacity: 1.0;
}



/* other style
-----------------------------------------------*/
body { overflow-x: visible !important; overflow-y: visible !important; }
.allwrapper { width: 100vw; background: #fff; overflow: hidden; animation-delay: 0.75s; }
@media (max-width:767px){
	.allwrapper { padding-top: 0 !important; padding-bottom: 110px; }
}
@media (min-width:768px){
	body.static .wrapper { margin-top: 0; }
	.sp-menu { display: none; }
}
@media (min-width:1100px){
	.allwrapper { width: 100%; padding-bottom: 140px; }
}
.sp-menu,
.pc-menu {
position: relative;
background: #fff;
z-index: 100;
}

.ff_sawarabi {
font-family: sawarabi-gothic, sans-serif;
font-weight: 500;
}


.mv {
min-height: 133vw;
}
.mv_title {
bottom: 6.6666666666vw;
left: 15.73333333335%;
width: 68.5333333333%;
animation-delay: 1.5s;
}
img.mv_brandlogo {
top: 4vw;
left: 31.2%;
width: 35.2%;
}
.intro_ico {
width: 57.0666666666%;
margin-top: 13.3333333333vw;
}
.intro_ico li {
width: 16vw;
}
.intro_txt {
margin-top: 5.3333333333vw;
line-height: 2.1666666666;
letter-spacing: 0.02em;
}
@media (min-width:768px){
	.mv {
	min-height: 66vw;
	}
	.mv_title {
	bottom: 5.4166666666vw;
	left: 4.5138888888%;
	width: 25.3472222222%;
	}
	img.mv_brandlogo {
	top: 2.0833333333vw;
	left: 2.0833333333%;
	width: 12.6388888888%;
	}
	.intro_ico {
	width: 270px;
	margin-top: 77px;
	}
	.intro_ico li {
	width: 76px;
	}
	.intro_txt {
	margin-top: 35px;
	font-size: 13.5px;
	line-height: 2.38;
	}
}
@media (min-width:1100px){
	.intro_ico {
	width: 352px;
	margin-top: 100px;
	}
	.intro_ico li {
	width: 100px;
	}
	.intro_txt {
	margin-top: 47px;
	font-size: 18px;
	}
}

.lineup {
margin-top: 18.6666666666vw;
}
.lineup_list {
justify-content: center;
gap: 8vw 3.6144578314%;
width: 88.53333333333%;
margin-top: 9.3333333333vw;
}
.lineup_list li {
width: 48.1927710843%;
font-size: min(3.46666666666vw, 13px);
line-height: 1.45;
}
.lineup_list li img {
margin-bottom: 2.6666666666vw;
}
.lineup_list li span {
display: block;
margin-top: 1.06666666vw;
text-decoration: underline;
}
@media (min-width:768px){
	.lineup {
	margin-top: 120px;
	}
	.lineup_list {
	justify-content: space-between;
	gap: 0;
	width: 626px;
	margin-top: 75px;
	}
	.lineup_list li {
	width: 197px;
	}
	.lineup_list li img {
	margin-bottom: 10px;
	}
	.lineup_list li span {
	margin-top: 7px;
	}
}
@media (min-width:1100px){
	.lineup {
	margin-top: 120px;
	}
	.lineup_list {
	width: 815px;
	margin-top: 96px;
	}
	.lineup_list li {
	width: 256px;
	font-size: 16px;
	}
	.lineup_list li img {
	margin-bottom: 15px;
	}
	.lineup_list li span {
	margin-top: 10px;
	}
}

.secbox {
margin-top: 38.6666666666vw;
}
.sectitle {
font-size: min(6.4vw, 24px);
text-align: center;
line-height: 1;
}
.secbox_mainbox {
width: 85.3333333333%;
margin-top: 10.1333333333vw;
}
.secbox_maintxt {
margin-top: 5.3333333333vw;
letter-spacing: 0.02em;
}
a.btn_more {
display: block;
width: min(74.6666666666%, 280px);
margin: 10.6666666666vw auto 0;
padding: min(5.3333333333vw, 20px);
background: #777;
color: #fff !important;
font-size: min(3.46666666666vw, 13px);
text-align: center;
border-radius: min(6.9333333333vw, 26px);
}
h3.sectitle {
margin-top: 16vw;
}
@media (min-width:768px){
	.secbox {
	margin-top: 220px;
	}
	.sectitle {
	font-size: 32px;
	}
	.secbox_mainbox {
	width: 490px;
	margin-top: 60px;
	}
	.secbox_maintxt {
	margin-top: 30px;
	font-size: 10.95px;
	}
	a.btn_more {
	margin-top: 60px;
	}
	h3.sectitle {
	margin-top: 100px;
	}
}
@media (min-width:1100px){
	.secbox {
	margin-top: 285px;
	}
	.sectitle {
	font-size: 40px;
	}
	.secbox_mainbox {
	width: 640px;
	margin-top: 75px;
	}
	.secbox_maintxt {
	margin-top: 40px;
	font-size: 14px;
	}
	a.btn_more {
	width: 300px;
	margin-top: 80px;
	padding: 22px 0;
	font-size: 14px;
	border-radius: 29px;
	}
	h3.sectitle {
	margin-top: 130px;
	}
}

.sec01 {
margin-top: 21.3333333333vw;
}
.sec01_subimg01 {
width: 72%;
margin: 5.3333333333vw auto 0 0;
}
.sec01_subimg02 {
width: 46.4%;
margin: 2.6666666666vw auto 0 45.3333333333%;
}
.item01_subimg02_point {
top: 11.7333333333vw;
left: -16.2666666666vw;
width: 22.9333333333vw;
animation-delay: 0.3s;
}
@media (min-width:768px){
	.sec01 {
	margin-top: 120px;
	}
	.sec01_subimg01 {
	width: 418px;
	margin: 60px auto 0 calc(50% - 287px);
	}
	.sec01_subimg02 {
	width: 268px;
	margin: 15px auto 0 calc(50% - 25px);
	}
	.item01_subimg02_point {
	top: 50px;
	left: -90px;
	width: 128px;
	}
}
@media (min-width:1100px){
	.sec01 {
	margin-top: 155px;
	}
	.sec01_subimg01 {
	width: 544px;
	margin: 80px auto 0 calc(50% - 375px);
	}
	.sec01_subimg02 {
	width: 348px;
	margin: 20px auto 0 calc(50% - 33px);
	}
	.item01_subimg02_point {
	top: 65px;
	left: -118px;
	width: 166px;
	}
}

.sec02_subimg01 {
width: 54.4%;
margin: 10.6666666666vw auto 0 37.3333333333%;
}
.sec02_subimg02 {
width: 46.4%;
margin: 2.6666666666vw auto 0 3.7333333333%;
}
img.item02_subimg02_point {
top: 38.1333333333vw;
left: 24vw;
width: 45.3333333333vw;
animation-delay: 0.3s;
}
@media (min-width:768px){
	.sec02_subimg01 {
	width: 315px;
	margin: 60px auto 0 calc(50% - 70px);
	}
	.sec02_subimg02 {
	width: 267px;
	margin: 16px auto 0 calc(50% - 265px);
	}
	img.item02_subimg02_point {
	top: 221px;
	left: 138px;
	width: 278px;
	}
}
@media (min-width:1100px){
	.sec02_subimg01 {
	width: 408px;
	margin: 80px auto 0 calc(50% - 94px);
	}
	.sec02_subimg02 {
	width: 348px;
	margin: 20px auto 0 calc(50% - 347px);
	}
	img.item02_subimg02_point {
	top: 288px;
	left: 179px;
	width: 361px;
	}
}

.sec03_subimg01 {
width: 54.4%;
margin: 10.6666666666vw auto 0 9.0666666666vw;
}
.sec03_subimg02 {
width: 46.4%;
margin: 2.6666666666vw auto 0 45.3333333333%;
}
img.item03_subimg02_point {
top: 5.3333333333vw;
left: -16.5333333333vw;
width: 32.8vw;
}
@media (min-width:768px){
	.sec03_subimg01 {
	width: 315px;
	margin: 60px auto 0 calc(50% - 235px);
	}
	.sec03_subimg02 {
	width: 267px;
	margin: 16px auto 0 calc(50% - 25px);
	}
	img.item03_subimg02_point {
	top: 32px;
	left: -87px;
	width: 179px;
	}
}
@media (min-width:1100px){
	.sec03_subimg01 {
	width: 408px;
	margin: 80px auto 0 calc(50% - 307px);
	}
	.sec03_subimg02 {
	width: 348px;
	margin: 20px auto 0 calc(50% - 33px);
	}
	img.item03_subimg02_point {
	top: 43px;
	left: -113px;
	width: 236px;
	}
}

.modalBtn {
display: block;
width: 49.0666666666vw;
cursor: pointer;
-webkit-transition: all 0.3s ease;
-moz-transition: all 0.3s ease;
-o-transition: all 0.3s ease;
transition: all  0.3s ease;
}
.modalBtn:hover {
opacity: 0.65;
filter: alpha(opacity=65);
}
.coordinate01 {
margin: 9.6vw auto 0 45.3333333333%;
}
.coordinate02 {
margin: -50.6666666666vw auto 0 5.3333333333%;
}
img.coordinate_open {
right: 1.3333333333vw;
bottom: 5.3333333333vw;
width: 9.0666666666vw;
}
@media (min-width:768px){
	.modalBtn {
	width: 283px;
	}
	.coordinate01 {
	margin: 60px auto 0 calc(50% - 25px);
	}
	.coordinate02 {
	margin: -292px auto 0 calc(50% - 257px);
	}
	img.coordinate_open {
	right: 20px;
	bottom: 41px;
	width: 30px;
	}
}
@media (min-width:1100px){
	.modalBtn {
	width: 370px;
	}
	.coordinate01 {
	margin: 75px auto 0 calc(50% - 33px);
	}
	.coordinate02 {
	margin: -380px auto 0 calc(50% - 335px);
	}
	img.coordinate_open {
	right: 25px;
	bottom: 55px;
	width: 40px;
	}
}

.staffcredit {
margin-top: 18.6666666666vw;
line-height: 2.16;
}
@media (min-width:768px){
	.staffcredit {
	margin-top: 110px;
	}
}
@media (min-width:1100px){
	.staffcredit {
	margin-top: 140px;
	}
}


/* ========== modal ========== */
.modal_lock.is-locked {
position: fixed;
width: 100%;
z-index: 10000;
}

.modal {
visibility: hidden;
overflow-y: scroll;
opacity: 0;
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
transition: opacity 0.3s, visibility 0s 0.5s;
background: rgba(0, 0, 0, 0.3);
}
.modal.is-active {
visibility: visible;
opacity: 1;
transition: opacity 0.5s, visibility 0s 0s;
z-index: 10000;
}

.modal_container {
display: flex;
min-height: 100%;
justify-content: center;
align-items: center;
}
@media all and (-ms-high-contrast: none){
	.modal_container {
		display: block;
		padding-top: 11vh
	}
}
.modal_inner {
margin: auto;
width: 94.6666666666%;
position:  relative;
}
.modal_content {
width: 100%;
max-height: 90vh;
overflow-y: auto;
margin: auto;
padding: 5.0666666666vw 5.0666666666vw 12vw;
background: #fff;
}
.modal_content.is-active {
display: block;
}
.modal_main {
position: relative;
}
.modal_details {
margin-top: 5.3333333333vw;
padding-top: 5.3333333333vw;
border-top: 1px solid #d9d9d9;
}
.modal_price li {
line-height: 2.16;
}
.modal_price li span {
text-decoration: underline;
}
.modal_card {
align-items: center;
margin-top: 5.3333333333vw;
background: #f5f5f5;
}
.modal_card picture {
width: 34.1333333333vw;
}
.modal_card_text {
width: calc(100% - 34.1333333333vw);
line-height: 1.45;
}
.modal_card_text span {
margin-top: 3.2vw;
text-decoration: underline;
}
button.modal_closebtn {
width: 40px;
position: absolute;
top: 20px;
right: 20px;
cursor: pointer;
z-index: 2;
}
@media (min-width:768px){
	.modal_inner {
		width: 540px;
	}
	.modal_content {
		padding: 55px 60px;
	}
	.modal_img {
	width: 420px;
	}
	.modal_details {
	width: 470px;
	margin: 55px -25px 0;
	padding-top: 40px;
	}
	.modal_price li {
	line-height: 2;
	}
	.modal_card {
	margin-top: 40px;
	}
	.modal_card picture {
	width: 190px;
	}
	.modal_card_text {
	width: calc(100% - 190px);
	font-size: 16px;
	}
	.modal_card_text span {
	margin-top: 15px;
	}
}
@media (min-width:1200px){
	.modal_inner {
		width: 1100px;
	}
	.modal_main {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.modal_content {
		padding: 55px 60px;
	}
	.modal_details {
	margin: 55px -25px 0;
	padding-top: 40px;
	}
	button.modal_closebtn {
	top: 30px;
	right: 30px;
	}
}
