@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=M+PLUS+Rounded+1c:wght@500;700;800&display=swap");
/* Reset */
*,
*::before,
*::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;
}

article,
aside,
details,
figcaption,
figure,
picture,
main,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

ul,
ol {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote::before,
blockquote::after,
q::before,
q::after {
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	empty-cells: show;
}

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: "";
}

/*----------
	base
----------*/
html {
	width: 100%;
	font-size: 62.5%;
	background-color: #fff;
}
html.is-locked {
	position: absolute;
	overflow: hidden;
}

body {
	position: relative;
	font-size: 1.6rem;
	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) {
	body {
		font-size: 1.4rem;
	}
}
@media print {
	body {
		min-width: 1240px;
		zoom: 0.8;
	}
}
body.is-locked {
	overflow: hidden;
}

a {
	text-decoration: none;
	color: var(--color-link);
}
@media (min-width: 768px), print {
	a:hover {
		text-decoration: none;
	}
}

img {
	width: 100%;
	height: auto;
	vertical-align: top;
}

sup {
	vertical-align: top;
	font-size: 0.7em;
}

sub {
	vertical-align: baseline;
	font-size: 0.7em;
}

input[type=text],
textarea,
select {
	font-family: inherit;
	font-size: 1.6rem;
}

/*----------
	main header
----------*/
@media print {
	header {
		display: none;
	}
}

.l-mainheader {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background-color: #fff;
	z-index: 10001;
}
.l-mainheader__nav {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	z-index: 1;
}
.l-mainheader__nav.is-open {
	display: block;
}
.l-mainheader__inner {
	z-index: 2;
}
@media (max-width: 1024px) {
	.l-mainheader__inner {
		width: 100%;
		height: 70px;
		padding: 0 20px;
	}
	.l-mainheader__nav {
		height: 100vh;
		background-color: #fff;
		overflow: auto;
	}
	.l-mainheader__nav.is-open {
		display: block;
		background-color: #fff;
		padding-top: 106px;
		padding-bottom: 150px;
	}
	.l-mainheader__logo {
		width: 180px;
		padding-top: 13px;
	}
	.l-mainheader__search {
		position: absolute;
		top: 20px;
		right: auto;
		left: 50%;
		transform: translateX(-50%);
		width: calc(100% - 40px);
		height: 56px;
		z-index: 3;
	}
	.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-weight: normal;
		line-height: 54px;
	}
	.l-mainheader__search .icon-search {
		position: absolute;
		top: 50%;
		right: 20px;
		transform: translateY(-50%);
		width: 17px;
		height: 16px;
		cursor: pointer;
	}
	.l-mainheader__navtoggle {
		position: absolute;
		top: 0;
		right: 0;
		display: flex;
		align-items: center;
		justify-content: center;
		width: 70px;
		height: 70px;
	}
	.l-mainheader__navtoggle__inner {
		position: relative;
		display: block;
		width: 24px;
		height: 2px;
		margin: 0 auto;
	}
	.l-mainheader__navtoggle__bartop, .l-mainheader__navtoggle__barmiddle, .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;
	}
	.l-mainheader__navtoggle__bartop {
		transform: translateY(-10px) rotate(0deg);
	}
	.l-mainheader__navtoggle__barbottom {
		transform: translateY(10px) rotate(0deg);
	}
	.l-mainheader__navtoggle.is-open .l-mainheader__navtoggle__bartop {
		opacity: 0;
	}
	.l-mainheader__navtoggle.is-open .l-mainheader__navtoggle__barmiddle {
		transform: translateY(0) rotate(45deg);
	}
	.l-mainheader__navtoggle.is-open .l-mainheader__navtoggle__barbottom {
		transform: translateY(0) rotate(-45deg);
	}
	.l-mainheader__layer {
		display: none;
	}
}
@media (min-width: 1025px) {
	.l-mainheader__inner {
		position: relative;
		width: 100%;
		max-width: 1560px;
		margin-inline: auto;
		height: 110px;
		padding: 0 60px;
	}
	.l-mainheader__search {
		position: relative;
		display: block;
		width: 200px;
		height: 32px;
		margin-left: 43px;
	}
	.l-mainheader__search__input[type=text] {
		width: 200px;
		padding-right: 35px;
		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-weight: normal;
		line-height: 32px;
	}
	.l-mainheader__search__input[type=text]::placeholder {
		color: var(--color-txt);
		font-size: 1.4rem;
	}
	.l-mainheader__search .icon-search {
		position: absolute;
		top: calc(50% + 1px);
		right: 20px;
		transform: translateY(-50%);
		width: 13px;
		height: 14px;
		cursor: pointer;
	}
	.l-mainheader__navtoggle {
		display: none;
	}
	.l-mainheader__nav {
		display: block;
		position: absolute;
		top: 0;
		left: auto;
		right: 60px;
		z-index: auto;
		width: 100%;
		max-width: 1320px;
		height: 100%;
	}
	.l-mainheader__nav__inner {
		display: flex;
		flex-direction: column;
	}
	.l-mainheader__logo {
		position: relative;
		width: 240px;
		padding-top: 27px;
		z-index: 1;
	}
	.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;
	}
	.l-mainheader__layer.pc-megamenu-active {
		opacity: 1;
		visibility: visible;
		pointer-events: visible;
		cursor: pointer;
	}
}
@media (min-width: 1025px) and (max-width: 1279px) {
	.l-mainheader__inner {
		padding: 0 30px;
	}
	.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 navigation
----------*/
@media (max-width: 1024px) {
	.l-mainnav {
		background: #fff;
	}
	.l-mainnav__item.is-hierarichical.is-open .l-mainnav__cattop > button::after {
		content: var(--icon-minus);
	}
	.l-mainnav__item.is-hierarichical.is-open .l-mainnav__sub {
		height: auto;
		opacity: 1;
		pointer-events: visible;
	}
	.l-mainnav__cattop {
		position: relative;
		border-top: 1px solid var(--color-border);
	}
	.l-mainnav__cattop > button {
		display: block;
		position: absolute;
		top: 0;
		right: 0;
		width: 60px;
		height: 100%;
		z-index: 1;
		cursor: pointer;
	}
	.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%;
	}
	.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-weight: 500;
		line-height: 22px;
	}
	.l-mainnav__cattop > a {
		display: block;
		padding: 14px 50px 14px 20px;
		color: inherit;
		font-size: 1.6rem;
		font-weight: 500;
	}
	.l-mainnav__sub {
		height: 0;
		position: relative;
		overflow: hidden;
		opacity: 0;
		pointer-events: none;
		transition: all 0.4s linear;
	}
	.l-mainnav__sub-close {
		display: none;
	}
	.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-weight: 500;
		text-align: center;
		line-height: 48px;
	}
	.l-mainnav__close > i {
		margin-left: 10px;
		color: var(--color-link);
		transform: translateY(0.1em);
	}
}
@media (min-width: 1025px) {
	.l-mainnav {
		order: 2;
		display: flex;
		justify-content: flex-end;
	}
	.l-mainnav__main {
		display: flex;
	}
	.l-mainnav__item:last-child .l-mainnav__cattop a,
	.l-mainnav__item:last-child .l-mainnav__cattop span {
		padding-right: 0;
	}
	.l-mainnav__cattop > button {
		display: none;
	}
	.l-mainnav__cattop > a {
		position: relative;
		display: block;
		height: 58px;
		color: inherit;
		transition: color 0.2s;
	}
	.l-mainnav__cattop > a span {
		display: block;
	}
	.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;
	}
	.l-mainnav__cattop > a:hover span::after {
		opacity: 1;
		transition-delay: 0.3s;
	}
	.l-mainnav__cattop > a.is-hover span::after, .l-mainnav__cattop > a.is-active span::after {
		opacity: 1;
	}
	.l-mainnav__cattop > span,
	.l-mainnav__cattop > a > span {
		display: block;
		padding: 15px 20px 14px;
		font-size: 1.6rem;
		font-weight: 500;
		line-height: var(--line-height-l);
	}
	.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;
	}
	.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-weight: 500;
		text-align: center;
		line-height: 48px;
		transition: color 0.2s;
		cursor: pointer;
	}
	.l-mainnav__sub-close > i {
		margin-left: 10px;
		color: var(--color-link);
		transform: translateY(0.1em);
	}
	.l-mainnav__sub-close:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
	.l-mainnav__sub.is-hung {
		opacity: 1;
		visibility: visible;
		pointer-events: visible;
	}
	.l-mainnav__close {
		display: none;
	}
}
@media (min-width: 1025px) and (max-width: 1279px) {
	.l-mainnav__cattop {
		height: 100%;
	}
	.l-mainnav__cattop > a {
		height: 100%;
	}
	.l-mainnav__cattop > span,
	.l-mainnav__cattop > a > span {
		padding: 8px 10px 5px;
		line-height: var(--line-height-s);
		text-align: center;
	}
}

