@charset "UTF-8";


.area-wrapper {}

.common-header {
	background-color: #6ac264;
	background: url(../images/bg.png);
	background-position: center center;
	background-repeat: repeat;
	background-size: 25rem auto;
	box-shadow: 0 1.5rem 1.5rem 0 rgb(0 0 0 / 15%);
	display: flex;
	padding: 1rem;
	align-items: center;
	margin: auto;
	min-width: 37.5rem;
}

.common-header .to-home[onclick],
.common-header .to-home[href] {
	display: block;
}

.common-header .to-home img {
	height: 1.5rem;
	zoom: 1;
}

.common-header .title {
	flex: 1 1 auto;
	color: #fff;
	line-height: 1.2;
	font-size: 1.6rem;
	font-weight: 700;
	text-align: left;

}


.common-body {
	padding: 0 0 1rem;
}


.rectBox {
	margin: 0 auto 2.5rem;
	border-radius: 1.5rem;
	/* padding: 0.7rem 1rem; */
	display: block;
	width: 35rem;
	background: #fff;
	box-shadow: .1rem .25rem 0.5rem 0.3rem rgba(0, 0, 0, 0.1);
	overflow: hidden;
}

.rectBox.top-content {
	background-color: #70c5c3;
	/* width: 37.5rem; */
	width: auto;
	border-radius: 0;
	box-shadow: inset 0 0rem 0.5rem 0.3rem rgba(0, 0, 0, 0.1);
}


.top-content-wrap {
	width: 37.5rem;
	margin: auto;
	background-image: url(../images/point_info_bg1.png), url(../images/point_info_bg2.png);
	background-position: center top, center bottom;
	background-size: contain, contain;
	background-repeat: no-repeat, no-repeat;
	padding: 4rem 1rem 12rem;
}

.top-content h1 {
	color: #fff;
	font-size: 3rem;
	font-weight: 900;
	line-height: 1.3;
	position: relative;
	text-shadow: 0.2rem 0.2rem 0.2rem rgba(0, 0, 0, 0.2);
}

.top-content h1::before {
	position: absolute;
	content: '';
	width: 1rem;
	height: 10rem;
	background: #fff;
	clip-path: polygon(0 0, 100% 0, 70% 100%, 30% 100%);
	left: 0;
	top: 3.5rem;
	transform-origin: left top;
	transform: rotate(-11deg);
}

.top-content h1::after {
	position: absolute;
	content: '';
	width: 1rem;
	height: 10rem;
	background: #fff;
	clip-path: polygon(0 0, 100% 0, 70% 100%, 30% 100%);
	right: 0;
	top: 3.5rem;
	transform-origin: right top;
	transform: rotate(11deg);
}

.top-content h1 em {
	color: #ffeb3d;
	font-size: 4rem;
	/* text-shadow: 0.5px 0 currentColor,
		-0.5px 0 currentColor,
		0 0.5px currentColor,
		0 -0.5px currentColor; */
}

.top-content h1 .point {
	position: relative;
}

.top-content h1 .point::after {
	content: '';
	background: url(../images/point.png) no-repeat;
	background-size: contain;
	width: 1.5rem;
	height: 1.5rem;
	position: absolute;
	right: -0.3rem;
	top: 0.8rem;
	filter: drop-shadow(0.2rem 0.2rem 0.1rem rgba(0, 0, 0, 0.2));
}

.top-content .description {
	margin: 2.5rem 1rem 1rem;
	text-align: left;
}

.top-content p {
	margin: 0 auto 2rem;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.5;
}



.store-icon {
	margin: 2rem auto;
	width: 10rem;
	height: 10rem;
	border-radius: 20%;
	overflow: hidden;
	box-shadow: 0 1.5rem 1.5rem 0 rgb(0 0 0 / 15%);
}

.store-icon img {
	zoom: 1;
	width: 100%;
}


.store-badge {
	display: flex;
	padding: 1rem 2rem;
	gap: 2rem;
	flex-wrap: nowrap;
	align-items: center;
}

.store-badge li {
	flex: 1 1 auto;
	height: 4.5rem;
}

.store-badge li a {
	display: block;
	width: 100%;
	height: 100%;

}

.store-badge li img {
	width: auto;
	height: 100%;
	zoom: 1;
}






.rectBox .app-image {
	background-color: #c6da95;
	box-shadow: 0rem 0rem 0.3rem 0.1rem rgba(0, 0, 0, 0.05);
}

.rectBox .app-image.green {
	background-color: #6ac264;
}

.rectBox .app-image.blue {
	background-color: #79b6ca;
}

.rectBox .app-image.gray {
	background-color: #ced5d4;
}


.rectBox .app-image img {
	width: 100%;
}


.rectBox .discription {
	padding: 1rem 1.5rem 1.5rem;
}

.rectBox .discription .section+.section {
	margin-top: 2rem;
}

.rectBox .discription .title {
	color: #459640;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 700;
	margin: 1rem auto 1rem;
}

.rectBox .discription .title .titleIco {
	display: inline-block;
	zoom: 1;
	height: 2.5rem;
	vertical-align: baseline;
	transform: translateY(0.6rem);
	margin-right: 0.2rem;
}

