@charset "UTF-8";
html,
body {
	width: 100%;
	font-size: 16px;
	margin: 0 auto;
	color: #2d0c07;
	background-color: #fcf9f5;
}

body {
	overflow-x: hidden;
}

img {
	width: 100%;
	height: auto;
	display: block;
}

a {
	display: block;
	text-decoration: none;
	transition: all 0.4s;
	color: #2d0c07;
}
@media screen and (min-width: 769px) {
	a:hover {
		opacity: 0.6;
		transition: all 0.4s;
	}
}

*, *::before, *::after {
  box-sizing: border-box;
}


/*---------------- indention ----------------*/
@media screen and (min-width: 768px){   
	.pcline-break { display:block; }
	.spline-break { display:none; }
}
@media screen and (max-width: 767px){   
	.pcline-break { display:none; }
	.spline-break { display:block; }
}


/* ---------------------------------------------------------
	item wapper
----------------------------------------------------------*/
.item-wapper {
	width: 100%;
	padding: 0;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 210px;
}
.item-wapper img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

.item-wapper-mid {
	width: 100%;
	padding: 0;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 120px;	
}
.item-wapper-mid img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

.item-wapper-small {
	width: 100%;
	padding: 0;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 90px;
}
.item-wapper-small img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

.item-wapper-tiny {
	width: 100%;
	padding: 0;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 30px;
}
.item-wapper-tiny img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

.item-wapper-pnk {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 90px;
}
.item-wapper-pnk img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
.pnk-wapper-inner {
	width: 100%;
	padding: 60px 0 30px;
	margin: 0 auto;
	background-color: #f5eae9;
}


.item-wapper-yel {
	width: 100%;
	height: 100%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 90px;
}
.item-wapper-yel img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
.yel-wapper-inner {
	width: 100%;
	padding: 60px 0 30px;
	margin: 0 auto;
	/*background-color: #f0f7f6;*/
	background-color: #e9eff8;
}

/*---------------- PC ----------------*/
@media screen and (min-width: 768px) {
	.item-wapper {
		max-width: 600px;
		margin-bottom: 350px;
	}
	.item-wapper-mid {
		max-width: 600px;
		margin-bottom: 300px;	
	}
	.item-wapper-small {
		max-width: 600px;
		margin-bottom: 120px;
	}
	.item-wapper-tiny {
		max-width: 600px;
		margin-bottom: 60px;
	}
	.item-wapper-pnk {
		max-width: 600px;
		margin-bottom: 120px;
	}
	.pnk-wapper-inner {
		width: 100vw;
		margin: 0 calc(50% - 50vw);
		padding: 120px 0 60px;
	}	
	.item-wapper-yel {
		max-width: 600px;
		margin-bottom: 120px;
	}
	.yel-wapper-inner {
		width: 100vw;
		margin: 0 calc(50% - 50vw);
		padding: 120px 0 60px;
	}	
}


/* ---------------------------------------------------------
	hero img
----------------------------------------------------------*/
.hero__staticimg {
	padding: 0;
	width: 100%;
	height: auto;
	margin-left: auto;
	margin-right: auto;
	margin-top: 0px;
	margin-bottom: 120px;
	position: relative;
}
.hero__staticimg img {
	max-width: 100%;
	height: auto;
}

/*---------------- TB ----------------*/
@media screen and (min-width: 768px) and ( max-width: 959px) {
	.hero__staticimg {
		width: 100%;
		max-width: 1500px;
		height:auto;
		margin-top: 0px;
		margin-bottom: 150px;		
	}
}

/*---------------- PC ----------------*/
@media screen and (min-width: 960px) {
	.hero__staticimg {
		width: 100%;
		height: auto;
		margin-top: -90px;
		margin-bottom: 180px
	}
}


/* ---------------------------------------------------------
	sec#01
----------------------------------------------------------*/
.twoimg__inner {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	z-index: 10;
}

.twoimg_uneven_hori__box {
	width: 100%;
	margin-bottom: 60px;
	display: flex;
	justify-content: space-between;
}
.twoimg_uneven_hori__left {
	width: 53.8%;
}
.twoimg_uneven_hori__right {
	width: 43.2%;
	align-self: flex-end;
}

.twoimg_uneven_hori__revbox {
	width: 92.3%;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}
.twoimg_uneven_hori__widebox {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}
.twoimg_uneven_hori__revleft {
	width: 53.8%;
}
.twoimg_uneven_hori__revright {
	width: 43.2%;
}