.l-megamenu {
	width: 100%;
	max-width: 1260px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
@media (min-width: 768px), print {
	.l-megamenu {
		padding-left: 30px;
		padding-right: 30px;
	}
}
@media (max-width: 1024px) {
	.l-megamenu {
		padding: 16px 20px 7px 36px;
		background-color: var(--color-bg-blue);
	}
	.l-megamenu__categorytop a {
		color: var(--color-txt);
		font-size: 1.6rem;
		font-weight: 400;
	}
	.l-megamenu__categorytop i {
		position: relative;
		top: 0.1em;
		color: var(--color-link);
		margin-right: 5px;
	}
	.l-megamenu__block {
		padding: 16px 22px 17px;
		border-bottom: 1px solid var(--color-border);
	}
	.l-megamenu__block:last-of-type {
		border-bottom: none;
	}
}
@media (min-width: 1025px) {
	.l-megamenu {
		position: relative;
		padding-top: 50px;
		padding-bottom: 50px;
	}
	.l-megamenu__categorytop {
		padding-right: 200px;
	}
	.l-megamenu__categorytop a {
		color: var(--color-txt);
		font-family: var(--font-mplus);
		font-size: 3.4rem;
		font-weight: 500;
		transition: color 0.2s;
	}
	.l-megamenu__categorytop a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
	.l-megamenu__categorytop i {
		position: relative;
		top: 0.1em;
		color: var(--color-link);
		margin-right: 15px;
	}
	.l-megamenu__block {
		margin-top: 44px;
	}
}

/*----------
	個別パーツ設定
----------*/
@media (max-width: 1024px) {
	/* 商品・キャンペーン */
	.l-megamenu__productitem__inner {
		position: relative;
		display: block;
		width: 100%;
		padding-left: 20px;
		color: var(--color-txt);
	}
	.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;
		line-height: 1;
	}
	.l-megamenu__productitem__inner[target=_blank] {
		position: relative;
		padding-left: 20px;
	}
	.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;
		line-height: 1;
	}
	.l-megamenu__productitem__image {
		display: none;
	}
	.l-megamenu__productitem__text {
		font-size: 1.4rem;
		font-weight: 400;
		line-height: 1.5;
	}
	.l-megamenu__productitem + .l-megamenu__productitem {
		margin-top: 10px;
	}
	/* 画像セット */
	.l-megamenu__imagelink__inner.u-pc-v {
		display: none;
	}
	.l-megamenu__imagelink__inner.u-sp-v {
		display: block;
	}
	.l-megamenu__imagelink__title {
		position: relative;
		padding-left: 20px;
		color: var(--color-txt);
		font-size: 1.4rem;
		font-weight: 400;
		line-height: var(--line-height-m);
	}
	.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;
		line-height: 1;
	}
	.l-megamenu__imagelink__title[target=_blank] {
		position: relative;
		padding-left: 20px;
	}
	.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;
		line-height: 1;
	}
	.l-megamenu__imagelink__content {
		padding-right: 0;
		padding-left: 0;
	}
	.l-megamenu__imagelink__image {
		display: none;
	}
	.l-megamenu__imagelink + .l-megamenu__imagelink {
		margin-top: 10px;
	}
	/* アイコン画像セット */
	.l-megamenu__iconitem__inner {
		display: block;
		position: relative;
		width: 100%;
		padding-left: 20px;
		color: var(--color-txt);
	}
	.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;
		line-height: 1;
	}
	.l-megamenu__iconitem__inner[target=_blank] {
		position: relative;
		padding-left: 20px;
	}
	.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;
		line-height: 1;
	}
	.l-megamenu__iconitem__image {
		display: none;
	}
	.l-megamenu__iconitem__text {
		font-size: 1.4rem;
		font-weight: 400;
		line-height: 1.5;
	}
	.l-megamenu__iconitem + .l-megamenu__iconitem {
		margin-top: 10px;
	}
	/* 汎用ボタン */
	.l-megamenu-button__inner {
		position: relative;
		display: block;
		width: 100%;
		color: var(--color-txt);
	}
	.l-megamenu-button__inner > span {
		padding: 0 0 0 20px;
		text-align: center;
		font-size: 1.4rem;
		font-weight: 400;
		line-height: var(--line-height-s);
		color: inherit;
	}
	.l-megamenu-button i {
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%);
		font-size: 1.2rem;
		color: var(--color-link);
	}
	.l-megamenu-button + .l-megamenu-button {
		margin-top: 10px;
	}
	/* テキストリンク */
	.l-megamenu__link {
		margin: 0 -22px;
	}
	.l-megamenu__link > a {
		display: block;
		position: relative;
		color: var(--color-txt);
		font-size: 1.4rem;
		line-height: var(--line-height-m);
	}
	.l-megamenu__link + .l-megamenu__link {
		margin-top: 10px;
	}
}
@media (min-width: 1025px) {
	/* 商品・キャンペーン */
	.l-megamenu__products {
		display: grid;
		grid-template-columns: repeat(6, 1fr);
		gap: 25px 30px;
	}
	.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;
	}
	.l-megamenu__productitem__inner .l-megamenu__productitem__image,
	.l-megamenu__productitem__inner .l-megamenu__productitem__text {
		transition: opacity 0.2s;
	}
	.l-megamenu__productitem__inner:hover .l-megamenu__productitem__image,
	.l-megamenu__productitem__inner:hover .l-megamenu__productitem__text {
		opacity: 0.7;
	}
	.l-megamenu__productitem__image {
		display: flex;
		justify-content: center;
	}
	.l-megamenu__productitem__image img {
		width: 77px;
	}
	.l-megamenu__productitem__text {
		margin-top: 10px;
		font-size: 1.4rem;
		font-weight: 500;
		line-height: 1.5;
	}
	.l-megamenu__productitem--milk .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(20%);
	}
	.l-megamenu__productitem--milk .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-20%);
	}
	.l-megamenu__productitem--juice .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(20%);
	}
	.l-megamenu__productitem--juice .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-20%);
	}
	.l-megamenu__productitem--takuhai .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(20%);
	}
	.l-megamenu__productitem--takuhai .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-20%);
	}
	.l-megamenu__productitem--cheese .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(5%);
	}
	.l-megamenu__productitem--cheese .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-5%);
	}
	.l-megamenu__productitem--butter-margarine .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(5%);
	}
	.l-megamenu__productitem--butter-margarine .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-5%);
	}
	.l-megamenu__productitem--baby-milk .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(5%);
	}
	.l-megamenu__productitem--baby-milk .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-5%);
	}
	.l-megamenu__productitem--functional-food .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(5%);
	}
	.l-megamenu__productitem--functional-food .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-5%);
	}
	.l-megamenu__productitem--other .l-megamenu__productitem__image figure:nth-child(1) {
		transform: translateX(10%);
	}
	.l-megamenu__productitem--other .l-megamenu__productitem__image figure:nth-child(2) {
		transform: translateX(-10%);
	}
	/* 画像セット */
	.l-megamenu__imagelink__inner.u-pc-v {
		display: block;
	}
	.l-megamenu__imagelink__inner.u-sp-v {
		display: none;
	}
	.l-megamenu__imagelink__title {
		position: relative;
		padding-left: 30px;
		color: var(--color-txt);
		font-size: 1.6rem;
		font-weight: 500;
		line-height: var(--line-height-m);
	}
	.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;
		line-height: 1;
	}
	.l-megamenu__imagelink__title[target=_blank] {
		position: relative;
		padding-left: 20px;
	}
	.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;
		line-height: 1;
	}
	.l-megamenu__imagelink a.l-megamenu__imagelink__inner {
		cursor: pointer;
	}
	.l-megamenu__imagelink a.l-megamenu__imagelink__inner .l-megamenu__imagelink__title {
		transition: color 0.2s;
	}
	.l-megamenu__imagelink a.l-megamenu__imagelink__inner .l-megamenu__imagelink__image img {
		transform: scale(1);
		transition: transform 0.3s ease-out;
	}
	.l-megamenu__imagelink a.l-megamenu__imagelink__inner:hover .l-megamenu__imagelink__title {
		color: var(--color-hover);
		text-decoration: underline;
	}
	.l-megamenu__imagelink a.l-megamenu__imagelink__inner:hover .l-megamenu__imagelink__image img {
		transform: scale(1.05);
	}
	.l-megamenu__imagelink__content {
		padding: 0 10px;
	}
	.l-megamenu__imagelink__image {
		margin-bottom: 16px;
		border-radius: 20px;
		overflow: hidden;
	}
	.l-megamenu__imagelink + .l-megamenu__imagelink {
		margin-top: 10px;
	}
	.l-megamenu__imagelink--sm .l-megamenu__imagelink__content {
		padding: 0;
	}
	.l-megamenu__imagelink--sm .l-megamenu__imagelink__title {
		position: relative;
		padding-left: 25px;
	}
	/* アイコン画像セット */
	.l-megamenu__iconset {
		display: grid;
		grid-template-columns: repeat(6, 1fr);
		gap: 25px 30px;
	}
	.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;
	}
	.l-megamenu__iconitem__inner .l-megamenu__iconitem__image,
	.l-megamenu__iconitem__inner .l-megamenu__iconitem__text {
		transition: opacity 0.2s;
	}
	.l-megamenu__iconitem__inner:hover .l-megamenu__iconitem__image,
	.l-megamenu__iconitem__inner:hover .l-megamenu__iconitem__text {
		opacity: 0.7;
	}
	.l-megamenu__iconitem__image img {
		width: 60px;
	}
	.l-megamenu__iconitem__text {
		margin-top: 28px;
		font-size: 1.4rem;
		font-weight: 500;
		line-height: 1.5;
	}
	/* 汎用ボタン */
	.l-megamenu-buttons {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 30px 40px;
	}
	.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;
	}
	.l-megamenu-button__inner > span {
		padding: 10px 44px 10px 20px;
		text-align: center;
		font-size: 1.6rem;
		font-weight: 500;
		line-height: var(--line-height-s);
		color: inherit;
	}
	.l-megamenu-button__inner:hover {
		color: var(--color-link);
		text-decoration: underline;
	}
	.l-megamenu-button__inner:hover i {
		color: var(--color-link);
	}
	.l-megamenu-button__inner:hover i.icon-pdf {
		color: var(--color-red);
	}
	.l-megamenu-button i {
		position: absolute;
		top: 50%;
		right: 23px;
		transform: translateY(-50%);
		font-size: 1.4rem;
		color: var(--color-link);
	}
	.l-megamenu-button i.icon-pdf {
		font-size: 1.6rem;
		color: var(--color-red);
	}
	/* テキストリンク */
	.l-megamenu__link {
		display: inline-block;
	}
	.l-megamenu__link > a {
		display: block;
		position: relative;
		padding-left: 25px;
		color: var(--color-txt);
		font-size: 1.6rem;
		font-weight: 500;
		line-height: var(--line-height-m);
		transition: color 0.2s;
	}
	.l-megamenu__link > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
	.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;
		line-height: 1;
	}
	.l-megamenu__link > a[target=_blank] {
		position: relative;
		padding-left: 20px;
	}
	.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;
		line-height: 1;
	}
	.l-megamenu__link + .l-megamenu__link {
		margin-left: 40px;
	}
}
@media (min-width: 768px) and (max-width: 1140px) {
	.l-megamenu__productitem__image img {
		width: 50px;
	}
}
@media (max-width: 1024px) {
	.l-subnav {
		background-color: #fff;
		border-top: 1px solid var(--color-border);
		padding: 40px 20px 0;
	}
	.l-subnav__item {
		color: var(--color-txt);
		font-size: 1.4rem;
	}
	.l-subnav__item a {
		color: inherit;
	}
	.l-subnav__item + .l-subnav__item {
		margin-top: 10px;
	}
}
@media (min-width: 1025px) {
	.l-subnav {
		order: 1;
		display: flex;
		justify-content: flex-end;
		padding-top: 20px;
	}
	.l-subnav__list {
		display: flex;
	}
	.l-subnav__item {
		color: var(--color-txt);
		font-size: 1.6rem;
		line-height: var(--line-height-l);
	}
	.l-subnav__item a {
		color: inherit;
		transition: color 0.2s;
	}
	.l-subnav__item a:hover {
		color: var(--color-hover);
	}
	.l-subnav__item + .l-subnav__item {
		margin-left: 40px;
	}
}

