@charset "UTF-8";
@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;800&family=Poppins:wght@400;500;700&display=swap);
@import url(https://cdn.jsdelivr.net/npm/yakuhanjp@3.4.1/dist/css/yakuhanjp.min.css);
@import url(https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&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: #2D4BBA;
	--color-seco: #ABC2F0;
	--color-txt: #333333;
	--color-txt-caption: #888888;
	--color-txt-disable: #CCCCCC;
	--color-txt-error: #E60000;
	--color-txt-link: #2D4BBA;
	--color-txt-hover: #3B61F1;
	--color-txt-hover-v2: #FA8800;
	--color-border: #C9CED7;
	--color-border-black: #333333;
	--color-bg: #F0F1F5;
	--color-caution: #E60000;
	--color-prim-rgb: 45, 75, 186;
	--color-seco-rgb: 171, 194, 240;
	--color-txt-rgb: 51, 51, 51;
	--color-txt-caption-rgb: 136, 136, 136;
	--color-txt-disable-rgb: 204, 204, 204;
	--color-txt-error-rgb: 230, 0, 0;
	--color-txt-link-rgb: 45, 75, 186;
	--color-txt-hover-rgb: 59, 97, 241;
	--color-txt-hover-v2-rgb: 250, 136, 0;
	--color-border-rgb: 201, 206, 215;
	--color-border-black-rgb: 51, 51, 51;
	--color-bg-rgb: 240, 241, 245;
	--color-caution-rgb: 230, 0, 0;
	/* font family */
	--font-sans: "Noto Sans JP", "ヒラギノ角ゴシック", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", Hiragino Sans, "メイリオ", Meiryo, sans-serif;
	--font-yakuhanjp: "YakuHanJP";
	--font-serif: "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
	--font-poppins: "Poppins", sans-serif;
	--font-inter: "Inter", sans-serif;
	/* line height */
	--line-height-s: 1.4;
	--line-height-m: 1.6;
	--line-height-l: 1.8;
	/* デフォルトマージン */
	--mb-default-sp: 48px;
	--mb-default-pc: 48px;
	/* 汎用マージン */
	--mb-a-sp: 100px;
	--mb-b-sp: 80px;
	--mb-c-sp: 40px;
	--mb-d-sp: 32px;
	--mb-e-sp: 24px;
	--mb-f-sp: 24px;
	--mb-g-sp: 16px;
	--mb-a-pc: 160px;
	--mb-b-pc: 120px;
	--mb-c-pc: 80px;
	--mb-d-pc: 64px;
	--mb-e-pc: 48px;
	--mb-f-pc: 24px;
	--mb-g-pc: 16px;
	/* icons */
	--icon-arrow1-r: "";
	--icon-arrow1-l: "";
	--icon-arrow1-b: "";
	--icon-arrow1-t: "";
	--icon-arrow2-r: "";
	--icon-arrow2-l: "";
	--icon-arrow2-b: "";
	--icon-arrow2-t: "";
	--icon-blank: "";
	--icon-plus: "";
	--icon-minus: "";
	--icon-close: "";
	--icon-download: "";
	--icon-serch: "";
	--icon-access: "";
	--icon-locked: "";
	--icon-unlocked: "";
	--icon-global: "";
	--icon-question: "";
	--icon-exclamation: "";
	--icon-pdf: "";
	--icon-excel: "";
	--icon-powerpoint: "";
	--icon-word: "";
	--icon-zip: "";
	--icon-url: "";
	--icon-doc: "";
	--icon-check: "";
	--icon-circle: "";
	--icon-circle_border: "";
	--icon-play: "";
	--icon-stop: "";
	--icon-swipe: "";
	--icon-rss: "";
	--icon-alert: "";
	--icon-print: "";
	--icon-calendar: "";
	--icon-cart: "";
	--icon-humberger: "";
	--icon-bookmark: "";
	--icon-mail: "";
	--icon-first: "";
	--icon-last: "";
	--icon-new: "";
	--icon-to-top: "";
	--icon-pinch-in: "";
	--icon-pinch-out: "";
	--icon-phone: "";
	--icon-home: "";
	--icon-zoom: "";
	--icon-menu: "";
	--icon-triangle_r: "";
	--icon-triangle_b: "";
}

/*----------
	base
----------*/
html {
	width: 100%;
	font-size: 62.5%;
	background-color: var(--color-bg);
}
html.is-locked {
	position: absolute;
	overflow: hidden;
}

body {
	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;
	}
}

a {
	text-decoration: none;
	color: var(--color-txt-link);
}
@media (min-width: 768px) {
	a:hover {
		text-decoration: none;
	}
}

img {
	width: 100%;
	height: auto;
	vertical-align: top;
}

