@charset "utf-8";

html {
	overflow-y: scroll;
	-webkit-text-size-adjust: none;
	-webkit-tap-highlight-color: transparent;
	font-size: 62.5%;
}

body {
	margin: 0;
	padding: 0;
	background: #f7f4ed;
	color: #000;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	font-size: 1.0rem;
	font-weight: normal;
	line-height: 1.5;
	overflow-wrap: anywhere;
	word-break: normal;
	line-break: strict;
}

article, aside, dialog, figure, footer, header, hgroup, nav, section, main {
	display: block;
}

body, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, article, aside, dialog, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

address,caption,cite,code,dfn,em,strong,th,var {
	font-weight: normal;
	font-style: normal;
}

ul, ol, li {
	list-style: none;
}

dt {
	font-weight: normal;
}

h1, h2, h3, h4, h5, h6 {
	font-size: inherit;
	font-weight: inherit;
}

hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
	border-top-width: 1px;
	margin: 0;
	clear: both;
	color: inherit;
}

pre {
	font-family: monospace, monospace;
	font-size: inherit;
}

address {
	font-style: inherit;
}

abbr[title] {
	text-decoration: underline dotted;
}

b,
strong {
	font-weight: bolder;
}

code,
kbd,
samp {
	font-family: monospace, monospace;
	font-size: inherit;
}

small {
	font-size: 100%;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

svg,
img,
embed,
object,
iframe {
	vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
	-webkit-appearance: none;
	appearance: none;
	vertical-align: middle;
	color: inherit;
	font: inherit;
	background: transparent;
	padding: 0;
	margin: 0;
	border-radius: 0;
	text-align: inherit;
	text-transform: inherit;
}

[type="checkbox"] {
	-webkit-appearance: checkbox;
	appearance: checkbox;
}

[type="radio"] {
	-webkit-appearance: radio;
	appearance: radio;
}

input:focus,
textarea:focus,
select:focus {
	outline: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
	cursor: pointer;
}

button:disabled,
[type="button"]:disabled,
[type="reset"]:disabled,
[type="submit"]:disabled {
	cursor: default;
}

:-moz-focusring {
	outline: auto;
}

select:disabled {
	opacity: inherit;
}

option {
	padding: 0;
}

fieldset {
	margin: 0;
	padding: 0;
	min-width: 0;
}

legend {
	padding: 0;
}

progress {
	vertical-align: baseline;
}

textarea {
	overflow: auto;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

[type="search"] {
	outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

label[for] {
	cursor: pointer;
}

details {
	display: block;
}

summary {
	display: list-item;
}

[contenteditable]:focus {
	outline: auto;
}

table {
	border-color: inherit;
	border-collapse: collapse;
}

caption {
	text-align: left;
}

td,
th {
	vertical-align: top;
	padding: 0;
}

th {
	text-align: left;
	font-weight: bold;
}

img {
	width: 100%;
	height: auto;
	border-style: none;
	vertical-align: top;
	font-size: 0;
	line-height: 0;
}

a {
	text-decoration: none;
	color: inherit;
	outline: none;
}

a:focus {
	outline: none;
}

a {
	transition-property: all;
	transition-duration: 0.5s;
}

/*----- .clearfix -----*/

.clearfix::after {
	visibility: hidden;
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
	height: 0;
}

body {
	background: #ffe8d1;
}

main {
	font-family: "M PLUS Rounded 1c", sans-serif;
	overflow: hidden;
}

main .opti {
	font-family: "Kaisei Opti", serif;
	font-weight: 400;
	font-style: normal;
}

.container {
	margin: 0 auto;
	text-align: left;
}

#mv {
	z-index: 10;
}

#lNav {
	padding: 62px 0 62px;
}

#lNav ul {
	justify-content: center;
	display: flex;
}

#lNav ul li:nth-of-type(2) {
	margin: 0 120px 0 76px;
}

#lNav ul li a {
	color: #333;
	display: block;
}

#lNav ul li a dl dt {
	margin-bottom: 12px;
	font-size: 3.2rem;
	font-weight: 500;
	line-height: 1;
	letter-spacing: 0.05em;
	align-items: center;
	display: flex;
}

