@charset "UTF-8";
@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Jost:wght@400;500;600;700&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: #15136C;
	--color-seco: #8FC31F;
	--color-txt: #111111;
	--color-txt-caption: #666;
	--color-txt-caption-v2: #6F7579;
	--color-txt-link: #15136C;
	--color-txt-hover: #2b65a2;
	--color-border: #CCCCCC;
	--color-bg: #FBFFF0;
	--color-caution: #DE5252;
	--color-cv: #FA8800;
	--color-red: #e6002f;
	--color-prim-rgb: 21, 19, 108;
	--color-seco-rgb: 143, 195, 31;
	--color-txt-rgb: 17, 17, 17;
	--color-txt-caption-rgb: 102, 102, 102;
	--color-txt-caption-v2-rgb: 111, 117, 121;
	--color-txt-link-rgb: 21, 19, 108;
	--color-txt-hover-rgb: 43, 101, 162;
	--color-border-rgb: 204, 204, 204;
	--color-bg-rgb: 251, 255, 240;
	--color-caution-rgb: 222, 82, 82;
	--color-cv-rgb: 250, 136, 0;
	--color-red-rgb: 230, 0, 47;
	/* font family */
	--font-sans: "Noto Sans JP", "ヒラギノ角ゴシック", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", Hiragino Sans, "メイリオ", Meiryo, sans-serif;
	--font-serif: "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
	--font-en: "Jost", sans-serif;
	/* line height */
	--line-height-s: 1.4;
	--line-height-m: 1.6;
	--line-height-l: 1.8;
	/* icons */
	--icon-access: "";
	--icon-alert: "";
	--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-blank: "";
	--icon-bookmark: "";
	--icon-calendar: "";
	--icon-cart: "";
	--icon-check: "";
	--icon-circle: "";
	--icon-circle_border: "";
	--icon-close: "";
	--icon-doc: "";
	--icon-download: "";
	--icon-excel: "";
	--icon-exclamation: "";
	--icon-first: "";
	--icon-global: "";
	--icon-humberger: "";
	--icon-last: "";
	--icon-locked: "";
	--icon-mail: "";
	--icon-minus: "";
	--icon-new: "";
	--icon-pdf: "";
	--icon-tel: "";
	--icon-pinch-in: "";
	--icon-pinch-out: "";
	--icon-play: "";
	--icon-plus: "";
	--icon-powerpoint: "";
	--icon-print: "";
	--icon-question: "";
	--icon-right_angle: "";
	--icon-rss: "";
	--icon-search: "";
	--icon-stop: "";
	--icon-swipe: "";
	--icon-to-top: "";
	--icon-unlocked: "";
	--icon-url: "";
	--icon-word: "";
	--icon-zip: "";
}

/*----------
	base
----------*/
html {
	width: 100%;
	font-size: 62.5%;
	background-color: #fff;
}
html.locked {
	position: fixed;
	overflow: hidden;
}

body {
	position: relative;
	min-width: 1200px;
	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 {
		min-width: 320px;
		font-size: 1.4rem;
	}
}

a {
	text-decoration: none;
	color: var(--color-txt-link);
}
a[href*="tel:"] {
	color: var(--color-txt);
}
@media (min-width: 768px) {
	a:hover {
		text-decoration: none;
	}
	a[href*="tel:"] {
		pointer-events: none;
		cursor: default;
	}
}

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

sup {
	font-size: 65%;
	display: inline-block;
	vertical-align: 0.5em;
}

sub {
	font-size: 65%;
	display: inline-block;
	vertical-align: text-bottom;
}