/*---------------- PC ----------------*/
@media screen and (min-width: 960px) {
	.twoimg_uneven_hori__box {
		margin-bottom: 120px;
	}
	.twoimg_uneven_hori__revbox {
		max-width: 600px;
		width: 92.3%;
		margin-bottom: 60px;
	}
	.twoimg_uneven_hori__revboxmbts {
		margin-bottom: 120px;
	}
}


/* ---------------------------------------------------------
	sec#02
----------------------------------------------------------*/
.fourimg__box {
	width: 92.3%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 20px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	row-gap: 12px;
}

.fourimg__item {
	width: 48.5%;
}


.two_col__horizon__warp {
	width: 92.3%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 20px;
	position: relative;
}

.two_col__horizonimg {
	width: 100%;
	margin-left: auto;
	display: flex;
	justify-content: space-between;
	line-height: 0;
	font-size: 0;
}
.two_col__horizonimg img {
	width: 100%;
	height: auto;
	object-fit: cover;
}

.two_col__item {
	width: 50%;
}

.two_col__midimg {
	width: 48.5%;
}


.ruptwoimg__warp {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 60px
}
.ruptwoimg__box {
	display: grid;
	grid-template-columns: 50% 50%;
	grid-template-rows: auto;
	grid-column-gap: 0px;
	grid-row-gap: 0px;
}
.ruptwoimg__right {
	grid-area: 1 / 2 / 3 / 3;
}
.ruptwoimg__left {
	grid-area: 2 / 1 / 4 / 2;
}

.two_col__hori__warp {
	width: 84.6%;
	margin-left: auto;
	margin-right: auto;	
}

.two_col__hrzn__warp {
	width: 92.3%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 30px;
}

/*---------------- PC ----------------*/
@media screen and (min-width: 960px) {
	.fourimg__box {
		max-width: 600px;
		width: 92.3%;
		margin-bottom: 30px;
		row-gap: 18px;
	}	
	.ruptwoimg__warp {
		margin-top: 120px;
		margin-bottom: 120px
	}
	.two_col__hrzn__warp {
		margin: 120px auto;
	}
}


/* ---------------------------------------------------------
	sec#03
----------------------------------------------------------*/
.twoimg_uneven_alnt__box {
	width: 100%;
	margin-bottom: 60px;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.twoimg_uneven_alnt__left {
	width: 43.2%;
}
.twoimg_uneven_alnt__right {
	width: 53.8%;
}

.twoimg_vertical__box {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	row-gap: 0px;
	position: relative;
}

.twoimg_vert_mid__item {
	width: 61.5%;
	margin-left: auto;
	margin-right: auto;
}

.center_slide__mediumbox {
	width: 76.9%;
	margin-left: auto;
	margin-right: auto;
}

.centerslide__midbox {
	width: 61.5%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 20px;
}
.centerslide__lrgbox {
	width: 76.9%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 60px;
}
.centerslide__widebox {
	width: 92.3%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 30px;
}

/*---------------- PC ----------------*/
@media screen and (min-width: 960px) {
	.twoimg_vertical_row__box {
		row-gap: 40px;
	}
	.centerslide__midbox {
		margin-bottom: 30px;
	}
	.centerslide__widebox {
		max-width: 600px;
		width: 92.3%;
		margin-bottom: 60px;
	}
}



/* ---------------------------------------------------------
	sec#04
----------------------------------------------------------*/
.lup_twoimg__box {
	display: grid;
	grid-template-columns: 46.2% 53.8%;
	grid-template-rows: 50px 50px 100px auto auto;
	grid-column-gap: 0px;
	grid-row-gap: 0px;
}
.lup_twoimg__left { 
	grid-area: 1 / 1 / 4 / 2;
	align-self: start;
}
.lup_twoimg__right {
	grid-area: 3 / 2 / 6 / 3;
	align-self: end;
}
.lup_twoimg__prc {
	grid-area: 5 / 1 / 6 / 2;
	align-self: end;
	padding-left: 1em;
}

/*---------------- PC ----------------*/
@media screen and (min-width: 960px) {
	.lup_twoimg__prc {
		padding-left: 0em;
	}
}


/* ---------------------------------------------------------
	subheading
----------------------------------------------------------*/
.subheading__sec01 {
	width: 30.8%;
	position: absolute;
	right: 1.6%;
	top: 0%;
	z-index: 70;
}

.subheading__sec03 {
	width: 30.8%;
	position: absolute;
	left: 1.6%;
	top: 0%;
	z-index: 70;	
}

/*---------------- PC ----------------*/
@media screen and (min-width: 960px) {
	.subheading__sec01 {
		width: 53.8%;
		right: 0%;
		top: 2%;
	}
	.subheading__sec03 {
		width: 53.8%;
		left: 0%;
		top: 2%;
	}
}


/* ---------------------------------------------------------
	swiper
----------------------------------------------------------*/
.swiper img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;	
}