/*----------
	button container
----------*/
.g-megamenu-container {
	margin: 0 auto;
}
@media (min-width: 1025px) {
	.g-megamenu-container .g-megamenu-container__item {
		margin: 0;
		max-width: none;
	}
	.g-megamenu-container--2up {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 40px;
	}
	.g-megamenu-container--3up {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 40px;
	}
	.g-megamenu-container--4up {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		gap: 40px 27px;
	}
	.g-megamenu-container--5up {
		display: grid;
		grid-template-columns: repeat(5, 1fr);
		gap: 40px 24px;
	}
	.g-megamenu-container--6up {
		display: grid;
		grid-template-columns: repeat(6, 1fr);
		gap: 40px 24px;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	.g-megamenu-container--3up, .g-megamenu-container--4up {
		grid-template-columns: repeat(2, 1fr);
	}
}

/*----------
	main sidenavi
----------*/
.l-sidenav-lv2 {
	padding: 14px 20px 12px;
	background-color: var(--color-prim);
	border-radius: 15px 15px 0 0;
	color: #fff;
	font-family: var(--font-mplus);
	font-size: 1.6rem;
	font-weight: 500;
	line-height: var(--line-height-m);
}
.l-sidenav-lv2 > span,
.l-sidenav-lv2 > a {
	display: block;
	color: inherit;
}
.l-sidenav-lv3 {
	border: 1px solid var(--color-border);
	border-top: 0;
	border-radius: 0 0 15px 15px;
}
.l-sidenav-lv3 > .l-sidenav__item {
	line-height: var(--line-height-l);
}
.l-sidenav-lv3 > .l-sidenav__item > .l-sidenav__title {
	position: relative;
	padding: 14px 20px 16px;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: var(--line-height-m);
}
.l-sidenav-lv3 > .l-sidenav__item > .l-sidenav__title > a {
	display: block;
	color: inherit;
}
.l-sidenav-lv3 > .l-sidenav__item > .l-sidenav__title > span,
.l-sidenav-lv3 > .l-sidenav__item > .l-sidenav__title > a {
	position: relative;
	display: block;
}
.l-sidenav-lv3 > .l-sidenav__item .l-sidenav__expand {
	display: block;
	position: absolute;
	top: 50%;
	right: 14px;
	transform: translateY(-50%);
	width: 24px;
	height: 24px;
	background-color: #fff;
	border: 1px solid var(--color-link);
	border-radius: 100%;
	z-index: 1;
	cursor: pointer;
}
.l-sidenav-lv3 > .l-sidenav__item .l-sidenav__expand::before {
	content: var(--icon-plus);
	font-family: iconfont !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	display: grid;
	place-content: center;
	color: var(--color-link);
	font-size: 1.2rem;
	font-weight: 500;
	line-height: 22px;
	text-align: center;
}
.l-sidenav-lv3 > .l-sidenav__item:not(:last-child) {
	border-bottom: 1px solid var(--color-border);
}
.l-sidenav-lv3 > .l-sidenav__item:has(.l-sidenav__expand) {
	position: relative;
}
.l-sidenav-lv3 > .l-sidenav__item:has(.l-sidenav__expand) > .l-sidenav__title {
	padding-right: 50px;
}
.l-sidenav-lv3 > .l-sidenav__item.is-active > .l-sidenav__title {
	color: var(--color-link);
	font-weight: 700;
	text-decoration: underline;
}
.l-sidenav-lv3 > .l-sidenav__item.is-active > .l-sidenav__title > a::before,
.l-sidenav-lv3 > .l-sidenav__item.is-active > .l-sidenav__title > span::before {
	content: "";
	display: block;
	position: absolute;
	top: 0.6em;
	left: -20px;
	width: 12px;
	height: 5px;
	background-color: var(--color-link);
	border-radius: 0 3px 3px 0;
}
.l-sidenav-lv3 > .l-sidenav__item.is-open {
	padding-bottom: 20px;
}
.l-sidenav-lv3 > .l-sidenav__item.is-open .l-sidenav__expand::before {
	content: var(--icon-minus);
}
.l-sidenav-lv3 > .l-sidenav__item.is-open .l-sidenav-lv4 {
	height: auto;
	opacity: 1;
	pointer-events: visible;
}
.l-sidenav-lv4 {
	height: 0;
	position: relative;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
	transition: all 0.4s linear;
}
.l-sidenav-lv4 > .l-sidenav__item {
	padding: 0 20px 0 36px;
}
.l-sidenav-lv4 > .l-sidenav__item > .l-sidenav__title {
	font-size: 1.4rem;
	font-weight: 400;
	line-height: var(--line-height-m);
}
.l-sidenav-lv4 > .l-sidenav__item > .l-sidenav__title > a,
.l-sidenav-lv4 > .l-sidenav__item > .l-sidenav__title > span {
	position: relative;
	display: block;
	color: #333;
}
.l-sidenav-lv4 > .l-sidenav__item + .l-sidenav__item {
	margin-top: 8px;
}
.l-sidenav-lv4 > .l-sidenav__item.is-active > .l-sidenav__title {
	font-weight: 700;
	text-decoration: underline;
}
.l-sidenav-lv4 > .l-sidenav__item.is-active > .l-sidenav__title > a,
.l-sidenav-lv4 > .l-sidenav__item.is-active > .l-sidenav__title > span {
	color: var(--color-link);
}
.l-sidenav-lv4 > .l-sidenav__item.is-active > .l-sidenav__title > a::before,
.l-sidenav-lv4 > .l-sidenav__item.is-active > .l-sidenav__title > span::before {
	content: "";
	display: block;
	position: absolute;
	top: 0.5em;
	left: -15px;
	width: 8px;
	height: 8px;
	background-color: var(--color-link);
	border-radius: 100%;
}
.l-sidenav-lv5 {
	padding-left: 13px;
	margin-top: 16px;
	margin-bottom: 14px;
	border-left: 2px dotted var(--color-border);
}
.l-sidenav-lv5 > .l-sidenav__item > .l-sidenav__title {
	font-size: 1.3rem;
	font-weight: 400;
	line-height: var(--line-height-m);
}
.l-sidenav-lv5 > .l-sidenav__item > .l-sidenav__title > a,
.l-sidenav-lv5 > .l-sidenav__item > .l-sidenav__title > span {
	position: relative;
	display: block;
	color: #333;
}
.l-sidenav-lv5 > .l-sidenav__item + .l-sidenav__item {
	margin-top: 5px;
}
.l-sidenav-lv5 > .l-sidenav__item.is-active > .l-sidenav__title {
	display: inline-block;
	text-decoration: underline;
	font-weight: 700;
	line-height: var(--line-height-m);
}
.l-sidenav-lv5 > .l-sidenav__item.is-active > .l-sidenav__title > a,
.l-sidenav-lv5 > .l-sidenav__item.is-active > .l-sidenav__title > span {
	color: var(--color-link);
}
.l-sidenav-lv5 > .l-sidenav__item.is-active > .l-sidenav__title > a::before,
.l-sidenav-lv5 > .l-sidenav__item.is-active > .l-sidenav__title > span::before {
	content: "";
	display: block;
	position: absolute;
	top: 0.5em;
	left: -18px;
	width: 8px;
	height: 8px;
	background-color: var(--color-link);
	border-radius: 100%;
}
@media (min-width: 768px), print {
	.l-sidenav-lv2 {
		padding: 24px 20px 21px;
		border-radius: 20px 20px 0 0;
		font-size: 2rem;
	}
	.l-sidenav-lv2 > span,
	.l-sidenav-lv2 > a {
		display: block;
		color: inherit;
	}
	.l-sidenav-lv2 > a:hover {
		text-decoration: underline;
	}
	.l-sidenav-lv3 {
		border-radius: 0 0 20px 20px;
	}
	.l-sidenav-lv3 > .l-sidenav__item {
		line-height: var(--line-height-l);
	}
	.l-sidenav-lv3 > .l-sidenav__item > .l-sidenav__title {
		padding: 14px 20px 16px;
		font-size: 1.6rem;
	}
	.l-sidenav-lv3 > .l-sidenav__item > .l-sidenav__title > a {
		transition: color 0.2s;
	}
	.l-sidenav-lv3 > .l-sidenav__item > .l-sidenav__title > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
	.l-sidenav-lv3 > .l-sidenav__item .l-sidenav__expand {
		transition: background-color 0.3s;
	}
	.l-sidenav-lv3 > .l-sidenav__item .l-sidenav__expand::before {
		transition: color 0.3s;
	}
	.l-sidenav-lv3 > .l-sidenav__item .l-sidenav__expand:hover {
		background-color: var(--color-hover);
	}
	.l-sidenav-lv3 > .l-sidenav__item .l-sidenav__expand:hover::before {
		color: #fff;
	}
	.l-sidenav-lv4 > .l-sidenav__item > .l-sidenav__title > a {
		transition: color 0.2s;
	}
	.l-sidenav-lv4 > .l-sidenav__item > .l-sidenav__title > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
	.l-sidenav-lv5 > .l-sidenav__item > .l-sidenav__title > a {
		transition: color 0.2s;
	}
	.l-sidenav-lv5 > .l-sidenav__item > .l-sidenav__title > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
}

/*----------
	main footer
----------*/
@media print {
	footer {
		display: none;
	}
}

.l-mainfooter {
	background: #fff;
	border-top: 2px solid var(--color-prim);
}
.l-mainfooter__inner {
	max-width: 1260px;
	margin: 0 auto;
	padding-bottom: 30px;
}
.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;
}
.l-mainfooter__backhead.is-visible {
	opacity: 1;
	pointer-events: auto;
}
.l-mainfooter__backhead > a {
	display: grid;
	place-content: center;
	height: 100%;
	background-color: #848484;
	border-radius: 100%;
	color: inherit;
}
.l-mainfooter__backhead i {
	display: inline-block;
	color: #fff;
	font-size: 1.4rem;
}
.l-mainfooter__logo {
	padding: 30px 20px 24px;
}
.l-mainfooter__logo img {
	display: block;
	max-width: 200px;
	margin: auto;
}
.l-mainfooter__copyright {
	margin-top: 30px;
	text-align: center;
	font-size: 1.1rem;
	color: var(--color-txt-caption);
}
.l-mainfooter__information {
	padding: 40px 20px 0;
}
.l-mainfooter__contact__inner {
	display: grid;
	place-content: center;
	width: 100%;
	height: 60px;
	background-color: var(--color-bg-blue);
	border-radius: 10px;
}
.l-mainfooter__contact__inner > p {
	display: inline;
	position: relative;
	padding-left: 60px;
	color: var(--color-txt);
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.5;
}
.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;
}
.l-mainfooter__sns {
	display: grid;
	place-content: center;
	place-items: center;
	gap: 26px 0;
	margin-top: 40px;
}
@media (min-width: 768px), print {
	.l-mainfooter__inner {
		padding: 0 30px 30px;
	}
	.l-mainfooter__backhead {
		width: 56px;
		height: 56px;
		right: 32px;
		bottom: 32px;
	}
	.l-mainfooter__backhead a {
		transition: background-color 0.3s;
	}
	.l-mainfooter__backhead a:hover {
		background-color: #333;
	}
	.l-mainfooter__logo {
		padding: 40px 0 35px;
	}
	.l-mainfooter__logo img {
		max-width: 240px;
	}
	.l-mainfooter__logo a {
		transition: opacity 0.3s;
	}
	.l-mainfooter__logo a:hover {
		opacity: 0.7;
	}
	.l-mainfooter__copyright {
		margin-top: 35px;
		font-size: 1.1rem;
	}
	.l-mainfooter__information {
		padding-left: 0;
		padding-right: 0;
	}
	.l-mainfooter__information__upper {
		display: flex;
		justify-content: center;
	}
	.l-mainfooter__contact {
		flex: 0 0 300px;
		margin-right: 40px;
	}
	.l-mainfooter__contact__inner {
		width: 300px;
		height: 75px;
		background-color: var(--color-bg-blue);
		border-radius: 15px;
	}
	.l-mainfooter__contact__inner > p {
		padding-left: 76px;
		transition: color 0.3s;
	}
	.l-mainfooter__contact__inner > p span {
		display: inline-block;
		text-indent: -0.5em;
	}
	.l-mainfooter__contact__inner > p::before {
		width: 64px;
		height: 48px;
	}
	.l-mainfooter__contact__inner:hover > p,
	.l-mainfooter__contact__inner:hover span {
		color: var(--color-hover);
		text-decoration: underline;
	}
	.l-mainfooter__sns {
		margin-top: 0;
		gap: 14px 0;
	}
	.l-mainfooter__sns__items a {
		transition: opacity 0.3s;
	}
	.l-mainfooter__sns__items a:hover {
		opacity: 0.7;
	}
}