strong {
	font-weight: bold;
}

em {
	font-style: italic;
}

/* stylelint-enable no-duplicate-selectors */
/*----------
	main header
----------*/
.l-mainheader {
	position: relative;
	padding: 25px 0 25px 20px;
	z-index: 10;
}

.l-mainheader__logo {
	width: 225px;
}

.l-mainheader__logo a {
	display: block;
}

@media (min-width: 768px) {
	.l-mainheader {
		padding: 40px 0 40px 40px;
	}

	.l-mainheader__logo {
		width: 300px;

	}
}

/*----------
	main footer
----------*/
.l-mainfooter {
	margin-top: 40px;
}
.l-mainfooter__backhead {
	position: fixed;
	bottom: 40px;
	left: 0;
	right: 20px;
	z-index: 100;
	height: 0;
	text-align: right;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s;
}
.l-mainfooter__backhead.is-visible {
	opacity: 1;
	pointer-events: auto;
}
.l-mainfooter__nav {
	padding: 0;
}
@media (min-width: 768px) {
	.l-mainfooter {
		margin-top: 80px;
	}
	.l-mainfooter__backhead {
		bottom: 64px;
		right: 24px;
	}
	.l-mainfooter__logo {
		padding: 60px 20px 50px;
	}
	.l-mainfooter__nav {
		padding: 0;
	}
}

.l-mainfooter-backhead {
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	color: var(--color-txt);
	display: flex;
	align-items: center;
	width: 48px;
	height: 48px;
}
.l-mainfooter-backhead__link {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	background-color: #888888;
	overflow: hidden;
}
.l-mainfooter-backhead__icon {
	position: relative;
	width: 100%;
	height: 100%;
}
.l-mainfooter-backhead__icon::before, .l-mainfooter-backhead__icon::after {
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	content: var(--icon-arrow2-t);
	position: absolute;
	width: 100%;
	height: 100%;
	font-size: 23px;
	opacity: 1;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	color: #fff;
}
.l-mainfooter-backhead__icon::after {
	transform: translate(-50%, 1em);
	opacity: 0;
}
@media (min-width: 768px) {
	.l-mainfooter-backhead {
		width: 56px;
		height: 56px;
	}
	.l-mainfooter-backhead__link {
		transition: 0.3s;
	}
	.l-mainfooter-backhead__link:hover {
		background-color: #333333;
	}
	.l-mainfooter-backhead__link:hover .l-mainfooter-backhead__icon::before {
		transform: translate(-50%, -100%);
		opacity: 0;
	}
	.l-mainfooter-backhead__link:hover .l-mainfooter-backhead__icon::after {
		transform: translate(-50%, -50%);
		opacity: 1;
	}
	.l-mainfooter-backhead__icon::before, .l-mainfooter-backhead__icon::after {
		font-size: 26px;
		transition: 0.2s ease;
	}
	.l-mainfooter-backhead__icon::after {
		transform: translate(-50%, 1em);
		opacity: 0;
	}
}

.l-fnav-main {
	position: relative;
	z-index: 200;
	width: 100%;
	overflow: hidden;
	background-color: black;
}
.l-fnav-main__inner {
	display: block;
	padding: 48px 40px;
}
.l-fnav-main__content {
	margin: 0 auto;
}
.l-fnav-main__titletext {
	display: flex;
	align-items: center;
	color: #fff;
	font-size: 1.8rem;
	line-height: 1.6;
	font-weight: 500;
}
.l-fnav-main__titletext::before {
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	content: var(--icon-mail);
	font-size: 2rem;
	margin-right: 10px;
}
.l-fnav-main__arrow {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: calc(100% - 80px);
	height: 0;
	pointer-events: none;
}
.l-fnav-main__arrow::before, .l-fnav-main__arrow::after {
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	content: var(--icon-arrow2-r);
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(0, -50%);
	color: #fff;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #000;
	border-radius: 50%;
	border: 1px solid #fff;
	width: 3rem;
	height: 3rem;
	font-size: 1.2rem;
}
.l-fnav-main__arrow::after {
	transform: translate(-100%, -50%);
	opacity: 0;
}
@media (min-width: 768px) {
	.l-fnav-main {
		position: relative;
		padding: 0;
	}
	.l-fnav-main__inner {
		padding: 104px 50px;
		max-width: 1140px;
		margin: auto;
	}
	.l-fnav-main__inner::after {
		content: "";
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
	}
	.l-fnav-main__inner:hover .l-fnav-main__inner {
		background-color: rgba(0, 0, 0, 0.7);
	}
	.l-fnav-main__inner:hover .l-fnav-main__arrow::before {
		transform: translate(100%, -50%);
		opacity: 0;
	}
	.l-fnav-main__inner:hover .l-fnav-main__arrow::after {
		transform: translate(0, -50%);
		opacity: 1;
	}
	.l-fnav-main__arrow {
		width: calc(100% - 100px);
		max-width: 1040px;
	}
	.l-fnav-main__arrow::before, .l-fnav-main__arrow::after {
		width: 6.4rem;
		height: 6.4rem;
		font-size: 2.5rem;
		transition: transform 0.3s, opacity 0.3s;
	}
	.l-fnav-main__content {
		margin: 0 auto;
	}
	.l-fnav-main__titletext {
		font-size: 3rem;
		line-height: 1.5;
	}
	.l-fnav-main__titletext::before {
		font-size: 3rem;
		margin-right: 20px;
	}
}