#lNav ul li a dl dt::after {
	content: " ";
	margin-left: 22px;
	width: 28px;
	height: 28px;
	background: url(../img/arrow.png) no-repeat center center / contain;
	display: block;
}

#lNav ul li a dl dt span {
	display: block;
}

#lNav ul li a dl dd {
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.5;
	text-align: center;
}

#lNav ul li a dl dt span,
#lNav ul li a dl dd {
	transition-property: opacity;
	transition-duration: 0.5s;
}

#lNav ul li a:hover dl dt span,
#lNav ul li a:hover dl dd {
	opacity: 0.7;
}

@media screen and (max-width: 767px) {

	#lNav {
		padding: 8px 0 40px;
	}
	
	#lNav ul {
		margin: 0 auto;
		width: calc(100% - 20px);
		max-width: 335px;
		display: block;
	}
	
	#lNav ul li {
		margin: 0;
		border-bottom: 1px solid #e3bf9c;
	}
	
	#lNav ul li:nth-of-type(2) {
		margin: 0;
	}
	
	#lNav ul li a {
		padding: 16px 48px 14px 10px;
		position: relative;
	}
	
	#lNav ul li a dl dt {
		margin-bottom: 11px;
		font-size: 2.5rem;
		display: block;
	}
	
	#lNav ul li a dl dt::after {
		margin-left: 0;
		width: 25px;
		height: 25px;
		right: 12px;
		top: 50%;
		position: absolute;
		transform: translateY(-50%);
	}
	
	#lNav ul li a dl dd {
		font-size: 1.2rem;
		text-align: left;
	}
	
}

#plateSec {
	position: relative;
}

#plateSec::before {
	content: " ";
	width: 756px;
	height: 144px;
	background: url(../img/front.png) no-repeat center center / contain;
	display: block;
	left: 50%;
	top: -40px;
	z-index: 3;
	position: absolute;
	transform: translateX(-50%);
}

#plateSec::after {
	content: " ";
	width: 1664px;
	height: 941px;
	background: url(../img/bg_dsc.png) no-repeat center center / contain;
	display: block;
	left: 50%;
	top: 0;
	z-index: 1;
	position: absolute;
	transform: translateX(-50%);
}

#plateInSec {
	margin: 0 auto;
	width: 535px;
	z-index: 2;
	position: relative;
}

#plateInSec::before {
	content: " ";
	width: 100%;
	height: 100%;
	background: #603125;
	clip-path: polygon(0 0, 420px 0, 100% 72px, 100% 100%, 0 100%);
	display: block;
	left: 0;
	top: 0;
	z-index: 1;
	position: absolute;
}

#plateSec .container {
	padding: 88px 30px 0;
	z-index: 2;
	position: relative;
}

#dscSec h1 {
	margin: 0 auto 30px;
	width: 427px;
}

#dscSec .hp {
	color: #fff;
	font-size: 1.8rem;
	font-weight: 400;
	line-height: 1.75;
	text-align: center;
}

#dscSec figure {
	margin: 40px auto 40px;
	width: 437px;
}

#pointSec,
#lineupSec {
	padding: 40px 33px 52px;
}

#pointSec h1,
#lineupSec h1 {
	padding: 26px 20px;
	background: #603125;
	color: #fff;
	font-size: 3.8rem;
	font-weight: 500;
	line-height: 1;
	text-align: center;
}

#pointSec h1 span,
#lineupSec h1 span {
	margin: 20px auto 0;
	font-size: 1.6rem;
	line-height: 1.5;
	display: block;
}

#pointSec {
	margin: 0 auto 50px;
	background: #ffe8d1;
}

#pointSec h1 {
	margin: 0 auto 64px;
}

#pointSec h2 {
	margin: 0 auto 14px;
	width: 380px;
	height: 50px;
	color: #603125;
	font-size: 4rem;
	line-height: 1.1;
	align-items: center;
	display: flex;
	position: relative;
}

#pointSec h2 span {
	display: block;
}

#pointSec h2 .num {
	margin-right: 12px;
	font-size: 4.2rem;
}

#pointSec h2 img {
	width: 50px;
	right: 0;
	top: 0;
	position: absolute;
}

#pointSec h3 {
	margin: 0 auto 40px;
	width: 400px;
	padding: 5px 0;
	background: #fff;
	border-radius: 16px;
	color: #603125;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.5;
	text-align: center;
	letter-spacing: -0.05em;
}