/*---------------- PC ----------------*/
@media screen and (min-width: 960px) {

}


/* ---------------------------------------------------------
	price box
----------------------------------------------------------*/
.large_prc__box {
	width: 76.9%;
	margin-left: auto;
	margin-right: auto;
}
.center_prc__largebox {
	width: 76.9%;
	margin-left: auto;
	margin-right: auto;
}
.right_prc__box {
	width: 84.6%;
	margin-left: auto;
	margin-right: auto;
}
.right_prc__midbox {
	width: 84.6%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 30px;
}
.center_price__box {
	width: 69.2%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 30px;
}
.center_price__midbox {
	width: 84.6%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 30px;
}
.center_leftprice__box {
	width: 80.75%;
	margin-left: 19.25%;
	margin-top: 30px;	
}


/*---------------- TB ----------------*/
@media screen and (min-width: 768px) {
	.large_prc__box {
		width: 50%;
	}
	.center_prc__largebox {
		width: 55%;
	}
	.center_price__midbox {
		width: 55%;
	}
	.center_price__box {
		width: 60%;
	}
}


/*---------------- PC ----------------*/
@media screen and (min-width: 960px) {
	.large_prc__box {
		max-width: 600px;
		width: 30%;
	}
	.center_prc__largebox {
		width: 70%;
	}
	.center_price__midbox {
		max-width: 600px;
		width: 40%;
	}
	.right_prc__box {
		margin-left: 30%;
	}
	.center_price__box {
		width: 60%;
	}
}


/* ---------------------------------------------------------
	items center
----------------------------------------------------------*/
.items_price_center {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	z-index: 20;
}
.items_price_center li {
	font-size: clamp(0.8125rem, calc(0.5rem + 1.5625vw), 1.4375rem);
	line-height: 1;
	letter-spacing: 0.05em;
	color: #2d0c07;
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
}

.items_price_center li:nth-child(even) {
	padding-left: 1em;
}

.items_price_center li:nth-child(n+3) {
	padding-top: 1em;
}

.items_price_center a {
	font-size: clamp(0.8125rem, calc(0.5rem + 1.5625vw), 1.4375rem);
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
	color: #2d0c07;
	letter-spacing: 0.05em;
	text-decoration: underline;
	text-decoration-color: #2d0c07;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.25ex;
	text-decoration-skip-ink: none;
	white-space: nowrap;
}