.l-fnav-sub {
	width: 100%;
	padding: 40px;
}
.l-fnav-sub__inner {
	margin: auto;
}
.l-fnav-sub__items {
	margin: 0;
}
.l-fnav-sub__item {
	font-size: 1.2rem;
	line-height: 1;
	color: #666;
}
.l-fnav-sub__item > a {
	color: #666;
	text-decoration: none;
}
.l-fnav-sub__item > a > span {
	display: block;
	padding: 0;
}
.l-fnav-sub__item + .l-fnav-sub__item {
	margin-top: 16px;
}
.l-fnav-sub__copyright {
	text-align: center;
	font-size: 1.2rem;
	color: #9297a1;
	margin: 40px 0 0;
}
@media (min-width: 768px) {
	.l-fnav-sub {
		padding: 40px 0;
	}
	.l-fnav-sub__inner {
		max-width: 1140px;
		padding: 0 50px;
	}
}
@media (min-width: 1025px) {
	.l-fnav-sub {
		padding: 75px 0 80px;
	}
	.l-fnav-sub__inner {
		display: flex;
		justify-content: space-between;
		max-width: 1140px;
		padding: 0 50px;
	}
	.l-fnav-sub__items {
		display: flex;
		align-items: center;
	}
	.l-fnav-sub__item > a:hover {
		text-decoration: underline;
	}
	.l-fnav-sub__item + .l-fnav-sub__item {
		margin-top: 0;
		margin-left: 80px;
	}
	.l-fnav-sub__copyright {
		margin: 0;
	}
}

/*----------
	main content
----------*/
.l-content {
	width: 100%;
	position: relative;
	overflow: hidden;
	margin-bottom: 80px;
}
@media (min-width: 768px) {
	.l-content {
		margin-bottom: 150px;
	}
}

