@charset "UTF-8";
/*----------
	リニューアル前用 base
----------*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700&family=M+PLUS+Rounded+1c:wght@500;700;800;900&display=swap");
/*----------
	リニューアル前用 リセット
----------*/
/* Reset */
#stage header *, #stage header::before,
#stage header *::before,
#stage header *::after,
#stage footer *,
#stage footer::before,
#stage footer *::before,
#stage footer *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	background: transparent;
	font-weight: inherit;
	font-size: inherit;
	font-style: inherit;
	-webkit-tap-highlight-color: transparent;
}
#stage header article,
#stage header aside,
#stage header details,
#stage header figcaption,
#stage header figure,
#stage header picture,
#stage header main,
#stage header footer,
#stage header header,
#stage header hgroup,
#stage header menu,
#stage header nav,
#stage header section,
#stage footer article,
#stage footer aside,
#stage footer details,
#stage footer figcaption,
#stage footer figure,
#stage footer picture,
#stage footer main,
#stage footer footer,
#stage footer header,
#stage footer hgroup,
#stage footer menu,
#stage footer nav,
#stage footer section {
	display: block;
}
#stage header ul,
#stage header ol,
#stage footer ul,
#stage footer ol {
	list-style: none;
}
#stage header blockquote,
#stage header q,
#stage footer blockquote,
#stage footer q {
	quotes: none;
}
#stage header blockquote::before,
#stage header blockquote::after,
#stage header q::before,
#stage header q::after,
#stage footer blockquote::before,
#stage footer blockquote::after,
#stage footer q::before,
#stage footer q::after {
	content: none;
}
#stage header table,
#stage footer table {
	border-collapse: collapse;
	border-spacing: 0;
	empty-cells: show;
}
#stage header button,
#stage footer button {
	font-family: inherit;
}

/*----------
	vars
----------*/
:root {
	/* color */
	--color-prim: #0075c2;
	--color-txt: #333;
	--color-txt-caption: #777;
	--color-link: #0075c2;
	--color-hover: #0075c2;
	--color-hover-light: #007AE6;
	--color-border: #DDDDDD;
	--color-bg-blue: #E8F4FF;
	--color-bg-gray: #F7F7F7;
	--color-red: #E64040;
	/* font family */
	--font-sans: "Noto Sans JP", "ヒラギノ角ゴシック", "Hiragino Sans", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "メイリオ", Meiryo, sans-serif;
	--font-mplus: "M PLUS Rounded 1c", serif;
	/* line height */
	--line-height-s: 1.4;
	--line-height-m: 1.6;
	--line-height-l: 1.8;
	/* icons */
	--icon-pause: "";
	--icon-search: "";
	--icon-modal: "";
	--icon-blank: "";
	--icon-pdf: "";
	--icon-arrow1-b: "";
	--icon-arrow1-l: "";
	--icon-arrow1-r: "";
	--icon-arrow1-t: "";
	--icon-arrow2-b: "";
	--icon-arrow2-l: "";
	--icon-arrow2-r: "";
	--icon-arrow2-t: "";
	--icon-close: "";
	--icon-minus: "";
	--icon-plus: "";
}

html.is-locked {
	position: absolute;
	overflow: hidden;
}

body.is-locked {
	overflow: hidden;
}

#stage header,
#stage footer {
	position: relative;
	width: 100%;
	background-color: #fff;
	font-size: 16px;
	text-align: left;
	line-height: var(--line-height-l);
	font-family: var(--font-sans);
	letter-spacing: 0;
	color: var(--color-txt);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
}
@media (max-width: 767px) {
	#stage header,
	#stage footer {
		font-size: 14px;
	}
}
#stage header a,
#stage footer a {
	text-decoration: none;
	color: var(--color-link);
}
@media (min-width: 768px), print {
	#stage header a:hover,
	#stage footer a:hover {
		text-decoration: none;
	}
}
#stage header img,
#stage footer img {
	width: 100%;
	height: auto;
	vertical-align: top;
}
#stage header sup,
#stage footer sup {
	vertical-align: top;
	font-size: 0.7em;
}
#stage header sub,
#stage footer sub {
	vertical-align: baseline;
	font-size: 0.7em;
}
#stage header input[type=text],
#stage header textarea,
#stage header select,
#stage footer input[type=text],
#stage footer textarea,
#stage footer select {
	font-family: inherit;
	font-size: 16px;
}

/*----------
	main header
----------*/
@media print {
	header {
		display: none;
	}
}

#stage .l-mainheader {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background-color: #fff;
	z-index: 10001;
	text-align: left;
}
#stage .l-mainheader.pos-absolute {
	position: absolute;
}
#stage .l-mainheader.pos-absolute.is-scrollup .l-mainnav__sub, #stage .l-mainheader.pos-absolute.is-scrolldown .l-mainnav__sub {
	position: absolute;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0s, visibility 0s;
}
#stage .l-mainheader__nav {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	z-index: 1;
}
#stage .l-mainheader__nav.is-open {
	display: block;
}
#stage .l-mainheader__inner {
	z-index: 2;
}
@media (max-width: 1024px) {
	#stage .l-mainheader__inner {
		width: 100%;
		height: 70px;
		padding: 0 20px;
	}
	#stage .l-mainheader__nav {
		height: 100vh;
		background-color: #fff;
		overflow: auto;
	}
	#stage .l-mainheader__nav.is-open {
		display: block;
		background-color: #fff;
		padding-top: 106px;
		padding-bottom: 150px;
	}
	#stage .l-mainheader__logo {
		width: 180px;
		padding-top: 13px;
	}
	#stage .l-mainheader__search {
		position: absolute;
		top: 20px;
		right: auto;
		left: 50%;
		transform: translateX(-50%);
		width: calc(100% - 40px);
		height: 56px;
		z-index: 3;
	}
	#stage .l-mainheader__search__input {
		width: 100%;
		padding-right: 40px;
		padding-left: 22px;
		border: 1px solid var(--color-border);
		border-radius: 28px;
		color: var(--color-txt);
		font-size: 1.6rem;
		font-size: 16px;
		font-weight: normal;
		line-height: 54px;
		cursor: pointer;
	}
	#stage .l-mainheader__search .icon-search {
		position: absolute;
		top: 50%;
		right: 20px;
		transform: translateY(-50%);
		width: 17px;
		height: 16px;
	}
	#stage .l-mainheader__navtoggle {
		position: absolute;
		top: 0;
		right: 0;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 70px;
		height: 70px;
	}
	#stage .l-mainheader__navtoggle__inner {
		position: relative;
		display: block;
		width: 24px;
		height: 2px;
		margin: 0 auto;
	}
	#stage .l-mainheader__navtoggle__bartop, #stage .l-mainheader__navtoggle__barmiddle, #stage .l-mainheader__navtoggle__barbottom {
		position: absolute;
		display: block;
		width: 100%;
		height: 100%;
		background-color: var(--color-txt);
		border-radius: 4px;
		transition: all 0.15s linear;
	}
	#stage .l-mainheader__navtoggle__bartop {
		transform: translateY(-10px) rotate(0deg);
	}
	#stage .l-mainheader__navtoggle__barbottom {
		transform: translateY(10px) rotate(0deg);
	}
	#stage .l-mainheader__navtoggle.is-open .l-mainheader__navtoggle__bartop {
		opacity: 0;
	}
	#stage .l-mainheader__navtoggle.is-open .l-mainheader__navtoggle__barmiddle {
		transform: translateY(0) rotate(45deg);
	}
	#stage .l-mainheader__navtoggle.is-open .l-mainheader__navtoggle__barbottom {
		transform: translateY(0) rotate(-45deg);
	}
	#stage .l-mainheader__layer {
		display: none;
	}
}
@media (min-width: 1025px) {
	#stage .l-mainheader__inner {
		position: relative;
		width: 100%;
		max-width: 1560px;
		margin-inline: auto;
		height: 110px;
		padding: 0 60px;
	}
	#stage .l-mainheader__search {
		position: relative;
		display: block;
		width: 200px;
		height: 32px;
		margin-left: 43px;
	}
	#stage .l-mainheader__search__input[type=text] {
		width: 200px;
		padding-right: 30px;
		padding-left: 20px;
		border: 1px solid var(--color-border);
		border-radius: 16px;
		box-sizing: border-box;
		color: var(--color-txt);
		font-size: 1.4rem;
		font-size: 14px;
		font-weight: normal;
		line-height: 32px;
		cursor: pointer;
	}
	#stage .l-mainheader__search__input[type=text]::placeholder {
		color: var(--color-txt);
		font-size: 1.4rem;
		font-size: 14px;
	}
	#stage .l-mainheader__search .icon-search {
		position: absolute;
		top: 50%;
		right: 20px;
		transform: translateY(-50%);
		width: 13px;
		height: 14px;
	}
	#stage .l-mainheader__navtoggle {
		display: none;
	}
	#stage .l-mainheader__nav {
		display: block;
		position: absolute;
		top: 0;
		left: auto;
		right: 60px;
		z-index: auto;
		width: 100%;
		max-width: 1320px;
		height: 100%;
	}
	#stage .l-mainheader__nav__inner {
		display: flex;
		flex-direction: column;
	}
	#stage .l-mainheader__logo {
		position: relative;
		width: 240px;
		padding-top: 27px;
		z-index: 1;
	}
	#stage .l-mainheader__layer {
		position: fixed;
		bottom: 0;
		left: 0;
		width: 100vw;
		height: 100vh;
		z-index: 10000;
		background-color: rgba(0, 0, 0, 0.3);
		transition: opacity 0.4s, visibility 0.4s;
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
	}
	#stage .l-mainheader__layer.pc-megamenu-active {
		opacity: 1;
		visibility: visible;
		pointer-events: visible;
		cursor: pointer;
	}
}
@media (min-width: 1025px) and (max-width: 1279px) {
	#stage .l-mainheader__inner {
		padding: 0 30px;
	}
	#stage .l-mainheader__nav {
		right: 30px;
	}
}