/*----------
	main header
----------*/
header {
	position: sticky;
	left: 0;
	top: 0;
	width: 100%;
	z-index: 9999;
	background-color: #FFF;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}
@media (min-width: 768px) {
	header {
		border-bottom: #CCC solid 1px;
		transform: translateY(-120px);
		position: fixed;
		left: 0;
		top: 0;
		transition: all 0.2s;
	}
	header.is-active {
		transform: translateY(0);
	}
}
@media (max-width: 1200px) {
	header {
		transform: translateY(0);
		position: sticky;
	}
}

.l-mainheader {
	margin: 0 auto;
	padding: 0 20px;
}
@media (min-width: 768px) {
	.l-mainheader {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		height: 110px;
		max-width: 1240px;
	}
}
@media (max-width: 1200px) {
	.l-mainheader {
		width: 100%;
		height: 80px;
	}
}
@media (max-width: 1200px) {
	.l-mainheader__main {
		display: flex;
		align-items: center;
		justify-content: space-between;
		width: 100%;
		height: 80px;
		padding-top: 0;
	}
}
@media (min-width: 768px) {
	.l-mainheader__left {
		display: flex;
		align-items: center;
		gap: 20px;
		padding-top: 15px;
	}
}
@media (max-width: 1200px) {
	.l-mainheader__left {
		padding-top: 0;
	}
}
.l-mainheader__list {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: flex-end;
}
@media (max-width: 1200px) {
	.l-mainheader__list {
		display: none;
	}
}
.l-mainheader__link {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 50px;
	border-radius: 0 0 0 10px;
	background-color: var(--color-prim);
	color: #FFF;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.5;
	padding: 10px 50px 10px 25px;
	transition: all 0.2s ease-out;
}
.l-mainheader__link::after {
	content: "";
	background-image: url(../images/common/icon_09-blank.svg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	position: absolute;
	right: 20px;
	top: calc(50% - 7px);
	display: block;
	width: 14px;
	height: 14px;
}
.l-mainheader__link:hover {
	opacity: 0.85;
}
.l-mainheader__menu {
	display: none;
}
@media (max-width: 1200px) {
	.l-mainheader__menu {
		position: relative;
		display: block;
		height: 100%;
		margin-right: -20px;
	}
	.l-mainheader__menu > a {
		display: inline-block;
		height: 100%;
	}
	.l-mainheader__menu > a > img {
		width: auto;
		height: 100%;
	}
}
.l-mainheader__logo > a {
	display: block;
}
@media (min-width: 768px) {
	.l-mainheader__logo {
		width: 240px;
	}
}
@media (max-width: 767px) {
	.l-mainheader__logo {
		width: 204px;
		margin-bottom: 5px;
	}
}
.l-mainheader__sub {
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 1.4;
	color: var(--color-prim);
}
@media (max-width: 767px) {
	.l-mainheader__sub-pconly {
		display: none;
	}
}
.l-mainheader__sub-sponly {
	display: none;
}
@media (max-width: 767px) {
	.l-mainheader__sub-sponly {
		display: block;
	}
}
@media (max-width: 1200px) {
	.l-mainheader__subB {
		font-size: 1.6rem;
	}
}
@media (max-width: 1200px) {
	.l-mainheader__sub2 {
		display: block;
		font-size: 1.2rem;
	}
}

/*----------
	main footer
----------*/
.l-mainfooter {
	position: relative;
	z-index: 20;
}
.l-mainfooter__btn {
	position: relative;
	background-color: #E9F3D2;
	padding: 80px 20px 60px;
}
@media (min-width: 768px) {
	.l-mainfooter__btn {
		padding: 80px 20px;
	}
}
.l-mainfooter__btn::before {
	content: "";
	position: absolute;
	top: -20px;
	left: 50%;
	width: 122px;
	height: 80px;
	background: url(../images/top/img_footer_01.png) center/contain no-repeat;
}
@media (min-width: 768px) {
	.l-mainfooter__btn::before {
		top: -74px;
		left: auto;
		right: calc(50% + 220px);
		width: 378px;
		height: 250px;
	}
}
@media (max-width: 767px) {
	.l-mainfooter__btn::before {
		transform: translateX(-50%);
	}
}
@media (min-width: 768px) {
	.l-mainfooter__btn::after {
		content: "";
		position: absolute;
		top: -84px;
		left: calc(50% + 258px);
		width: 294px;
		height: 260px;
		background: url(../images/top/img_footer_02.png) center/contain no-repeat;
	}
}
.l-mainfooter__copyright {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 55px;
	background-color: #333;
	color: #FFF;
	font-size: 1rem;
	letter-spacing: -0.01rem;
}
.l-mainfooter__pagetop {
	position: fixed;
	right: 0;
	bottom: 0;
	z-index: 100;
	opacity: 0;
	transition: opacity 0.2s ease-out;
}
.l-mainfooter__pagetop > a {
	display: inline-block;
	cursor: default;
	clip-path: polygon(100% 0, 0 100%, 100% 100%);
}
.l-mainfooter__pagetop.is-visible {
	pointer-events: all;
	opacity: 1;
}
.l-mainfooter__pagetop.is-visible > a {
	cursor: pointer;
}

/*----------
	main content
----------*/
.l-content {
	width: 100%;
	position: relative;
	overflow-x: hidden;
	padding-bottom: 40px;
}
@media (min-width: 768px) {
	.l-content {
		width: 100%;
		margin: 0 0 0 auto;
		padding-bottom: 60px;
	}
}
@media (max-width: 980px) {
	.l-content {
		width: 100%;
	}
}

.l-section {
	background-color: #FFF;
	background-position: top right;
	background-repeat: no-repeat;
	background-size: 125px;
	padding: 80px 0;
}
@media (max-width: 980px) {
	.l-section {
		max-width: 100%;
	}
}
@media (min-width: 768px) {
	.l-section {
		padding: 120px 0;
		background-size: 250px;
	}
}
.l-section#p01 {
	background-image: url(../images/top/bg_01.png);
}
.l-section#p02 {
	background-image: url(../images/top/bg_02.png);
}
.l-section#p03 {
	background-image: url(../images/top/bg_03.png);
}
.l-section#p04 {
	background-image: url(../images/top/bg_04.png);
}
.l-section#p05 {
	background-image: url(../images/top/bg_05.png);
}
.l-section#p06 {
	background-image: url(../images/top/bg_06.png);
}
.l-section#p07 {
	background-image: url(../images/top/bg_07.png);
}
.l-section--bg {
	background-color: var(--color-bg);
}
.l-section-inner {
	width: 100%;
	max-width: 1288px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 5.3333333333%;
	padding-right: 5.3333333333%;
}
@media (min-width: 768px) {
	.l-section-inner {
		padding-left: 44px;
		padding-right: 44px;
	}
}
.l-section-anchor {
	margin-top: -100px;
	padding-top: 100px;
}
@media (max-width: 980px) {
	.l-section-anchor {
		margin-top: -80px;
		padding-top: 80px;
	}
}