.l-fnav-main {
	border-top: 1px solid var(--color-border);
}
.l-fnav-main__item {
	border-bottom: 1px solid var(--color-border);
}
.l-fnav-main__item > a {
	display: block;
	padding: 16px 20px 15px;
	color: var(--color-txt);
	font-size: 1.6rem;
	font-weight: 700;
	line-height: var(--line-height-l);
}
@media (min-width: 768px), print {
	.l-fnav-main {
		border-top: 0;
	}
	.l-fnav-main__items {
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
		gap: 10px 35px;
	}
	.l-fnav-main__item {
		border-bottom: 0;
	}
	.l-fnav-main__item > a {
		position: relative;
		padding: 0 0 12px;
		transition: color 0.3s;
	}
	.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;
	}
	.l-fnav-main__item > a:hover {
		color: var(--color-hover);
	}
	.l-fnav-main__item > a:hover::after {
		opacity: 1;
	}
}

.l-fnav-sub__items {
	display: flex;
	flex-wrap: wrap;
	gap: 15px 18px;
	margin-top: 30px;
}
.l-fnav-sub__item {
	font-size: 1.2rem;
	line-height: 1;
	color: var(--color-txt);
}
.l-fnav-sub__item > a {
	color: inherit;
}
.l-fnav-sub__item > a > span {
	display: block;
	padding: 0 20px;
}
@media (min-width: 768px), print {
	.l-fnav-sub__items {
		justify-content: center;
		gap: 15px 30px;
	}
	.l-fnav-sub__item > a {
		color: var(--color-txt);
		font-size: 1.3rem;
		transition: color 0.2s;
	}
	.l-fnav-sub__item > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
}