.l-mainheader.is-scrollup {
	position: fixed;
	animation: scrollupSP 0.5s forwards;
}
@media (min-width: 1025px) {
	.l-mainheader.is-scrollup {
		min-width: 100%;
		animation: scrollupPC 0.5s forwards;
	}
}

@keyframes scrollupSP {
	from {
		transform: translateY(-70px);
	}
	to {
		transform: translateY(0);
	}
}
@keyframes scrollupPC {
	from {
		transform: translateY(-110px);
	}
	to {
		transform: translateY(0);
	}
}
.l-mainheader.is-scrolldown {
	position: fixed;
	animation: scrolldownSP 0.5s forwards;
}
@media (min-width: 1025px) {
	.l-mainheader.is-scrolldown {
		min-width: 100%;
		animation: scrolldownPC 0.5s forwards;
	}
}

@keyframes scrolldownSP {
	from {
		transform: translateY(0);
	}
	to {
		transform: translateY(-70px);
	}
}
@keyframes scrolldownPC {
	from {
		transform: translateY(0);
	}
	to {
		transform: translateY(-110px);
	}
}
/*----------
	main footer
----------*/
@media print {
	footer {
		display: none;
	}
}

#stage .l-mainfooter {
	margin-top: 20px;
	background: #fff;
	border-top: 2px solid var(--color-prim);
}
#stage .l-mainfooter__inner {
	max-width: 1260px;
	margin: 0 auto;
	padding-bottom: 30px;
}
#stage .l-mainfooter__backhead {
	position: fixed;
	bottom: 16px;
	right: 16px;
	width: 40px;
	height: 40px;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s;
	z-index: 15;
}
#stage .l-mainfooter__backhead.is-visible {
	opacity: 1;
	pointer-events: auto;
}
#stage .l-mainfooter__backhead > a {
	display: grid;
	place-content: center;
	height: 100%;
	background-color: #848484;
	border-radius: 100%;
	color: inherit;
}
#stage .l-mainfooter__backhead i {
	display: inline-block;
	color: #fff;
	font-size: 14px;
}
#stage .l-mainfooter__logo {
	padding: 30px 20px 24px;
}
#stage .l-mainfooter__logo img {
	display: block;
	max-width: 200px;
	margin: auto;
}
#stage .l-mainfooter__copyright {
	margin-top: 30px;
	text-align: center;
	font-size: 11px;
	color: var(--color-txt-caption);
}
#stage .l-mainfooter__information {
	padding: 40px 20px 0;
}
#stage .l-mainfooter__contact__inner {
	display: grid;
	place-content: center;
	width: 100%;
	height: 60px;
	background-color: var(--color-bg-blue);
	border-radius: 10px;
}
#stage .l-mainfooter__contact__inner > p {
	display: inline;
	position: relative;
	padding-left: 60px;
	color: var(--color-txt);
	font-size: 16px;
	font-weight: 500;
	line-height: 1.5;
}
#stage .l-mainfooter__contact__inner > p::before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	width: 50px;
	height: 38px;
	background: url(/assets/images/common/icon_contact.svg) no-repeat 0 0;
	background-size: cover;
}
#stage .l-mainfooter__sns {
	display: grid;
	place-content: center;
	place-items: center;
	gap: 26px 0;
	margin-top: 40px;
}
@media (min-width: 768px), print {
	#stage .l-mainfooter__inner {
		padding: 0 30px 30px;
	}
	#stage .l-mainfooter__backhead {
		width: 56px;
		height: 56px;
		right: 32px;
		bottom: 32px;
	}
	#stage .l-mainfooter__backhead a {
		transition: background-color 0.3s;
	}
	#stage .l-mainfooter__backhead a:hover {
		background-color: #333;
	}
	#stage .l-mainfooter__logo {
		padding: 40px 0 35px;
	}
	#stage .l-mainfooter__logo img {
		max-width: 240px;
	}
	#stage .l-mainfooter__logo a {
		transition: opacity 0.3s;
	}
	#stage .l-mainfooter__logo a:hover {
		opacity: 0.7;
	}
	#stage .l-mainfooter__copyright {
		margin-top: 35px;
		font-size: 11px;
	}
	#stage .l-mainfooter__information {
		padding-left: 0;
		padding-right: 0;
	}
	#stage .l-mainfooter__information__upper {
		display: flex;
		justify-content: center;
	}
	#stage .l-mainfooter__contact {
		flex: 0 0 300px;
		margin-right: 40px;
	}
	#stage .l-mainfooter__contact__inner {
		width: 300px;
		height: 75px;
		background-color: var(--color-bg-blue);
		border-radius: 15px;
	}
	#stage .l-mainfooter__contact__inner > p {
		padding-left: 76px;
		transition: color 0.3s;
	}
	#stage .l-mainfooter__contact__inner > p span {
		display: inline-block;
		text-indent: -0.5em;
	}
	#stage .l-mainfooter__contact__inner > p::before {
		width: 64px;
		height: 48px;
	}
	#stage .l-mainfooter__contact__inner:hover > p,
	#stage .l-mainfooter__contact__inner:hover span {
		color: var(--color-hover);
		text-decoration: underline;
	}
	#stage .l-mainfooter__sns {
		margin-top: 0;
		gap: 14px 0;
	}
	#stage .l-mainfooter__sns__items a {
		transition: opacity 0.3s;
	}
	#stage .l-mainfooter__sns__items a:hover {
		opacity: 0.7;
	}
}

#stage .l-fnav-main {
	border-top: 1px solid var(--color-border);
}
#stage .l-fnav-main__item {
	border-bottom: 1px solid var(--color-border);
}
#stage .l-fnav-main__item > a {
	display: block;
	padding: 16px 20px 15px;
	color: var(--color-txt);
	font-size: 16px;
	font-weight: 700;
	line-height: var(--line-height-l);
}
@media (min-width: 768px), print {
	#stage .l-fnav-main {
		border-top: 0;
	}
	#stage .l-fnav-main__items {
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
		gap: 10px 35px;
	}
	#stage .l-fnav-main__item {
		border-bottom: 0;
	}
	#stage .l-fnav-main__item > a {
		position: relative;
		padding: 0 0 12px;
		transition: color 0.3s;
	}
	#stage .l-fnav-main__item > a::after {
		content: "";
		display: block;
		position: absolute;
		left: 50%;
		bottom: 0;
		transform: translateX(-50%);
		width: 30px;
		height: 4px;
		background-color: var(--color-prim);
		border-radius: 2px;
		opacity: 0;
		transition: opacity 0.3s;
	}
	#stage .l-fnav-main__item > a:hover {
		color: var(--color-hover);
	}
	#stage .l-fnav-main__item > a:hover::after {
		opacity: 1;
	}
}

