@charset "UTF-8";
/*
@include mq(sp){}
@include mq(tb){}
@include mq(pc){}
@include mq(pcw){}
*/
/* =======================================================================
normalize
======================================================================= */
/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
	font-family: sans-serif; /* 1 */
	-ms-text-size-adjust: 100%; /* 2 */
	-webkit-text-size-adjust: 100%; /* 2 */
}

/**
 * Remove default margin.
 */
body {
	margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
	display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
	display: inline-block; /* 1 */
	vertical-align: baseline; /* 2 */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
	display: none;
	height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
 */
[hidden],
template {
	display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
	outline: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
	border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
	font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
	font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/**
 * Address styling not present in IE 8/9.
 */
mark {
	background: #ff0;
	color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sup {
	top: -0.5em;
}

sub {
	bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
	border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
	overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
	margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
	-moz-box-sizing: content-box;
	box-sizing: content-box;
	height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
	overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
	font-family: monospace, monospace;
	font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
	color: inherit; /* 1 */
	font: inherit; /* 2 */
	margin: 0; /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
	overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
	text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type=button],
input[type=reset],
input[type=submit] {
	-webkit-appearance: button; /* 2 */
	cursor: pointer; /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
	cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
	line-height: normal;
}

/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type=checkbox],
input[type=radio] {
	box-sizing: border-box; /* 1 */
	padding: 0; /* 2 */
}

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome
 *    (include `-moz` to future-proof).
 */
input[type=search] {
	-webkit-appearance: textfield; /* 1 */
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box; /* 2 */
	box-sizing: content-box;
}

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
	border: 1px solid #c0c0c0;
	margin: 0 2px;
	padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
	border: 0; /* 1 */
	padding: 0; /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
	overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
	font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
	border-collapse: collapse;
	border-spacing: 0;
}

td,
th {
	padding: 0;
}

/* =======================================================================
reset
======================================================================= */
img {
	vertical-align: top;
	font-size: 0;
	line-height: 0;
	max-width: 100%;
	height: auto;
}

ul, ol, li, dl, dt, dd, h1, h2, h3, h4, h5, h6, p, figure {
	margin: 0;
	padding: 0;
}

h1, h2, h3, h4, h5, h6 {
	font-weight: 600;
	font-size: 100%;
}

ol, ul {
	list-style: none;
}

i {
	font-style: normal;
}

label {
	cursor: pointer;
}

th, td {
	vertical-align: middle;
}

th {
	font-weight: normal;
	text-align: left;
}

em {
	font-weight: bold;
	font-style: normal;
}

figcaption {
	line-height: normal;
}

button,
input[type=reset],
input[type=submit] {
	display: inline-block;
	appearance: none;
	-webkit-appearance: none;
	border: 0;
	background: none;
	outline: none;
	vertical-align: top;
	margin: 0;
	padding: 0;
}

hr {
	margin: 0;
}

* {
	box-sizing: border-box;
}
*:before, *:after {
	box-sizing: border-box;
}

@media screen and (max-width: 767px) {
	img {
		width: 100%;
		max-width: inherit;
	}
}
/* =======================================================================
root
======================================================================= */
:root {
	--fontsize: 16;
	--width_primary: 1500px;
	--width_secondary: 1100px;
	--width_tertiary: 800px;
	--color_primary: #2d2d2e;
	--color_secondary: #4aa85a;
	--color_tertiary: #376ab3;
	--color_quaternary: #f0844a;
	--color_quinary: #ed798e;
	--color_purpose: var(--color_secondary);
	--color_use: var(--color_tertiary);
	--color_consult: var(--color_quaternary);
	--color_join: var(--color_quinary);
	--color_alert: #dd0000;
	--color_clear: #ffffff;
	--line_primary: #ccc;
	--line_secondary: #aaa;
	--bg_primary: #f0f0f0;
	--bg_secondary: #eeeeee;
}
@media screen and (min-width: 1025px) {
	:root {
		--global_margin: 60px;
		--global_margin_m: 60px;
		--global_margin_l: 80px;
		--u_margin_xs: 10px;
		--u_margin_s: 20px;
		--u_margin_m: 30px;
		--u_margin_l: 40px;
		--u_margin_xl: 60px;
		--u_margin_2xl: 80px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	:root {
		--global_margin: 40px;
		--global_margin_m: 60px;
		--global_margin_l: 80px;
		--u_margin_xs: 10px;
		--u_margin_s: 20px;
		--u_margin_m: 30px;
		--u_margin_l: 40px;
		--u_margin_xl: 60px;
		--u_margin_2xl: 80px;
	}
}
@media screen and (max-width: 767px) {
	:root {
		--global_margin: 20px;
		--global_margin_m: 30px;
		--global_margin_l: 40px;
		--u_margin_xs: 5px;
		--u_margin_s: 10px;
		--u_margin_m: 20px;
		--u_margin_l: 30px;
		--u_margin_xl: 40px;
		--u_margin_2xl: 60px;
	}
}

.t-use {
	--color_purpose: var(--color_use);
}

.t-consult {
	--color_purpose: var(--color_consult);
}

.t-join {
	--color_purpose: var(--color_join);
}

/* =======================================================================
main
======================================================================= */
html {
	font-size: calc(var(--fontsize) / 16 * 100%);
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
}

body {
	font-family: "M PLUS Rounded 1c", sans-serif;
	font-weight: 500;
	font-style: normal;
	font-size: calc(16 / (var(--fontsize)) * 1rem);
	line-height: 1.231;
	color: var(--color_primary);
}

.l-wrapper {
	position: relative;
	display: grid;
	grid-template-rows: auto 1fr auto;
	min-height: 100vh;
	margin-left: auto;
	margin-right: auto;
}
@media screen and (max-width: 767px) {
	.l-wrapper {
		padding-top: 60px;
	}
}

.l-inner {
	position: relative;
	margin-left: auto;
	margin-right: auto;
	box-sizing: content-box;
	max-width: var(--width_secondary);
	padding-left: var(--global_margin);
	padding-right: var(--global_margin);
}

.l-main {
	overflow: hidden;
}

.l-content {
	position: relative;
	background-image: url("../images/common/bg.webp");
	background-position: 50% 0;
	background-size: 1590px auto;
}
@media screen and (min-width: 768px) {
	.l-content {
		padding-top: 20px;
		padding-bottom: 120px;
	}
}
@media screen and (max-width: 767px) {
	.l-content {
		padding-top: 10px;
		padding-bottom: 60px;
	}
}
@media screen and (min-width: 768px) {
	.l-content--top {
		padding-top: 60px;
	}
}
@media screen and (max-width: 767px) {
	.l-content--top {
		padding-top: 30px;
	}
}
.l-content:before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 25px;
	translate: 0 -100%;
	mask: url("../images/common/mask_bg.svg");
	mask-size: auto 100%;
	-webkit-mask-size: auto 100%;
	background-image: url("../images/common/bg.webp");
	background-position: 50% 0;
	background-size: 1590px auto;
}

/* =======================================================================
header
======================================================================= */
.l-header {
	z-index: 5020;
	background-color: var(--color_clear);
}
@media screen and (max-width: 767px) {
	.l-header {
		position: fixed;
		left: 0;
		top: 0;
		width: 100%;
	}
}
.t-top .l-header {
	opacity: 0;
	animation: kf_fadein 1s linear forwards 1;
	animation-delay: 0.5s;
}
.l-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--global_margin);
}
@media screen and (min-width: 768px) {
	.l-header__inner {
		min-height: 120px;
		padding-top: 20px;
		padding-left: var(--global_margin);
		padding-right: var(--global_margin);
	}
}
@media screen and (max-width: 767px) {
	.l-header__inner {
		min-height: 60px;
		padding-left: var(--global_margin);
	}
}
.l-header__inner__sub {
	display: flex;
	justify-content: end;
	align-items: center;
}
@media screen and (min-width: 768px) {
	.l-header__inner__sub {
		gap: 20px;
	}
}
@media screen and (max-width: 767px) {
	.l-header__inner__sub {
		gap: 5px;
	}
}