#pointSec h3 span {
	color: #d45a32;
}

#pointSec p {
	color: #603125;
	font-size: 1.8rem;
	font-weight: 400;
	line-height: 1.75;
	text-align: center;
}

@media screen and (max-width: 767px) {

	#plateSec::before {
		width: 453px;
		height: 98px;
		background-image: url(../img/front_sp.png);
		top: -24px;
	}
	
	#plateSec::after {
		width: 725px;
		height: 688px;
		background-image: url(../img/bg_dsc_sp.png);
		top: 10px;
		z-index: 4;
	}
	
	#plateInSec {
		width: 335px;
	}
	
	#plateInSec::before {
		clip-path: polygon(0 0, 280px 0, 100% 32px, 100% 100%, 0 100%);
	}
	
	#plateSec .container {
		padding: 50px 12px 0;
	}
	
	#dscSec h1 {
		margin: 0 auto 24px;
		width: 280px;
	}
	
	#dscSec .hp {
		font-size: 1.4rem;
	}
	
	#dscSec figure {
		margin: 24px auto 24px;
		width: 287px;
	}
	
	#pointSec,
	#lineupSec {
		padding: 24px 14px 24px;
	}
	
	#pointSec h1,
	#lineupSec h1 {
		padding: 16px 10px 14px;
		font-size: 2.8rem;
	}
	
	#pointSec h1 span,
	#lineupSec h1 span {
		margin: 13px auto 0;
		font-size: 1.2rem;
	}
	
	#pointSec {
		margin: 0 auto 35px;
		padding-bottom: 36px;
	}
	
	#pointSec h1 {
		margin: 0 auto 40px;
	}
	
	#pointSec h2 {
		margin: 0 auto 8px;
		width: 100%;
		max-width: 270px;
		height: 35px;
		font-size: 2.7rem;
	}
	
	#pointSec h2 .num {
		margin-right: 10px;
		font-size: 2.9rem;
	}
	
	#pointSec h2 img {
		width: 35px;
	}
	
	#pointSec h3 {
		margin: 0 auto 26px;
		width: 100%;
		max-width: 270px;
		padding: 3px 0;
		border-radius: 13px;
		font-size: 1.2rem;
	}
	
	#pointSec p {
		font-size: 1.4rem;
	}
}

#photoSec dl {
	position: absolute;
}

#photoSec #photo01,
#photoSec #photo03 {
	width: 416px;
	right: 100%;
}

#photoSec #photo02,
#photoSec #photo04 {
	width: 415px;
	left: 100%;
}

#photoSec #photo01,
#photoSec #photo02 {
	bottom: 610px;
}

#photoSec #photo03,
#photoSec #photo04 {
	bottom: 134px;
}

#photoSec dl dt {
	margin: 0 auto 30px;
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.2;
	align-items: center;
	justify-content: center;
	display: flex;
	position: relative;
}

#photoSec dl dt::before,
#photoSec dl dt::after {
	content: " ";
	width: 30px;
	height: 30px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	display: block;
}

#photoSec dl dt::before {
	background-image: url("../img/p_pop_l.png");
}

#photoSec dl dt::after {
	background-image: url("../img/p_pop_r.png");
}

#photoSec dl dt span {
	margin: 0 10px;
	display: block;
}

#photoSec .photoP {
	display: block;
}

#photoSec .photoS {
	display: none;
}

@media screen and (max-width: 1365px) {

	#photoSec dl {
		margin: 0 auto 24px;
		position: relative;
	}
	
	#photoSec #photo01,
	#photoSec #photo02,
	#photoSec #photo03,
	#photoSec #photo04 {
		width: 100%;
		left: auto;
		right: auto;
		bottom: auto;
	}
	
	#photoSec dl dt {
		margin: 0 auto 15px;
		color: #fff;
		font-size: 1.6rem;
	}
	
	#photoSec dl dt::before,
	#photoSec dl dt::after {
		width: 22px;
		height: 22px;
	}
	
	#photoSec dl dt::before {
		background-image: url("../img/p_pop_w_l.png");
	}
	
	#photoSec dl dt::after {
		background-image: url("../img/p_pop_w_r.png");
	}
	
	#photoSec dl dt span {
		margin: 0 10px;
		display: block;
	}
	
	#photoSec .photoP {
		display: none;
	}

	#photoSec .photoS {
		display: block;
	}
}