/*----------
	main content
----------*/
.l-content {
	width: 100%;
	position: relative;
	overflow-x: hidden;
	padding-top: 70px;
	padding-bottom: 80px;
}
@media (min-width: 768px), print {
	.l-content {
		padding-top: 110px;
		padding-bottom: 100px;
	}
}
@media (max-width: 1024px) {
	.l-content {
		padding-top: 70px;
	}
}
@media (min-width: 1025px) {
	.l-content {
		padding-top: 110px;
	}
}

.l-structure--double {
	width: 100%;
	max-width: 1260px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
@media (min-width: 768px), print {
	.l-structure--double {
		padding-left: 30px;
		padding-right: 30px;
	}
}
.l-structure--double .l-section {
	padding-left: 0;
	padding-right: 0;
}
.l-structure--double .l-structure__side {
	margin-top: 80px;
}
@media (min-width: 768px), print {
	.l-structure--double {
		display: flex;
	}
	.l-structure--double .l-structure__main {
		flex: 1;
	}
	.l-structure--double .l-structure__side {
		flex: 0 0 280px;
		margin-left: 5%;
		margin-top: 0;
		padding: 0;
	}
}
@media (min-width: 1025px) and (max-width: 1279px) {
	.l-structure--double .l-structure__side {
		flex: 0 0 260px;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	.l-structure--double {
		display: block;
	}
	.l-structure--double .l-structure__side {
		width: 100%;
		margin-left: 0;
		margin-top: 80px;
	}
}

.l-main .l-section:first-child [class^=c-heading]:first-child {
	margin-top: 0;
}

.l-section {
	width: 100%;
	max-width: 1260px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
@media (min-width: 768px), print {
	.l-section {
		padding-left: 30px;
		padding-right: 30px;
	}
}
.l-section--gapless {
	padding-left: 0;
	padding-right: 0;
}
.l-section--full {
	max-width: 100%;
	padding-left: 0;
	padding-right: 0;
}

.l-breadcrumb {
	padding: 9px 0 10px;
	background-color: var(--color-bg-gray);
}
.l-breadcrumb__list {
	display: inline-flex;
	flex-wrap: nowrap;
	white-space: nowrap;
	font-size: 1.1rem;
	line-height: 1;
}
.l-breadcrumb__list > li {
	display: block;
}
.l-breadcrumb__list > li > a {
	text-decoration: none;
	color: var(--color-txt);
}
.l-breadcrumb__list > li + li::before {
	content: var(--icon-arrow2-r);
	display: inline-block;
	font-family: iconfont !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	color: var(--color-prim);
	font-size: 1.1rem;
	margin: 0 8px;
}
.l-breadcrumb__list > li:last-child > a {
	pointer-events: none;
	color: var(--color-txt);
}
@media (max-width: 767px) {
	.l-breadcrumb__inner {
		overflow-x: auto;
	}
	.l-breadcrumb__list {
		width: 100%;
		max-width: 1260px;
		margin-left: auto;
		margin-right: auto;
		padding-left: 20px;
		padding-right: 20px;
		width: auto;
		max-width: none;
	}
}
@media (max-width: 767px) and (min-width: 768px), print and (max-width: 767px) {
	.l-breadcrumb__list {
		padding-left: 30px;
		padding-right: 30px;
	}
}
@media (min-width: 768px), print {
	.l-breadcrumb {
		padding: 20px 0;
	}
	.l-breadcrumb__inner {
		width: 100%;
		max-width: 1260px;
		margin-left: auto;
		margin-right: auto;
		padding-left: 20px;
		padding-right: 20px;
	}
}
@media (min-width: 768px) and (min-width: 768px), print and (min-width: 768px), print and (min-width: 768px), print {
	.l-breadcrumb__inner {
		padding-left: 30px;
		padding-right: 30px;
	}
}
@media (min-width: 768px), print {
	.l-breadcrumb__list {
		display: block;
		font-size: 1.4rem;
		line-height: 1.2;
		white-space: normal;
	}
	.l-breadcrumb__list > li {
		display: inline;
	}
	.l-breadcrumb__list > li + li::before {
		font-size: 1.2rem;
	}
	.l-breadcrumb__list > li > a {
		transition: color 0.3s;
	}
	.l-breadcrumb__list > li > a:hover {
		color: var(--color-hover);
		text-decoration: underline;
	}
}

/*----------
	IRニュース（CMS）
----------*/
.c-data-newsitem {
	border-bottom: 1px solid var(--color-border);
}
.c-data-newsitem:first-child {
	border-top: 1px solid var(--color-border);
}
.c-data-newsitem__inner {
	display: grid;
	grid-template-columns: auto auto;
	grid-template-rows: auto auto auto;
	padding: 16px 0;
}
.c-data-newsitem__date {
	grid-column: 1/3;
	grid-row: 1;
	margin-right: 16px;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: var(--line-height-m);
}
.c-data-newsitem__tag {
	grid-column: 1/3;
	grid-row: 2;
	vertical-align: middle;
	border-color: var(--color-prim);
	color: #fff;
}
.c-data-newsitem__tag > span {
	height: 25px;
	display: inline-block;
	max-width: 100%;
	min-width: 125px;
	padding: 0 10px;
	color: inherit;
	border: 1px solid;
	border-color: inherit;
	background-color: var(--color-prim);
	border-radius: 13px;
	overflow: hidden;
	text-align: center;
	white-space: nowrap;
	text-overflow: ellipsis;
	font-size: 1.3rem;
	font-weight: 500;
	line-height: 23px;
}
.c-data-newsitem__text {
	grid-column: 1/3;
	grid-row: 3;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
}
.c-data-newsitem > a {
	color: var(--color-txt);
}
.c-data-newsitem > a[target=_blank] .c-data-newsitem__text {
	position: relative;
	padding-left: 20px;
}
.c-data-newsitem > a[target=_blank] .c-data-newsitem__text::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.6rem;
	line-height: 1;
}
.c-data-newsitem > a[href$=".pdf"] .c-data-newsitem__text::before {
	content: var(--icon-pdf);
	top: 0.3em;
	color: var(--color-red);
}
@media (max-width: 767px) {
	.c-data-newsitem__date {
		margin-bottom: 10px;
	}
	.c-data-newsitem__tag {
		margin-bottom: 12px;
	}
}
@media (min-width: 768px), print {
	.c-data-newsitem__inner {
		grid-template-columns: auto 1fr;
		grid-template-rows: auto auto;
		padding-top: 25px;
		padding-bottom: 25px;
	}
	.c-data-newsitem__date {
		grid-column: 1;
		grid-row: 1;
		margin-right: 18px;
	}
	.c-data-newsitem__tag {
		grid-column: 2;
		grid-row: 1;
		margin-top: 2px;
		margin-right: 8px;
	}
	.c-data-newsitem__text {
		grid-column: 1/3;
		grid-row: 2;
		margin-top: 10px;
		font-size: 1.6rem;
	}
	.c-data-newsitem__title {
		transition: color 0.3s;
	}
	.c-data-newsitem > a .c-data-newsitem__text {
		transition: color 0.2s;
	}
	.c-data-newsitem > a[target=_blank] .c-data-newsitem__text {
		padding-left: 26px;
	}
	.c-data-newsitem > a[target=_blank] .c-data-newsitem__text::before {
		font-size: 1.8rem;
	}
	.c-data-newsitem > a:hover .c-data-newsitem__text {
		color: var(--color-hover);
		text-decoration: underline;
	}
}

/*----------
	ニュースリリース（CMS）
----------*/
.c-newsrelease__item {
	border-bottom: 1px solid var(--color-border);
}
.c-newsrelease__item:first-child {
	border-top: 1px solid var(--color-border);
}
.c-newsrelease__inner {
	display: grid;
	grid-template-columns: auto 1fr;
	grid-template-rows: auto auto auto;
	padding: 16px 0;
}
.c-newsrelease__date {
	grid-column: 1/3;
	grid-row: 1;
	margin-right: 16px;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: var(--line-height-m);
}
.c-newsrelease__tag {
	grid-column: 1/3;
	grid-row: 2;
	display: flex;
	flex-wrap: wrap;
	margin-top: -8px;
	vertical-align: middle;
}
.c-newsrelease__tag li {
	color: var(--color-prim);
	border-color: var(--color-prim);
}
.c-newsrelease__tag li span {
	display: block;
	height: 25px;
	max-width: 100%;
	min-width: 125px;
	padding: 0 10px;
	margin-right: 10px;
	margin-top: 8px;
	color: inherit;
	border: 1px solid;
	border-color: inherit;
	background-color: #fff;
	border-radius: 13px;
	text-align: center;
	white-space: nowrap;
	text-overflow: ellipsis;
	font-size: 1.3rem;
	font-weight: 500;
	line-height: 23px;
	overflow: hidden;
}
.c-newsrelease__tag .c-newsrelease__tag-fill {
	border-color: var(--color-prim);
	color: #fff;
}
.c-newsrelease__tag .c-newsrelease__tag-fill span {
	background-color: var(--color-prim);
}
.c-newsrelease__headline {
	grid-column: 1/3;
	grid-row: 3;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
}
.c-newsrelease__button {
	width: 100%;
	max-width: 300px;
	margin: 40px auto 0;
}
.c-newsrelease a {
	color: var(--color-txt);
}
.c-newsrelease a[target=_blank] .c-newsrelease__text {
	position: relative;
	padding-left: 20px;
}
.c-newsrelease a[target=_blank] .c-newsrelease__text::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.6rem;
	line-height: 1;
}
.c-newsrelease a[href$=".pdf"] .c-newsrelease__text::before {
	content: var(--icon-pdf);
	top: 0.3em;
	color: var(--color-red);
}
@media (max-width: 767px) {
	.c-newsrelease__date {
		margin-bottom: 12px;
	}
	.c-newsrelease__tag {
		margin-bottom: 12px;
	}
}
@media (min-width: 768px), print {
	.c-newsrelease__inner {
		grid-template-columns: auto 1fr;
		grid-template-rows: auto auto;
		padding-top: 25px;
		padding-bottom: 25px;
	}
	.c-newsrelease__date {
		grid-column: 1;
		grid-row: 1;
		margin-right: 18px;
	}
	.c-newsrelease__tag {
		grid-column: 2;
		grid-row: 1;
	}
	.c-newsrelease__headline {
		grid-column: 1/3;
		grid-row: 2;
		margin-top: 10px;
		font-size: 1.6rem;
	}
	.c-newsrelease a .c-newsrelease__text {
		transition: color 0.2s;
	}
	.c-newsrelease a[target=_blank] .c-newsrelease__text {
		padding-left: 26px;
	}
	.c-newsrelease a[target=_blank] .c-newsrelease__text::before {
		font-size: 1.8rem;
	}
	.c-newsrelease a:hover .c-newsrelease__text {
		color: var(--color-hover);
		text-decoration: underline;
	}
}

/*----------
	重要なお知らせ（CMS）
----------*/
.l-content .wrp-important-news {
	padding: 16px 20px 22px;
}
.l-content .wrp-important-news .important-title {
	margin-bottom: 5px;
	font-size: 1.4rem;
	font-weight: 700;
	line-height: var(--line-height-l);
	white-space: nowrap;
}
.l-content .wrp-important-news .important-list li {
	line-height: 1;
}
.l-content .wrp-important-news .important-list li + li {
	margin-top: 8px;
}
.l-content .wrp-important-news .date,
.l-content .wrp-important-news .text {
	position: relative;
	color: var(--color-txt);
	display: inline;
	line-height: var(--line-height-m);
}
.l-content .wrp-important-news .text.icon img {
	display: none;
}
.l-content .wrp-important-news a[target=_blank] .text {
	padding-left: 2px;
}
.l-content .wrp-important-news a[target=_blank] .text::before {
	font-family: iconfont !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	content: var(--icon-blank);
	display: inline-block;
	position: relative;
	color: var(--color-link);
	font-size: 1.6rem;
	line-height: 1;
}
.l-content .wrp-important-news a[href$=".pdf"] .text::before {
	content: var(--icon-pdf);
	color: var(--color-red);
}
.l-content .wrp-important-news .date {
	font-weight: 500;
}
@media (min-width: 768px), print {
	.l-content .wrp-important-news {
		width: 100%;
		max-width: 1260px;
		margin: 0 auto;
		padding: 18px 30px;
		display: flex;
	}
	.l-content .wrp-important-news .important-title {
		margin-right: 30px;
		margin-bottom: 0;
		font-size: 1.6rem;
		line-height: var(--line-height-m);
	}
	.l-content .wrp-important-news .important-list li + li {
		margin-top: 10px;
	}
	.l-content .wrp-important-news .date,
	.l-content .wrp-important-news .text {
		font-size: 1.6rem;
		line-height: var(--line-height-m);
	}
	.l-content .wrp-important-news .date {
		margin-right: 15px;
	}
	.l-content .wrp-important-news a {
		display: flex;
	}
	.l-content .wrp-important-news a:hover .date,
	.l-content .wrp-important-news a:hover .text {
		color: var(--color-hover);
	}
	.l-content .wrp-important-news a:hover .text {
		text-decoration: underline;
	}
	.l-content wrp-important-news a[target=_blank] .text::before {
		top: 0.35em;
		left: 0;
	}
}
@media (min-width: 768px) and (max-width: 1024px) {
	.l-content .wrp-important-news {
		padding: 18px 60px 18px 30px;
	}
}
/*----------
	お知らせ（CMS）
----------*/
.wrp-other-news .item a {
	position: relative;
	display: flex;
	align-items: center;
	height: 100%;
	min-height: 70px;
	padding: 14px 20px;
	position: relative;
	border: 1px solid var(--color-border);
	color: var(--color-txt);
}
.wrp-other-news .item a[target=_blank] p,
.wrp-other-news .item a[target=_pdf] p {
	padding-right: 25px;
}
.wrp-other-news .item a[target=_blank]::after {
	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: 50%;
	right: 20px;
	transform: translateY(-50%);
	color: var(--color-link);
	font-size: 1.6rem;
	line-height: 1;
}
.wrp-other-news .item a[href$=".pdf"]::after {
	content: var(--icon-pdf);
	color: var(--color-red);
}
.wrp-other-news .item p {
	position: relative;
	font-size: 1.4rem;
	line-height: var(--line-height-m);
}
.wrp-other-news .item img {
	display: none;
}
@media (max-width: 767px) {
	.wrp-other-news .item {
		width: 100%;
	}
	.wrp-other-news .item a {
		margin-top: -1px;
	}
	.wrp-other-news .item p {
		color: var(--color-txt);
	}
}
@media (min-width: 768px), print {
	.wrp-other-news {
		display: flex;
		flex-wrap: wrap;
	}
	.wrp-other-news .item {
		width: 50%;
	}
	.wrp-other-news .item:not(:nth-child(2n-1)) a {
		border-left: 0;
	}
	.wrp-other-news .item:nth-child(n+3) a {
		border-top: 0;
	}
	.wrp-other-news .item a {
		min-height: 66px;
		padding: 25px 30px;
	}
	.wrp-other-news .item a::before {
		content: "";
		display: block;
		position: absolute;
		top: -1px;
		left: -1px;
		width: calc(100% + 2px);
		height: calc(100% + 2px);
		border: 1px solid var(--color-hover);
		z-index: 10;
		transition: opacity 0.3s;
		opacity: 0;
	}
	.wrp-other-news .item a[target=_blank]::after, .wrp-other-news .item a[target=_pdf]::after {
		right: 30px;
	}
	.wrp-other-news .item a p {
		transition: color 0.2s;
	}
	.wrp-other-news .item a:hover {
		border-color: #fff;
	}
	.wrp-other-news .item a:hover p {
		color: var(--color-hover);
		text-decoration: underline;
	}
	.wrp-other-news .item a:hover::before {
		opacity: 1;
	}
}

/*----------
	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;
}

.u-mb-10 {
	margin-bottom: 10px !important;
}

.u-mb-20 {
	margin-bottom: 20px !important;
}

.u-mb-30 {
	margin-bottom: 30px !important;
}

.u-mb-40 {
	margin-bottom: 40px !important;
}

.u-mb-50 {
	margin-bottom: 50px !important;
}

.u-mb-60 {
	margin-bottom: 60px !important;
}

.u-mb-70 {
	margin-bottom: 70px !important;
}

.u-mb-80 {
	margin-bottom: 80px !important;
}

.u-mb-90 {
	margin-bottom: 90px !important;
}

.u-mb-100 {
	margin-bottom: 100px !important;
}
/* SP-PC別マージン */
@media (min-width: 768px), print {
	.u-pc-mt-20 {
		margin-top: 20px !important;
	}
	.u-pc-mb-20 {
		margin-bottom: 20px !important;
	}
	.u-pc-ml-20 {
		margin-left: 20px !important;
	}
	.u-pc-mr-20 {
		margin-right: 20px !important;
	}
}
@media (max-width: 767px) {
	.u-sp-mt-20 {
		margin-top: 20px !important;
	}
	.u-sp-mb-20 {
		margin-bottom: 20px !important;
	}
	.u-sp-ml-20 {
		margin-left: 20px !important;
	}
	.u-sp-mr-20 {
		margin-right: 20px !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-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-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;
	}
}
/*----------
	image
----------*/
/* 角丸 */
.u-image-round img {
	border-radius: 15px;
	overflow: hidden;
}

.u-image-round figcaption {
	border-radius: none;
}
@media (min-width: 768px), print {
	.u-image-round img {
		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;
}