#stage .l-fnav-sub__items {
	display: flex;
	flex-wrap: wrap;
	gap: 15px 18px;
	margin-top: 30px;
}
#stage .l-fnav-sub__item {
	font-size: 12px;
	line-height: 1;
	color: var(--color-txt);
}
#stage .l-fnav-sub__item > a {
	color: inherit;
}
#stage .l-fnav-sub__item > a > span {
	display: block;
	padding: 0 20px;
}
@media (min-width: 768px), print {
	#stage .l-fnav-sub__items {
		justify-content: center;
		gap: 15px 30px;
	}
	#stage .l-fnav-sub__item > a {
		color: var(--color-txt);
		font-size: 13px;
		transition: color 0.2s;
	}
	#stage .l-fnav-sub__item > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
}

/*----------
	main navigation
----------*/
@media (max-width: 1024px) {
	#stage .l-mainnav {
		background: #fff;
	}
	#stage .l-mainnav__item.is-hierarichical.is-open .l-mainnav__cattop > button::after {
		content: var(--icon-minus);
	}
	#stage .l-mainnav__item.is-hierarichical.is-open .l-mainnav__sub {
		height: auto;
		opacity: 1;
		pointer-events: visible;
	}
	#stage .l-mainnav__cattop {
		position: relative;
		border-top: 1px solid var(--color-border);
	}
	#stage .l-mainnav__cattop > button {
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		width: 60px;
		height: 100%;
		z-index: 1;
		cursor: pointer;
	}
	#stage .l-mainnav__cattop > button::before {
		content: "";
		display: block;
		position: absolute;
		top: 50%;
		right: 20px;
		transform: translateY(-50%);
		width: 24px;
		height: 24px;
		background-color: #fff;
		border: 1px solid var(--color-link);
		border-radius: 100%;
	}
	#stage .l-mainnav__cattop > button::after {
		content: var(--icon-plus);
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		position: absolute;
		top: 50%;
		right: 20px;
		transform: translateY(-50%);
		display: grid;
		place-content: center;
		width: 24px;
		height: 24px;
		color: var(--color-link);
		font-size: 1.2rem;
		font-size: 12px;
		font-weight: 500;
		line-height: 22px;
	}
	#stage .l-mainnav__cattop > a {
		display: block;
		padding: 14px 50px 14px 20px;
		color: inherit;
		font-size: 1.6rem;
		font-size: 16px;
		font-weight: 500;
	}
	#stage .l-mainnav__sub {
		height: 0;
		position: relative;
		overflow: hidden;
		opacity: 0;
		pointer-events: none;
		transition: all 0.4s linear;
	}
	#stage .l-mainnav__sub-close {
		display: none;
	}
	#stage .l-mainnav__close {
		display: block;
		width: 134px;
		height: 50px;
		border: 1px solid var(--color-border);
		border-radius: 25px;
		margin: 40px auto 100px;
		color: var(--color-txt);
		font-size: 1.6rem;
		font-size: 16px;
		font-weight: 500;
		text-align: center;
		line-height: 48px;
	}
	#stage .l-mainnav__close > i {
		margin-left: 10px;
		color: var(--color-link);
		transform: translateY(0.1em);
	}
}
@media (min-width: 1025px) {
	#stage .l-mainnav {
		order: 2;
		display: flex;
		justify-content: flex-end;
	}
	#stage .l-mainnav__main {
		display: flex;
	}
	#stage .l-mainnav__item:last-child .l-mainnav__cattop a,
	#stage .l-mainnav__item:last-child .l-mainnav__cattop span {
		padding-right: 0;
	}
	#stage .l-mainnav__cattop > button {
		display: none;
	}
	#stage .l-mainnav__cattop > a {
		position: relative;
		display: block;
		height: 58px;
		color: inherit;
		transition: color 0.2s;
	}
	#stage .l-mainnav__cattop > a span {
		display: block;
	}
	#stage .l-mainnav__cattop > a span::after {
		content: "";
		display: block;
		position: absolute;
		left: 50%;
		bottom: 0;
		transform: translateX(-50%);
		width: 30px;
		height: 4px;
		border-radius: 2px;
		background-color: var(--color-prim);
		opacity: 0;
		transition: opacity 0.2s;
	}
	#stage .l-mainnav__cattop > a:hover span::after {
		opacity: 1;
		transition-delay: 0.3s;
	}
	#stage .l-mainnav__cattop > a.is-hover span::after, #stage .l-mainnav__cattop > a.is-active span::after {
		opacity: 1;
	}
	#stage .l-mainnav__cattop > span,
	#stage .l-mainnav__cattop > a > span {
		display: block;
		padding: 15px 20px 14px;
		font-size: 1.6rem;
		font-size: 16px;
		font-weight: 500;
		line-height: var(--line-height-l);
	}
	#stage .l-mainnav__sub {
		position: fixed;
		top: 110px;
		left: 0;
		width: 100%;
		max-height: 780px;
		background: var(--color-bg-blue);
		z-index: 10001;
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transition: opacity 0.4s, visibility 0.4s;
	}
	#stage .l-mainnav__sub-close {
		display: block;
		position: absolute;
		top: 8px;
		right: 30px;
		width: 134px;
		height: 50px;
		background-color: #fff;
		border: 1px solid var(--color-border);
		border-radius: 25px;
		margin: 40px auto 0;
		font-size: 1.6rem;
		font-size: 16px;
		font-weight: 500;
		text-align: center;
		line-height: 48px;
		transition: color 0.2s;
		cursor: pointer;
	}
	#stage .l-mainnav__sub-close > i {
		margin-left: 10px;
		color: var(--color-link);
		transform: translateY(0.1em);
	}
	#stage .l-mainnav__sub-close:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
	#stage .l-mainnav__sub.is-hung {
		opacity: 1;
		visibility: visible;
		pointer-events: visible;
	}
	#stage .l-mainnav__close {
		display: none;
	}
}
@media (min-width: 1025px) and (max-width: 1279px) {
	#stage .l-mainnav__cattop {
		height: 100%;
	}
	#stage .l-mainnav__cattop > a {
		height: 100%;
	}
	#stage .l-mainnav__cattop > span,
	#stage .l-mainnav__cattop > a > span {
		padding: 8px 10px 5px;
		line-height: var(--line-height-s);
		text-align: center;
	}
}

#stage .l-megamenu {
	width: 100%;
	max-width: 1260px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
@media (min-width: 768px), print {
	#stage .l-megamenu {
		padding-left: 30px;
		padding-right: 30px;
	}
}
@media (max-width: 1024px) {
	#stage .l-megamenu {
		padding: 16px 20px 7px 36px;
		background-color: var(--color-bg-blue);
	}
	#stage .l-megamenu__categorytop a {
		color: var(--color-txt);
		font-size: 1.6rem;
		font-size: 16px;
		font-weight: 400;
	}
	#stage .l-megamenu__categorytop i {
		position: relative;
		top: 0.1em;
		color: var(--color-link);
		margin-right: 5px;
	}
	#stage .l-megamenu__block {
		padding: 16px 22px 17px;
		border-bottom: 1px solid var(--color-border);
	}
	#stage .l-megamenu__block:last-of-type {
		border-bottom: none;
	}
}
@media (min-width: 1025px) {
	#stage .l-megamenu {
		position: relative;
		padding-top: 50px;
		padding-bottom: 50px;
	}
	#stage .l-megamenu__categorytop {
		padding-right: 200px;
	}
	#stage .l-megamenu__categorytop a {
		color: var(--color-txt);
		font-family: var(--font-mplus);
		font-size: 3.4rem;
		font-size: 34px;
		font-weight: 500;
		transition: color 0.2s;
	}
	#stage .l-megamenu__categorytop a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
	#stage .l-megamenu__categorytop i {
		position: relative;
		top: 0.1em;
		color: var(--color-link);
		margin-right: 15px;
	}
	#stage .l-megamenu__block {
		margin-top: 44px;
	}
}