#lineupListSec {
	padding: 0 83px 30px;
	z-index: 10;
	position: relative;
}

#lineupListSec .container {
	width: 100%;
	max-width: 1200px;
}

#lineupListSec .item {
	margin-bottom: 100px;
	height: 344px;
	border-radius: 70px 0 70px 0;
	position: relative;
}

#lineupListSec .item::before {
	content: " ";
	display: block;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	position: absolute;
}

#lineupListSec .item .itemInfo {
	padding: 48px 450px 10px 100px;
	color: #603125;
}

#lineupListSec .item .itemInfo h2 {
	margin: 0 auto 48px;
	font-size: 3.8rem;
	font-weight: 500;
	line-height: 1;
	position: relative;
}

#lineupListSec .item .itemInfo h2::before {
	content: " ";
	width: 291px;
	height: 24px;
	background: url(../img/line_dot.png) no-repeat center center / contain;
	display: block;
	left: -6px;
	bottom: -34px;
	position: absolute;
}

#lineupListSec .item .itemInfo h3 {
	margin: 0 auto 13px;
	font-size: 2.2rem;
	line-height: 1.75;
}

#lineupListSec .item .itemInfo p {
	margin: 0 auto 36px;
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.75;
}

#lineupListSec .item .itemInfo .link {
	margin: 0;
	width: 300px;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.5;
	text-align: center;
}

#lineupListSec .item .itemInfo .link a {
	padding: 10px 0;
	border-radius: 10px;
	color: #fff;
	display: block;
}

#lineupListSec .item .itemInfo .link a:hover {
	opacity: 0.7;
}

#lineupListSec .item figure {
	width: 438px;
	right: 0;
	bottom: 0;
	position: absolute;
}

#lineupListSec #item01 {
	background: #f8e0d2;
}

#lineupListSec #item02 {
	background: #e5e8d8;
}

#lineupListSec #item03 {
	background: #eae1d8;
}

#lineupListSec #item01::before {
	width: 129px;
	height: 104px;
	background-image: url(../img/pat01.png);
	left: -48px;
	top: -40px;
}

#lineupListSec #item02::before {
	width: 192px;
	height: 147px;
	background-image: url(../img/pat02.png);
	left: -46px;
	top: -70px;
}

#lineupListSec #item03::before {
	width: 129px;
	height: 118px;
	background-image: url(../img/pat03.png);
	left: -38px;
	top: -28px;
}

#lineupListSec #item01 .itemInfo .link a {
	background: #d45a32;
}

#lineupListSec #item02 .itemInfo .link a {
	background: #7ead8c;
}

#lineupListSec #item03 .itemInfo .link a {
	background: #4b4744;
}

@media screen and (max-width: 1199px) {

	#lineupListSec {
		padding: 0 20px 50px;
	}
	
	#lineupListSec .container {
		max-width: 335px;
	}
	
	#lineupListSec .item {
		margin-bottom: 32px;
		height: auto;
		border-radius: 45px 0 45px 0;
	}
	
	#lineupListSec .item .itemInfo {
		padding: 37px 30px 268px;
	}
	
	#lineupListSec .item .itemInfo h2 {
		margin: 0 auto 48px;
		font-size: 2.8rem;
		text-align: center;
	}
	
	#lineupListSec .item .itemInfo h2::before {
		width: 205px;
		height: 18px;
		left: 50%;
		bottom: -26px;
		transform: translateX(-50%);
	}
	
	#lineupListSec .item .itemInfo h3 {
		margin: 0 auto 5px;
		font-size: 1.7rem;
		text-align: center;
	}
	
	#lineupListSec .item .itemInfo p {
		margin: 0 auto 27px;
		font-size: 1.4rem;
		text-align: center;
	}
	
	#lineupListSec .item .itemInfo .link {
		margin: 0 auto;
		width: 100%;
		max-width: 259px;
		font-size: 1.4rem;
	}
	
	#lineupListSec .item .itemInfo .link a {
		padding: 6px 0;
		border-radius: 8px;
	}
	
	#lineupListSec .item figure {
		width: 100%;
		right: 0;
		bottom: 0;
		position: absolute;
	}
	
	#lineupListSec #item01::before {
		width: 113px;
		height: 91px;
		left: -40px;
		top: -15px;
	}
	
	#lineupListSec #item02::before {
		width: 120px;
		height: 92px;
		left: -18px;
		top: -24px;
	}
	
	#lineupListSec #item03::before {
		width: 66px;
		height: 60px;
		left: -18px;
		top: -22px;
	}
	
}