@media screen and (min-width: 1025px) {
	.c-header-logo {
		width: 300px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-header-logo {
		width: 240px;
	}
}
@media screen and (max-width: 767px) {
	.c-header-logo {
		width: 180px;
	}
}
@media (hover: hover) and (pointer: fine) {
	.c-header-logo a {
		transition: opacity 0.3s;
	}
	.c-header-logo a:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}

.c-header-contact {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	background-color: var(--color_tertiary);
}
@media (hover: hover) and (pointer: fine) {
	.c-header-contact {
		transition: opacity 0.3s;
	}
	.c-header-contact:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}
@media screen and (min-width: 1025px) {
	.c-header-contact {
		min-height: 40px;
		min-width: 160px;
		padding: 5px 15px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-header-contact {
		min-height: 40px;
		min-width: 140px;
		padding: 5px 10px;
	}
}
@media screen and (max-width: 767px) {
	.c-header-contact {
		min-height: 40px;
		min-width: 40px;
	}
}
.c-header-contact .ico {
	background-size: 100%;
	background-image: url("../images/common/ico_header_mail.svg");
}
@media screen and (min-width: 768px) {
	.c-header-contact .ico {
		width: 24px;
		height: 16px;
	}
}
@media screen and (max-width: 767px) {
	.c-header-contact .ico {
		width: 24px;
		height: 16px;
	}
}
.c-header-contact .txt {
	font-size: calc(15 / (var(--fontsize)) * 1rem);
	color: var(--color_clear);
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-header-contact .txt {
		font-size: calc(13 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-header-contact .txt {
		display: none;
	}
}

.c-header-tel {
	display: grid;
}

.c-header-tel-num {
	display: flex;
	align-items: center;
}
@media screen and (min-width: 768px) {
	.c-header-tel-num {
		gap: 10px;
		pointer-events: none;
	}
}
.c-header-tel-num .ico {
	background-color: var(--color_tertiary);
	border-radius: 4px;
	background-size: 100%;
	background-image: url("../images/common/ico_tel.svg");
}
@media screen and (min-width: 768px) {
	.c-header-tel-num .ico {
		width: 25px;
		height: 25px;
	}
}
@media screen and (max-width: 767px) {
	.c-header-tel-num .ico {
		width: 40px;
		height: 40px;
		background-repeat: no-repeat;
		background-size: 32px;
		background-position: 50%;
		border-radius: 0;
	}
}
.c-header-tel-num .txt {
	color: var(--color_tertiary);
}
@media screen and (min-width: 1025px) {
	.c-header-tel-num .txt {
		font-size: calc(28 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-header-tel-num .txt {
		font-size: calc(24 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-header-tel-num .txt {
		display: none;
	}
}

.c-header-tel-txt {
	color: var(--color_tertiary);
}
@media screen and (min-width: 1025px) {
	.c-header-tel-txt {
		font-size: calc(12 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-header-tel-txt {
		font-size: calc(10 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-header-tel-txt {
		display: none;
	}
}

@media screen and (min-width: 768px) {
	.c-header-menu {
		display: none;
	}
}
@media screen and (max-width: 767px) {
	.c-header-menu {
		position: relative;
		width: 60px;
		height: 60px;
	}
	.c-header-menu figure {
		position: absolute;
		left: 50%;
		width: 50%;
		height: 2px;
		background-color: var(--color_tertiary);
		translate: -50% 0;
		transition: 0.3s;
	}
	.c-header-menu figure:nth-of-type(1) {
		top: 50%;
		margin-top: -10px;
	}
	.c-header-menu figure:nth-of-type(2) {
		top: 50%;
		margin-top: -1px;
	}
	.c-header-menu figure:nth-of-type(3) {
		bottom: 50%;
		margin-bottom: -10px;
	}
	.c-header-menu[aria-expanded=true] figure:nth-of-type(1) {
		translate: -50% 9px;
		rotate: -30deg;
	}
	.c-header-menu[aria-expanded=true] figure:nth-of-type(2) {
		height: 0;
		opacity: 0;
	}
	.c-header-menu[aria-expanded=true] figure:nth-of-type(3) {
		translate: -50% -9px;
		rotate: 30deg;
	}
}

.c-gnav {
	background-color: var(--color_secondary);
	scrollbar-width: none;
	-ms-overflow-style: none;
}
@media screen and (min-width: 768px) {
	.c-gnav {
		display: flex;
		align-items: center;
		justify-content: center;
		min-height: 80px;
	}
}
@media screen and (max-width: 767px) {
	.c-gnav {
		position: fixed;
		left: 0;
		top: 60px;
		width: 100%;
		height: calc(100vh - 60px);
		padding-block: 30px;
		padding-inline: var(--global_margin);
		overflow: auto;
		pointer-events: none;
		opacity: 0;
		transition: 0.3s;
	}
	.c-gnav[aria-hidden=false] {
		pointer-events: auto;
		opacity: 1;
	}
}
.c-gnav::-webkit-scrollbar {
	display: none;
}
@media screen and (min-width: 768px) {
	.c-gnav__inner {
		width: 100%;
		display: flex;
		align-items: center;
		justify-content: space-between;
		max-width: var(--width_secondary);
		box-sizing: content-box;
		padding-left: var(--global_margin);
		padding-right: var(--global_margin);
	}
}
@media screen and (min-width: 1025px) {
	.c-gnav__inner {
		gap: 60px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-gnav__inner {
		gap: 20px;
	}
}
.c-gnav__inner__main {
	flex: 1 0 auto;
}
.c-gnav__inner__sub {
	flex-shrink: 0;
}

.c-gnav-main {
	display: flex;
}
@media screen and (min-width: 1025px) {
	.c-gnav-main {
		gap: 15px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-gnav-main {
		gap: 10px;
	}
}
@media screen and (max-width: 767px) {
	.c-gnav-main {
		flex-direction: column;
		gap: 10px;
	}
}
.c-gnav-main__item {
	flex: 1 1 0;
}
.c-gnav-main__item a {
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	width: 100%;
	border: solid 1px;
	background-color: var(--color_clear);
	border-radius: 100vmax;
}
@media screen and (min-width: 768px) {
	.c-gnav-main__item a {
		min-height: 40px;
	}
}
@media screen and (min-width: 1025px) {
	.c-gnav-main__item a {
		font-size: calc(20 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-gnav-main__item a {
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-gnav-main__item a {
		min-height: 50px;
		font-size: calc(20 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (min-width: 1025px) {
	.c-gnav-main__item a .em {
		font-size: calc(24 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-gnav-main__item a .em {
		font-size: calc(20 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-gnav-main__item a .em {
		font-size: calc(24 / (var(--fontsize)) * 1rem);
	}
}
@media (hover: hover) and (pointer: fine) {
	.c-gnav-main__item a {
		transition: 0.3s;
	}
	.c-gnav-main__item a:hover {
		color: var(--color_clear);
		text-decoration: none;
	}
}
.c-gnav-main__item--use a {
	border-color: var(--color_use);
	color: var(--color_use);
}
@media (hover: hover) and (pointer: fine) {
	.c-gnav-main__item--use a:hover {
		background-color: var(--color_use);
	}
}
.c-gnav-main__item--consult a {
	border-color: var(--color_consult);
	color: var(--color_consult);
}
@media (hover: hover) and (pointer: fine) {
	.c-gnav-main__item--consult a:hover {
		background-color: var(--color_consult);
	}
}
.c-gnav-main__item--join a {
	border-color: var(--color_join);
	color: var(--color_join);
}
@media (hover: hover) and (pointer: fine) {
	.c-gnav-main__item--join a:hover {
		background-color: var(--color_join);
	}
}

.c-gnav-sub {
	position: relative;
	display: flex;
}
@media screen and (max-width: 767px) {
	.c-gnav-sub {
		margin-top: 20px;
		flex-direction: column;
	}
}
.c-gnav-sub:before {
	content: "";
	position: absolute;
}
@media screen and (min-width: 768px) {
	.c-gnav-sub:before {
		height: 100%;
		right: 0;
		top: 0;
		border-left: 2px dotted var(--color_clear);
	}
}
@media screen and (max-width: 767px) {
	.c-gnav-sub:before {
		width: 100%;
		left: 0;
		top: 0;
		border-top: 2px dotted var(--color_clear);
	}
}
.c-gnav-sub__item {
	position: relative;
}
@media screen and (min-width: 1025px) {
	.c-gnav-sub__item {
		font-size: calc(17 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-gnav-sub__item {
		font-size: calc(14 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-gnav-sub__item {
		font-size: calc(17 / (var(--fontsize)) * 1rem);
	}
}
.c-gnav-sub__item:before {
	content: "";
	position: absolute;
}
@media screen and (min-width: 768px) {
	.c-gnav-sub__item:before {
		height: 100%;
		left: 0;
		top: 0;
		border-left: 2px dotted var(--color_clear);
	}
}
@media screen and (max-width: 767px) {
	.c-gnav-sub__item:before {
		width: 100%;
		left: 0;
		bottom: 0;
		border-bottom: 2px dotted var(--color_clear);
	}
}
.c-gnav-sub__item a {
	display: flex;
	align-items: center;
	color: var(--color_clear);
}
@media screen and (min-width: 768px) {
	.c-gnav-sub__item a {
		min-height: 40px;
	}
}
@media screen and (min-width: 1025px) {
	.c-gnav-sub__item a {
		padding-inline: 20px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-gnav-sub__item a {
		padding-inline: 15px;
	}
}
@media screen and (max-width: 767px) {
	.c-gnav-sub__item a {
		min-height: 50px;
		justify-content: center;
		text-align: center;
	}
}

@media screen and (min-width: 768px) {
	.c-gnav-tel {
		display: none;
	}
}
@media screen and (max-width: 767px) {
	.c-gnav-tel {
		display: grid;
		gap: 5px;
		margin-top: 30px;
	}
}

.c-gnav-tel-num {
	display: flex;
	gap: 10px;
	align-items: center;
	justify-content: center;
}
.c-gnav-tel-num .ico {
	background-color: var(--color_tertiary);
	border-radius: 4px;
	background-size: 100%;
	background-image: url("../images/common/ico_tel.svg");
}
@media screen and (max-width: 767px) {
	.c-gnav-tel-num .ico {
		width: 28px;
		height: 28px;
	}
}
.c-gnav-tel-num .txt {
	color: var(--color_clear);
	font-size: calc(28 / (var(--fontsize)) * 1rem);
}
.c-gnav-tel-num .txt a {
	color: var(--color_clear);
}

.c-gnav-tel-txt {
	text-align: center;
	font-size: calc(12 / (var(--fontsize)) * 1rem);
	color: var(--color_clear);
}

/* =======================================================================
footer
======================================================================= */
.c-btm-nav {
	position: relative;
	background-color: var(--color_secondary);
}
@media screen and (min-width: 768px) {
	.c-btm-nav {
		padding-top: 50px;
		padding-bottom: 50px;
	}
}
@media screen and (max-width: 767px) {
	.c-btm-nav {
		padding-top: 30px;
		padding-bottom: 30px;
	}
}
.c-btm-nav:before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 25px;
	translate: 0 -100%;
	mask: url("../images/common/mask_bg.svg");
	mask-size: auto 100%;
	background-color: var(--color_secondary);
	z-index: 1;
}

.c-btm-nav-col {
	display: grid;
	align-items: center;
	justify-content: center;
	grid-template-columns: auto auto;
	grid-template-rows: auto auto;
	gap: 20px 30px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-btm-nav-col {
		grid-template-columns: auto;
		grid-template-rows: auto auto auto;
	}
}
@media screen and (max-width: 767px) {
	.c-btm-nav-col {
		display: flex;
		flex-direction: column;
	}
}

.c-btm-nav-main {
	display: flex;
}
@media screen and (min-width: 768px) {
	.c-btm-nav-main {
		gap: 20px;
	}
}
@media screen and (min-width: 1025px) {
	.c-btm-nav-main {
		justify-content: end;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-btm-nav-main {
		justify-content: center;
	}
}
@media screen and (max-width: 767px) {
	.c-btm-nav-main {
		width: 100%;
		flex-direction: column;
		gap: 10px;
		justify-content: center;
	}
}
.c-btm-nav-main__item {
	font-size: calc(18 / (var(--fontsize)) * 1rem);
}
.c-btm-nav-main__item a {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 20px;
	border-radius: 100vmax;
	gap: 10px;
	background-color: var(--color_clear);
	color: var(--color_secondary);
}
@media (hover: hover) and (pointer: fine) {
	.c-btm-nav-main__item a {
		transition: opacity 0.3s;
	}
	.c-btm-nav-main__item a:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}
@media screen and (min-width: 768px) {
	.c-btm-nav-main__item a {
		min-height: 32px;
		max-width: 190px;
	}
}
@media screen and (max-width: 767px) {
	.c-btm-nav-main__item a {
		min-height: 40px;
	}
}
.c-btm-nav-main__item a:before {
	content: "";
	border-left: solid 12px var(--color_secondary);
	border-top: solid 6px transparent;
	border-bottom: solid 6px transparent;
}

.c-btm-nav-sub {
	display: flex;
	gap: 20px;
}
@media screen and (min-width: 1025px) {
	.c-btm-nav-sub {
		justify-content: end;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-btm-nav-sub {
		justify-content: center;
	}
}
@media screen and (max-width: 767px) {
	.c-btm-nav-sub {
		justify-content: center;
	}
}
@media screen and (min-width: 768px) {
	.c-btm-nav-sub__item {
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-btm-nav-sub__item {
		font-size: calc(14 / (var(--fontsize)) * 1rem);
	}
}
.c-btm-nav-sub__item a {
	position: relative;
	display: flex;
	align-items: center;
	gap: 10px;
	color: var(--color_clear);
}
.c-btm-nav-sub__item a:before {
	content: "";
	border-left: solid 12px var(--color_clear);
	border-top: solid 6px transparent;
	border-bottom: solid 6px transparent;
}

.c-btm-nav-other {
	grid-column: 2/3;
	display: flex;
	justify-content: end;
	gap: 20px;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-btm-nav-other {
		grid-column: 1/2;
		justify-content: center;
	}
}
@media screen and (max-width: 767px) {
	.c-btm-nav-other {
		justify-content: center;
	}
}
@media screen and (min-width: 768px) {
	.c-btm-nav-other__item {
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-btm-nav-other__item {
		font-size: calc(14 / (var(--fontsize)) * 1rem);
	}
}
.c-btm-nav-other__item a {
	position: relative;
	display: flex;
	align-items: center;
	min-height: 40px;
	padding: 0 30px;
	gap: 10px;
	border: solid 1px var(--color_clear);
	color: var(--color_clear);
}
.c-btm-nav-other__item a:before {
	content: "";
	border-left: solid 12px var(--color_clear);
	border-top: solid 6px transparent;
	border-bottom: solid 6px transparent;
}

.l-footer {
	position: relative;
	display: grid;
}
@media screen and (min-width: 768px) {
	.l-footer {
		padding-top: 60px;
		padding-bottom: 30px;
	}
}
@media screen and (max-width: 767px) {
	.l-footer {
		padding-top: 40px;
		padding-bottom: 20px;
	}
}
.l-footer__inner {
	padding-left: var(--global_margin);
	padding-right: var(--global_margin);
}

.c-footer-main {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 30px;
}
@media screen and (max-width: 767px) {
	.c-footer-main > * {
		width: 100%;
	}
}

.c-footer-logo {
	margin-inline: auto;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.c-footer-logo {
		width: 300px;
	}
}
@media screen and (max-width: 767px) {
	.c-footer-logo {
		width: 240px;
	}
}

.c-footer-address {
	margin-top: 15px;
	font-style: normal;
	font-size: calc(15 / (var(--fontsize)) * 1rem);
	text-align: center;
	line-height: 1.5;
}

.c-footer-contact {
	border-radius: 10px;
	border: solid 1px var(--color_tertiary);
}
@media screen and (min-width: 768px) {
	.c-footer-contact {
		padding: 20px 40px;
	}
}
@media screen and (max-width: 767px) {
	.c-footer-contact {
		padding: 20px 20px;
	}
}

.c-footer-contact-title {
	font-size: calc(20 / (var(--fontsize)) * 1rem);
	text-align: center;
	color: var(--color_tertiary);
}

.c-footer-contact-col {
	display: flex;
	align-items: center;
	justify-content: center;
}
@media screen and (min-width: 768px) {
	.c-footer-contact-col {
		margin-top: 10px;
		gap: var(--global_margin);
	}
}
@media screen and (max-width: 767px) {
	.c-footer-contact-col {
		margin-top: 20px;
		gap: 40px;
		flex-direction: column;
	}
}
.c-footer-contact-col__item {
	position: relative;
}
.c-footer-contact-col__item + .c-footer-contact-col__item:before {
	content: "";
	background-color: var(--color_clear);
	position: absolute;
	background-color: var(--color_tertiary);
}
@media screen and (min-width: 768px) {
	.c-footer-contact-col__item + .c-footer-contact-col__item:before {
		width: 1px;
		height: 100%;
		left: calc(var(--global_margin) / -2);
		top: 0;
	}
}
@media screen and (max-width: 767px) {
	.c-footer-contact-col__item + .c-footer-contact-col__item:before {
		width: 100%;
		height: 1px;
		top: -20px;
		left: 0;
	}
}

.c-footer-contact-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 40px;
	padding: 5px 20px;
	gap: 10px;
	background-color: #e5e8f5;
	border: solid 1px var(--color_tertiary);
	color: var(--color_tertiary);
	font-size: calc(16 / (var(--fontsize)) * 1rem);
}
@media (hover: hover) and (pointer: fine) {
	.c-footer-contact-btn {
		transition: opacity 0.3s;
	}
	.c-footer-contact-btn:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}
@media screen and (min-width: 768px) {
	.c-footer-contact-btn {
		min-width: 230px;
	}
}
.c-footer-contact-btn .ico {
	width: 24px;
	height: 16px;
	background-size: 100%;
	background-image: url("../images/common/ico_footer_mail.svg");
}

.c-footer-contact-tel {
	display: flex;
	gap: 10px;
}
.c-footer-contact-tel .ico {
	translate: 0 6px;
	width: 25px;
	height: 25px;
	background-color: var(--color_tertiary);
	border-radius: 4px;
	background-size: 100%;
	background-image: url("../images/common/ico_tel.svg");
}
.c-footer-contact-tel .txt {
	display: grid;
	color: var(--color_tertiary);
}
.c-footer-contact-tel .txt a {
	color: var(--color_tertiary);
}
.c-footer-contact-tel .txt .tel {
	font-size: calc(30 / (var(--fontsize)) * 1rem);
}
.c-footer-contact-tel .txt .fax {
	font-size: calc(14 / (var(--fontsize)) * 1rem);
}

.c-footer-ig {
	display: flex;
	width: 50px;
	height: 50px;
	border-radius: 100vmax;
	border: solid 1px var(--color_tertiary);
	background-color: var(--color_clear);
}
@media (hover: hover) and (pointer: fine) {
	.c-footer-ig {
		transition: opacity 0.3s;
	}
	.c-footer-ig:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}
@media screen and (max-width: 767px) {
	.c-footer-ig {
		margin-inline: auto;
	}
}

.c-footer-bg {
	background-image: url("../images/common/illust_footer.webp");
	background-size: auto 100%;
	background-position: 50%;
	background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
	.c-footer-bg {
		height: 128px;
		margin-top: 30px;
	}
}
@media screen and (max-width: 767px) {
	.c-footer-bg {
		height: 12.5vw;
		margin-top: 20px;
	}
}

.c-footer-cr {
	margin-top: 20px;
	display: block;
	text-align: center;
}
@media screen and (min-width: 768px) {
	.c-footer-cr {
		font-size: calc(11 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-footer-cr {
		font-size: calc(10 / (var(--fontsize)) * 1rem);
	}
}

.c-pagetop {
	z-index: 5010;
	position: fixed;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	border-radius: 4px;
	background-color: var(--color_tertiary);
	color: var(--color_clear);
	text-align: center;
	width: 60px;
	height: 60px;
	font-size: calc(12 / (var(--fontsize)) * 1rem);
}
@media (hover: hover) and (pointer: fine) {
	.c-pagetop {
		transition: opacity 0.3s;
	}
	.c-pagetop:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}
@media screen and (min-width: 768px) {
	.c-pagetop {
		right: 40px;
		bottom: 30px;
	}
}
@media screen and (max-width: 767px) {
	.c-pagetop {
		right: 20px;
		bottom: 20px;
	}
}
.c-pagetop .ico {
	width: 12px;
	height: 12px;
	border-radius: 2px;
	border-top: solid 2px var(--color_clear);
	border-right: solid 2px var(--color_clear);
	rotate: -45deg;
}

.u-align-c {
	text-align: center;
}
@media screen and (max-width: 767px) {
	.u-align-c--pc-only {
		text-align: initial;
	}
}

.u-align-l {
	text-align: left;
}

.u-align-r {
	text-align: right;
}

.u-valign-t {
	vertical-align: top;
}

.u-valign-m {
	vertical-align: middle;
}

.u-valign-b {
	vertical-align: bottom;
}

.u-bg-primary {
	background-color: var(--bg_primary);
}

.u-bg-secondary {
	background-color: var(--bg_secondary);
}

.u-c-primary {
	color: var(--color_primary);
}
.u-c-primary a {
	color: var(--color_primary);
}

.u-c-secondary {
	color: var(--color_secondary);
}
.u-c-secondary a {
	color: var(--color_secondary);
}

.u-c-tertiary {
	color: var(--color_tertiary);
}
.u-c-tertiary a {
	color: var(--color_tertiary);
}

.u-c-quaternary {
	color: var(--color_quaternary);
}
.u-c-quaternary a {
	color: var(--color_quaternary);
}

.u-c-use {
	color: var(--color_use);
}
.u-c-use a {
	color: var(--color_use);
}

.u-c-consult {
	color: var(--color_consult);
}
.u-c-consult a {
	color: var(--color_consult);
}

.u-c-join {
	color: var(--color_join);
}
.u-c-join a {
	color: var(--color_join);
}

.u-c-clear {
	color: var(--color_clear);
}
.u-c-clear a {
	color: var(--color_clear);
}

.u-c-alert {
	color: var(--color_alert);
}
.u-c-alert a {
	color: var(--color_alert);
}

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

@media screen and (max-width: 767px) {
	.u-pc-only {
		display: none;
	}
}

.u-ff-primary {
	font-family: "M PLUS Rounded 1c", sans-serif;
	font-weight: 500;
	font-style: normal;
}

.u-ff-secondary {
	font-family: "Noto Sans JP", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
}

a {
	color: var(--color_primary);
	outline: none;
	text-decoration: none;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0.1);
}
@media (hover: hover) and (pointer: fine) {
	a:hover {
		text-decoration: underline;
	}
}
@media screen and (max-width: 767px) {
	a:hover {
		text-decoration: none;
	}
}

.u-uline {
	text-decoration: underline;
}
@media (hover: hover) and (pointer: fine) {
	.u-uline:hover {
		text-decoration: none;
	}
}

@media (hover: hover) and (pointer: fine) {
	.u-hline {
		text-decoration: none;
	}
}
@media (hover: hover) and (pointer: fine) {
	.u-hline:hover {
		text-decoration: underline;
	}
}

@media (hover: hover) and (pointer: fine) {
	.u-op {
		display: block;
	}
}
@media (hover: hover) and (pointer: fine) and (hover: hover) and (pointer: fine) {
	.u-op {
		transition: opacity 0.3s;
	}
	.u-op:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}

.u-list01 {
	display: grid;
	gap: 0.5em;
}

.u-list02 {
	display: flex;
}
@media screen and (min-width: 768px) {
	.u-list02 {
		flex-wrap: wrap;
		align-items: center;
		gap: 8px 32px;
	}
}
@media screen and (max-width: 767px) {
	.u-list02 {
		flex-direction: column;
		gap: 10px;
	}
}

.u-list-dot > * {
	position: relative;
	padding-left: 1em;
}
.u-list-dot > *:before {
	content: "・";
	position: absolute;
	left: 0;
	top: 0;
}

.u-list-circle > * {
	position: relative;
	padding-left: 1em;
}
.u-list-circle > *:before {
	content: "●";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--color_secondary);
}

.u-list-asterisk > * {
	position: relative;
	padding-left: 1em;
}
.u-list-asterisk > *:before {
	content: "※";
	position: absolute;
	left: 0;
	top: 0;
}

.u-list-decimal {
	counter-reset: decimal;
	list-style: none;
}
.u-list-decimal > * {
	position: relative;
	padding-left: 1.25em;
	counter-increment: decimal;
}
.u-list-decimal > *:before {
	position: absolute;
	left: 0;
	top: 0;
}
.u-list-decimal > *:nth-child(1)::before {
	content: "①";
}
.u-list-decimal > *:nth-child(2)::before {
	content: "②";
}
.u-list-decimal > *:nth-child(3)::before {
	content: "③";
}
.u-list-decimal > *:nth-child(4)::before {
	content: "④";
}
.u-list-decimal > *:nth-child(5)::before {
	content: "⑤";
}
.u-list-decimal > *:nth-child(6)::before {
	content: "⑥";
}
.u-list-decimal > *:nth-child(7)::before {
	content: "⑦";
}
.u-list-decimal > *:nth-child(8)::before {
	content: "⑧";
}
.u-list-decimal > *:nth-child(9)::before {
	content: "⑨";
}
.u-list-decimal > *:nth-child(10)::before {
	content: "⑩";
}

.u-list-ar > * {
	position: relative;
	padding-left: 20px;
}
.u-list-ar > *:before {
	content: "";
	width: 10px;
	height: 10px;
	border-top: solid 2px var(--color_secondary);
	border-right: solid 2px var(--color_secondary);
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
}

/* =======================================================================
margin
padding
======================================================================= */
.u-mt-xs {
	margin-top: var(--u_margin_xs);
}

.u-mt-s {
	margin-top: var(--u_margin_s);
}

.u-mt-m {
	margin-top: var(--u_margin_m);
}

.u-mt-l {
	margin-top: var(--u_margin_l);
}

.u-mt-xl {
	margin-top: var(--u_margin_xl);
}

.u-mt-2xl {
	margin-top: var(--u_margin_2xl);
}

.u-mb-xs {
	margin-bottom: var(--u_margin_xs);
}

.u-mb-s {
	margin-bottom: var(--u_margin_s);
}

.u-mb-m {
	margin-bottom: var(--u_margin_m);
}

.u-mb-l {
	margin-bottom: var(--u_margin_l);
}

.u-mb-xl {
	margin-bottom: var(--u_margin_xl);
}

.u-mb-2xl {
	margin-bottom: var(--u_margin_2xl);
}

.u-m-xs {
	margin: var(--u_margin_xs);
}

.u-m-s {
	margin: var(--u_margin_s);
}

.u-m-m {
	margin: var(--u_margin_m);
}

.u-m-l {
	margin: var(--u_margin_l);
}

.u-m-xl {
	margin: var(--u_margin_xl);
}

.u-m-2xl {
	margin: var(--u_margin_2xl);
}

.u-pt-xs {
	padding-top: var(--u_margin_xs);
}

.u-pt-s {
	padding-top: var(--u_margin_s);
}

.u-pt-m {
	padding-top: var(--u_margin_m);
}

.u-pt-l {
	padding-top: var(--u_margin_l);
}

.u-pt-xl {
	padding-top: var(--u_margin_xl);
}

.u-pt-2xl {
	padding-top: var(--u_margin_2xl);
}

.u-pb-xs {
	padding-bottom: var(--u_margin_xs);
}

.u-pb-s {
	padding-bottom: var(--u_margin_s);
}

.u-pb-m {
	padding-bottom: var(--u_margin_m);
}

.u-pb-l {
	padding-bottom: var(--u_margin_l);
}

.u-pb-xl {
	padding-bottom: var(--u_margin_xl);
}

.u-pb-2xl {
	padding-bottom: var(--u_margin_2xl);
}

.u-p-xs {
	padding: var(--u_margin_xs);
}

.u-p-s {
	padding: var(--u_margin_s);
}

.u-p-m {
	padding: var(--u_margin_m);
}

.u-p-l {
	padding: var(--u_margin_l);
}

.u-p-xl {
	padding: var(--u_margin_xl);
}

.u-p-2xl {
	padding: var(--u_margin_2xl);
}

.u-fw-n {
	font-weight: 500;
}

.u-fw-b {
	font-weight: 700;
}

.u-fs-default {
	font-size: calc(15 / (var(--fontsize)) * 1rem);
	line-height: 1.75;
}

.u-fs-10 {
	font-size: calc(10 / (var(--fontsize)) * 1rem);
	line-height: 1.75;
}

.u-fs-11 {
	font-size: calc(11 / (var(--fontsize)) * 1rem);
	line-height: 1.75;
}

.u-fs-12 {
	font-size: calc(12 / (var(--fontsize)) * 1rem);
	line-height: 1.75;
}

.u-fs-13 {
	font-size: calc(13 / (var(--fontsize)) * 1rem);
	line-height: 1.75;
}

.u-fs-14 {
	font-size: calc(14 / (var(--fontsize)) * 1rem);
	line-height: 1.75;
}

.u-fs-16 {
	font-size: calc(16 / (var(--fontsize)) * 1rem);
	line-height: 1.875;
}

.u-fs-18 {
	font-size: calc(18 / (var(--fontsize)) * 1rem);
	line-height: 1.5;
}

.u-fs-20 {
	font-size: calc(20 / (var(--fontsize)) * 1rem);
	line-height: 1.5;
}

.u-fs-22 {
	font-size: calc(22 / (var(--fontsize)) * 1rem);
	line-height: 1.5;
}

.u-fs-24 {
	font-size: calc(24 / (var(--fontsize)) * 1rem);
	line-height: 1.5;
}

@media screen and (max-width: 767px) {
	.u-fs-default {
		font-size: calc(13 / (var(--fontsize)) * 1rem);
		line-height: 1.75;
	}
	.u-fs-10 {
		font-size: calc(10 / (var(--fontsize)) * 1rem);
		line-height: 1.75;
	}
	.u-fs-11 {
		font-size: calc(11 / (var(--fontsize)) * 1rem);
		line-height: 1.75;
	}
	.u-fs-12 {
		font-size: calc(12 / (var(--fontsize)) * 1rem);
		line-height: 1.75;
	}
	.u-fs-13 {
		font-size: calc(13 / (var(--fontsize)) * 1rem);
		line-height: 1.75;
	}
	.u-fs-14 {
		font-size: calc(14 / (var(--fontsize)) * 1rem);
		line-height: 1.75;
	}
	.u-fs-16 {
		font-size: calc(16 / (var(--fontsize)) * 1rem);
		line-height: 1.875;
	}
	.u-fs-18 {
		font-size: calc(18 / (var(--fontsize)) * 1rem);
		line-height: 1.5;
	}
	.u-fs-20 {
		font-size: calc(20 / (var(--fontsize)) * 1rem);
		line-height: 1.5;
	}
	.u-fs-22 {
		font-size: calc(22 / (var(--fontsize)) * 1rem);
		line-height: 1.5;
	}
	.u-fs-24 {
		font-size: calc(24 / (var(--fontsize)) * 1rem);
		line-height: 1.5;
	}
}
.u-lh-l {
	line-height: 2;
}

.u-lh-s {
	line-height: 1.5;
}

.u-ls-m {
	letter-spacing: 0.1em;
}

.u-ls-l {
	letter-spacing: 0.2em;
}

.u-ti-1em {
	text-indent: 1em;
}

.c-breadcrumb-wrap {
	max-width: var(--width_secondary);
	margin-inline: auto;
	overflow: hidden;
}
@media screen and (min-width: 768px) {
	.c-breadcrumb-wrap + * {
		margin-top: 70px;
	}
}
@media screen and (max-width: 767px) {
	.c-breadcrumb-wrap + * {
		margin-top: 35px;
	}
}

.c-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	justify-content: end;
}
@media screen and (min-width: 768px) {
	.c-breadcrumb {
		font-size: calc(13 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-breadcrumb {
		font-size: calc(10 / (var(--fontsize)) * 1rem);
	}
}
.c-breadcrumb__item {
	position: relative;
	padding-right: 2em;
	flex-shrink: 0;
}
.c-breadcrumb__item:before {
	content: "＞";
	position: absolute;
	right: 0.5em;
	top: 0;
	color: var(--color_secondary);
}
.c-breadcrumb__item:last-child:before {
	display: none;
}

button.c-btn01,
input.c-btn01,
a.c-btn01,
.c-btn01 {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	background-color: var(--color_secondary);
	border-radius: 100vmax;
	color: var(--color_clear);
	font-size: calc(18 / (var(--fontsize)) * 1rem);
	text-align: center;
}
@media (hover: hover) and (pointer: fine) {
	button.c-btn01,
	input.c-btn01,
	a.c-btn01,
	.c-btn01 {
		transition: opacity 0.3s;
	}
	button.c-btn01:hover,
	input.c-btn01:hover,
	a.c-btn01:hover,
	.c-btn01:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}
@media screen and (min-width: 768px) {
	button.c-btn01,
	input.c-btn01,
	a.c-btn01,
	.c-btn01 {
		min-height: 40px;
		max-width: 240px;
	}
}
@media screen and (max-width: 767px) {
	button.c-btn01,
	input.c-btn01,
	a.c-btn01,
	.c-btn01 {
		min-height: 50px;
	}
}
button.c-btn01:before,
input.c-btn01:before,
a.c-btn01:before,
.c-btn01:before {
	content: "";
	position: absolute;
	right: 20px;
	top: 50%;
	width: 12px;
	height: 8px;
	background-image: url("../images/common/ico_arrow-wh.svg");
	background-size: 100%;
	translate: 0 -50%;
}
button.c-btn01--r,
input.c-btn01--r,
a.c-btn01--r,
.c-btn01--r {
	margin-left: auto;
}
button.c-btn01--s,
input.c-btn01--s,
a.c-btn01--s,
.c-btn01--s {
	font-size: calc(15 / (var(--fontsize)) * 1rem);
}
@media screen and (min-width: 768px) {
	button.c-btn01--s,
	input.c-btn01--s,
	a.c-btn01--s,
	.c-btn01--s {
		min-height: 30px;
		max-width: 170px;
	}
}
@media screen and (max-width: 767px) {
	button.c-btn01--s,
	input.c-btn01--s,
	a.c-btn01--s,
	.c-btn01--s {
		min-height: 40px;
	}
}
button.c-btn01--back,
input.c-btn01--back,
a.c-btn01--back,
.c-btn01--back {
	background-color: var(--line_primary);
}
button.c-btn01[disabled],
input.c-btn01[disabled],
a.c-btn01[disabled],
.c-btn01[disabled] {
	background-color: var(--line_primary);
}
button.c-btn01[disabled]:hover,
input.c-btn01[disabled]:hover,
a.c-btn01[disabled]:hover,
.c-btn01[disabled]:hover {
	opacity: 1;
}

.c-pdf-link01 {
	position: relative;
}
@media screen and (min-width: 768px) {
	.c-pdf-link01 {
		display: inline-block;
		vertical-align: middle;
	}
}
@media screen and (max-width: 767px) {
	.c-pdf-link01 {
		display: flex;
		align-items: start;
		justify-content: space-between;
		gap: 10px;
	}
}
.c-pdf-link01 .txt {
	line-height: 1.5;
}
@media screen and (min-width: 768px) {
	.c-pdf-link01 .txt {
		display: inline;
		font-size: calc(15 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-pdf-link01 .txt {
		flex: 1 1 0;
		font-size: calc(13 / (var(--fontsize)) * 1rem);
	}
}
.c-pdf-link01 .ico {
	display: inline-block;
	background-size: 100%;
	width: 16px;
	height: 20px;
	background-image: url("../images/common/ico_pdf.svg");
	background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
	.c-pdf-link01 .ico {
		margin-right: 10px;
		translate: 0 15%;
	}
}
@media screen and (max-width: 767px) {
	.c-pdf-link01 .ico {
		flex-shrink: 0;
	}
}
.c-pdf-link01 .dl {
	display: inline-block;
	background-size: 100%;
	width: 16px;
	height: 16px;
	background-image: url("../images/common/ico_download.svg");
	background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
	.c-pdf-link01 .dl {
		margin-left: 10px;
		translate: 0 15%;
	}
}
@media screen and (max-width: 767px) {
	.c-pdf-link01 .dl {
		flex-shrink: 0;
	}
}

.c-pdf-link02,
.c-pdf-link03 {
	display: flex;
	align-items: center;
	min-height: 50px;
	border: solid 1px var(--color_secondary);
	border-radius: 100vmax;
}
@media (hover: hover) and (pointer: fine) {
	.c-pdf-link02,
	.c-pdf-link03 {
		transition: opacity 0.3s;
	}
	.c-pdf-link02:hover,
	.c-pdf-link03:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}
@media screen and (min-width: 768px) {
	.c-pdf-link02,
	.c-pdf-link03 {
		gap: 10px;
		padding: 10px 30px;
	}
}
@media screen and (max-width: 767px) {
	.c-pdf-link02,
	.c-pdf-link03 {
		justify-content: space-between;
		gap: 10px;
		padding: 10px 20px;
	}
}
.c-pdf-link02 .txt,
.c-pdf-link03 .txt {
	display: inline;
	line-height: 1.5;
}
@media screen and (min-width: 768px) {
	.c-pdf-link02 .txt,
	.c-pdf-link03 .txt {
		font-size: calc(15 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-pdf-link02 .txt,
	.c-pdf-link03 .txt {
		flex: 1 1 0;
		font-size: calc(13 / (var(--fontsize)) * 1rem);
	}
}
.c-pdf-link02 .ico,
.c-pdf-link03 .ico {
	flex-shrink: 0;
	background-size: 100%;
	width: 16px;
	height: 20px;
	background-image: url("../images/common/ico_pdf.svg");
	background-repeat: no-repeat;
}
.c-pdf-link02 .dl,
.c-pdf-link03 .dl {
	flex-shrink: 0;
	background-size: 100%;
	width: 16px;
	height: 16px;
	background-image: url("../images/common/ico_download.svg");
	background-repeat: no-repeat;
}
.c-pdf-link02--l .ico,
.c-pdf-link03--l .ico {
	width: 24px;
	height: 30px;
}
@media screen and (min-width: 768px) {
	.c-pdf-link02--l .txt,
	.c-pdf-link03--l .txt {
		font-size: calc(17 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-pdf-link02--l .txt,
	.c-pdf-link03--l .txt {
		font-size: calc(14 / (var(--fontsize)) * 1rem);
	}
}

.c-pdf-link02 {
	width: fit-content;
	background-color: var(--color_secondary);
	color: var(--color_clear);
}
.c-pdf-link02 .dl {
	background-image: url("../images/common/ico_download-wh.svg");
}

.c-pdf-link03 {
	background-color: var(--color_clear);
}

.c-mask-img {
	mask-image: url("../images/common/mask_img.svg");
	mask-size: 100% 100%;
	-webkit-mask-size: 100% 100%;
}

@media screen and (max-width: 767px) {
	.c-sp-illust {
		width: 50%;
		margin-inline: auto;
	}
	.c-sp-illust img {
		width: 100%;
	}
}

@media screen and (min-width: 768px) {
	.c-unit + .c-unit {
		margin-top: 30px;
	}
}
@media screen and (max-width: 767px) {
	.c-unit + .c-unit {
		margin-top: 20px;
	}
}
@media screen and (min-width: 768px) {
	.c-unit--flex {
		display: flex;
		gap: 15px;
	}
}

.c-box01 {
	border: solid 1px var(--line_primary);
}
@media screen and (min-width: 768px) {
	.c-box01 {
		padding: 16px 24px;
	}
}
@media screen and (max-width: 767px) {
	.c-box01 {
		padding: 16px;
	}
}

.c-block {
	border-radius: 16px;
	background-color: var(--color_clear);
	border: solid 1px var(--color_purpose);
}
.t-about .c-block {
	border-color: transparent;
}
@media screen and (min-width: 768px) {
	.c-block {
		padding: 50px;
	}
}
@media screen and (max-width: 767px) {
	.c-block {
		padding: 20px;
	}
}
@media screen and (min-width: 768px) {
	.c-block + .c-block {
		margin-top: 80px;
	}
}
@media screen and (max-width: 767px) {
	.c-block + .c-block {
		margin-top: 40px;
	}
}

@media screen and (min-width: 768px) {
	* + .c-block-foot {
		margin-top: 30px;
	}
}
@media screen and (max-width: 767px) {
	* + .c-block-foot {
		margin-top: 20px;
	}
}

.c-block-foot {
	position: relative;
	display: grid;
	gap: 20px;
}
@media screen and (min-width: 768px) {
	.c-block-foot {
		padding-top: 30px;
	}
}
@media screen and (max-width: 767px) {
	.c-block-foot {
		padding-top: 20px;
	}
}
.c-block-foot:before {
	content: "";
	position: absolute;
	left: 50%;
	top: 0;
	border-top: dashed 1px var(--color_purpose);
	translate: -50% 0;
}
@media screen and (min-width: 768px) {
	.c-block-foot:before {
		width: calc(100% + 100px - 20px);
	}
}
@media screen and (max-width: 767px) {
	.c-block-foot:before {
		width: calc(100% + 20px);
	}
}

input[type=text].c-input-text,
textarea.c-textarea {
	transition: 0.3s;
	appearance: none;
	-webkit-appearance: none;
	border: solid 1px var(--line_primary);
	box-shadow: none;
	padding: 10px 15px;
	border-radius: 4px;
	width: 100%;
	background-color: #ffffff;
	outline: none;
	font-size: calc(16 / (var(--fontsize)) * 1rem);
}
input[type=text].c-input-text:focus,
textarea.c-textarea:focus {
	background-color: #ffffe4;
}
input[type=text].c-input-text--s,
textarea.c-textarea--s {
	max-width: 160px;
}

textarea.c-textarea {
	resize: none;
	line-height: 1.875;
}

input[type=radio].c-input-radio,
input[type=checkbox].c-input-checkbox {
	position: relative;
	appearance: none;
	-webkit-appearance: none;
	border: solid 1px var(--line_primary);
	box-shadow: none;
	background-color: #ffffff;
	outline: none;
	width: 18px;
	height: 18px;
	vertical-align: middle;
}
@media screen and (min-width: 768px) {
	input[type=radio].c-input-radio--l,
	input[type=checkbox].c-input-checkbox--l {
		width: 32px;
		height: 32px;
	}
}
@media screen and (max-width: 767px) {
	input[type=radio].c-input-radio--l,
	input[type=checkbox].c-input-checkbox--l {
		width: 24px;
		height: 24px;
	}
}

input[type=radio].c-input-radio:after {
	content: "";
	width: 8px;
	height: 8px;
	background-color: var(--color_secondary);
	position: absolute;
	left: 50%;
	top: 50%;
	translate: -50% -50%;
	border-radius: 100%;
	display: none;
}
@media screen and (min-width: 768px) {
	input[type=radio].c-input-radio--l:after {
		width: 14px;
		height: 14px;
	}
}
@media screen and (max-width: 767px) {
	input[type=radio].c-input-radio--l:after {
		width: 10px;
		height: 10px;
	}
}
input[type=radio].c-input-radio:checked:after {
	display: block;
}

input[type=checkbox].c-input-checkbox:after {
	content: "";
	width: 6px;
	height: 12px;
	position: absolute;
	left: 50%;
	top: 50%;
	border-bottom: solid 2px var(--color_secondary);
	border-right: solid 2px var(--color_secondary);
	display: none;
	translate: -50% -66.6%;
	rotate: 45deg;
}
@media screen and (min-width: 768px) {
	input[type=checkbox].c-input-checkbox--l:after {
		width: 12px;
		height: 24px;
		border-width: 4px;
	}
}
@media screen and (max-width: 767px) {
	input[type=checkbox].c-input-checkbox--l:after {
		width: 8px;
		height: 16px;
		border-width: 3px;
	}
}
input[type=checkbox].c-input-checkbox:checked:after {
	display: block;
}

input[type=radio].c-input-radio {
	border-radius: 100%;
}

input[type=checkbox].c-input-checkbox {
	border-radius: 0;
}

label.c-label-set {
	display: flex;
	align-items: flex-start;
}
label.c-label-set input[type=radio].c-input-radio,
label.c-label-set input[type=checkbox].c-input-checkbox {
	flex-shrink: 0;
	margin-right: 10px;
	display: block;
	transform: translateY(5px);
}

select.c-select {
	position: relative;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	min-height: 40px;
	padding: 12px 45px 12px 15px;
	border: solid 2px var(--line_primary);
	box-shadow: none;
	border-radius: 4px;
	background-color: #ffffff;
	background-repeat: no-repeat;
	background-size: 40px auto;
	background-image: url(../images/icon-select.png);
	background-position: right 50%;
	cursor: pointer;
	font-size: calc(16 / (var(--fontsize)) * 1rem);
	outline: none;
	line-height: 1.231;
	text-overflow: "";
}

select.c-select::-ms-expand {
	display: none;
}

.c-page-heading {
	display: flex;
	align-items: center;
	justify-content: center;
	padding-inline: var(--global_margin);
}
.c-page-heading__content {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}
@media screen and (min-width: 768px) {
	.c-page-heading__content {
		min-height: 200px;
		gap: 40px;
	}
}
@media screen and (max-width: 767px) {
	.c-page-heading__content {
		min-height: 160px;
		gap: 20px;
		translate: 20px 0;
	}
}

.c-page-heading-ico {
	position: absolute;
	top: 50%;
	translate: -100% -50%;
}
@media screen and (min-width: 768px) {
	.c-page-heading-ico {
		width: 140px;
		left: -40px;
	}
}
@media screen and (max-width: 767px) {
	.c-page-heading-ico {
		width: 60px;
		left: -20px;
	}
}

.c-page-heading-txt {
	display: grid;
	text-align: center;
}
@media screen and (min-width: 768px) {
	.c-page-heading-txt {
		gap: 10px;
	}
}
@media screen and (max-width: 767px) {
	.c-page-heading-txt {
		gap: 5px;
	}
}

.c-page-heading-title {
	letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
	.c-page-heading-title {
		font-size: calc(44 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-page-heading-title {
		font-size: calc(24 / (var(--fontsize)) * 1rem);
	}
}

.c-page-heading-en {
	font-size: calc(10 / (var(--fontsize)) * 1rem);
	letter-spacing: 0.1em;
}

.c-h01 {
	position: relative;
	width: fit-content;
	margin-inline: auto;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: var(--color_clear);
	min-height: 54px;
}
@media screen and (min-width: 768px) {
	.c-h01 {
		min-width: 352px;
		padding: 10px 30px;
		font-size: calc(22 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-h01 {
		min-width: 100%;
		padding: 15px 15px;
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}
.c-h01:before {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	inset: 0;
	background-color: var(--color_purpose);
	mask-size: 100% 100%;
	-webkit-mask-size: 100% 100%;
	mask-image: url("../images/common/bg_title.svg");
	mask-repeat: no-repeat;
	-webkit-mask-repeat: no-repeat;
	mask-position: 50%;
	-webkit-mask-position: 50%;
}
.c-h01 > * {
	position: relative;
	z-index: 1;
}

.c-h02 {
	display: flex;
	align-items: center;
	min-height: 44px;
	background-color: var(--color_secondary);
	border-radius: 100vmax;
	color: var(--color_clear);
}
@media screen and (min-width: 768px) {
	.c-h02 {
		padding: 8px 40px;
		font-size: calc(22 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-h02 {
		padding: 8px 20px;
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}

.c-tbl01 {
	table-layout: fixed;
	width: 100%;
	background-color: var(--color_clear);
}
.c-tbl01--wa {
	width: fit-content;
}
.c-tbl01 th, .c-tbl01 td {
	padding: 5px;
	border: solid 1px var(--line_primary);
	line-height: 1.5;
	text-align: center;
	font-weight: 500;
}
@media screen and (min-width: 768px) {
	.c-tbl01 th, .c-tbl01 td {
		font-size: calc(14 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-tbl01 th, .c-tbl01 td {
		font-size: calc(12 / (var(--fontsize)) * 1rem);
	}
}
.c-tbl01 th.align-l, .c-tbl01 td.align-l {
	padding: 5px 10px;
	text-align: unset;
}
.c-tbl01 th {
	background-color: #e3eedf;
}

body.c-cms-admin-body {
	background-color: #ffffff;
	color: var(--color_primary);
	max-width: 760px !important;
	padding: 40px !important;
}

body.c-cms-admin-body,
.c-wysiwyg {
	line-height: 1.875;
	overflow: hidden;
}
@media screen and (min-width: 768px) {
	body.c-cms-admin-body,
	.c-wysiwyg {
		font-size: calc(15 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body,
	.c-wysiwyg {
		font-size: calc(13 / (var(--fontsize)) * 1rem);
	}
}
body.c-cms-admin-body a,
.c-wysiwyg a {
	text-decoration: underline;
	color: var(--color_secondary);
}
@media (hover: hover) and (pointer: fine) {
	body.c-cms-admin-body a:hover,
	.c-wysiwyg a:hover {
		text-decoration: none;
	}
}
body.c-cms-admin-body h1, body.c-cms-admin-body h2, body.c-cms-admin-body h3, body.c-cms-admin-body h4, body.c-cms-admin-body h5, body.c-cms-admin-body h6,
.c-wysiwyg h1,
.c-wysiwyg h2,
.c-wysiwyg h3,
.c-wysiwyg h4,
.c-wysiwyg h5,
.c-wysiwyg h6 {
	margin-bottom: 15px;
	line-height: 1.4;
	font-weight: 700;
}
body.c-cms-admin-body h2,
.c-wysiwyg h2 {
	display: flex;
	align-items: center;
	min-height: 40px;
	border-radius: 100vmax;
	padding: 10px 20px;
	color: var(--color_clear);
	background-color: var(--color_secondary);
}
@media screen and (min-width: 768px) {
	body.c-cms-admin-body h2,
	.c-wysiwyg h2 {
		font-size: calc(24 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body h2,
	.c-wysiwyg h2 {
		font-size: calc(20 / (var(--fontsize)) * 1rem);
	}
}
body.c-cms-admin-body h3,
.c-wysiwyg h3 {
	color: var(--color_secondary);
}
@media screen and (min-width: 768px) {
	body.c-cms-admin-body h3,
	.c-wysiwyg h3 {
		font-size: calc(22 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body h3,
	.c-wysiwyg h3 {
		font-size: calc(18 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (min-width: 768px) {
	body.c-cms-admin-body h4,
	.c-wysiwyg h4 {
		font-size: calc(20 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body h4,
	.c-wysiwyg h4 {
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (min-width: 768px) {
	body.c-cms-admin-body h5,
	.c-wysiwyg h5 {
		font-size: calc(18 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body h5,
	.c-wysiwyg h5 {
		font-size: calc(15 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (min-width: 768px) {
	body.c-cms-admin-body h6,
	.c-wysiwyg h6 {
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body h6,
	.c-wysiwyg h6 {
		font-size: calc(14 / (var(--fontsize)) * 1rem);
	}
}
body.c-cms-admin-body i,
.c-wysiwyg i {
	font-style: italic;
}
body.c-cms-admin-body pre,
.c-wysiwyg pre {
	overflow: auto;
	white-space: pre-wrap;
	word-wrap: break-word;
}
body.c-cms-admin-body blockquote,
.c-wysiwyg blockquote {
	margin: 0 0 30px;
	padding: 20px;
	border: solid 1px var(--line_primary);
}
@media screen and (min-width: 768px) {
	body.c-cms-admin-body blockquote,
	.c-wysiwyg blockquote {
		font-size: calc(13 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body blockquote,
	.c-wysiwyg blockquote {
		font-size: calc(11 / (var(--fontsize)) * 1rem);
	}
}
body.c-cms-admin-body hr,
.c-wysiwyg hr {
	height: 1px;
	background-color: var(--line_primary);
	border: 0;
	margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body hr,
	.c-wysiwyg hr {
		margin-bottom: 20px;
	}
}
body.c-cms-admin-body p,
.c-wysiwyg p {
	*zoom: 1;
	line-height: 2;
	margin-bottom: 30px;
}
body.c-cms-admin-body p:after,
.c-wysiwyg p:after {
	content: "";
	display: table;
	clear: both;
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body p,
	.c-wysiwyg p {
		margin-bottom: 20px;
	}
}
body.c-cms-admin-body ul, body.c-cms-admin-body ol,
.c-wysiwyg ul,
.c-wysiwyg ol {
	margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body ul, body.c-cms-admin-body ol,
	.c-wysiwyg ul,
	.c-wysiwyg ol {
		margin-bottom: 20px;
	}
}
body.c-cms-admin-body ol li,
.c-wysiwyg ol li {
	list-style-type: decimal;
	margin-left: 1.5em;
}
body.c-cms-admin-body ul li,
.c-wysiwyg ul li {
	list-style-type: disc;
	margin-left: 1.5em;
}
body.c-cms-admin-body img,
.c-wysiwyg img {
	max-width: 100%;
	height: auto;
}
body.c-cms-admin-body img.alignleft,
.c-wysiwyg img.alignleft {
	float: left;
	margin-right: 20px;
	margin-bottom: 20px;
}
body.c-cms-admin-body img.alignright,
.c-wysiwyg img.alignright {
	float: right;
	margin-left: 20px;
	margin-bottom: 20px;
}
body.c-cms-admin-body img.aligncenter,
.c-wysiwyg img.aligncenter {
	display: block;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}
body.c-cms-admin-body table,
.c-wysiwyg table {
	width: 100%;
	background-color: #ffffff;
	table-layout: fixed;
}
body.c-cms-admin-body table th, body.c-cms-admin-body table td,
.c-wysiwyg table th,
.c-wysiwyg table td {
	padding: 10px 20px;
	border: solid 1px var(--line_primary);
}
@media screen and (min-width: 768px) {
	body.c-cms-admin-body table th, body.c-cms-admin-body table td,
	.c-wysiwyg table th,
	.c-wysiwyg table td {
		font-size: calc(14 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body table th, body.c-cms-admin-body table td,
	.c-wysiwyg table th,
	.c-wysiwyg table td {
		font-size: calc(12 / (var(--fontsize)) * 1rem);
	}
}
body.c-cms-admin-body table th,
.c-wysiwyg table th {
	background-color: var(--color_secondary);
	color: #ffffff;
	font-weight: 700;
}
body.c-cms-admin-body .wp-caption-text,
.c-wysiwyg .wp-caption-text {
	margin-top: 0.5em;
}
@media screen and (min-width: 768px) {
	body.c-cms-admin-body .wp-caption-text,
	.c-wysiwyg .wp-caption-text {
		font-size: calc(13 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	body.c-cms-admin-body .wp-caption-text,
	.c-wysiwyg .wp-caption-text {
		font-size: calc(11 / (var(--fontsize)) * 1rem);
	}
}
body.c-cms-admin-body .wp-caption.alignleft,
.c-wysiwyg .wp-caption.alignleft {
	display: block;
	float: left;
	margin-bottom: 10px;
	width: calc(50% - 20px) !important;
	margin-right: 20px;
}
body.c-cms-admin-body .wp-caption.alignleft img,
.c-wysiwyg .wp-caption.alignleft img {
	width: 100%;
	height: auto;
}
body.c-cms-admin-body .wp-caption.alignright,
.c-wysiwyg .wp-caption.alignright {
	display: block;
	float: right;
	margin-bottom: 10px;
	width: calc(50% - 20px) !important;
	margin-left: 20px;
}
body.c-cms-admin-body .wp-caption.alignright img,
.c-wysiwyg .wp-caption.alignright img {
	width: 100%;
	height: auto;
}
body.c-cms-admin-body .wp-caption.aligncenter, body.c-cms-admin-body .wp-caption.alignnone,
.c-wysiwyg .wp-caption.aligncenter,
.c-wysiwyg .wp-caption.alignnone {
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 20px;
}

.wp-pagenavi {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
@media screen and (min-width: 768px) {
	.wp-pagenavi {
		gap: 10px;
		margin-top: 60px;
	}
}
@media screen and (max-width: 767px) {
	.wp-pagenavi {
		gap: 10px;
		margin-top: 40px;
	}
}
.wp-pagenavi > a, .wp-pagenavi > span {
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	border-radius: 50%;
	color: var(--color_secondary);
	background-color: var(--color_clear);
	transition: 0.3s;
}
.wp-pagenavi > a.current, .wp-pagenavi > a:hover, .wp-pagenavi > span.current, .wp-pagenavi > span:hover {
	background-color: var(--color_secondary);
	color: var(--color_clear);
	text-decoration: none;
}
@media screen and (min-width: 768px) {
	.wp-pagenavi > a, .wp-pagenavi > span {
		width: 40px;
		height: 40px;
		font-size: calc(15 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.wp-pagenavi > a, .wp-pagenavi > span {
		width: 30px;
		height: 30px;
		font-size: calc(13 / (var(--fontsize)) * 1rem);
	}
}

/* =======================================================================
top
======================================================================= */
@keyframes kf_fadein {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
.p-top-mv {
	position: relative;
	max-width: var(--width_primary);
	margin-inline: auto;
}
@media screen and (min-width: 768px) {
	.p-top-mv {
		padding: var(--global_margin);
	}
}
@media screen and (max-width: 767px) {
	.p-top-mv {
		padding: 20px var(--global_margin) 40px;
	}
}
.p-top-mv__inner {
	container-type: inline-size;
	gap: 0.3676470588%;
}
@media screen and (min-width: 768px) {
	.p-top-mv__inner {
		display: grid;
		grid-template-columns: auto 58.9705882353%;
	}
}
@media screen and (max-width: 767px) {
	.p-top-mv__inner {
		display: flex;
		flex-direction: column;
		gap: var(--global_margin);
	}
}
.p-top-mv__inner__main {
	position: relative;
	z-index: 1;
}

.p-top-mv-img {
	opacity: 0;
	animation: kf_fadein 1s linear forwards 1;
	animation-delay: 1.5s;
}

.p-top-mv-illust {
	opacity: 0;
	animation: kf_fadein 1s linear forwards 1;
	animation-delay: 1.25s;
}

.p-top-mv-title {
	opacity: 0;
	position: relative;
	width: fit-content;
	margin-inline: auto;
	line-height: 1.7;
	letter-spacing: 0.1em;
	animation: kf_fadein 1s linear forwards 1;
	animation-delay: 1s;
}
@media screen and (min-width: 768px) {
	.p-top-mv-title {
		font-size: clamp(0px, 2.3333333333vw, 35px);
	}
}
@media screen and (max-width: 767px) {
	.p-top-mv-title {
		font-size: clamp(0px, 6.8359375vw, 52.5px);
	}
}
.p-top-mv-title:before {
	opacity: 0;
	content: "";
	background-size: 100% auto;
	background-repeat: no-repeat;
	position: absolute;
	aspect-ratio: 664/142;
	background-image: url("../images/top/ico_mv.svg");
	animation: kf_fadein 1s linear forwards 1;
	animation-delay: 1.25s;
}
@media screen and (min-width: 768px) {
	.p-top-mv-title:before {
		top: -1.1029411765cqw;
		left: -3.6764705882cqw;
		width: 48.8235294118cqw;
	}
}
@media screen and (max-width: 767px) {
	.p-top-mv-title:before {
		top: -3.0906593407cqw;
		left: -10.3021978022cqw;
		width: 136.8131868132cqw;
	}
}
.p-top-mv-title .em {
	color: var(--color_consult);
}

@keyframes kf_top_mv_btn {
	0% {
		transform: translate(0, 0) rotate(0deg);
	}
	20% {
		transform: translate(-2px, 0) rotate(-2deg);
	}
	40% {
		transform: translate(2px, 0) rotate(2deg);
	}
	60% {
		transform: translate(-2px, 0) rotate(-1deg);
	}
	80% {
		transform: translate(2px, 0) rotate(1deg);
	}
	100% {
		transform: translate(0, 0) rotate(0deg);
	}
}
.p-top-mv-btn {
	opacity: 0;
	position: absolute;
	animation: kf_fadein 1s linear forwards 1;
	animation-delay: 1.75s;
}
@media screen and (min-width: 1025px) {
	.p-top-mv-btn {
		right: 80px;
		bottom: 60px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.p-top-mv-btn {
		right: 40px;
		bottom: 30px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-mv-btn {
		right: 10px;
		bottom: 30px;
	}
}

.p-top-mv-btn-link {
	display: block;
}
@media screen and (min-width: 1025px) {
	.p-top-mv-btn-link {
		width: 152px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.p-top-mv-btn-link {
		width: 108px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-mv-btn-link {
		width: 108px;
	}
}
@media (hover: hover) and (pointer: fine) {
	.p-top-mv-btn-link:hover {
		animation: kf_top_mv_btn 0.4s linear 1;
	}
}

.p-top-title {
	position: relative;
	display: flex;
	justify-content: center;
	margin-inline: auto;
	text-align: center;
}
@media screen and (min-width: 768px) {
	.p-top-title {
		font-size: calc(33 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-top-title {
		font-size: calc(22 / (var(--fontsize)) * 1rem);
	}
}
.p-top-title:before {
	content: "";
	position: absolute;
	left: 50%;
	translate: -50% 0;
	background-size: 100% auto;
	background-repeat: no-repeat;
}

.p-top-purpose-title {
	padding-top: 20px;
}
@media screen and (min-width: 768px) {
	.p-top-purpose-title {
		height: 118px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-purpose-title {
		height: 78.6666666667px;
	}
}
.p-top-purpose-title:before {
	top: 0;
	height: 100%;
	background-image: url("../images/top/ico_title-purpose.webp");
}
@media screen and (min-width: 768px) {
	.p-top-purpose-title:before {
		width: 456px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-purpose-title:before {
		width: 304px;
	}
}

.p-top-information-title {
	height: 128px;
	padding-top: 20px;
}
@media screen and (min-width: 768px) {
	.p-top-information-title {
		height: 128px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-information-title {
		height: 85.3333333333px;
	}
}
.p-top-information-title:before {
	top: 0;
	height: 100%;
	translate: -35% 0;
	background-image: url("../images/top/ico_title-information.webp");
}
@media screen and (min-width: 768px) {
	.p-top-information-title:before {
		width: 460px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-information-title:before {
		width: 306.6666666667px;
	}
}

@media screen and (min-width: 768px) {
	.p-top-about-title {
		height: 70px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-about-title {
		height: 46.6666666667px;
	}
}
.p-top-about-title:before {
	top: 0;
	width: 520px;
	height: 100%;
	background-image: url("../images/top/ico_title-about.webp");
}
@media screen and (min-width: 768px) {
	.p-top-about-title:before {
		width: 520px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-about-title:before {
		width: 346.6666666667px;
	}
}

@media screen and (min-width: 1025px) {
	.p-top-sec + .p-top-sec {
		padding-top: 80px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.p-top-sec + .p-top-sec {
		padding-top: 60px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-sec + .p-top-sec {
		padding-top: 40px;
	}
}

.p-top-purpose-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
}
@media screen and (min-width: 768px) {
	.p-top-purpose-list {
		gap: 40px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-purpose-list {
		gap: 20px;
	}
}
.p-top-purpose-list__item {
	position: relative;
	padding: 20px 20px 30px;
	background-color: var(--color_clear);
	border-radius: 15px;
}
@media (hover: hover) and (pointer: fine) {
	.p-top-purpose-list__item {
		transition: opacity 0.3s;
	}
	.p-top-purpose-list__item:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}
.p-top-purpose-list__item:before {
	content: "";
	position: absolute;
	right: 10px;
	bottom: 10px;
	border-radius: 100vmax;
	border: solid 1px var(--color);
	width: 30px;
	height: 30px;
	background-image: url("../images/common/ico_arrow.svg");
	background-size: 12px 8px;
	background-position: 50%;
	background-repeat: no-repeat;
}
.p-top-purpose-list__item--use {
	--color: var(--color_use);
}
.p-top-purpose-list__item--use:before {
	background-image: url("../images/common/ico_arrow-use.svg");
}
.p-top-purpose-list__item--consult {
	--color: var(--color_consult);
}
.p-top-purpose-list__item--consult:before {
	background-image: url("../images/common/ico_arrow-consult.svg");
}
.p-top-purpose-list__item--join {
	--color: var(--color_join);
}
.p-top-purpose-list__item--join:before {
	background-image: url("../images/common/ico_arrow-join.svg");
}

.p-top-purpose-list-img {
	margin-bottom: 30px;
	aspect-ratio: 300/200;
}
.p-top-purpose-list-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.p-top-purpose-list-title {
	display: flex;
	gap: 5px;
	align-items: center;
	justify-content: center;
	font-size: calc(24 / (var(--fontsize)) * 1rem);
	text-align: center;
	color: var(--color);
}
.p-top-purpose-list-title .em {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color);
	color: var(--color_clear);
	border-radius: 100vmax;
	padding: 5px 40px;
	min-width: 140px;
	font-size: calc(27 / (var(--fontsize)) * 1rem);
}

.p-top-purpose-list-txt {
	margin-top: 10px;
	font-size: calc(14 / (var(--fontsize)) * 1rem);
	text-align: center;
}

.p-top-information-main {
	background-color: var(--color_clear);
	border-radius: 15px;
}
@media screen and (min-width: 1025px) {
	.p-top-information-main {
		padding: 40px 80px;
	}
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
	.p-top-information-main {
		padding: 40px 40px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-information-main {
		padding: 40px 20px;
	}
}

.p-top-information-list {
	display: grid;
	gap: 20px;
}
.p-top-information-list + * {
	margin-top: 20px;
	padding-top: 20px;
	border-top: dashed 1px var(--color_primary);
}
.p-top-information-list__item {
	display: flex;
	align-items: center;
	gap: 20px;
}
@media screen and (max-width: 767px) {
	.p-top-information-list__item {
		flex-wrap: wrap;
	}
}
@media (hover: hover) and (pointer: fine) {
	.p-top-information-list__item:hover {
		text-decoration: none;
	}
	.p-top-information-list__item:hover .txt {
		text-decoration: underline;
	}
}
.p-top-information-list__item .datetime {
	width: 100px;
	flex-shrink: 0;
	font-size: calc(15 / (var(--fontsize)) * 1rem);
}
.p-top-information-list__item .cat {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: fit-content;
	width: 170px;
	flex-shrink: 0;
	min-height: 30px;
	border-radius: 100vmax;
	border: solid 1px var(--color_secondary);
	color: var(--color_secondary);
	font-size: calc(15 / (var(--fontsize)) * 1rem);
}
.p-top-information-list__item .txt {
	overflow: hidden;
	display: -webkit-box;
	text-overflow: ellipsis;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	max-height: 18.465em;
	font-size: calc(15 / (var(--fontsize)) * 1rem);
}
@media screen and (min-width: 768px) {
	.p-top-information-list__item .txt {
		flex: 1 1 0;
	}
}
@media screen and (max-width: 767px) {
	.p-top-information-list__item .txt {
		width: 100%;
	}
}

.p-top-about-col {
	margin-inline: auto;
	gap: 30px;
}
@media screen and (min-width: 768px) {
	.p-top-about-col {
		margin-top: 50px;
		display: grid;
		max-width: var(--width_tertiary);
		grid-template-columns: auto 51.875%;
	}
}
@media screen and (max-width: 767px) {
	.p-top-about-col {
		margin-top: 30px;
		display: flex;
		flex-direction: column-reverse;
	}
}

.p-top-about-btns {
	margin-top: 30px;
}
@media screen and (min-width: 768px) {
	.p-top-about-btns {
		display: grid;
		gap: 20px;
	}
}
@media screen and (max-width: 767px) {
	.p-top-about-btns {
		display: flex;
		flex-direction: column;
		gap: 10px;
		justify-content: center;
	}
}

/* =======================================================================
about
======================================================================= */
.p-about-col01 {
	display: grid;
}
@media screen and (min-width: 768px) {
	.p-about-col01 {
		grid-template-columns: 1fr 1fr;
	}
}
@media screen and (min-width: 768px) {
	.p-about-col01__item:nth-of-type(odd) {
		padding-right: 30px;
	}
}
@media screen and (min-width: 768px) {
	.p-about-col01__item:nth-of-type(even) {
		padding-left: 30px;
	}
}
@media screen and (min-width: 768px) {
	.p-about-col01__item + .p-about-col01__item {
		border-left: solid 1px var(--color_secondary);
	}
}
@media screen and (max-width: 767px) {
	.p-about-col01__item + .p-about-col01__item {
		margin-top: 20px;
		padding-top: 20px;
		border-top: dashed 1px var(--color_secondary);
	}
}

.p-about-list01-item + .p-about-list01-item {
	border-top: dashed 1px var(--color_secondary);
}
@media screen and (min-width: 768px) {
	.p-about-list01-item + .p-about-list01-item {
		margin-top: 30px;
		padding-top: 30px;
	}
}
@media screen and (max-width: 767px) {
	.p-about-list01-item + .p-about-list01-item {
		margin-top: 20px;
		padding-top: 20px;
	}
}

.p-about-col02 {
	display: grid;
	gap: var(--global_margin);
}
@media screen and (min-width: 768px) {
	.p-about-col02 {
		align-items: end;
		grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	}
}

.p-about-list02-item {
	border-bottom: dashed 1px var(--color_secondary);
}
@media screen and (min-width: 768px) {
	.p-about-list02-item {
		gap: 20px;
		display: flex;
	}
}
@media screen and (max-width: 767px) {
	.p-about-list02-item {
		padding: 10px 0;
	}
}
@media screen and (min-width: 768px) {
	.p-about-list02-item__title {
		padding: 10px 0;
		width: 80px;
	}
}
@media screen and (min-width: 768px) {
	.p-about-list02-item__txt {
		padding: 10px 0;
		flex: 1 1 0;
	}
}

.p-about-access-title {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	color: var(--color_consult);
}
@media screen and (min-width: 768px) {
	.p-about-access-title {
		font-size: calc(17 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-about-access-title {
		font-size: calc(15 / (var(--fontsize)) * 1rem);
	}
}
.p-about-access-title .ico {
	flex-shrink: 0;
	width: 70px;
	height: 30px;
	background-size: 100%;
	background-image: url("../images/about/ico_access.webp");
}

.p-about-access-map {
	position: relative;
	aspect-ratio: 500/300;
	overflow: hidden;
}
.p-about-access-map iframe {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.p-about-disclosure-btns {
	display: grid;
}
@media screen and (min-width: 768px) {
	.p-about-disclosure-btns {
		gap: 16px 30px;
		grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
	}
}
@media screen and (max-width: 767px) {
	.p-about-disclosure-btns {
		gap: 10px;
	}
}

.p-about-organization {
	margin-inline: auto;
}
@media screen and (min-width: 768px) {
	.p-about-organization {
		width: fit-content;
	}
}
@media screen and (max-width: 767px) {
	.p-about-organization {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scroll-behavior: smooth;
	}
	.p-about-organization img {
		width: 640px;
		scroll-snap-align: start;
	}
}

.p-about-col03 {
	display: grid;
	gap: var(--global_margin);
}
@media screen and (min-width: 768px) {
	.p-about-col03 {
		grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
	}
}

.p-about-col04 {
	display: grid;
	align-items: end;
	gap: var(--global_margin);
}
@media screen and (min-width: 768px) {
	.p-about-col04 {
		grid-template-columns: 1fr 190px;
	}
}

.p-about-tbl01 col:nth-of-type(1), .p-about-tbl01 col:nth-of-type(3) {
	width: 24.064171123%;
}

/* =======================================================================
use
consult
join
======================================================================= */
.c-purpuse-nav {
	position: relative;
	margin-inline: auto;
	display: grid;
}
@media screen and (min-width: 768px) {
	.c-purpuse-nav {
		max-width: 920px;
		grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
		gap: 24px 50px;
		padding-bottom: 120px;
	}
}
@media screen and (max-width: 767px) {
	.c-purpuse-nav {
		gap: 10px;
		padding-bottom: 60px;
	}
}
.c-purpuse-nav:before {
	content: "";
	position: absolute;
	left: 50%;
	background-size: 100%;
	background-image: url("../images/common/ico_arrow-purpose.svg");
	translate: -50% 0;
}
@media screen and (min-width: 768px) {
	.c-purpuse-nav:before {
		bottom: 40px;
		width: 32px;
		height: 32px;
	}
}
@media screen and (max-width: 767px) {
	.c-purpuse-nav:before {
		bottom: 20px;
		width: 16px;
		height: 16px;
	}
}
.c-purpuse-nav__item a {
	position: relative;
	display: flex;
	align-items: center;
	gap: 10px;
	min-height: 60px;
	border-radius: 100vmax;
	color: var(--color_clear);
	background-color: var(--color_purpose);
}
@media (hover: hover) and (pointer: fine) {
	.c-purpuse-nav__item a {
		transition: opacity 0.3s;
	}
	.c-purpuse-nav__item a:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}
@media screen and (min-width: 768px) {
	.c-purpuse-nav__item a {
		padding: 10px 50px 10px 30px;
		font-size: calc(17 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.c-purpuse-nav__item a {
		padding: 10px 40px 10px 20px;
		font-size: calc(15 / (var(--fontsize)) * 1rem);
	}
}
.c-purpuse-nav__item a .ico {
	flex-shrink: 0;
}
@media screen and (min-width: 768px) {
	.c-purpuse-nav__item a .ico {
		width: 48px;
		height: 36px;
	}
}
@media screen and (max-width: 767px) {
	.c-purpuse-nav__item a .ico {
		width: 36px;
		height: 24px;
	}
}
.c-purpuse-nav__item a:before {
	content: "";
	position: absolute;
	top: 50%;
	right: 20px;
	width: 15px;
	height: 10px;
	background-size: 100%;
	background-image: url("../images/common/ico_arrow-wh.svg");
	rotate: 90deg;
	translate: 0 -50%;
}

.p-purpose-col {
	display: grid;
	gap: var(--global_margin);
}
@media screen and (min-width: 768px) {
	.p-purpose-col {
		align-items: start;
		grid-template-columns: 1fr 36%;
	}
}
.p-purpose-col__sub {
	display: grid;
}
@media screen and (min-width: 768px) {
	.p-purpose-col__sub {
		gap: 24px;
	}
}
@media screen and (max-width: 767px) {
	.p-purpose-col__sub {
		gap: 10px;
	}
}
@media screen and (min-width: 768px) {
	.p-purpose-col__sub.as-end {
		align-self: end;
	}
}
@media screen and (min-width: 768px) {
	.p-purpose-col__sub.as-center {
		align-self: center;
	}
}

.p-purpose-prp-btn {
	margin-left: auto;
	display: flex;
	padding: 10px;
	border: solid 2px var(--color_consult);
}
@media (hover: hover) and (pointer: fine) {
	.p-purpose-prp-btn {
		transition: opacity 0.3s;
	}
	.p-purpose-prp-btn:hover {
		opacity: 0.7;
		text-decoration: none;
	}
}
@media screen and (min-width: 768px) {
	.p-purpose-prp-btn {
		max-width: 272px;
	}
}
.p-purpose-prp-btn--row {
	flex-direction: column;
}
.p-purpose-prp-btn__img {
	width: 47.0588235294%;
}
.p-purpose-prp-btn--row .p-purpose-prp-btn__img {
	width: unset;
}
.p-purpose-prp-btn__content {
	flex: 1 1 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 16px;
	background-color: var(--color_consult);
	padding: 15px 15px;
	color: var(--color_clear);
	font-size: calc(14 / (var(--fontsize)) * 1rem);
	line-height: 1.5;
}
.p-purpose-prp-btn--row .p-purpose-prp-btn__content {
	flex-direction: row;
}
.p-purpose-prp-btn__content .ico {
	position: relative;
	flex-shrink: 0;
	width: 30px;
	height: 8px;
}
.p-purpose-prp-btn__content .ico:before {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 1px;
	background-color: var(--color_clear);
}
.p-purpose-prp-btn__content .ico:after {
	content: "";
	position: absolute;
	right: 0;
	bottom: 0;
	width: 1px;
	height: 100%;
	background-color: var(--color_clear);
	transform: skewX(45deg);
	transform-origin: 100% 100%;
}

.p-purpose-box {
	position: relative;
	display: grid;
	gap: 16px;
	padding: 20px;
	border-radius: 16px;
	background-color: #ebf4e9;
}

@media screen and (min-width: 768px) {
	.p-purpose-box-img {
		position: absolute;
		right: 20px;
		top: 50%;
		translate: 0 -50%;
		width: 39.5604395604%;
	}
}

.p-purpose-box-title {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: fit-content;
	margin-inline: auto;
	min-height: 30px;
	padding: 0 40px;
	border-radius: 100vmax;
	border: solid 1px var(--color_secondary);
	background-color: var(--color_clear);
	color: var(--color_secondary);
	text-align: center;
}
.p-purpose-box-title .ico {
	position: absolute;
	top: -1px;
	left: 50%;
	min-width: 144px;
	translate: -50% -100%;
}
@media screen and (max-width: 767px) {
	.p-purpose-box-title .ico {
		display: none;
	}
}

.p-use-service {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
}
@media screen and (min-width: 768px) {
	.p-use-service {
		gap: 24px;
	}
}
@media screen and (max-width: 767px) {
	.p-use-service {
		gap: 10px;
	}
}

.p-use-service-item {
	border: solid 1px var(--line_primary);
}

.p-use-service-heading {
	display: flex;
	justify-content: space-between;
	gap: 10px;
	padding: 10px 20px;
	background-color: #9e998b;
	background-image: repeating-linear-gradient(-45deg, #9e998b 0, #9e998b 5px, rgba(0, 0, 0, 0.1) 5px, rgba(0, 0, 0, 0.1) 6px);
	color: var(--color_clear);
}
@media screen and (min-width: 768px) {
	.p-use-service-heading {
		font-size: calc(17 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-use-service-heading {
		font-size: calc(15 / (var(--fontsize)) * 1rem);
	}
}

@media screen and (min-width: 768px) {
	.p-use-service-content {
		padding: 10px 30px;
	}
}
@media screen and (max-width: 767px) {
	.p-use-service-content {
		padding: 10px 20px;
	}
}

.p-use-service-txt {
	display: flex;
	justify-content: space-between;
	gap: 10px;
}

.p-use-odekake {
	position: relative;
	container-type: inline-size;
}

.p-use-odekake-txt {
	margin-inline: auto;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 69.4444444444cqw;
	height: 69.4444444444cqw;
	border: solid 1px var(--color_secondary);
	border-radius: 100%;
	color: var(--color_secondary);
	font-size: 4.5833333333cqw;
	line-height: 1.7;
	text-align: center;
	translate: 0 11.1111111111cqw;
}

@media screen and (min-width: 768px) {
	.p-use-tbl02 {
		width: 83.3333333333%;
	}
}
.p-use-tbl02 col:nth-of-type(1) {
	width: 40%;
}

.p-use-tbl03 col:nth-of-type(1) {
	width: 30%;
}
.p-use-tbl03 col:nth-of-type(2) {
	width: 20%;
}

@media screen and (min-width: 768px) {
	.p-use-tbl04 {
		width: 87.5%;
	}
}

.p-use-dayservice-title {
	padding: 10px 20px;
	background-color: #9e998b;
	background-image: repeating-linear-gradient(-45deg, #9e998b 0, #9e998b 5px, rgba(0, 0, 0, 0.1) 5px, rgba(0, 0, 0, 0.1) 6px);
	color: var(--color_clear);
	text-align: center;
}
@media screen and (min-width: 768px) {
	.p-use-dayservice-title {
		font-size: calc(21 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-use-dayservice-title {
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}

.p-use-dayservice-imgs01 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	justify-content: center;
}
@media screen and (min-width: 768px) {
	.p-use-dayservice-imgs01 {
		gap: 20px;
	}
}
@media screen and (max-width: 767px) {
	.p-use-dayservice-imgs01 {
		gap: 10px;
	}
}

.p-use-dayservice-imgs02 {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	justify-content: center;
	gap: 10px;
}

.p-use-dayservice-col01 {
	display: grid;
}
@media screen and (min-width: 768px) {
	.p-use-dayservice-col01 {
		align-items: start;
		grid-template-columns: 1fr 49.5%;
		gap: 40px;
	}
}
@media screen and (max-width: 767px) {
	.p-use-dayservice-col01 {
		gap: 30px;
	}
}

.p-use-dayservice-col02 {
	display: grid;
}
@media screen and (min-width: 768px) {
	.p-use-dayservice-col02 {
		align-items: start;
		grid-template-columns: 1fr 20.8%;
		gap: 40px;
	}
}
@media screen and (max-width: 767px) {
	.p-use-dayservice-col02 {
		gap: 30px;
	}
}
.p-use-dayservice-col02__sub {
	display: grid;
	gap: 10px;
}
@media screen and (max-width: 767px) {
	.p-use-dayservice-col02__sub {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media screen and (min-width: 768px) {
	.p-use-dayservice-schedule {
		display: flex;
	}
}
@media screen and (max-width: 767px) {
	.p-use-dayservice-schedule {
		padding: 10px 0;
	}
}
.p-use-dayservice-schedule + .p-use-dayservice-schedule {
	border-top: dashed 1px var(--color_tertiary);
}
@media screen and (min-width: 768px) {
	.p-use-dayservice-schedule__time {
		width: 100px;
		padding: 10px 15px;
		flex-shrink: 0;
	}
}
@media screen and (min-width: 768px) {
	.p-use-dayservice-schedule__title {
		width: 160px;
		padding: 10px 15px;
		flex-shrink: 0;
		border-left: dashed 1px var(--color_tertiary);
	}
}
@media screen and (min-width: 768px) {
	.p-use-dayservice-schedule__text {
		flex: 1 1 0;
		padding: 10px 15px;
		border-left: dashed 1px var(--color_tertiary);
	}
}

.p-conlust-col01 {
	display: grid;
}
@media screen and (min-width: 768px) {
	.p-conlust-col01 {
		grid-template-columns: 1fr 48%;
		gap: 24px var(--global_margin);
	}
}
@media screen and (max-width: 767px) {
	.p-conlust-col01 {
		gap: 30px;
	}
}

.p-consult-tbl01 col:nth-of-type(4) {
	width: 37.5%;
}

.p-consult-tbl02 col:nth-of-type(1) {
	width: 40px;
}
.p-consult-tbl02 col:nth-of-type(2) {
	width: 100px;
}

.p-consult-tbl03 col:nth-of-type(1) {
	width: 40px;
}
.p-consult-tbl03 col:nth-of-type(2) {
	width: 30.1075268817%;
}

.p-join-principle {
	display: grid;
	background-color: #87bd81;
	border-radius: 16px;
}
@media screen and (min-width: 768px) {
	.p-join-principle {
		grid-template-columns: repeat(auto-fill, minmax(480px, 1fr));
	}
}
.p-join-principle__item {
	border: solid 1px var(--color_clear);
}
@media screen and (min-width: 768px) {
	.p-join-principle__item {
		padding: 24px 36px;
	}
}
@media screen and (max-width: 767px) {
	.p-join-principle__item {
		padding: 20px;
	}
}

.p-join-principle-title {
	width: fit-content;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-inline: auto;
	min-width: calc(100% - 60px);
	min-height: 40px;
	padding: 5px 20px;
	border-radius: 8px;
	background-color: var(--color_clear);
	color: var(--color_secondary);
}
@media screen and (min-width: 768px) {
	.p-join-principle-title {
		font-size: calc(15 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-join-principle-title {
		font-size: calc(13 / (var(--fontsize)) * 1rem);
	}
}

/* =======================================================================
public-relations-paper
======================================================================= */
@media screen and (min-width: 768px) {
	.p-prp-sec + .p-prp-sec {
		margin-top: var(--global_margin);
	}
}
@media screen and (max-width: 767px) {
	.p-prp-sec + .p-prp-sec {
		margin-top: 40px;
	}
}

.p-prp-sec-title {
	position: relative;
	display: flex;
	align-items: center;
	background-color: var(--color_secondary);
	color: var(--color_clear);
}
@media screen and (min-width: 768px) {
	.p-prp-sec-title {
		min-height: 64px;
		padding: 10px 30px;
		font-size: calc(20 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-prp-sec-title {
		min-height: 64px;
		padding: 10px 20px;
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}
.p-prp-sec-title::before, .p-prp-sec-title::after {
	height: 100%;
	content: "";
	position: absolute;
	width: 16px;
}
.p-prp-sec-title::before {
	left: 0;
	background: linear-gradient(-45deg, var(--color_secondary) 8px, transparent 0), linear-gradient(225deg, var(--color_secondary) 8px, transparent 0);
	background-size: 16px 16px;
	translate: -100% 0;
}
.p-prp-sec-title::after {
	right: 0;
	background: linear-gradient(45deg, var(--color_secondary) 8px, transparent 0), linear-gradient(135deg, var(--color_secondary) 8px, transparent 0);
	background-size: 16px 16px;
	translate: 100% 0;
}

.p-prp-archives {
	margin-top: var(--global_margin);
	display: flex;
	margin-inline: auto;
}
@media screen and (min-width: 768px) {
	.p-prp-archives {
		justify-content: end;
		gap: 50px;
	}
}
@media screen and (max-width: 767px) {
	.p-prp-archives {
		gap: 30px;
		flex-direction: column;
	}
}
@media screen and (min-width: 768px) {
	.p-prp-archives__recently {
		flex: 1 1 0;
		max-width: 420px;
	}
}
@media screen and (min-width: 768px) {
	.p-prp-archives__backnumber {
		width: 44.5454545455%;
	}
}

.p-prp-recently-cover {
	display: flex;
	align-items: center;
}
@media screen and (min-width: 768px) {
	.p-prp-recently-cover {
		gap: 40px;
	}
}
@media screen and (max-width: 767px) {
	.p-prp-recently-cover {
		gap: 30px;
	}
}
.p-prp-recently-cover__title {
	position: relative;
	flex-shrink: 0;
	width: 100px;
	height: 100px;
	border-radius: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 10px;
	background-color: var(--color_tertiary);
}
.p-prp-recently-cover__title .ico {
	width: 20px;
	height: 16px;
	background-size: 100%;
	background-image: url(../images/public-relations-paper/ico_book.svg);
}
.p-prp-recently-cover__title .txt {
	color: #f9c158;
	font-size: calc(16 / (var(--fontsize)) * 1rem);
}
.p-prp-recently-cover__title:before {
	content: "";
	border-left: solid 12px var(--color_tertiary);
	border-top: solid 8px transparent;
	border-bottom: solid 8px transparent;
	position: absolute;
	right: 0;
	top: 50%;
	translate: 90% -50%;
}
.p-prp-recently-cover__img {
	flex: 1 1 0;
}
.p-prp-recently-cover__img img {
	box-shadow: 4px 4px 8px 0 rgba(0, 0, 0, 0.3);
}

/* =======================================================================
information
recruit
======================================================================= */
.p-information-article {
	padding-bottom: var(--global_margin);
	border-bottom: solid 1px var(--color_secondary);
}
.p-information-article + .p-information-article {
	padding-top: var(--global_margin);
}

.p-information-article-heading {
	display: grid;
	gap: 10px;
}

.p-information-article-title {
	position: relative;
	padding-left: 40px;
	color: var(--color_secondary);
	line-height: 1.5;
}
.p-information-article-title a {
	color: var(--color_secondary);
}
@media screen and (min-width: 768px) {
	.p-information-article-title {
		font-size: calc(27 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-information-article-title {
		font-size: calc(20 / (var(--fontsize)) * 1rem);
	}
}
.p-information-article-title:before {
	content: "";
	position: absolute;
	left: 0;
	width: 28px;
	height: 24px;
	background-size: 100%;
	background-image: url("../images/common/ico_h.svg");
}
@media screen and (min-width: 768px) {
	.p-information-article-title:before {
		top: 10px;
	}
}
@media screen and (max-width: 767px) {
	.p-information-article-title:before {
		top: 5px;
	}
}

.p-information-article-datetime {
	font-size: calc(14 / (var(--fontsize)) * 1rem);
}

/* =======================================================================
contact
======================================================================= */
.p-contact-sec + .p-contact-sec {
	margin-top: var(--global_margin);
}

.p-contact-tel {
	display: grid;
}
@media screen and (min-width: 768px) {
	.p-contact-tel {
		margin-left: 40px;
	}
}
@media screen and (max-width: 767px) {
	.p-contact-tel {
		margin-left: 20px;
	}
}

.p-contact-tel-num {
	display: flex;
	gap: 10px;
	align-items: center;
}
.p-contact-tel-num .ico {
	background-color: var(--color_tertiary);
	border-radius: 4px;
	background-size: 100%;
	background-image: url("../images/common/ico_tel.svg");
}
@media screen and (min-width: 768px) {
	.p-contact-tel-num .ico {
		width: 30px;
		height: 30px;
	}
}
@media screen and (max-width: 767px) {
	.p-contact-tel-num .ico {
		width: 24px;
		height: 24px;
	}
}
.p-contact-tel-num .txt {
	color: var(--color_tertiary);
}
@media screen and (min-width: 768px) {
	.p-contact-tel-num .txt {
		font-size: calc(34 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-contact-tel-num .txt {
		font-size: calc(28 / (var(--fontsize)) * 1rem);
	}
}
.p-contact-tel-num .txt a {
	color: var(--color_tertiary);
}

@media screen and (min-width: 768px) {
	.p-contact-tel-txt {
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-contact-tel-txt {
		font-size: calc(14 / (var(--fontsize)) * 1rem);
	}
}

.p-contact-form-item {
	display: flex;
	border: solid 1px var(--line_primary);
}
@media screen and (max-width: 767px) {
	.p-contact-form-item {
		flex-direction: column;
	}
}
.p-contact-form-item + .p-contact-form-item {
	margin-top: -1px;
}
.p-contact-form-item__title {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	background-color: #fde7bf;
	font-size: calc(15 / (var(--fontsize)) * 1rem);
	line-height: 1.875;
}
@media screen and (min-width: 768px) {
	.p-contact-form-item__title {
		width: 330px;
		padding: 10px 20px;
	}
}
@media screen and (max-width: 767px) {
	.p-contact-form-item__title {
		padding: 10px;
	}
}
.p-contact-form-item__title .require {
	display: inline-flex;
	color: var(--color_clear);
	font-size: calc(13 / (var(--fontsize)) * 1rem);
	background-color: var(--color_consult);
	padding: 2px 8px;
}
.p-contact-form-item__title .inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	gap: 20px;
}
.p-contact-form-item__content {
	display: grid;
	gap: 10px;
	flex: 1 1 0;
	background-color: var(--color_clear);
	font-size: calc(15 / (var(--fontsize)) * 1rem);
	line-height: 1.875;
}
@media screen and (min-width: 768px) {
	.p-contact-form-item__content {
		padding: 10px 20px;
	}
}
@media screen and (max-width: 767px) {
	.p-contact-form-item__content {
		padding: 10px;
	}
}

.p-contact-privacy {
	overflow-y: auto;
	max-height: 300px;
	padding: 20px;
	border: solid 1px var(--line_primary);
	background-color: var(--color_clear);
}

.p-contact-privacy-title {
	padding-bottom: 10px;
	border-bottom: solid 1px var(--line_primary);
	line-height: 1.5;
}
@media screen and (min-width: 768px) {
	.p-contact-privacy-title {
		font-size: calc(20 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-contact-privacy-title {
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}

.p-contact-privacy-label {
	width: fit-content;
	margin-inline: auto;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
}
@media screen and (min-width: 768px) {
	.p-contact-privacy-label {
		font-size: calc(20 / (var(--fontsize)) * 1rem);
	}
}
@media screen and (max-width: 767px) {
	.p-contact-privacy-label {
		font-size: calc(16 / (var(--fontsize)) * 1rem);
	}
}

.p-contact-btns {
	display: flex;
	justify-content: center;
	align-items: center;
}
@media screen and (min-width: 768px) {
	.p-contact-btns {
		gap: 20px;
	}
}
@media screen and (max-width: 767px) {
	.p-contact-btns {
		flex-direction: column;
		gap: 10px;
	}
}

.slick-slider {
	position: relative;
	display: block;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-ms-touch-action: pan-y;
	touch-action: pan-y;
	-webkit-tap-highlight-color: transparent;
}

.slick-list {
	position: relative;
	overflow: hidden;
	display: block;
	margin: 0;
	padding: 0;
}
.slick-list:focus {
	outline: none;
}
.slick-list.dragging {
	cursor: pointer;
	cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
	transform: translate3d(0, 0, 0);
	-webkit-transform: translate3d(0, 0, 0);
	-moz-transform: translate3d(0, 0, 0);
	-ms-transform: translate3d(0, 0, 0);
	-o-transform: translate3d(0, 0, 0);
}

.slick-track {
	position: relative;
	left: 0;
	top: 0;
	display: block;
}
.slick-track:before, .slick-track:after {
	content: "";
	display: table;
}
.slick-track:after {
	clear: both;
}
.slick-loading .slick-track {
	visibility: hidden;
}

.slick-slide {
	float: left;
	min-height: 1px;
	display: none;
	outline: none;
}
[dir=rtl] .slick-slide {
	float: right;
}
.slick-slide.slick-loading img {
	display: none;
}
.slick-slide.dragging img {
	pointer-events: none;
}
.slick-initialized .slick-slide {
	display: block;
}
.slick-loading .slick-slide {
	visibility: hidden;
}
.slick-vertical .slick-slide {
	display: block;
}

.slick-arrow.slick-disabled {
	display: none;
	opacity: 0;
}