/*----------
	個別パーツ設定
----------*/
@media (max-width: 1024px) {
	/* 商品・キャンペーン */
	#stage .l-megamenu__productitem__inner {
		position: relative;
		display: block;
		width: 100%;
		padding-left: 20px;
		color: var(--color-txt);
	}
	#stage .l-megamenu__productitem__inner::before {
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		content: var(--icon-arrow2-r);
		display: inline-block;
		position: absolute;
		top: 0.4em;
		left: 0;
		color: var(--color-link);
		font-size: 1.2rem;
		font-size: 12px;
		line-height: 1;
	}
	#stage .l-megamenu__productitem__inner[target=_blank] {
		position: relative;
		padding-left: 20px;
	}
	#stage .l-megamenu__productitem__inner[target=_blank]::before {
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		content: var(--icon-blank);
		display: inline-block;
		position: absolute;
		top: 0.35em;
		left: 0;
		color: var(--color-link);
		font-size: 1.4rem;
		font-size: 14px;
		line-height: 1;
	}
	#stage .l-megamenu__productitem__image {
		display: none;
	}
	#stage .l-megamenu__productitem__text {
		font-size: 1.4rem;
		font-size: 14px;
		font-weight: 400;
		line-height: 1.5;
	}
	#stage .l-megamenu__productitem + .l-megamenu__productitem {
		margin-top: 10px;
	}
	/* 画像セット */
	#stage .l-megamenu__imagelink__inner.u-pc-v {
		display: none;
	}
	#stage .l-megamenu__imagelink__inner.u-sp-v {
		display: block;
	}
	#stage .l-megamenu__imagelink__title {
		position: relative;
		padding-left: 20px;
		color: var(--color-txt);
		font-size: 1.4rem;
		font-size: 14px;
		font-weight: 400;
		line-height: var(--line-height-m);
	}
	#stage .l-megamenu__imagelink__title::before {
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		content: var(--icon-arrow2-r);
		display: inline-block;
		position: absolute;
		top: 0.5em;
		left: 0;
		color: var(--color-link);
		font-size: 1.2rem;
		font-size: 12px;
		line-height: 1;
	}
	#stage .l-megamenu__imagelink__title[target=_blank] {
		position: relative;
		padding-left: 20px;
	}
	#stage .l-megamenu__imagelink__title[target=_blank]::before {
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		content: var(--icon-blank);
		display: inline-block;
		position: absolute;
		top: 0.35em;
		left: 0;
		color: var(--color-link);
		font-size: 1.4rem;
		font-size: 14px;
		line-height: 1;
	}
	#stage .l-megamenu__imagelink__content {
		padding-right: 0;
		padding-left: 0;
	}
	#stage .l-megamenu__imagelink__image {
		display: none;
	}
	#stage .l-megamenu__imagelink + .l-megamenu__imagelink {
		margin-top: 10px;
	}
	/* アイコン画像セット */
	#stage .l-megamenu__iconitem__inner {
		display: block;
		position: relative;
		width: 100%;
		padding-left: 20px;
		color: var(--color-txt);
	}
	#stage .l-megamenu__iconitem__inner::before {
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		content: var(--icon-arrow2-r);
		display: inline-block;
		position: absolute;
		top: 0.5em;
		left: 0;
		color: var(--color-link);
		font-size: 1.2rem;
		font-size: 12px;
		line-height: 1;
	}
	#stage .l-megamenu__iconitem__inner[target=_blank] {
		position: relative;
		padding-left: 20px;
	}
	#stage .l-megamenu__iconitem__inner[target=_blank]::before {
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		content: var(--icon-blank);
		display: inline-block;
		position: absolute;
		top: 0.35em;
		left: 0;
		color: var(--color-link);
		font-size: 1.4rem;
		font-size: 14px;
		line-height: 1;
	}
	#stage .l-megamenu__iconitem__image {
		display: none;
	}
	#stage .l-megamenu__iconitem__text {
		font-size: 1.4rem;
		font-size: 14px;
		font-weight: 400;
		line-height: 1.5;
	}
	#stage .l-megamenu__iconitem + .l-megamenu__iconitem {
		margin-top: 10px;
	}
	/* 汎用ボタン */
	#stage .l-megamenu-button__inner {
		position: relative;
		display: block;
		width: 100%;
		color: var(--color-txt);
	}
	#stage .l-megamenu-button__inner > span {
		padding: 0 0 0 20px;
		text-align: center;
		font-size: 1.4rem;
		font-size: 14px;
		font-weight: 400;
		line-height: var(--line-height-s);
		color: inherit;
	}
	#stage .l-megamenu-button i {
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%);
		font-size: 1.2rem;
		font-size: 12px;
		color: var(--color-link);
	}
	#stage .l-megamenu-button + .l-megamenu-button {
		margin-top: 10px;
	}
	/* テキストリンク */
	#stage .l-megamenu__link {
		margin: 0 -22px;
	}
	#stage .l-megamenu__link > a {
		display: block;
		position: relative;
		color: var(--color-txt);
		font-size: 1.4rem;
		font-size: 14px;
		line-height: var(--line-height-m);
	}
	#stage .l-megamenu__link + .l-megamenu__link {
		margin-top: 10px;
	}
}
@media (min-width: 1025px) {
	/* 商品・キャンペーン */
	#stage .l-megamenu__products {
		display: grid;
		grid-template-columns: repeat(6, 1fr);
		gap: 25px 30px;
	}
	#stage .l-megamenu__productitem__inner {
		display: grid;
		place-content: center;
		place-items: center;
		width: 100%;
		height: 100%;
		min-height: 160px;
		background-color: #fff;
		border-radius: 15px;
		overflow: hidden;
		color: var(--color-txt);
		text-align: center;
	}
	#stage .l-megamenu__productitem__inner .l-megamenu__productitem__image,
	#stage .l-megamenu__productitem__inner .l-megamenu__productitem__text {
		transition: opacity 0.2s;
	}
	#stage .l-megamenu__productitem__inner:hover .l-megamenu__productitem__image,
	#stage .l-megamenu__productitem__inner:hover .l-megamenu__productitem__text {
		opacity: 0.7;
	}
	#stage .l-megamenu__productitem__image {
		display: flex;
		justify-content: center;
	}
	#stage .l-megamenu__productitem__image img {
		width: 77px;
	}
	#stage .l-megamenu__productitem__text {
		margin-top: 10px;
		font-size: 1.4rem;
		font-size: 14px;
		font-weight: 500;
		line-height: 1.5;
	}
	#stage .l-megamenu__productitem--milk .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(20%);
	}
	#stage .l-megamenu__productitem--milk .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-20%);
	}
	#stage .l-megamenu__productitem--juice .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(20%);
	}
	#stage .l-megamenu__productitem--juice .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-20%);
	}
	#stage .l-megamenu__productitem--takuhai .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(20%);
	}
	#stage .l-megamenu__productitem--takuhai .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-20%);
	}
	#stage .l-megamenu__productitem--cheese .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(5%);
	}
	#stage .l-megamenu__productitem--cheese .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-5%);
	}
	#stage .l-megamenu__productitem--butter-margarine .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(5%);
	}
	#stage .l-megamenu__productitem--butter-margarine .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-5%);
	}
	#stage .l-megamenu__productitem--baby-milk .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(5%);
	}
	#stage .l-megamenu__productitem--baby-milk .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-5%);
	}
	#stage .l-megamenu__productitem--functional-food .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(5%);
	}
	#stage .l-megamenu__productitem--functional-food .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-5%);
	}
	#stage .l-megamenu__productitem--other .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(10%);
	}
	#stage .l-megamenu__productitem--other .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-10%);
	}
	/* 画像セット */
	#stage .l-megamenu__imagelink__inner.u-pc-v {
		display: block;
	}
	#stage .l-megamenu__imagelink__inner.u-sp-v {
		display: none;
	}
	#stage .l-megamenu__imagelink__title {
		position: relative;
		padding-left: 30px;
		color: var(--color-txt);
		font-size: 1.6rem;
		font-size: 16px;
		font-weight: 500;
		line-height: var(--line-height-m);
	}
	#stage .l-megamenu__imagelink__title::before {
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		content: var(--icon-arrow1-r);
		display: inline-block;
		position: absolute;
		top: 0.2em;
		left: 0;
		color: var(--color-link);
		font-size: 1.8rem;
		font-size: 18px;
		line-height: 1;
	}
	#stage .l-megamenu__imagelink__title[target=_blank] {
		position: relative;
		padding-left: 20px;
	}
	#stage .l-megamenu__imagelink__title[target=_blank]::before {
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		content: var(--icon-blank);
		display: inline-block;
		position: absolute;
		top: 0.35em;
		left: 0;
		color: var(--color-link);
		font-size: 1.4rem;
		font-size: 14px;
		line-height: 1;
	}
	#stage .l-megamenu__imagelink a.l-megamenu__imagelink__inner {
		cursor: pointer;
	}
	#stage .l-megamenu__imagelink a.l-megamenu__imagelink__inner .l-megamenu__imagelink__title {
		transition: color 0.2s;
	}
	#stage .l-megamenu__imagelink a.l-megamenu__imagelink__inner .l-megamenu__imagelink__image img {
		transform: scale(1);
		transition: transform 0.3s ease-out;
	}
	#stage .l-megamenu__imagelink a.l-megamenu__imagelink__inner:hover .l-megamenu__imagelink__title {
		color: var(--color-hover);
		text-decoration: underline;
	}
	#stage .l-megamenu__imagelink a.l-megamenu__imagelink__inner:hover .l-megamenu__imagelink__image img {
		transform: scale(1.05);
	}
	#stage .l-megamenu__imagelink__content {
		padding: 0 10px;
	}
	#stage .l-megamenu__imagelink__image {
		margin-bottom: 16px;
		border-radius: 20px;
		overflow: hidden;
	}
	#stage .l-megamenu__imagelink + .l-megamenu__imagelink {
		margin-top: 10px;
	}
	#stage .l-megamenu__imagelink--sm .l-megamenu__imagelink__content {
		padding: 0;
	}
	#stage .l-megamenu__imagelink--sm .l-megamenu__imagelink__title {
		position: relative;
		padding-left: 25px;
	}
	/* アイコン画像セット */
	#stage .l-megamenu__iconset {
		display: grid;
		grid-template-columns: repeat(6, 1fr);
		gap: 25px 30px;
	}
	#stage .l-megamenu__iconitem__inner {
		display: grid;
		place-content: center;
		place-items: center;
		width: 100%;
		height: 100%;
		min-height: 160px;
		background-color: #fff;
		border-radius: 15px;
		overflow: hidden;
		color: var(--color-txt);
		text-align: center;
	}
	#stage .l-megamenu__iconitem__inner .l-megamenu__iconitem__image,
	#stage .l-megamenu__iconitem__inner .l-megamenu__iconitem__text {
		transition: opacity 0.2s;
	}
	#stage .l-megamenu__iconitem__inner:hover .l-megamenu__iconitem__image,
	#stage .l-megamenu__iconitem__inner:hover .l-megamenu__iconitem__text {
		opacity: 0.7;
	}
	#stage .l-megamenu__iconitem__image img {
		width: 60px;
	}
	#stage .l-megamenu__iconitem__text {
		margin-top: 28px;
		font-size: 1.4rem;
		font-size: 14px;
		font-weight: 500;
		line-height: 1.5;
	}
	/* 汎用ボタン */
	#stage .l-megamenu-buttons {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 30px 40px;
	}
	#stage .l-megamenu-button__inner {
		position: relative;
		display: flex;
		flex-wrap: nowrap;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 100%;
		min-height: 60px;
		overflow: hidden;
		background-color: #fff;
		border-radius: 30px;
		color: var(--color-txt);
		cursor: pointer;
		transition: color 0.3s;
	}
	#stage .l-megamenu-button__inner > span {
		padding: 10px 44px 10px 20px;
		text-align: center;
		font-size: 1.6rem;
		font-size: 16px;
		font-weight: 500;
		line-height: var(--line-height-s);
		color: inherit;
	}
	#stage .l-megamenu-button__inner:hover {
		color: var(--color-link);
		text-decoration: underline;
	}
	#stage .l-megamenu-button__inner:hover i {
		color: var(--color-link);
	}
	#stage .l-megamenu-button__inner:hover i.icon-pdf {
		color: var(--color-red);
	}
	#stage .l-megamenu-button i {
		position: absolute;
		top: 50%;
		right: 23px;
		transform: translateY(-50%);
		font-size: 1.4rem;
		font-size: 14px;
		color: var(--color-link);
	}
	#stage .l-megamenu-button i.icon-pdf {
		font-size: 1.6rem;
		font-size: 16px;
		color: var(--color-red);
	}
	/* テキストリンク */
	#stage .l-megamenu__link {
		display: inline-block;
	}
	#stage .l-megamenu__link > a {
		display: block;
		position: relative;
		padding-left: 25px;
		color: var(--color-txt);
		font-size: 1.6rem;
		font-size: 16px;
		font-weight: 500;
		line-height: var(--line-height-m);
		transition: color 0.2s;
	}
	#stage .l-megamenu__link > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
	#stage .l-megamenu__link > a::before {
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		content: var(--icon-arrow1-r);
		display: inline-block;
		position: absolute;
		top: 0.35em;
		left: 0;
		color: var(--color-link);
		font-size: 1.6rem;
		font-size: 16px;
		line-height: 1;
	}
	#stage .l-megamenu__link > a[target=_blank] {
		position: relative;
		padding-left: 20px;
	}
	#stage .l-megamenu__link > a[target=_blank]::before {
		font-family: iconfont !important;
		speak: none;
		font-style: normal;
		font-weight: normal;
		line-height: 1;
		content: var(--icon-blank);
		display: inline-block;
		position: absolute;
		top: 0.35em;
		left: 0;
		color: var(--color-link);
		font-size: 1.4rem;
		font-size: 14px;
		line-height: 1;
	}
	#stage .l-megamenu__link + .l-megamenu__link {
		margin-left: 40px;
	}
}
@media (min-width: 768px) and (max-width: 1140px) {
	#stage .l-megamenu__productitem__image img {
		width: 50px;
	}
}
@media (max-width: 1024px) {
	#stage .l-subnav {
		background-color: #fff;
		border-top: 1px solid var(--color-border);
		padding: 40px 20px 0;
	}
	#stage .l-subnav__item {
		color: var(--color-txt);
		font-size: 1.4rem;
		font-size: 14px;
	}
	#stage .l-subnav__item a {
		color: inherit;
	}
	#stage .l-subnav__item + .l-subnav__item {
		margin-top: 10px;
	}
}
@media (min-width: 1025px) {
	#stage .l-subnav {
		order: 1;
		display: flex;
		justify-content: flex-end;
		padding-top: 20px;
	}
	#stage .l-subnav__list {
		display: flex;
	}
	#stage .l-subnav__item {
		color: var(--color-txt);
		font-size: 1.6rem;
		font-size: 16px;
		line-height: var(--line-height-l);
	}
	#stage .l-subnav__item a {
		color: inherit;
		transition: color 0.2s;
	}
	#stage .l-subnav__item a:hover {
		color: var(--color-hover);
	}
	#stage .l-subnav__item + .l-subnav__item {
		margin-left: 40px;
	}
}