.l-breadcrumb {
	overflow-x: auto;
}
.l-breadcrumb__list {
	display: flex;
	flex-wrap: nowrap;
	white-space: nowrap;
	font-size: 1.2rem;
	line-height: 1.2;
	text-align: right;
	width: 100%;
	max-width: 1288px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 5.3333333333%;
	padding-right: 5.3333333333%;
}
@media (min-width: 768px) {
	.l-breadcrumb__list {
		padding-left: 44px;
		padding-right: 44px;
	}
}
.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: "/";
	display: inline-block;
	margin: 0 5px;
}
.l-breadcrumb__list > li:last-child > a {
	pointer-events: none;
}
@media (min-width: 768px) {
	.l-breadcrumb {
		background: none;
		padding: 14px 0;
		margin: 0;
	}
	.l-breadcrumb__list {
		display: block;
		white-space: normal;
	}
	.l-breadcrumb__list > li {
		display: inline;
	}
	.l-breadcrumb__list > li > a:hover {
		text-decoration: underline;
	}
}
@media (max-width: 980px) {
	.l-breadcrumb {
		order: 2;
		background: #F7F7F7;
		padding: 11px 0;
		margin-top: 100px;
	}
	.l-breadcrumb__list {
		text-align: left;
		max-width: 100%;
	}
}

/*----------
	main navigation
----------*/
.l-mainsidemenu__main {
	width: 100%;
}
.l-mainsidemenu__list {
	display: flex;
	align-items: center;
	gap: 20px;
}
.l-mainsidemenu__sub {
	position: absolute;
	right: 0;
	top: 0;
	display: flex;
	align-items: center;
	gap: 20px;
}
.l-mainsidemenu__link {
	color: var(--color-txt);
	font-size: 1.4rem;
	font-weight: 700;
	line-height: var(--line-height-s);
	display: flex;
	align-items: center;
	transition: color 0.2s ease-out;
	position: relative;
	padding: 15px 0;
	letter-spacing: 0.01em;
}
.l-mainsidemenu__link::after {
	content: "";
	width: 16px;
	height: 16px;
	background: url(../images/common/icon_03-arrow1-b.svg) center/contain no-repeat;
	display: inline-block;
	margin-left: 10px;
	transition: all 0.2s ease-out;
}
.l-mainsidemenu__link:hover {
	color: var(--color-prim);
}
.l-mainsidemenu__link:hover::after {
	background-image: url(../images/common/icon_07-arrow2-b.svg);
}
@media (max-width: 1200px) {
	.l-mainsidemenu {
		display: none;
	}
}