.rectBox .discription p {
	font-size: 1.4rem;
	text-align: left;
	line-height: 1.7;
}


.rectBox .discription p.note {
	line-height: 1.3;
}

.rectBox .discription p.note .sub {
	font-size: 1.1rem;
	line-height: 1.3;
}

.rectBox .discription p em {
	color: #459640;
}

.rectBox .discription p .mainIco {
	display: inline-block;
	border-radius: 100rem;
	background-color: #459640;

	box-shadow: 0 0.1rem 0.1rem 0.1rem rgba(0, 0, 0, 0.1);
	width: 2.5rem;
	height: 2.5rem;
	margin: 0 0.2rem;
	text-align: center;
	padding: 0;
	vertical-align: bottom;
}

.rectBox .discription p .mainIco.space {
	padding: 0.3rem;
}

.rectBox .discription p .mainIco img {
	vertical-align: baseline;
	text-align: center;
	width: 100%;

}


.rectBox .discription p .ico {
	display: inline-block;
	width: 1.4rem;
	height: 1.4rem;
	margin: 0 0.2rem;
	text-align: center;
	padding: 0;
	vertical-align: baseline;
	transform: translateY(0.1rem);
}

.rectBox .discription p em .ico {
	display: inline-block;
	width: 1.8rem;
	height: 1.8rem;
	margin: 0 0.2rem;
	text-align: center;
	padding: 0;
	vertical-align: baseline;
	transform: translateY(0.45rem);
}


.rectBox .discription p .ico img {
	vertical-align: inherit;
	text-align: center;
	width: 100%;
}

.rectBox .discription p+p {
	margin-top: 2rem;
}

.rectBox .discription p+p.note {
	margin-top: 0;
}


.rectBox .priceTable {
	/* background-color: #F6FaF6; */
	font-size: 1.4rem;
	width: 95%;
	margin: 1.5rem auto 0.5rem;
}

.rectBox .priceTable thead th {
	color: #459640;
	font-weight: 500;
	font-size: 1.2rem;
	text-align: right;
	padding: 0.5rem 0.3rem;

}

.rectBox .priceTable tbody th {
	border-bottom: 1px solid #aaa;
	padding: 0.5rem 0.3rem;
}

.rectBox .priceTable tbody td {
	text-align: right;
	border-bottom: 1px solid #aaa;
	padding: 0.5rem 0.3rem;
}


.rectBox .noteArea {
	border: 0.1rem #6ac264 solid;
	border-radius: 0.2rem;
	font-size: 1.3rem;
	width: 98%;
	margin: 1.5rem auto 1.0rem;
	padding: 1rem 1.5rem;
}

.rectBox .noteArea ul {
	text-align: left;
	margin: 1rem auto;
}

.rectBox .noteArea li {
	color: #459640;
}

.rectBox .noteArea li::before {
	content: '- ';

}

.flexArea {
	display: flex;
	gap: 2rem;
	padding: 1rem 1rem 1.5rem;
	align-items: center;
}

.circleImage {
	flex: 1 1 auto;
	border-radius: 37.5rem;
	background-color: #9fc1c4;
	overflow: hidden;
	aspect-ratio: 1;
	display: flex;
	align-items: flex-end;
	box-shadow: .1rem .1rem 0.3rem 0.3rem rgba(0, 0, 0, 0.1);
}

.circleImage.squarePrint {
	padding: 1.5rem 0 0 0;
	background-color: #79b6ca;
}

.circleImage.photoBook {
	padding: 1.5rem 0 0 0;
	background-color: #e1c58c;
}

.circleImage img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
}

.circleImage.squarePrint img,
.circleImage.photoBook img {
	width: 98%;
	height: 98%;
	object-fit: cover;
	object-position: bottom;
}


/*
	footer
=========================================*/
footer {
	position: relative;
	z-index: 1;
	margin: 2rem auto 0;
	border-top: 0.4rem solid #fff;
	background: url(../images/bg.png);
	background-color: #6ac264;
	background-position: center center;
	background-repeat: repeat;
	background-size: 25rem auto;
	box-shadow: 0 -0.5rem 1.5rem 0 rgb(0 0 0 / 10%);


}

footer .wrapper {
	width: 37.5rem;
	margin: auto;
	padding: 2.2rem 0 0;
	position: relative;
	color: #fff;
}

footer .wrapper::after {
	content: "";
	display: block;
	position: absolute;
	width: 4.8rem;
	height: 4.45rem;
	background: url(../images/header_ornaments_pin.png) no-repeat;
	background-size: contain;
	left: 0.9rem;
	top: -1.25rem;
}

footer .heading {
	width: 24rem;
	margin: auto auto 2rem;
}


footer .nav {
	margin: 3rem auto 0;

}

footer .nav li {
	margin-top: 1.5rem;
}

footer .nav li:first-child {
	margin-top: 0;
}

footer .nav li a[href] {
	color: #fff;
	font-weight: 500;
	font-size: 1.8rem;

}

footer .copy {
	background-size: contain;
	color: #fff;
	font-size: 1.3rem;
	margin: 3rem;
	padding-bottom: 3rem;
}