/*----------
	button container
----------*/
#stage .g-megamenu-container {
	margin: 0 auto;
}
@media (min-width: 1025px) {
	#stage .g-megamenu-container .g-megamenu-container__item {
		margin: 0;
		max-width: none;
	}
	#stage .g-megamenu-container--2up {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 40px;
	}
	#stage .g-megamenu-container--3up {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 40px;
	}
	#stage .g-megamenu-container--4up {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		gap: 40px 27px;
	}
	#stage .g-megamenu-container--5up {
		display: grid;
		grid-template-columns: repeat(5, 1fr);
		gap: 40px 24px;
	}
	#stage .g-megamenu-container--6up {
		display: grid;
		grid-template-columns: repeat(6, 1fr);
		gap: 40px 24px;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	#stage .g-megamenu-container--3up, #stage .g-megamenu-container--4up {
		grid-template-columns: repeat(2, 1fr);
	}
}

/*----------
	margin
----------*/
/* 汎用マージン */
.u-mt-xs {
	margin-top: 16px !important;
}
@media (min-width: 768px), print {
	.u-mt-xs {
		margin-top: 24px !important;
	}
}

.u-mb-xs {
	margin-bottom: 16px !important;
}
@media (min-width: 768px), print {
	.u-mb-xs {
		margin-bottom: 24px !important;
	}
}