.l-structure--double {
	width: 100%;
	max-width: 1140px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
@media (min-width: 768px) {
	.l-structure--double {
		padding-left: 50px;
		padding-right: 50px;
	}
}
.l-structure--double .l-structure__side {
	margin-top: 40px;
}
@media (min-width: 768px) {
	.l-structure--double {
		display: flex;
	}
	.l-structure--double .l-structure__main {
		flex: 1;
	}
	.l-structure--double .l-structure__side {
		width: 23.1666666667%;
		margin-left: 2.5%;
		margin-top: 0;
		padding: 0;
	}
}

.l-section {
	width: 100%;
	max-width: 1140px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
@media (min-width: 768px) {
	.l-section {
		padding-left: 50px;
		padding-right: 50px;
	}
}
.l-section--gapless {
	padding-left: 0;
	padding-right: 0;
}
@media (min-width: 768px) {
	.l-section--narrow {
		max-width: 960px;
		margin: 0 auto;
	}
}

.orb-canvas {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	min-height: 100vh;
	min-height: var(--vh);
	pointer-events: none;
	z-index: -1;
	opacity: 0;
	transition: all 1s;
	filter: blur(50px);
}
.orb-canvas.is-shown {
	opacity: 1;
}

/*----------
	margin
----------*/
.u-mb-reg8 {
	margin-bottom: 8px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mb-reg16 {
	margin-bottom: 16px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mb-reg24 {
	margin-bottom: 24px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mb-reg32 {
	margin-bottom: 32px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mb-reg40 {
	margin-bottom: 40px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mb-reg48 {
	margin-bottom: 48px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mb-reg56 {
	margin-bottom: 56px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mb-reg64 {
	margin-bottom: 64px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mb-reg72 {
	margin-bottom: 72px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mb-reg80 {
	margin-bottom: 80px !important; /* stylelint-disable-line declaration-no-important */
}

/* 固定マージン */
.u-mt-none {
	margin-top: 0 !important; /* stylelint-disable-line declaration-no-important */
}

.u-mt-10 {
	margin-top: 10px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mt-20 {
	margin-top: 20px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mt-30 {
	margin-top: 30px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mt-40 {
	margin-top: 40px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mt-50 {
	margin-top: 50px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mt-60 {
	margin-top: 60px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mt-70 {
	margin-top: 70px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mt-80 {
	margin-top: 80px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mt-90 {
	margin-top: 90px !important; /* stylelint-disable-line declaration-no-important */
}

.u-mt-100 {
	margin-top: 100px !important; /* stylelint-disable-line declaration-no-important */
}

/* 汎用マージン */
.u-margin-xxl {
	margin-bottom: 100px !important; /* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-xxl {
		margin-bottom: 160px !important; /* stylelint-disable-line declaration-no-important */
	}
}

.u-margin-xl {
	margin-bottom: 80px !important; /* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-xl {
		margin-bottom: 120px !important; /* stylelint-disable-line declaration-no-important */
	}
}

.u-margin-lg {
	margin-bottom: 40px !important; /* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-lg {
		margin-bottom: 80px !important; /* stylelint-disable-line declaration-no-important */
	}
}

.u-margin-md {
	margin-bottom: 32px !important; /* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-md {
		margin-bottom: 64px !important; /* stylelint-disable-line declaration-no-important */
	}
}

.u-margin-sm {
	margin-bottom: 24px !important; /* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-sm {
		margin-bottom: 48px !important; /* stylelint-disable-line declaration-no-important */
	}
}

.u-margin-sm-v2 {
	margin-bottom: 40px !important; /* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-sm-v2 {
		margin-bottom: 48px !important; /* stylelint-disable-line declaration-no-important */
	}
}

.u-margin-xs {
	margin-bottom: 24px !important; /* stylelint-disable-line declaration-no-important */
}

.u-margin-xxs {
	margin-bottom: 16px !important; /* stylelint-disable-line declaration-no-important */
}

.u-margin-none {
	margin-bottom: 0 !important; /* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-none {
		margin-bottom: 0 !important; /* stylelint-disable-line declaration-no-important */
	}
}

.u-margin-top-none {
	margin-top: 0 !important; /* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-top-none {
		margin-top: 0 !important; /* stylelint-disable-line declaration-no-important */
	}
}

/*----------
	display
----------*/
@media (max-width: 767px) {
	.u-pc-v {
		display: none;
	}
}

@media (min-width: 768px) {
	.u-sp-v {
		display: none;
	}
}

/*----------
	text
----------*/
@media (max-width: 767px) {
	.u-pcbr {
		display: none;
	}
}

@media (min-width: 768px) {
	.u-spbr {
		display: none;
	}
}

.u-txt-center {
	text-align: center !important; /* stylelint-disable-line declaration-no-important */
}

@media (min-width: 768px) {
	.u-txt-pccenter {
		text-align: center !important; /* stylelint-disable-line declaration-no-important */
	}
}

.u-txt-right {
	text-align: right !important; /* stylelint-disable-line declaration-no-important */
}

.u-txt-left {
	text-align: left !important; /* stylelint-disable-line declaration-no-important */
}

.u-txt-medium {
	font-weight: 500 !important; /* stylelint-disable-line declaration-no-important */
}

.u-txt-bold {
	font-weight: bold !important; /* stylelint-disable-line declaration-no-important */
}

.u-txt-strike {
	text-decoration: line-through !important; /* stylelint-disable-line declaration-no-important */
}

.u-text-indent {
	text-indent: -3em;
	padding-left: 3em;
}

.u-txt-marker {
	font-weight: bold;
	background-image: linear-gradient(transparent 80%, #FFF7A6 80%);
}

.u-txt-prim {
	color: var(--color-prim) !important; /* stylelint-disable-line declaration-no-important */
}

.u-txt-seco {
	color: var(--color-seco) !important; /* stylelint-disable-line declaration-no-important */
}

.u-txt-default {
	color: var(--color-txt) !important; /* stylelint-disable-line declaration-no-important */
}

.u-txt-white {
	color: #fff !important; /* stylelint-disable-line declaration-no-important */
}

.u-txt-caution {
	color: var(--color-caution) !important; /* stylelint-disable-line declaration-no-important */
}

/* 文中リンク */
.u-txt-link {
	text-decoration: underline;
	color: var(--color-txt-link);
}
@media (min-width: 768px) {
	.u-txt-link {
		transition: color 0.2s;
	}
	.u-txt-link:hover {
		color: var(--color-txt-hover);
	}
}

/* フォント */
.u-txt-sans {
	font-family: var(--font-sans);
}

.u-txt-serif {
	font-family: var(--font-serif);
}

.u-txt-poppins {
	font-family: var(--font-poppins);
}
/*# sourceMappingURL=common.css.map */