#snsSec {
	padding: 20px 83px 150px;
	background: url(../img/bg_sns.png) no-repeat center bottom 114px / 1391px auto;
	z-index: 10;
	position: relative;
}

#snsSec .container {
	color: #603125;
}

#snsSec h1 {
	margin: 0 auto 80px;
	font-size: 3.8rem;
	font-weight: 500;
	line-height: 1;
	text-align: center;
}

#snsSec h1 span {
	margin: 20px auto 0;
	font-size: 1.6rem;
	line-height: 1.5;
	display: block;
}

#snsSec .snsItem h2 {
	margin: 0 auto 24px;
	font-size: 2.7rem;
	font-weight: 500;
	line-height: 1.2;
	align-items: center;
	justify-content: center;
	display: flex;
	position: relative;
}

#snsSec .snsItem h2::before,
#snsSec .snsItem h2::after {
	content: " ";
	width: 23px;
	height: 25px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	display: block;
}

#snsSec .snsItem h2::before {
	background-image: url("../img/p_dot_l.png");
}

#snsSec .snsItem h2::after {
	background-image: url("../img/p_dot_r.png");
}

#snsSec .snsItem h2 span {
	margin: 0 24px;
	display: block;
}

#snsSec .snsItem p {
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.75;
	text-align: center;
}

#snsSec #snsItem01 ul {
	padding: 35px 0 65px;
	align-items: center;
	justify-content: center;
	display: flex;
	gap: 18px;
}

#snsSec #snsItem01 ul li {
	width: 78px;
}

#snsSec #snsItem02 ul {
	padding: 35px 0 0;
	align-items: center;
	justify-content: center;
	display: flex;
	gap: 16px;
}

#snsSec #snsItem02 ul li {
	width: 78px;
}


@media screen and (max-width: 767px) {

	#snsSec {
		padding: 20px 0 100px;
		background: url(../img/bg_sns_sp.png) no-repeat center bottom 10px / 398px auto;
	}
	
	#snsSec h1 {
		margin: 0 auto 40px;
		font-size: 2.8rem;
	}
	
	#snsSec h1 span {
		margin: 13px auto 0;
		font-size: 1.2rem;
	}
	
	#snsSec .snsItem h2 {
		margin: 0 auto 18px;
		font-size: 2.4rem;
	}
	
	#snsSec .snsItem h2::before,
	#snsSec .snsItem h2::after {
		width: 18px;
		height: 21px;
	}
	
	#snsSec .snsItem h2 span {
		margin: 0 16px;
		display: block;
	}

	#snsSec .snsItem p {
		font-size: 1.4rem;
	}

	#snsSec #snsItem01 ul {
		padding: 25px 0 40px;
		gap: 16px;
	}
	
	#snsSec #snsItem01 ul li {
		width: 58px;
	}
	
	#snsSec #snsItem02 ul {
		padding: 25px 0 0;
		gap: 16px;
	}
		
}

footer {
	background: #62674e;
	position: relative;
}

footer .container {
	padding: 30px;
}

footer .copy {
	color: #fff;
	font-size: 1.2rem;
	font-weight: 500;
	line-height: 1.5;
	text-align: center;
}

footer .copy small {
	font-size: 1em;
}

@media screen and (max-width: 767px) {

	footer .container {
		padding: 10px;
	}
	
	footer .copy {
		font-size: 1rem;
		line-height: 2;
	}
	
	}

/*----- flg -----*/

.flgP {
	display: block;
}

.flgS {
	display: none;
}

@media screen and (max-width: 767px) {

	.flgP {
		display: none;
	}

	.flgS {
		display: block;
	}
}

@media screen and (max-width: 1199px) {

	#lineupListSec .flgP {
		display: none;
	}

	#lineupListSec .flgS {
		display: block;
	}
	
}