.u-mt-s {
	margin-top: 24px !important;
}
@media (min-width: 768px), print {
	.u-mt-s {
		margin-top: 32px !important;
	}
}

.u-mb-s {
	margin-bottom: 24px !important;
}
@media (min-width: 768px), print {
	.u-mb-s {
		margin-bottom: 32px !important;
	}
}

.u-mt-m {
	margin-top: 32px !important;
}
@media (min-width: 768px), print {
	.u-mt-m {
		margin-top: 48px !important;
	}
}

.u-mb-m {
	margin-bottom: 32px !important;
}
@media (min-width: 768px), print {
	.u-mb-m {
		margin-bottom: 48px !important;
	}
}

.u-mt-l {
	margin-top: 48px !important;
}
@media (min-width: 768px), print {
	.u-mt-l {
		margin-top: 64px !important;
	}
}

.u-mb-l {
	margin-bottom: 48px !important;
}
@media (min-width: 768px), print {
	.u-mb-l {
		margin-bottom: 64px !important;
	}
}

.u-mt-xl {
	margin-top: 64px !important;
}
@media (min-width: 768px), print {
	.u-mt-xl {
		margin-top: 80px !important;
	}
}

.u-mb-xl {
	margin-bottom: 64px !important;
}
@media (min-width: 768px), print {
	.u-mb-xl {
		margin-bottom: 80px !important;
	}
}

.u-mt-xxl {
	margin-top: 80px !important;
}
@media (min-width: 768px), print {
	.u-mt-xxl {
		margin-top: 100px !important;
	}
}

.u-mb-xxl {
	margin-bottom: 80px !important;
}
@media (min-width: 768px), print {
	.u-mb-xxl {
		margin-bottom: 100px !important;
	}
}

.u-mt-none {
	margin-top: 0 !important;
}
@media (min-width: 768px), print {
	.u-mt-none {
		margin-top: 0 !important;
	}
}

.u-mb-none {
	margin-bottom: 0 !important;
}
@media (min-width: 768px), print {
	.u-mb-none {
		margin-bottom: 0 !important;
	}
}

/* ----------
マージンバリエーションその他（必要に応じて）
----------*/
/* 10px倍数 */
.u-mt-10 {
	margin-top: 10px !important;
}

.u-mt-20 {
	margin-top: 20px !important;
}

.u-mt-30 {
	margin-top: 30px !important;
}

.u-mt-40 {
	margin-top: 40px !important;
}

.u-mt-50 {
	margin-top: 50px !important;
}

.u-mt-60 {
	margin-top: 60px !important;
}

.u-mt-70 {
	margin-top: 70px !important;
}

.u-mt-80 {
	margin-top: 80px !important;
}

.u-mt-90 {
	margin-top: 90px !important;
}

.u-mt-100 {
	margin-top: 100px !important;
}

/* 8px倍数 */
.u-mt-8 {
	margin-top: 8px !important;
}

.u-mt-16 {
	margin-top: 16px !important;
}

.u-mt-24 {
	margin-top: 24px !important;
}

.u-mt-32 {
	margin-top: 32px !important;
}

.u-mt-40 {
	margin-top: 40px !important;
}

.u-mt-48 {
	margin-top: 48px !important;
}

.u-mt-56 {
	margin-top: 56px !important;
}

.u-mt-64 {
	margin-top: 64px !important;
}

.u-mt-72 {
	margin-top: 72px !important;
}

.u-mt-80 {
	margin-top: 80px !important;
}

/* SP-PC 倍マージン double */
.u-mt-dbl8 {
	margin-top: 8px !important;
}

.u-mt-dbl16 {
	margin-top: 16px !important;
}

.u-mt-dbl24 {
	margin-top: 24px !important;
}

.u-mt-dbl32 {
	margin-top: 32px !important;
}

.u-mt-dbl40 {
	margin-top: 40px !important;
}

.u-mt-dbl48 {
	margin-top: 48px !important;
}

.u-mt-dbl56 {
	margin-top: 56px !important;
}

.u-mt-dbl64 {
	margin-top: 64px !important;
}

.u-mt-dbl72 {
	margin-top: 72px !important;
}

.u-mt-dbl80 {
	margin-top: 80px !important;
}

