@charset "utf-8";
/* CSS Document */


/*---------------------
　TITLE
-----------------------*/
.blaLabelTit {
	background: #000;
	color: #fff;
	font-size: 5.6rem;
	text-align: center;
	line-height: 1.5;
	display: inline-block;
	padding: 10px 32px;
	position: relative;
	margin-bottom: 6rem;
}
.blaLabelTit.line_right:before {
    content: "";
    width: 2.4rem;
    height: 1px;
    background: linear-gradient(90deg, #fff 0%, #fff 50%, #212121 50%, #212121 100%);
    position: absolute;
    top: 50%;
    right: -1.2rem;
}
.blaLabelTit.line_btm:before {
    content: "";
    width: 1px;
    height: 2.4rem;
    background: linear-gradient(180deg, #fff 0%, #fff 50%, #212121 50%, #212121 100%);
    position: absolute;
    bottom: -1.2rem;
    left: 50%;
}
.blaLabelTit.center {
	display: table;
	margin: 0 auto 6rem;
}
.twoColTitBox {
	display: flex;
	justify-content: space-between;
	margin-bottom: 8rem;
}
.twoColTitBox .secTit {
}
.twoColTitBox .secTit .small {
	font-size: 2.6rem;
	display: block;
	line-height: 1.4;
	border-bottom: solid 1px #fff;
	padding: 0 2rem 2rem 0;
	margin: 0 0 1.5rem;
}
.twoColTitBox .secTit .big {
	font-size: 5.6rem;
	line-height: 1.4;
}
.twoColTitBox .secTit a {
	color: #fff;
	text-decoration: none;
}
.twoColTitBox .rightBox {
	max-width: 63rem;
}
.twoColTitBox .rightBox p {
	line-height: 1.5;
	color: #fff;
	margin: 0;
}
.twoColTitBox .btn-small {
	float: right;
}

/*---------------------
　BUTTON
-----------------------*/
.btn-small {
	width: 12rem;
	margin-top: 3rem;
}
.btn-small a {
	font-family: "Cormorant Garamond", serif;
	text-align: center;
	color: #fff;
	border: solid 1px #fff;
	text-decoration: none;
	border-radius: 2rem;
	background: url("img/arr_wh_right.png") no-repeat center right 0.8rem;
	background-size: 1.2rem auto;
	display: block;
	line-height: 1.5;
	padding: 2px 20px 2px 5px;
}


/*---------------------
　KEY
-----------------------*/
header:after {
    content: "";
    background: url("img/key_home.jpg") no-repeat;
    background-size: cover;
    width: 54.4%;
    height: auto;
    aspect-ratio: 784 / 866;
    position: absolute;
    top: 0;
    right: 0;
}
.key {
	position: relative;
	padding: 9.72vw 1.80vw 9.72vw;
}
.key:before {
	content: "";
	background: #A7955A;
	width: 100%;
	height: 24.3vw;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: -2;
}
.key:after {
	content: "";
    background: url("img/key_home02.jpg") no-repeat;
    background-size: cover;
	width: 38%;
	height: auto;
	aspect-ratio: 550 / 553;
	position: absolute;
	bottom: 0;
	left: 0;
}
.keyInr:after {
	content: "";
    background: url("img/key_radius_gld.png") no-repeat;
    background-size: cover;
	width: 13%;
	height: auto;
	aspect-ratio: 196 / 382;
	position: absolute;
	bottom: 11.1vw;
	right: 0;
	mix-blend-mode: color-burn;
}
.outer {
	position: relative;
	z-index: 1;
}
.black{
    position:absolute;
    left: 0;
    top: 0;
    font-size: 6.73vw;
	line-height: 1.3;
    color:#fff;
    z-index: -1;
	width: 110%;
}
.white{
    position:relative;
    width: 45%;
    height: 17.5vw;
    overflow: hidden;
}
.white::after{
	font-family: "Cormorant Garamond", serif;
    font-weight: 700;
    position:absolute;
	left: 0;
    top: 0;
    content:"Japanese Food Franchise \A Originating in Japan";
    white-space: pre;
    font-size: 6.73vw;
    color: #212121;
    z-index:1;
	line-height: 1.3;
	width: 110%;
}
.key .txtBox {
	display: flex;
	justify-content: flex-end;
	margin-top: 27.7vw;
}
.key .txtBox p {
	max-width: 57%;
	line-height: 1.8;
	color: #fff;
	font-size: 1.25vw;
}
.keyArea .lower_bottom {
    background: none;
    margin: -5rem 0 0;
    padding: 0;
    z-index: 1;
    position: relative;
}


/*---------------------
　SEC01
-----------------------*/
.sec01 {
    background: #212121;
	padding: 10rem 0;
	position: relative;
	margin: 16rem 0;
}
.sec01:before {
    content: "";
	background: url("img/sec01_radius_wh.png") no-repeat;
	background-size: 100%;
	width: 59rem;;
	height: 30.2rem;
	position: absolute;
	bottom: -15rem;
	right: -18rem;
	z-index: 1;
}
.sec01 .flexBox {
    display: flex;
	justify-content: flex-end;
	max-width: 120rem;
	margin: 0 auto;
}
.sec01 .cclBox {
	position: absolute;
	top: -3rem;
	left: 0;
	padding: 0 0 0 7rem;
}
.sec01 .cclBox:before {
	content: "";
	width: 64.3rem;
	height: 64.3rem;
	border-radius: 50%;
    background: #A2081D;
	position: absolute;
	top: 50%;
	left: 60%;
	transform: translate(-50%, -50%);
}
.sec01 .cclBox:after {
	content: "";
	background: url("img/sec01_radius_top.png") no-repeat;
	background-size: 100%;
	width: 50.8rem;
	height: 57.1rem;
	position: absolute;
	top: 12rem;
	left: -26rem;
}
.sec01 .secTit {
	color: #fff;
	z-index: 1;
	position: relative;
}
.sec01 .secTit .small {
	font-size: 2.6rem;
	display: block;
	line-height: 1.4;
	border-bottom: solid 1px #fff;
	padding: 0 2rem 2rem 0;
	margin: 0 0 1.5rem;
	position: relative;
}
.sec01 .secTit .small:before {
    content: "";
	background: #fff;
	width: 6rem;
	height: 1px;
	position: absolute;
	bottom: -1px;
	right: -6rem;
}
.sec01 .secTit .big {
	font-size: 5.6rem;
	line-height: 1.4;
}
.sec01 .sqWrap {
	display: flex;
	flex-wrap: wrap;
	gap: 1.6rem;
	width: 99.3rem;
}
.sec01 .sqBox {
	/*width: 32rem;
	height: 32rem;*/
	width: calc(33% - 0.8rem);
	height: auto;
	aspect-ratio: 1 / 1;
	position: relative;
	cursor: pointer;
	transition: all 0.2s;
}
.sec01 .sqBox .link {
	text-decoration: none;
}
.sec01 .sqBox a:hover {
	opacity: 1;
}
.sec01 .sqBox .bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}
.sec01 .sqBox .bg:before {
	content: "";
	background: rgba(0,0,0,0.28);
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	transition: background 0.2s ease;
}
.sec01 .sqBox.on .bg:before {
	content: "";
	background: rgba(0,0,0,0.65);
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
.sec01 .sqBox .layer01 {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 1;
}
.sec01 .sqBox .layer01 .tit {
	color: #fff;
	font-size: 2.4rem;
	text-align: center;
	position: relative;
	z-index: 1;
}
.sec01 .sqBox .layer01 .tit span {
	font-size: 3.6rem;
}
.sec01 .sqBox .layer02 {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	padding: 0 5rem;
}
.sec01 .sqBox .layer02 .btn-close {
	display: none;
}
.sec01 .sqBox .layer02 .tit {
	font-family: "Cormorant Garamond", serif;
	color: #fff;
	font-size: 2.4rem;
	line-height: 1.4;
	text-align: center;
	position: relative;
	z-index: 1;
	padding-bottom: 0.6rem;
}
.sec01 .sqBox .layer02 .tit:before {
	content: "";
	background: #fff;
	width: 5rem;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}
.sec01 .sqBox .layer02 p {
	color: #fff;
	line-height: 1.5;
	font-size: 1.6rem;
}
.sec01 .sqBox .layer02 .btn-small {
	margin: 0 auto;
}
.sec01 .sqBox .layer02 .btn-small {
	border: solid 1px #A7955A;
    font-family: "Cormorant Garamond", serif;
    text-align: center;
    color: #fff;
    text-decoration: none;
    border-radius: 2rem;
    background: url(img/arr_wh_right.png) no-repeat center right 0.8rem;
	background-color: #A7955A;
    background-size: 1.2rem auto;
    display: block;
    line-height: 1.5;
    padding: 2px 20px 2px 5px;
}


/*---------------------
　SEC02
-----------------------*/
.sec02:before {
	height: 40.5rem;
    top: -8rem;
    right: calc(50% - -55.4rem);
    z-index: 1;
    width: 50%;
}
.sec02 .grayBox {
    width: 100%;
	background: none;
    padding: 12rem 4rem 0 5rem;
	position: relative;
}
.sec02 .grayBox:before {
    content: "";
    background: #F5F5F5;
    width: 100%;
    height: 39rem;
    position: absolute;
    top: 0;
    left: 0;
	z-index: -1;
}
.sec02 .grayBox:after {
    content: "";
    background: #F5F5F5;
    width: 100%;
    height: 39rem;
    position: absolute;
    top: 0;
    right: -100%;
	z-index: -1;
}
.sec02 .artArea:before {
    content: none;
}
.sec02 .blackLabel {
    font-size: 5.6rem;
    color: #fff;
    left: -5rem;
    top: -4.7rem;
}
.sec02 .update {
    text-align: left;
	margin-bottom: 6rem;
}
.sec02 .artSliderArea {
    display: flex;
	gap: 8rem;
	padding: 0 0 0 4rem;
}
.sec02 .artSlider {
    flex: 1;
}
.sec02 .slick-track {
  display: flex;
	gap: 4.4rem;
}
.sec02 .slick-slide {
  height: auto;
}
.sec02 .arrow_box {
	width: 7.7rem;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.sec02 .slick-arrow {
	width: 7.7rem;
	height: 7.5rem;
	cursor: pointer;
	transition: all 0.4s;
}
.sec02 .slick-arrow:hover {
	opacity: 0.6;
}
.sec02 .prev-arrow {
	background: url("img/arr_slider_prev_wh.png") no-repeat;
	background-size: 100%;
}
.sec02 .next-arrow {
	background: url("img/arr_slider_next_wh.png") no-repeat;
	background-size: 100%;
}
.sec02 .slick-num {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin: 3rem 0;
	gap: 1.6rem;
}
.sec02 .slick-num .all-count {
	position: relative;
}
.sec02 .slick-num .all-count:before {
	content: "";
	background: #212121;
	width: 1rem;
	height: 1px;
	position: absolute;
	top: -9px;
	left: 50%;
	transform: translateX(-50%);
}
.sec02 .artBox {
    width: 39.2rem;
}
.sec02 .artBox a {
    display: flex;
	flex-direction: column;
}
.sec02 .artBox .titBox {
    display: flex;
	margin-bottom: 2rem;
}
.sec02 .artBox .rankccl {
    width: 4.2rem;
    height: 4.2rem;
    font-size: 1.5rem;
    margin-right: 15px;
}
.sec02 .artBox .rankccl span {
    font-size: 3.7rem;
}
.sec02 .artBox .no01 {
	background: #A7955A;
}
.sec02 .artBox .no02 {
	background: #A7A7A7;
}
.sec02 .artBox .no03 {
	background: #A27A51;
}
.sec02 .artBox .artTit {
    font-size: 2.6rem;
	flex: 1;
	padding: 0 0 0.5rem;
	display: flex;
    flex-direction: column;
    justify-content: center;
}
.sec02 .artBox .picBox {
    width: 100%;
    margin-right: 0;
    /* background: #F5F5F5; */
    padding: 0 0 5px;
}
.sec02 .artBox .picBox img {
    width: 100%;
    height: auto;
    object-fit: contain;
    aspect-ratio: 392 / 210;
}
.sec02 .artBox .caption {
    padding: 0 1rem;
}

/*---------------------
　SEC03
-----------------------*/
.sec03 {
	position: relative;
	z-index: 1;
	margin: 15rem 0;
	padding: 10rem 0 0;
	overflow: hidden;
}
.sec03 .sec03Inr:before {
	content: "";
	background: #A7955A;
	width: 100%;
	height: 46rem;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}
.sec03 .twoColTitBox {
	position: relative;
}
.sec03 .twoColTitBox:after {
	content: "";
	background: url("img/deco_radius_gld_tate.png") no-repeat;
	background-size: 100%;
	width: 41.4rem;
	height: 80.6rem;
	position: absolute;
    top: -58rem;
    left: -32rem;
	z-index: -1;
	mix-blend-mode: color-burn;
	opacity: 0.45;
}
.sec03 .cardWrap {
	display: flex;
	flex-wrap: wrap;
	gap: 4.4rem;
}
.sec03 .cardBox {
	max-width: 52.8rem;
	width: calc(50% - 2.2rem);
}
.sec03 .cardBox a {
	display: block;
	text-decoration: none;
	position: relative;
}
.sec03 .cardBox a:hover {
	opacity: 1;
}
.sec03 .cardBox .pic {
    overflow: hidden;
    position: relative;
    width: 100%;
}
.sec03 .cardBox .pic:before {
	content: "";
	background: url("img/sec03_grad.png") no-repeat bottom;
	background-size: 100%;
	width: 100%;
	height: 13.7rem;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 1;
}
.sec03 .cardBox a img {
    height: auto;
    transition: transform .6s ease;
}
.sec03 .cardBox a:hover img {
	transform: scale(1.1);
}
.sec03 .cardBox .cardTit {
	color: #fff;
	font-size: 2.6rem;
	border-left: solid 1px #fff;
	padding: 0 8rem 0 2rem;
	line-height: 1.5;
	position: absolute;
	bottom: 2rem;
	left: 2rem;
	background: url("img/arr_ccl_wh_right.png") no-repeat center right 2rem;
	background-size: 4rem auto;
	z-index: 2;
	min-height: 7.8rem;
	display: flex;
	align-items: center;
	width: calc(100% - 2rem);
}


/*---------------------
　SEC04
-----------------------*/
.sec04 {
	margin: 0 0 20rem;
	overflow: hidden;
}
.sec04 .wi1200 {
	position: relative;
	z-index: 1;
	padding: 10rem 0 0;
	background: #fff;
}
.sec04 .wi1200:before {
	content: "";
	background: #212121;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 44rem;
	z-index: -1;
}
.sec04 .wi1200:after {
	content: "";
	background: #212121;
	position: absolute;
	top: 0;
	right: -100%;
	width: 100%;
	height: 44rem;
	z-index: -2;
}
.sec04 .twoColTitBox {
	padding: 0 10rem;
	position: relative;
}
.sec04 .twoColTitBox:after {
	content: "";
	background: url("img/deco_radius_gld_tate.png") no-repeat;
	background-size: 100%;
	width: 41.4rem;
	height: 80.6rem;
	position: absolute;
    top: -30rem;
    right: -1rem;
	mix-blend-mode: color-burn;
	opacity: 0.45;
	transform: rotate(45deg);
	z-index: -1;
}
.sec04 .caseSlider {
	padding: 0 5rem;
}
.sec04 .slick-track {
	display: flex;
}
.sec04 .caseBox {
	width: 33.8rem;
	margin: 0 2rem;
	display: flex;
	height: auto;
}
.sec04 .caseBox a {
	display: flex;
	flex-direction: column;
	text-decoration: none;
}
.sec04 .caseBox .caseTit {
	font-family: "Cormorant Garamond", serif;
	color: #fff;
	font-size: 2.8rem;
	text-align: center;
	line-height: 1.5;
	position: relative;
	margin: 0 auto;
	margin-bottom: 2.3rem;
	display: table;
}
.sec04 .caseBox .caseTit:before {
	content: "";
	background: #fff;
	width: 1px;
	height: 2.3rem;
	position: absolute;
	bottom: -2.3rem;
	left: 50%;
}
.sec04 .caseBox .caseTit:after {
	content: "";
	background: #A2081D;
	width: 2rem;
	height: 2rem;
	position: absolute;
	top: 0rem;
	left: -0.8rem;
	border-radius: 50%;
	z-index: -1;
}
.sec04 .caseBox .thumb {
	background: #F5F5F5;
}
.sec04 .caseBox .thumb img {
	width: 100%;
	height: auto;
	aspecr-tatio: 34 / 24;
	object-fit: cover;
}
.sec04 .caseBox .caption {
	padding: 0 1rem;
}
.sec04 .caseBox .txtBody {
	background: #F5F5F5;
	padding: 2rem 2rem 3rem;
	flex-grow: 1;
    display: flex;
    flex-direction: column;
}
.sec04 .caseBox .catch {
	font-size: 2.6rem;
	line-height: 1.5;
	border-bottom: solid 1px #212121;
	padding: 0 0 1.5rem;
	position: relative;
}
.sec04 .caseBox .catch:before {
	content: "";
	background: #212121;
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: -1px;
	left: -2rem;
}
.sec04 .caseBox p {
	line-height: 1.5;
	flex-grow: 1;
	color: #494949;
}
.sec04 .caseBox .btnWrap {
}
.sec04 .caseBox .btn-small {
	font-family: "Cormorant Garamond", serif;
	text-align: center;
	color: #fff;
	border: solid 1px #A7955A;
	text-decoration: none;
	border-radius: 2rem;
	background: #A7955A url("img/arr_wh_right.png") no-repeat center right 0.8rem;
	background-size: 1.2rem auto;
	display: block;
	line-height: 1.5;
	padding: 2px 20px 2px 5px;
	margin-top: 0;
	float: right;
}
.sec04 .slick-arrow {
	position: absolute;
	top: 16rem;
	width: 6.4rem;
	height: 6.4rem;
	font-size: 0;
	cursor: pointer;
	transition: all 0.4s;
	z-index: 1;
}
.sec04 .slick-arrow:hover {
	opacity: 0.7;
}
.sec04 .slick-prev {
	left: -3rem;
	background: url("img/arr_slider_prev.png") no-repeat;
	background-size: 100%;
}
.sec04 .slick-next {
	right: -3rem;
	background: url("img/arr_slider_next.png") no-repeat;
	background-size: 100%;
}
.sec04 .slick-dots {
	display: flex;
	gap: 2rem;
	justify-content: center;
	margin: 5rem 0 0;
}
.sec04 .slick-dots li {
	font-size: 0;
	width: 1rem;
	height: 1rem;
	border-radius: 50%;
	background: #D5D5D5;
	padding: 0;
	margin: 0;
	cursor: pointer;
	transition: all 0.4s;
}
.sec04 .slick-dots li:hover {
	opacity: 0.7;
}
.sec04 .slick-dots li.slick-active {
	background: #A2081D;
}
.sec04 .slick-dots li.slick-active:hover {
	opacity: 1;
}


/*---------------------
　SEC05
-----------------------*/
.sec05 {
	margin-top: 5rem;
}
.sec05 .wi1200 {
	background: #F5F5F5;
	position: relative;
	padding: 0 0 12rem;
}
.sec05 .wi1200:before {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: -100%;
	background: #F5F5F5;
}
.sec05 .titBox {
	position: relative;
    top: -5.2rem;
}
.sec05 .blaLabelTit {
	margin-bottom: 4rem;
}
.sec05 .lead {
	width: 63rem;
	line-height: 1.5;
	border-left: solid 1px #212121;
	padding: 0 0 0 3rem;
	margin: 0 0 0 2rem;
	color: #494949;
}
.sec05 .picBox {
	background: #fff;
	max-width: 100rem;
	margin: -9rem auto 0;
	padding: 9rem 5rem 4rem;
}



/*---------------------
　SEC06
-----------------------*/
.sec06 {
	padding: 12rem 0 2rem;
}
.sec06 .itemBoxWrap {
	display: flex;
	justify-content: center;
	gap: 8rem;
	margin-bottom: 10rem;
}
.sec06 .itemBox {
	width: 18rem;
}
.sec06 .itemBox .ediName {
	font-size: 2.4rem;
    font-weight: 700;
	line-height: 1.6;
	position: relative;
	padding: 4rem 0 0;
	text-align: center;
	margin-bottom: 1.5rem;
}
.sec06 .itemBox .ediName:before {
	content: "";
	background: #212121;
	width: 1px;
	height: 16px;
	position: absolute;
	top: 1.8rem;
	left: 50%;
}
.sec06 .itemBox p {
	line-height: 1.5;
	margin: 0;
	color: #494949;
}
.sec06 .btn-link {
	text-align: center;
}
.sec06 .btn-link a {
	font-size: 2.4rem;
}



@media screen and (max-width: 1024px) {
	
.sec02 .blackLabel {
    left: 0;
}	
	
.sec04 .wi1200:before {
	height: 60vw;
}
.sec04 .twoColTitBox {
    padding: 0 4rem;
}
.sec04 .slick-prev {
	left: 1rem;
}
.sec04 .slick-next {
	right: 1rem;
}
}


@media screen and (max-width: 768px) {
	
	
/*---------------------
　TITLE
-----------------------*/
.blaLabelTit {
	font-size: 2.4rem;
	line-height: 1.5;
	padding: 5px 30px;
	margin-bottom: 4rem;
}
.blaLabelTit.line_right:before {
    content: "";
    width: 2.4rem;
    height: 1px;
    background: linear-gradient(90deg, #fff 0%, #fff 50%, #212121 50%, #212121 100%);
    position: absolute;
    top: 50%;
    right: -1.2rem;
}
.blaLabelTit.line_btm:before {
    height: 1.6rem;
    bottom: -0.8rem;
}
.blaLabelTit.center {
	display: table;
	margin: 0 auto 6rem;
}
.twoColTitBox {
	display: flex;
	justify-content: space-between;
	flex-direction: column;
	margin-bottom: 4rem;
	gap: 1.8rem;
}
.twoColTitBox .leftBox {
	max-width: 25rem;
}
.twoColTitBox .secTit {
}
.twoColTitBox .secTit .small {
	font-size: 1.8rem;
	padding: 0 1.5rem 1.5rem 0;
	margin: 0 0 1.5rem;
}
.twoColTitBox .secTit .big {
	font-size: 3.6rem;
}
.twoColTitBox .secTit a {
	color: #fff;
	text-decoration: none;
}
.twoColTitBox .rightBox {
	max-width: 100%;
}
.twoColTitBox .rightBox p {
	line-height: 1.5;
	color: #fff;
	margin: 0;
}
.twoColTitBox .btn-small {
	float: right;
}

/*---------------------
　BUTTON
-----------------------*/
.btn-small {
	width: 12rem;
	margin-top: 3rem;
}
.btn-small a {
	font-family: "Cormorant Garamond", serif;
	text-align: center;
	color: #fff;
	border: solid 1px #fff;
	text-decoration: none;
	border-radius: 2rem;
	background: url("img/arr_wh_right.png") no-repeat center right 0.8rem;
	background-size: 1.2rem auto;
	display: block;
	line-height: 1.5;
	padding: 2px 20px 2px 5px;
}


/*---------------------
　KEY
-----------------------*/
header {
    padding: 1rem 1rem 9rem;
}
header:after {
    content: "";
    background: url("img/key_home_sp.jpg") no-repeat;
    background-size: cover;
    width: 84%;
	height: auto;
    max-height: 472px;
    aspect-ratio: 315 / 472;
    position: absolute;
    top: 5rem;
    right: 0;
	z-index: 1;
}
.keyArea {
	margin-bottom: 5rem;
}
.key {
	position: relative;
	padding: 0;
}
.key:before {
	content: none;
	background: #A7955A;
	width: 100%;
	height: 24.3vw;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: -2;
}
.key:after {
	content: none;
}
.keyInr:after {
    content: none;
}
.outer {
	position: relative;
	z-index: 1;
}
.black{
    position: absolute;
    left: 1.5rem;
    top: 0;
    font-size: 4.2rem;
	width: 100%;
}
.white{
    position:relative;
    width: 16%;
    height: 22rem;
    overflow: hidden;
}
.white::after{
	font-family: "Cormorant Garamond", serif;
    font-weight: 700;
    position:absolute;
	left: 1.5rem;
    top: 0;
    content:"Japanese food \A franchises \A originating in Japan";
    white-space: pre;
    font-size: 4.2rem;
	width: 100%;
}
.key .txtWrap {
    background: #A7955A url("img/key_home02_sp.jpg") no-repeat bottom;
    background-size: cover;
	padding: 6rem 1.5rem 10rem;
	margin-top: 14rem;
}
.key .txtWrap:after {
    content: "";
    background: url(img/key_radius_gld.png) no-repeat;
    background-size: cover;
    width: 10.5rem;
    height: 22.3rem;
    aspect-ratio: inherit;
    position: absolute;
    top: 24rem;
    right: 0;
    z-index: 1;
	mix-blend-mode: color-burn;
}
/*.key .txtWrap:after {
	content: "";
    background: #A7955A url("img/key_home02_sp.jpg") no-repeat bottom;
    background-size: cover;
	width: 100%;
	height: auto;
	min-height: 35rem;
	position: absolute;
	top: 33rem;
	left: 0;
	aspect-ratio: inherit;
	z-index: -1;
}*/
.key .txtBox {
	display: flex;
	justify-content: flex-end;
	margin-top: 0;
	position: relative;
}
.key .txtBox p {
	width: 100%;
	max-width: 100%;
	line-height: 1.8;
	font-size: 1.8rem;
}
.keyArea .lower_bottom {
    margin: 0;
}
.keyArea .lower_bottom:before {
	content: "";
	width: 100%;
	height: 28rem;
	position: absolute;
	top: 0;
	left: 0;
    background: #A7955A;
	z-index: -1;
}


/*---------------------
　SEC01
-----------------------*/
.overlay-bg {
	display: none;
}
.overlay-bg.active {
	display: block;
	background: rgba(33,33,33,0.7);
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	z-index: 2;
}
.sec01 {
	padding: 2rem 1.5rem 8rem;
	position: relative;
	margin: 5rem 0;
}
.sec01:before {
    content: "";
	background: url("img/sec01_radius_wh.png") no-repeat;
	background-size: 100%;
	width: 19.3rem;
	height: 10rem;
    bottom: -5rem;
    right: -5rem;
}
.sec01 .flexBox {
    display: flex;
	flex-direction: column;
	justify-content: center;
}
.sec01 .cclBox {
	position: static;
	padding: 0;
	margin-bottom: 2.5rem;
}
.sec01 .cclBox:before {
	width: 30rem;
	height: 30rem;
	position: absolute;
    top: -5rem;
    left: -34%;
	transform: inherit;
}
.sec01 .cclBox:after {
	content: "";
	background: url("img/sec01_radius_top.png") no-repeat;
	background-size: 100%;
	width: 24.4rem;
	height: 22.6rem;
	position: absolute;
    top: -3.5rem;
    left: -16rem;
}
.sec01 .secTit {
	color: #fff;
	z-index: 1;
	position: relative;
}
.sec01 .secTit .small {
	font-size: 1.8rem;
	display: inline-block;
	padding: 0 1rem 0.5rem 0;
	margin: 0 0 0.8rem;
}
.sec01 .secTit .small:before {
    content: none;
}
.sec01 .secTit .big {
	font-size: 3.6rem;
}
.sec01 .sqWrap {
	display: flex;
	flex-wrap: wrap;
	gap: 0.8rem;
	width: 100%;
}
.sec01 .sqBox {
	width: calc(50% - 0.4rem);
	height: auto;
	aspect-ratio: 1 / 1;
}
.sec01 .sqBox .link {
	padding: 4rem 3rem;
	text-decoration: none;
}
.sec01 .sqBox .bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}
.sec01 .sqBox .bg:before {
	content: "";
	background: rgba(0,0,0,0.28);
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	transition: background 0.4s ease;
}
.sec01 .sqBox.on .bg:before {
	content: "";
	background: rgba(0,0,0,0.65);
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
.sec01 .sqBox .layer01 {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 1;
}
.sec01 .sqBox .layer01 .tit {
	font-size: 1.2rem;
	line-height: 1.3;
}
.sec01 .sqBox .layer01 .tit span {
	font-size: 2.2rem;
}
.sec01 .sqBox .layer02 {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 91vw;
	height: auto;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	padding: 4rem 3rem;
	border: solid 2px #A7955A;
	background: #000;
	z-index: 10;
	padding: 0;
}
.sec01 .sqBox .layer02 .txtBox {
	position: relative;
	z-index: 1;
}
.sec01 .sqBox .layer02 .btn-close {
	width: 2.7rem;
	height: 2.7rem;
	position: absolute;
	top: -4rem;
	right: 0;
	z-index: 1;
	display: block;
}
.sec01 .sqBox .layer02 .tit {
    font-family: "Cormorant Garamond", serif;
	color: #fff;
	font-size: 3.2rem;
	line-height: 1.4;
	text-align: center;
	position: relative;
	z-index: 1;
	padding-bottom: 0.6rem;
}
.sec01 .sqBox .layer02 .tit:before {
	content: "";
	background: #fff;
	width: 4rem;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}
.sec01 .sqBox .layer02 p {
	color: #fff;
	line-height: 1.5;
	font-size: 1.6rem;
}
.sec01 .sqBox .layer02 .btn-small {
	margin: 3rem auto 0;
	position: relative;
	z-index: 100;
}
.sec01 .sqBox .layer02 .btn-small {
	border: solid 1px #A7955A;
    background: url(img/arr_wh_right.png) no-repeat center right 0.8rem;
	background-color: #A7955A;
    background-size: 1.2rem auto;
    padding: 2px 20px 2px 5px;
}



/*---------------------
　SEC02
-----------------------*/
.sec02:before {
	width: 7rem;
    height: 16rem;
    top: -8rem;
    right: auto;
	left: 0;
	z-index: 1;
}
.sec02 .wi1200 {
    display: flex;
	justify-content: flex-end;
}
.sec02 .grayBox {
    width: 96%;
	background: #F5F5F5;
    padding: 8rem 0 0 0;
	position: relative;
}
.sec02 .grayBox:before {
    content: none;
	background: #fff;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: -100%;
}
.sec02 .grayBox:after {
    content: none;
}
.sec02 .artArea:before {
    content: none;
}
.sec02 .blackLabel {
    font-size: 2.4rem;
    left: 1.5rem;
    top: -2.5rem;
}
.sec02 .update {
	font-size: 1.4rem;
    text-align: left;
	margin-bottom: 3rem;
	padding: 0 0 0 2.5rem;
}
.sec02 .artSliderArea {
    display: flex;
	flex-direction: column-reverse;
	gap: 0;
	padding: 0;
}
.sec02 .artSlider {
    flex: 1;
	background: #F5F5F5;
}
.sec02 .artSlider:before {
    content: "";
	background: #F5F5F5;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	right: -100%;
}
.sec02 .slick-track {
  display: flex;
	gap: 0;
}
.sec02 .slick-slide {
  height: auto;
}
.sec02 .arrow_box {
	width: auto;
	display: flex;
	flex-direction:row;
	align-items: center;
	justify-content: center;
	background: #fff;
	padding: 3rem 2rem 0 0;
}
.sec02 .slick-arrow {
	width: 4rem;
	height: 4rem;
}
.sec02 .slick-arrow:hover {
	opacity: 1;
}
.sec02 .slick-num {
	display: flex;
	flex-direction:row;
	align-items: center;
	margin: 0 4rem;
	gap: 3rem;
}
.sec02 .slick-num .all-count {
	position: relative;
}
.sec02 .slick-num .all-count:before {
	content: "";
	background: #212121;
	width: 1px;
	height: 12px;
	position: absolute;
	top: 50%;
	left: -15px;
	transform: translateY(-50%);
}
.sec02 .artBox {
    width: 100%;
	max-width: 35rem;
	padding: 0 2.5rem 0 2rem;
	margin: 0 0 3rem;
}
.sec02 .artBox a {
    display: flex;
	flex-direction: column;
}
.sec02 .artBox .titBox {
    display: flex;
	margin-bottom: 2rem;
}
.sec02 .artBox .rankccl {
    width: 4.2rem;
    height: 4.2rem;
    font-size: 1.5rem;
    margin-right: 15px;
}
.sec02 .artBox .rankccl > div {
	line-height: 2.6;
}
.sec02 .artBox .rankccl span {
    font-size: 3.7rem;
	line-height: 1;
}
.sec02 .artBox .artTit {
    font-size: 2.6rem;
	flex: 1;
	padding: 0 0 0.5rem;
}
.sec02 .artBox .picBox {
    width: 100%;
    margin-right: 0;
	background: #F5F5F5;
	padding: 0 0 5px;
}
.sec02 .artBox .picBox img {
    width: 100%;
    height: auto;
    object-fit: cover;
	aspect-ratio: 392 / 210;
}
.sec02 .artBox .caption {
    padding: 0 1rem;
}

/*---------------------
　SEC03
-----------------------*/
.sec03 {
	margin: 9rem 0 8rem;
	padding: 4rem 1.5rem 0;
}
.sec03 .sec03Inr:before {
	height: 48%;
}
.sec03 .twoColTitBox {
}
.sec03 .twoColTitBox:after {
	width: 17.7rem;
	height: 34.5rem;
    top: -20rem;
    left: -5rem;
}
.sec03 .cardWrap {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	gap: 2rem;
}
.sec03 .cardBox {
	width: 100%;
	max-width: 100%;
}
.sec03 .cardBox .pic {
}
.sec03 .cardBox .pic:before {
	content: "";
	background: url("img/sec03_grad.png") no-repeat bottom;
	background-size: 100%;
	width: 100%;
	height: 10.5rem;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 1;
}
.sec03 .cardBox img {
	width: 100%;
	height: auto;
	aspect-ratio: 343 / 136;
	object-fit: cover;
}
.sec03 .cardBox a:hover img {
	transform: inherit;
}
.sec03 .cardBox .cardTit {
	font-size: 2.2rem;
	border-left: solid 1px #fff;
	padding: 0 6rem 0 1.5rem;
	line-height: 1.3;
	position: absolute;
	bottom: 1.5rem;
	left: 1.5rem;
	background: url("img/arr_ccl_wh_right.png") no-repeat center right 2rem;
	background-size: 2.5rem auto;
	min-height: inherit;
	width: calc(100% - 1.5rem);
}


/*---------------------
　SEC04
-----------------------*/
.sec04 {
	margin: 0 0 10rem;
}
.sec04 .wi1200 {
	padding: 4rem 0 0;
}
.sec04 .wi1200:before {
	content: "";
	background: #212121;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 65vw;
}
.sec04 .wi1200:after {
	content: "";
	background: #212121;
	position: absolute;
	top: 0;
	right: -100%;
	width: 100%;
	height: 50%;
}
.sec04 .twoColTitBox {
	padding: 0 1.5rem;
	position: relative;
}
.sec04 .twoColTitBox:after {
	width: 17.7rem;
	height: 34.4rem;
    top: -9rem;
    right: 2rem;
}
.sec04 .caseSlider {
	padding: 0 1.5rem;
}
.sec04 .slick-track {
	display: flex;
	gap: 1rem;
}
.sec04 .caseBox {
	width: 100%;
	margin: 0;
	display: flex;
	height: auto;
}
.sec04 .caseBox a {
}
.sec04 .caseBox .caseTit {
	font-size: 2.8rem;
	position: relative;
	margin: 0 auto;
	margin-bottom: 2.3rem;
	display: table;
}
.sec04 .caseBox .caseTit:before {
	content: "";
	background: #fff;
	width: 1px;
	height: 2.3rem;
	position: absolute;
	bottom: -2.3rem;
	left: 50%;
}
.sec04 .caseBox .caseTit:after {
	content: "";
	background: #A2081D;
	width: 2rem;
	height: 2rem;
	position: absolute;
	top: 0rem;
	left: -0.8rem;
	border-radius: 50%;
	z-index: -1;
}
.sec04 .caseBox .thumb {
}
.sec04 .caseBox .thumb img {
	width: 100%;
	height: auto;
	aspecr-tatio: 34 / 24;
	object-fit: cover;
}
.sec04 .caseBox .caption {
	padding: 0 1.5rem;
}
.sec04 .caseBox .txtBody {
	padding: 2rem 2rem 3rem;
}
.sec04 .caseBox .catch {
	font-size: 2.2rem;
	line-height: 1.5;
	border-bottom: solid 1px #212121;
	padding: 0 0 1.5rem;
	position: relative;
}
.sec04 .caseBox .catch:before {
	content: none;
}
.sec04 .caseBox .btnWrap {
}
.sec04 .caseBox .btn-small {
}
.sec04 .slick-arrow {
	position: absolute;
	top: 16rem;
	width: 4rem;
	height: 4rem;
}
.sec04 .slick-arrow:hover {
	opacity: 1;
}
.sec04 .slick-prev {
	left: 0.5rem;
}
.sec04 .slick-next {
	right: 0.5rem;
}
.sec04 .slick-dots {
	gap: 2rem;
	margin: 3rem 0 0;
}
.sec04 .slick-dots li:hover {
	opacity: 1;
}


/*---------------------
　SEC05
-----------------------*/
.sec05 {
	margin-top: 5rem;
}
.sec05 .wi1200 {
	background: #F5F5F5;
	position: relative;
	padding: 0 1.5rem 5rem;
}
.sec05 .titBox {
	position: relative;
    top: auto;
}
.sec05 .blaLabelTit {
	top: -2.3rem;
	margin-bottom: 0;
}
.sec05 .lead {
	width: 100%;
	line-height: 1.5;
	border-left: solid 1px #212121;
	padding: 0 0 0 2rem;
	margin: 0;
}
.sec05 .picBox {
	margin: 3rem auto 0;
	padding: 2rem 2rem 2rem;
}



/*---------------------
　SEC06
-----------------------*/
.sec06 {
	padding: 8rem 1.5rem 0;
}
.sec06 .itemBoxWrap {
	display: flex;
	justify-content: center;
	flex-direction: column;
	gap: 3rem;
	margin-bottom: 5rem;
}
.sec06 .itemBox {
	width: 100%;
	display: flex;
	gap: 3rem;
}
.sec06 .itemBox .ccl {
	width: 11.2rem;
}
.sec06 .itemBox .txtBox {
	flex: 1;
}
.sec06 .itemBox .ediName {
    font-family: "Cormorant Garamond", serif;
	font-size: 2.2rem;
	padding: 0;
	text-align: left;
	margin-bottom: 1rem;
}
.sec06 .itemBox .ediName:before {
	content: "";
	background: #212121;
	width: 16px;
	height: 1px;
	position: absolute;
	top: 50%;
	left: -2.5rem;
}
.sec06 .itemBox p {
	font-size: 1.4rem;
	color: #646464;
}
.sec06 .btn-link {
	text-align: center;
}
.sec06 .btn-link a {
	font-size: 1.8rem;
}

.contents .btn-link_text {
	width: 100%;
	text-align: right;
}	
.contents .btn-link_text a {
	font-family: "Inter", sans-serif;
	background: url(img/arr_ccl_bla_right.png) no-repeat right center;
    background-size: 3.2rem auto;
    position: relative;
    display: inline-block;
    padding: 0.8rem 4.5rem 0.8rem 0;
    line-height: 1.6;
    text-decoration: underline;
    font-weight: 700;
	border: none;
	border-radius: 0;
	min-height: inherit;
}	
	
	
}



@media screen and (max-width: 599px) {
.sec04 .wi1200:before {
	height: auto;
	aspect-ratio: 2 / 3;
}
}