/*----------
	spmenu
----------*/
.l-spmenu {
	position: relative;
}
.l-spmenu__main {
	min-height: calc(100vh - 55px);
}
@media (max-width: 1200px) {
	.l-spmenu__main {
		min-height: calc(100vh - 135px);
		padding: 0 0 80px 20px;
	}
}
.l-spmenu__inner {
	width: 100%;
	max-width: 1288px;
	margin: 0 auto;
	padding: 44px 44px 0;
	background-color: #E9F3D2;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}
@media (max-width: 1200px) {
	.l-spmenu__inner {
		padding: 30px 30px 0;
	}
}
.l-spmenu__logo {
	width: 260px;
	display: inline-block;
}
.l-spmenu__title {
	color: var(--color-prim);
	font-size: 2.4rem;
	font-weight: bold;
	line-height: var(--line-height-m);
}
.l-spmenu__title--small {
	display: block;
	font-size: 1.8rem;
	color: var(--color-txt);
	margin-top: 5px;
}
.l-spmenu__sub {
	font-size: 1.4rem;
	font-weight: bold;
	line-height: var(--line-height-s);
	margin-top: 10px;
}
.l-spmenu__code {
	display: inline-block;
	border: #333 solid 1px;
	font-size: 1.2rem;
	line-height: var(--line-height-s);
	text-align: center;
	padding: 5px 20px;
	margin-top: 10px;
}
.l-spmenu__list {
	margin-top: 10px;
}
.l-spmenu__item {
	border-bottom: 1px solid var(--color-border);
}
.l-spmenu__itemBtn {
	border-bottom: none;
	margin: 20px 0 5px;
}
.l-spmenu__itemBtn--sub {
	display: flex;
	justify-content: flex-end;
	width: calc(100% + 88px);
	margin: 30px -44px 0;
}
@media (max-width: 1200px) {
	.l-spmenu__itemBtn--sub {
		width: calc(100% + 60px);
		margin: 30px -30px 0;
	}
}
.l-spmenu__itemBtn--sub > .c-button {
	width: calc(50% - 1px);
	max-width: 300px;
}
.l-spmenu__itemBtn--sub > .c-button > .c-button__inner {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 10px 35px 10px 15px;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.5;
	height: 100%;
}
.l-spmenu__itemBtn--sub > .c-button > .c-button__inner.js-anchor::after {
	background: url(../images/common/icon_03-arrow1-b.svg) center/contain no-repeat;
}
.l-spmenu__itemBtn--sub > .c-button:first-child > .c-button__inner {
	border-radius: 0 8px 0 0;
}
.l-spmenu__itemBtn--sub > .c-button:last-child > .c-button__inner {
	border-radius: 8px 0 0;
}
.l-spmenu__link {
	position: relative;
	color: var(--color-txt);
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.5;
	display: flex;
	justify-content: space-between;
	align-items: center;
	transition: color 0.2s ease-out;
	padding: 15px 20px;
	letter-spacing: 0.04em;
}
.l-spmenu__link::before {
	content: "";
	position: absolute;
	top: 15px;
	left: 0;
	width: 2px;
	height: 24px;
	background-color: var(--color-prim);
}
.l-spmenu__link::after {
	content: "";
	width: 16px;
	height: 16px;
	background: url(../images/common/icon_03-arrow1-b.svg) center/contain no-repeat;
	display: inline-block;
	margin-left: 10px;
	transition: all 0.2s ease-out;
}
.l-spmenu__link:hover {
	color: var(--color-prim);
}
.l-spmenu__link:hover::after {
	background-image: url(../images/common/icon_07-arrow2-b.svg);
}
.l-spmenu__link--nodeco::before {
	content: none;
}

/* @forward '_main-nav'; */
/* @forward '_search-modal'; */
/*----------
	margin
----------*/
/* 固定マージン */
/* 汎用マージン */
.u-margin-xxs {
	margin-bottom: 10px !important;
	/* stylelint-disable-line declaration-no-important */
}

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

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

.u-margin-md {
	margin-bottom: 30px !important;
	/* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-md {
		margin-bottom: 40px !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: 60px !important;
		/* stylelint-disable-line declaration-no-important */
	}
}

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

.u-margin-xxl {
	margin-bottom: 80px !important;
	/* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-xxl {
		margin-bottom: 120px !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-topnone {
	margin-top: 0 !important;
	/* stylelint-disable-line declaration-no-important */
}
@media (min-width: 768px) {
	.u-margin-topnone {
		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;
	}
}

.u-dis-ib {
	display: inline-block;
}

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

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

.u-tabbr {
	display: none;
}
@media (max-width: 980px) {
	.u-tabbr {
		display: block;
	}
}

.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-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-top {
	vertical-align: top !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-font-sans {
	font-family: var(--font-sans) !important;
}

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

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