@media (min-width: 768px), print {
	.u-mt-dbl8 {
		margin-top: 16px !important;
	}
	.u-mt-dbl16 {
		margin-top: 32px !important;
	}
	.u-mt-dbl24 {
		margin-top: 48px !important;
	}
	.u-mt-dbl32 {
		margin-top: 64px !important;
	}
	.u-mt-dbl40 {
		margin-top: 80px !important;
	}
	.u-mt-dbl48 {
		margin-top: 96px !important;
	}
	.u-mt-dbl56 {
		margin-top: 112px !important;
	}
	.u-mt-dbl64 {
		margin-top: 128px !important;
	}
	.u-mt-dbl72 {
		margin-top: 144px !important;
	}
	.u-mt-dbl80 {
		margin-top: 160px !important;
	}
}
/* SP-PC別マージン */
@media (min-width: 768px), print {
	.u-pc-mt-8 {
		margin-top: 8px !important;
	}
	.u-pc-mb-8 {
		margin-bottom: 8px !important;
	}
	.u-pc-ml-8 {
		margin-left: 8px !important;
	}
	.u-pc-mr-8 {
		margin-right: 8px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-8 {
		margin-top: 8px !important;
	}
	.u-sp-mb-8 {
		margin-bottom: 8px !important;
	}
	.u-sp-ml-8 {
		margin-left: 8px !important;
	}
	.u-sp-mr-8 {
		margin-right: 8px !important;
	}
}
@media (min-width: 768px), print {
	.u-pc-mt-16 {
		margin-top: 16px !important;
	}
	.u-pc-mb-16 {
		margin-bottom: 16px !important;
	}
	.u-pc-ml-16 {
		margin-left: 16px !important;
	}
	.u-pc-mr-16 {
		margin-right: 16px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-16 {
		margin-top: 16px !important;
	}
	.u-sp-mb-16 {
		margin-bottom: 16px !important;
	}
	.u-sp-ml-16 {
		margin-left: 16px !important;
	}
	.u-sp-mr-16 {
		margin-right: 16px !important;
	}
}
@media (min-width: 768px), print {
	.u-pc-mt-24 {
		margin-top: 24px !important;
	}
	.u-pc-mb-24 {
		margin-bottom: 24px !important;
	}
	.u-pc-ml-24 {
		margin-left: 24px !important;
	}
	.u-pc-mr-24 {
		margin-right: 24px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-24 {
		margin-top: 24px !important;
	}
	.u-sp-mb-24 {
		margin-bottom: 24px !important;
	}
	.u-sp-ml-24 {
		margin-left: 24px !important;
	}
	.u-sp-mr-24 {
		margin-right: 24px !important;
	}
}
@media (min-width: 768px), print {
	.u-pc-mt-32 {
		margin-top: 32px !important;
	}
	.u-pc-mb-32 {
		margin-bottom: 32px !important;
	}
	.u-pc-ml-32 {
		margin-left: 32px !important;
	}
	.u-pc-mr-32 {
		margin-right: 32px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-32 {
		margin-top: 32px !important;
	}
	.u-sp-mb-32 {
		margin-bottom: 32px !important;
	}
	.u-sp-ml-32 {
		margin-left: 32px !important;
	}
	.u-sp-mr-32 {
		margin-right: 32px !important;
	}
}
@media (min-width: 768px), print {
	.u-pc-mt-40 {
		margin-top: 40px !important;
	}
	.u-pc-mb-40 {
		margin-bottom: 40px !important;
	}
	.u-pc-ml-40 {
		margin-left: 40px !important;
	}
	.u-pc-mr-40 {
		margin-right: 40px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-40 {
		margin-top: 40px !important;
	}
	.u-sp-mb-40 {
		margin-bottom: 40px !important;
	}
	.u-sp-ml-40 {
		margin-left: 40px !important;
	}
	.u-sp-mr-40 {
		margin-right: 40px !important;
	}
}
@media (min-width: 768px), print {
	.u-pc-mt-48 {
		margin-top: 48px !important;
	}
	.u-pc-mb-48 {
		margin-bottom: 48px !important;
	}
	.u-pc-ml-48 {
		margin-left: 48px !important;
	}
	.u-pc-mr-48 {
		margin-right: 48px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-48 {
		margin-top: 48px !important;
	}
	.u-sp-mb-48 {
		margin-bottom: 48px !important;
	}
	.u-sp-ml-48 {
		margin-left: 48px !important;
	}
	.u-sp-mr-48 {
		margin-right: 48px !important;
	}
}
@media (min-width: 768px), print {
	.u-pc-mt-56 {
		margin-top: 56px !important;
	}
	.u-pc-mb-56 {
		margin-bottom: 56px !important;
	}
	.u-pc-ml-56 {
		margin-left: 56px !important;
	}
	.u-pc-mr-56 {
		margin-right: 56px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-56 {
		margin-top: 56px !important;
	}
	.u-sp-mb-56 {
		margin-bottom: 56px !important;
	}
	.u-sp-ml-56 {
		margin-left: 56px !important;
	}
	.u-sp-mr-56 {
		margin-right: 56px !important;
	}
}
@media (min-width: 768px), print {
	.u-pc-mt-64 {
		margin-top: 64px !important;
	}
	.u-pc-mb-64 {
		margin-bottom: 64px !important;
	}
	.u-pc-ml-64 {
		margin-left: 64px !important;
	}
	.u-pc-mr-64 {
		margin-right: 64px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-64 {
		margin-top: 64px !important;
	}
	.u-sp-mb-64 {
		margin-bottom: 64px !important;
	}
	.u-sp-ml-64 {
		margin-left: 64px !important;
	}
	.u-sp-mr-64 {
		margin-right: 64px !important;
	}
}
@media (min-width: 768px), print {
	.u-pc-mt-72 {
		margin-top: 72px !important;
	}
	.u-pc-mb-72 {
		margin-bottom: 72px !important;
	}
	.u-pc-ml-72 {
		margin-left: 72px !important;
	}
	.u-pc-mr-72 {
		margin-right: 72px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-72 {
		margin-top: 72px !important;
	}
	.u-sp-mb-72 {
		margin-bottom: 72px !important;
	}
	.u-sp-ml-72 {
		margin-left: 72px !important;
	}
	.u-sp-mr-72 {
		margin-right: 72px !important;
	}
}
@media (min-width: 768px), print {
	.u-pc-mt-80 {
		margin-top: 80px !important;
	}
	.u-pc-mb-80 {
		margin-bottom: 80px !important;
	}
	.u-pc-ml-80 {
		margin-left: 80px !important;
	}
	.u-pc-mr-80 {
		margin-right: 80px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-80 {
		margin-top: 80px !important;
	}
	.u-sp-mb-80 {
		margin-bottom: 80px !important;
	}
	.u-sp-ml-80 {
		margin-left: 80px !important;
	}
	.u-sp-mr-80 {
		margin-right: 80px !important;
	}
}

/*----------
	display
----------*/
@media (max-width: 767px) {
	.u-pc-v {
		display: none;
	}
}

@media (min-width: 768px), print {
	.u-sp-v {
		display: none;
	}
}

@media (min-width: 768px) and (max-width: 1024px) {
	.u-tab-v {
		display: block;
	}
}

@media (max-width: 1024px) {
	.u-tabpc-v {
		display: none;
	}
}

@media (min-width: 1024px) {
	.u-tabsp-v {
		display: none;
	}
}


/*----------
	text
----------*/
@media (min-width: 768px), print {
	.u-pcbr {
		display: block;
	}
}
@media (max-width: 767px) {
	.u-pcbr {
		display: none;
	}
}

@media (min-width: 768px), print {
	.u-pcsmbr {
		display: none;
	}
}
@media (max-width: 767px) {
	.u-pcsmbr {
		display: none;
	}
}
@media (min-width: 1025px) and (max-width: 1279px) {
	.u-pcsmbr {
		display: block;
	}
}

@media (min-width: 768px), print {
	.u-pcmdbr {
		display: none;
	}
}
@media (max-width: 767px) {
	.u-pcmdbr {
		display: none;
	}
}
@media (min-width: 1025px) and (max-width: 1279px) {
	.u-pcmdbr {
		display: none;
	}
}
@media (min-width: 1280px) and (max-width: 1439px) {
	.u-pcmdbr {
		display: block;
	}
}

@media (min-width: 768px), print {
	.u-tabbr {
		display: none;
	}
}
@media (max-width: 767px) {
	.u-tabbr {
		display: none;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	.u-tabbr {
		display: block;
	}
}

@media (max-width: 1024px) {
	.u-tabpcbr {
		display: none;
	}
}

@media (min-width: 768px), print {
	.u-spbr {
		display: none;
	}
}
@media (max-width: 767px) {
	.u-spbr {
		display: block;
	}
}

.u-txt-center {
	text-align: center !important;
}

@media (min-width: 768px), print {
	.u-txt-pccenter {
		text-align: center !important;
	}
}

.u-txt-right {
	text-align: right !important;
}

.u-txt-left {
	text-align: left !important;
}

.u-txt-normal {
	font-weight: 400 !important;
}

.u-txt-medium {
	font-weight: 500 !important;
}

.u-txt-bold {
	font-weight: 700 !important;
}

.u-txt-italic {
	font-style: italic !important;
}

.u-txt-strike {
	text-decoration: line-through !important;
}

.u-txt-indent {
	text-indent: 1em;
}

.u-txt-marker {
	font-weight: bold;
	background-image: linear-gradient(transparent 80%, #FFF7A6 80%);
}

.u-txt-prim {
	color: var(--color-prim) !important;
}

.u-txt-txt {
	color: var(--color-txt) !important;
}

.u-txt-white {
	color: #fff !important;
}

.u-txt-red {
	color: var(--color-red) !important;
}

.u-txt-caption {
	color: var(--color-txt-caption) !important;
}

.u-txt-nowrap {
	white-space: nowrap !important;
}

/* 文中リンク */
.u-txt-link {
	text-decoration: underline;
	color: var(--color-link);
}
@media (min-width: 768px), print {
	.u-txt-link {
		transition: color 0.2s;
	}
	.u-txt-link:hover {
		color: var(--color-hover);
	}
}

/* 文字サイズ */
.u-fz-10 {
	font-size: 1rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-10 {
		font-size: 1rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-10 {
		font-size: 1rem !important;
	}
}
.u-fz-11 {
	font-size: 1.1rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-11 {
		font-size: 1.1rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-11 {
		font-size: 1.1rem !important;
	}
}
.u-fz-12 {
	font-size: 1.2rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-12 {
		font-size: 1.2rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-12 {
		font-size: 1.2rem !important;
	}
}
.u-fz-13 {
	font-size: 1.3rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-13 {
		font-size: 1.3rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-13 {
		font-size: 1.3rem !important;
	}
}
.u-fz-14 {
	font-size: 1.4rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-14 {
		font-size: 1.4rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-14 {
		font-size: 1.4rem !important;
	}
}
.u-fz-15 {
	font-size: 1.5rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-15 {
		font-size: 1.5rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-15 {
		font-size: 1.5rem !important;
	}
}
.u-fz-16 {
	font-size: 1.6rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-16 {
		font-size: 1.6rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-16 {
		font-size: 1.6rem !important;
	}
}
.u-fz-17 {
	font-size: 1.7rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-17 {
		font-size: 1.7rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-17 {
		font-size: 1.7rem !important;
	}
}
.u-fz-18 {
	font-size: 1.8rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-18 {
		font-size: 1.8rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-18 {
		font-size: 1.8rem !important;
	}
}
.u-fz-19 {
	font-size: 1.9rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-19 {
		font-size: 1.9rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-19 {
		font-size: 1.9rem !important;
	}
}
.u-fz-20 {
	font-size: 2rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-20 {
		font-size: 2rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-20 {
		font-size: 2rem !important;
	}
}
.u-fz-21 {
	font-size: 2.1rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-21 {
		font-size: 2.1rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-21 {
		font-size: 2.1rem !important;
	}
}
.u-fz-22 {
	font-size: 2.2rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-22 {
		font-size: 2.2rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-22 {
		font-size: 2.2rem !important;
	}
}
.u-fz-23 {
	font-size: 2.3rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-23 {
		font-size: 2.3rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-23 {
		font-size: 2.3rem !important;
	}
}
.u-fz-24 {
	font-size: 2.4rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-24 {
		font-size: 2.4rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-24 {
		font-size: 2.4rem !important;
	}
}
.u-fz-25 {
	font-size: 2.5rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-25 {
		font-size: 2.5rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-25 {
		font-size: 2.5rem !important;
	}
}
.u-fz-26 {
	font-size: 2.6rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-26 {
		font-size: 2.6rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-26 {
		font-size: 2.6rem !important;
	}
}
.u-fz-27 {
	font-size: 2.7rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-27 {
		font-size: 2.7rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-27 {
		font-size: 2.7rem !important;
	}
}
.u-fz-28 {
	font-size: 2.8rem !important;
}

@media (min-width: 768px), print {
	.u-pc-fz-28 {
		font-size: 2.8rem !important;
	}
}
@media (max-width: 767px) {
	.u-sp-fz-28 {
		font-size: 2.8rem !important;
	}
}
/*----------
	image
----------*/
/* 角丸 */
.u-image-round {
	border-radius: 15px;
	overflow: hidden;
}
@media (min-width: 768px), print {
	.u-image-round {
		border-radius: 20px;
	}
}

/*----------
	width
----------*/
/* 固定px */
.u-w5px {
	width: 5px !important;
}

.u-w10px {
	width: 10px !important;
}

.u-w15px {
	width: 15px !important;
}

.u-w20px {
	width: 20px !important;
}

.u-w25px {
	width: 25px !important;
}

.u-w30px {
	width: 30px !important;
}

.u-w35px {
	width: 35px !important;
}

.u-w40px {
	width: 40px !important;
}

.u-w45px {
	width: 45px !important;
}

.u-w50px {
	width: 50px !important;
}

.u-w55px {
	width: 55px !important;
}

.u-w60px {
	width: 60px !important;
}

.u-w65px {
	width: 65px !important;
}

.u-w70px {
	width: 70px !important;
}

.u-w75px {
	width: 75px !important;
}

.u-w80px {
	width: 80px !important;
}

.u-w85px {
	width: 85px !important;
}

.u-w90px {
	width: 90px !important;
}

.u-w95px {
	width: 95px !important;
}

.u-w100px {
	width: 100px !important;
}

/* 相対% */
.u-w5per {
	width: 5% !important;
}

.u-w10per {
	width: 10% !important;
}

.u-w15per {
	width: 15% !important;
}

.u-w20per {
	width: 20% !important;
}

.u-w25per {
	width: 25% !important;
}

.u-w30per {
	width: 30% !important;
}

.u-w33per {
	width: 33% !important;
}

.u-w35per {
	width: 35% !important;
}

.u-w40per {
	width: 40% !important;
}

.u-w45per {
	width: 45% !important;
}

.u-w50per {
	width: 50% !important;
}

.u-w55per {
	width: 55% !important;
}

.u-w60per {
	width: 60% !important;
}

.u-w65per {
	width: 65% !important;
}

.u-w70per {
	width: 70% !important;
}

.u-w75per {
	width: 75% !important;
}

.u-w80per {
	width: 80% !important;
}

.u-w85per {
	width: 85% !important;
}

.u-w90per {
	width: 90% !important;
}

.u-w95per {
	width: 95% !important;
}

.u-w100per {
	width: 100% !important;
}

/* override */
#stage {
	padding-top: 70px;
}
@media (min-width: 1025px) {
	#stage {
		padding-top: 110px;
	}
}

#stage #header,
#stage .wrp-gnav,
#stage .mod-pagetop,
#stage .rwd-footer,
#stage #btnPagetop {
	display: none !important;
}

#stage .b-pagetop {
	visibility: hidden;
	pointer-events: none;
}

#stage .c-icontext > a,
#stage .c-icontext > span {
	font-size: 14px;
}
#stage .c-icontext i[class^=icon-] {
	font-size: 14px;
}
@media (min-width: 768px), print {
	#stage .c-icontext > a,
	#stage .c-icontext > span {
		font-size: 16px;
	}
	#stage .c-icontext i[class^=icon-] {
		font-size: 16px;
	}
}

/* icon */
@font-face {
	font-family: iconfont;
	src: url(/assets/fonts/iconfont.woff) format("woff"), url(/assets/fonts/iconfont.svg) format("svg");
	font-weight: normal;
	font-style: normal;
	font-display: block;
}
#stage .icon-plus, #stage .icon-minus, #stage .icon-close, #stage .icon-arrow2-t, #stage .icon-arrow2-r, #stage .icon-arrow2-l, #stage .icon-arrow2-b, #stage .icon-arrow1-t, #stage .icon-arrow1-r, #stage .icon-arrow1-l, #stage .icon-arrow1-b, #stage .icon-pdf, #stage .icon-blank, #stage .icon-modal, #stage .icon-search, #stage .icon-pause {
	display: inline-block;
	font-family: iconfont !important;
	speak: never;
	font-style: normal !important;
	font-size: inherit;
	font-weight: normal !important;
	font-variant: normal !important;
	text-transform: none;
	line-height: 1;
	color: inherit;
}
#stage .icon-pause::before {
	content: "\e900";
}
#stage .icon-search::before {
	content: "\e901";
}
#stage .icon-modal::before {
	content: "\e902";
}
#stage .icon-blank::before {
	content: "\e903";
}
#stage .icon-pdf::before {
	content: "\e904";
}
#stage .icon-arrow1-b::before {
	content: "\e905";
}
#stage .icon-arrow1-l::before {
	content: "\e906";
}
#stage .icon-arrow1-r::before {
	content: "\e907";
}
#stage .icon-arrow1-t::before {
	content: "\e908";
}
#stage .icon-arrow2-b::before {
	content: "\e909";
}
#stage .icon-arrow2-l::before {
	content: "\e90a";
}
#stage .icon-arrow2-r::before {
	content: "\e90b";
}
#stage .icon-arrow2-t::before {
	content: "\e90c";
}
#stage .icon-close::before {
	content: "\e90d";
}
#stage .icon-minus::before {
	content: "\e90e";
}
#stage .icon-plus::before {
	content: "\e910";
}

#stage .icon-pdf {
	color: var(--color-red);
}

#stage .icon-sns {
	display: inline-block;
	vertical-align: baseline;
	line-height: 1;
	width: 42px;
}

/* g-icon-container */
#stage .g-icon-container {
	display: flex;
	justify-content: center;
	font-size: 0;
}
#stage .g-icon-container__item {
	display: inline-block;
	margin-right: 20px;
}

/* c-icontext */
#stage .c-icontext > a,
#stage .c-icontext > span {
	display: table;
	padding-left: 20px;
	text-indent: -20px;
	color: var(--color-txt);
	font-size: 14px;
	line-height: var(--line-height-m);
}
#stage .c-icontext i[class^=icon-] {
	text-indent: 0;
	margin-right: 4px;
	font-size: 14px;
	transform: translateY(0.05em);
	color: var(--color-link);
}
#stage .c-icontext i[class^=icon-].icon-pdf {
	color: var(--color-red);
}
#stage .c-icontext + .c-icontext {
	margin-top: 8px;
}
@media (min-width: 768px), print {
	#stage .c-icontext > a,
	#stage .c-icontext > span {
		font-size: 16px;
	}
	#stage .c-icontext i[class^=icon-] {
		font-size: 16px;
		margin-right: 8px;
	}
	#stage .c-icontext > a {
		transition: color 0.2s;
	}
	#stage .c-icontext > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
}
#stage .c-icontext--right > a,
#stage .c-icontext--right > span {
	padding-right: 20px;
	text-indent: 0;
	color: var(--color-txt);
}
#stage .c-icontext--right i[class^=icon-] {
	margin-left: 10px;
	color: var(--color-link);
}
#stage .c-icontext--right i[class^=icon-].icon-pdf {
	color: var(--color-red);
}
@media (min-width: 768px), print {
	#stage .c-icontext--right i[class^=icon-] {
		margin-left: 10px;
	}
}