/* ---------------------------------------------------------
	items center
----------------------------------------------------------*/
.items_price_center_col {
	list-style: none;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.items_price_center_col li {
	font-size: clamp(0.8125rem, calc(0.5rem + 1.5625vw), 1.4375rem);
	line-height: 1;
	letter-spacing: 0.05em;
	color: #2d0c07;
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 300;
}

.items_price_center_col li:not(:first-child) {
	padding-top: 1em;
}

.items_price_center_col a {
	ffont-size: clamp(0.8125rem, calc(0.5rem + 1.5625vw), 1.4375rem);
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
	color: #2d0c07;
	letter-spacing: 0.05em;
	text-decoration: underline;
	text-decoration-color: #2d0c07;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.25ex;
	text-decoration-skip-ink: none;
	white-space: nowrap;
}

/* ---------------------------------------------------------
	list left
----------------------------------------------------------*/
.items_price_left_col {
	list-style: none;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.items_price_left_col li {
	font-size: clamp(0.8125rem, calc(0.5rem + 1.5625vw), 1.4375rem);
	line-height: 1;
	letter-spacing: 0.05em;
	color: #2d0c07;
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
}

.items_price_left_col li:not(:first-child) {
	padding-top: 1em;
}

.items_price_left_col a {
	font-size: clamp(0.8125rem, calc(0.5rem + 1.5625vw), 1.4375rem);
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
	color: #2d0c07;
	letter-spacing: 0.05em;
	text-decoration: underline;
	text-decoration-color: #2d0c07;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.25ex;
	text-decoration-skip-ink: none;
	white-space: none;
}


/* ---------------------------------------------------------
	list right
----------------------------------------------------------*/
.items_price_right_col {
	list-style: none;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
}
.items_price_right_col li {
	font-size: clamp(0.8125rem, calc(0.5rem + 1.5625vw), 1.4375rem);
	line-height: 1;
	letter-spacing: 0.05em;
	color: #2d0c07;
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
}
.items_price_right_col li:not(:first-child) {
	padding-top: 1em;
}

.items_price_right_col a {
	font-size: clamp(0.8125rem, calc(0.5rem + 1.5625vw), 1.4375rem);
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
	color: #2d0c07;
	letter-spacing: 0.05em;
	text-decoration: underline;
	text-decoration-color: #2d0c07;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.25ex;
	text-decoration-skip-ink: none;
	white-space: none;
}


/* ---------------------------------------------------------
	yen
----------------------------------------------------------*/
.price_yen {
	font-size: clamp(0.625rem, calc(0.4375rem + 0.9375vw), 1rem);
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
	color: #2d0c07;
	font-feature-settings: "palt" 1;
}

.line_br {
	width: 100%;
}


/* ---------------------------------------------------------
	item btn
----------------------------------------------------------*/
.itembtn_wapper {
	text-align: center;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
}

.itemlk {
	display: inline-block;
	width: 100%;
	padding: 1.25em 0;
	margin: 0 auto;
	border: 1px #2d0c07 solid;
	border-radius: 100px;
	transition: all .3s ease-out;
}

.itemlk a {
	font-size: clamp(0.8125rem, calc(0.5rem + 1.5625vw), 1.4375rem);
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
	letter-spacing: 0.8em;
	color: #2d0c07;
	text-decoration: none;
	vertical-align: middle;
}

/* --------------- PC --------------- */
@media screen and (min-width: 768px) {
	.itembtn_wapper {
		width: 90%;
	}
	.itemlk {
		padding: 2em 1em;
	}
}


/* ---------------------------------------------------------
	footer
----------------------------------------------------------*/
footer {
	/* background-color: #aec4d8; */
	background-image: url("../images/footer_bg_img.jpg");
	background-repeat:  no-repeat; 
	background-size: cover;
	margin: 0 auto;
	padding: 60px 0 40px;
	width: 100%;
	max-width: 9999px;
	z-index: 10;
	color: #2d0c07;
}
footer #footer__box {
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding: 40px 0 20px;
}
footer #niceclaup_logo {
	width: 25%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 1em;
}
footer #footer__box {
	width: 100%;
	margin: 0 auto;
	padding: 40px 0 20px;
}
footer #niceclaup_logo {
	width: 25%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 1em;
}
footer .footer__p {
	display: block;
	text-align: center;
	color: #2d0c07;
	font-size: clamp(1.4375rem, calc(1.3920454545454546rem + 0.22727272727272727vw), 1.5625rem);
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 600;
	letter-spacing: 0.15em;
	line-height: 1.5;
}
footer .footer__txtlink {
	display: block;
	padding: 1em 0 4em;
	text-align: center;
}
footer .footer__txtlink a {
	text-align: center;
	font-family: "Noto Serif JP", serif;
	font-style: normal;
	font-weight: 400;
	letter-spacing: 0.2em;
	font-size: clamp(1rem, calc(0.9318181818181819rem + 0.3409090909090909vw), 1.1875rem);
	line-height: 1;
	color: #2d0c07;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2ex;
	text-decoration-skip-ink: none;
}
footer .footer_r {
	display: block;
	text-align: center;
	color: #2d0c07;
	font-size: clamp(0.6875rem, calc(0.6420454545454546rem + 0.22727272727272727vw), 0.8125rem);
	padding-top: 1em;
	line-height: 1;
	font-family: "garamond-premier-pro", serif;
	font-style: normal;
	font-weight: 400;
	font-feature-settings: "palt" 1;
}
footer #sns__area {
	list-style: none;
	width: 70%;
	margin-left: auto;
	margin-right: auto;
	padding: 20px 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	column-gap: 15px;
}
footer #sns__area li {
	width: calc(100% / 4 - 35px);
}

/*---------------- TB ----------------*/
@media screen and (min-width: 768px) and ( max-width: 959px) {
	footer #niceclaup_logo {
		width: 15%;
	}
	footer #sns__area {
		width: 40%;
		column-gap: 15px;
	}
	footer #sns__area li {
		width: calc(100% / 4 - 45px);
	}
}

/*---------------- PC ----------------*/
@media screen and (min-width: 960px) {
	footer #niceclaup_logo {
		width: 10%;
	}
	footer #sns__area {
		width: 40%;
		column-gap: 110px;
	}
	footer #sns__area li {
		width: calc((100% / 4 - 330px) 960 * 100vw);
	}
}