/* all
-------------------------------------------------------------------*/
:root {
	--hover: background .4s, color .4s, border-color .4s, opacity .4s, text-decoration-color .4s, transform .4s, translate .4s, scale .4s, outline .4s, filter .4s, box-shadow .4s;
	--header: 120px;
	--container: 1200px;
	--wide: 1680px;
	--inner: 2em;
	--fontcolor: #1c2c43;
	--whitecolor: #fff;
	--bgcolor: var(--whitecolor);
	--keycolor: #1ed2bb;
	--accent01: #d9f2f0;
	--reverse: invert(1);
	--white: brightness(0) invert(1);
	--filter_keycolor: brightness(0) saturate(100%) invert(70%) sepia(75%) saturate(461%) hue-rotate(115deg) brightness(86%) contrast(95%);
}
:root img {
	transition: opacity .4s, filter .4s;
	border-style:solid;
}
:root :is(ul, ol, li) {
	margin: 0;
	padding: 0;
	line-height: 1.4;
}
body.home p {
	margin-bottom: 0;
	line-height: 1.6;
}
:root :is(h1, h2, h3, h4, h5) {
	margin-block: 0;
}
:root :is(a, button),
:root :is(a, button) :is(span, i),
:root :is(a, button)::before,
:root :is(a, button)::after,
:root :is(a, button) :is(span, i) ::before,
:root :is(a, button) :is(span, i)::after {
	transition: var(--hover);
}
:root p a{
	color:var(--keycolor);
	text-decoration:underline;
}
html,
body {
	background: var(--whitecolor);
	color: var(--fontcolor);
	font-family: "Noto Sans JP", sans-serif;
	font-size: 16px;
	line-height: 1.4;
	scroll-padding: var(--header);
	scroll-behavior: smooth;
	font-feature-settings: 'palt';
	font-optical-sizing: auto;
	font-style: normal;
	letter-spacing: 0.1em;
}
html :is([lang="en"], .eng) {
	font-family: "Roboto", sans-serif;
	letter-spacing: 0;
}
body {
	width: 100%;
	font-size: 100%;
	text-align: center;
	min-width: var(--container);
	position: relative;
	z-index: 2;
	background: var(--bgcolor);
}
main {
	overflow: clip;
	width: 100%;
	margin-top: var(--header);
}
body img,
body svg {
	max-width: 100%;
	height: auto;
}
.sitewrap,
.widewrap {
	width: var(--container);
	margin: 0 auto;
	text-align: left;
	box-sizing: border-box;
}
.widewrap {
	max-width: 1700px;
	padding-inline: 1em;
	width: auto;
}
*:has(> .sitewrap) {
	width: 100%;
	overflow-x: clip;
}
*:has(>wbr) {
	word-break: keep-all
}
@media (any-hover: hover) {
	:root p a:hover{
		text-decoration-color:transparent;
	}
}
@media screen and (max-width:1270px) {
	:root {
		--container: 100%;
	}
	body,
	.sitewrap {
		width: 100%;
		min-width: 0;
	}
	.sitewrap>* {
		padding-inline: var(--inner);
	}
}
@media screen and (max-width:767px) {
	:root {
		--inner: 1.14rem;
		--header: 60px;
	}
	html {
		font-size: 14px;
	}
	main {
		margin-top: 0;
	}
}
/* header
-------------------------------------------------------------------*/
:is(header,footer) * {
	margin:0;
	padding:0;
	line-height:inherit;
}
header#fix_menu {
	position: fixed;
	z-index: 100;
	top: 0;
	left: 0;
	right: 0;
	display: flex;
	align-items: center;
	height: var(--header);
	text-align: left;
	background: var(--keycolor);
}
header #site_ttl {
	display: flex;
	justify-content: flex-start;
	flex-direction: column;
	gap: 1em;
	font-size: clamp(0.75rem, 0.875vw, 1rem);
	color: var(--whitecolor);
	margin-inline: 2.875em;
}
header #site_ttl .logo-lead{
	padding-left: calc(126px + 1.5em);
}
:is(header #site_ttl, #footer .copy_style) a {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 1.5em;
	text-align: left;
	text-decoration: none;
}
:is(header #site_ttl, #footer .copy_style) a img {
	display: block;
	max-width: inherit;
}
:is(header #site_ttl, #footer .copy_style) a .logo-text_ja {
	font-size: 1.75em;
	font-weight: bold;
	line-height: 1;
}
:is(header #site_ttl, #footer .copy_style) a span,
header #site_ttl .logo-lead {
	font-size: 0.875em;
}
header .drop_menu {
	margin-left: auto;
}
header #switch {
	position: absolute;
	width: 0;
	height: 0;
	opacity: 0;
	z-index: -1;
}
header label[for="switch"] {
	display: none;
}
header #NavWrap .scroll_wrap {
	position: relative;
	z-index: 2;
	display: flex;
	height: var(--header);
	font-size: 1rem;
	font-weight: bold;
	letter-spacing: 0.05em;
	padding: 1em 1.25em;
}
header #NavWrap ul {
	flex-basis: 100%;
	display: flex;
	justify-content: flex-end;
	white-space: nowrap;
}
header #NavWrap ul li {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 2;
}
header #NavWrap ul.scroll_content>li:not(:first-child)::before {
	content: "";
	width: 2px;
	height: 1.25em;
	background: var(--whitecolor);
}
header #NavWrap ul li :is(a, p) {
	transition: var(--hover);
	font-size: 1.25rem;
	font-weight: bold;
	margin-bottom: 0;
}
header #NavWrap ul li> :is(p, a) {
	position: relative;
	z-index: 1;
	display: flex;
	gap: 0.5em;
	align-items: center;
	justify-content: center;
	color: var(--whitecolor);
	cursor: pointer;
	padding: 0.75em 1.25em;
	text-decoration:none;
	transition:.5s border-color;
}
header #NavWrap ul li> :is(p, a):before{
	content:"";
	height:2px;
	background:transparent;
	position:absolute;
	inset:auto 0 0.25em 0;
	margin:auto;
	transition:var(--hover);
}
header #NavWrap ul li> :is(p, a):hover:before{
	background:var(--whitecolor);
}
header #NavWrap ul li> :is(p, a) .en{
	display:block;
	font-size:0.75rem;
	text-align:center;
}
header #NavWrap ul li.drop_wrap {
	cursor: pointer;
}
header #NavWrap ul li.drop_wrap .drop_child {
	position: absolute;
	z-index: 5;
	inset: calc(var(--header) - 3em) auto auto;
	left: 50%;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-direction: column;
	gap: 0.625em;
	width: fit-content;
	min-width: 11em;
	background: var(--bgcolor);
	border-radius: 0.3125em;
	padding: 1em 0.75em;
	margin: 0;
	pointer-events: none;
	opacity: 0;
	cursor: auto;
	transition: .2s;
	translate: -50%;
}
header #NavWrap ul li.drop_wrap:hover .drop_child {
	opacity: 1;
	transition: .4s;
	pointer-events: auto;
}
header #NavWrap ul li.drop_wrap .drop_child li {
	width: 100%;
}
header #NavWrap ul li.drop_wrap .drop_child a {
	justify-content: flex-start;
	width: 100%;
	font-size: 1rem;
	color: var(----fontcolor);
	padding: 0;
	transition: .2s;
}
header #NavWrap ul li.drop_wrap .drop_child a i {
	position: relative;
	width: 1.92857142857em;
	aspect-ratio: 1/1;
	background: var(--accent05);
	border-radius: 0.3125em;
	overflow: clip;
}
header #NavWrap ul li.drop_wrap .drop_child a:hover i {
	background: var(--keycolor);
}
header #NavWrap ul li.drop_wrap .drop_child a i::before {
	position: absolute;
	inset: 50% auto auto 50%;
	z-index: 10;
	display: inline-block;
	content: "";
	width: 0.625em;
	aspect-ratio: 1/1;
	background: var(--keycolor);
	translate: -50% -50%;
	clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
	scale: 1;
}
header #NavWrap ul li.drop_wrap .drop_child a:hover i::before {
	background: var(--whitecolor);
}
header .submenu {
	display: flex;
	justify-content: center;
	align-items: center;
}
:is(header, footer) .submenu>a {
	position: relative;
	z-index: 10;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.65em;
	width: 220px;
	min-height: 2.5em;
	font-size: 1.25rem;
	color: var(--fontcolor);
	background: var(--whitecolor);
	border: 1px solid var(--fontcolor);
	border-radius: 2.5em;
	text-decoration: none;
	overflow: clip;
}
header .submenu>a .en{
	font-size:0.75rem;
	display:block;
	text-align:center;
}
:is(header, footer) .submenu>a::after {
	position: absolute;
	z-index: -5;
	inset: 50% 1.5em auto auto;
	display: inline-block;
	content: "";
	width: 0.5em;
	aspect-ratio: 1/1;
	background: var(--fontcolor);
	clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
	translate: 0 -50%;
	transition: var(--hover);
}
@media (any-hover: hover) {
	:is(header, footer) .submenu a:hover {
		background: var(--fontcolor);
		text-decoration: none;
		color: var(--whitecolor);
	}
	:is(header, footer) .submenu a:hover::after {
		background: var(--whitecolor);
	}
}
@media screen and (max-width:1360px) {
	header#fix_menu {
		--slide: 360px;
		padding-right: 6em;
	}
	header #NavWrap {
		position: fixed;
		z-index: 50;
		top: 0;
		bottom: 0;
		right: calc(-1 * var(--slide));
		width: var(--slide);
		background: var(--whitecolor);
		padding: var(--header) 1em 1em;
		transition: right .2s;
	}
	header #NavWrap .scroll_wrap {
		width: 100%;
		flex-direction: column;
		gap: 1.25em;
		max-height: 100%;
		height: 100%;
		font-size: 1rem;
		overflow-x: hidden;
		overflow-y: auto;
		scrollbar-width: thin;
		scrollbar-color: var(--keycolor) var(--whitecolor);
		overscroll-behavior: contain;
		padding: 0;
	}
	header label[for="switch"] {
		position: fixed;
		z-index: 100;
		top: 1.875em;
		right: 1.25em;
		display: flex;
		justify-content: center;
		align-items: center;
		flex-direction: column;
		gap: 0.25em;
		width: 3.75em;
		aspect-ratio: 1 / 1;
		background: var(--whitecolor);
		border-radius: 0.17857142857em;
		padding: 0.5em;
		transition: right .2s, background .2s, border-color .2s;
	}
	header label[for="switch"] span,
	header label[for="switch"] span::before,
	header label[for="switch"] span::after {
		position: absolute;
		inset: -10px 0 auto;
		content: "";
		display: block;
		width: 1.75em;
		height: 2px;
		background: var(--keycolor);
		margin: 0 auto;
		transition: transform .2s;
	}
	header label[for="switch"] span {
		position: relative;
		inset: 0;
		display: block;
	}
	header label[for="switch"] span::after {
		top: auto;
		bottom: -10px;
	}
	header #switch~label::after {
		position: fixed;
		inset: 0;
		z-index: -10;
		display: inline-block;
		content: "";
		width: calc(100% - var(--slide));
		height: 100vh;
		opacity: 0;
		visibility: hidden;
	}
	header:has(#switch:checked) label[for="switch"] {
		background: var(--keycolor);
	}
	header:has(#switch:checked) label[for="switch"] span {
		transform: rotate(360deg);
		background: transparent;
	}
	header:has(#switch:checked) label[for="switch"] span::before,
	header:has(#switch:checked) label[for="switch"] span::after {
		transform: rotate(45deg);
		inset: 0;
		background: var(--whitecolor);
	}
	header:has(#switch:checked) label[for="switch"] span::after {
		transform: rotate(-45deg);
	}
	header #switch:checked~label::after {
		opacity: 1;
		visibility: visible;
	}
	header:has(#switch:checked) #NavWrap {
		right: 0;
	}
	header #NavWrap ul {
		flex-basis: inherit;
		flex-direction: column;
		justify-content: flex-start;
	}
	header #NavWrap ul li {
		flex-direction: column;
		justify-content: flex-start;
	}
	header #NavWrap ul.scroll_content>li:not(:first-child)::before {
		display: none;
	}
	header #NavWrap ul li> :is(p, a) {
		width: 100%;
		justify-content: space-between;
		color: var(--fontcolor);
		padding: 0.5em;
	}
	header #NavWrap ul.scroll_content>li> :is(p, a) {
		border-bottom: 1px solid var(--keycolor);
		text-decoration: none;
	}
	header #NavWrap ul li> :is(p, a) .en{
		display:inline-block;
		margin-left:1em;
	}
	header #NavWrap ul.scroll_content>li> :is(p, a)::after {
		content: "";
		display: inline-block;
		width: 0.35em;
		aspect-ratio: 1/1;
		border-top: 2px solid;
		border-right: 2px solid;
		rotate: 45deg;
	}
	header #NavWrap ul.scroll_content>li> :is(p, a):hover {
		text-decoration: none;
		background: var(--accent01);
	}
	header #NavWrap ul li> :is(p, a):before{
		display:none;
	}
	header #NavWrap ul li.drop_wrap .drop_child {
		position: static;
		gap: 0.625em;
		width: 100%;
		min-width: 0;
		border-radius: 0;
		padding: 0.75em 0;
		pointer-events: visible;
		opacity: 1;
		translate: 0;
	}
}
@media screen and (max-width:767px) {
	header#fix_menu {
		position: relative;
		align-items: center;
		height: auto;
		--slide: 100%;
		padding: 0;
	}
	header #site_ttl {
		gap: 0;
		font-size: 3vw;
		margin-inline: 0;
		width: 100%;
	}
	:is(header #site_ttl) a {
		height: var(--header);
		padding: 1em;
	}
	:is(header #site_ttl, #footer .copy_style) a {
		gap: 0.5em;
		padding-block: 0;
		padding-right: 4.75rem;
	}
	:is(header #site_ttl, #footer .copy_style) a img {
		width: 12vw;
	}
	:is(header #site_ttl, #footer .copy_style) a .logo-text_ja {
		font-size: 1.4em;
		line-height: 1.4;
	}
	header #site_ttl .logo-lead {
		font-size: 0.875rem;
		color: var(--keycolor);
		background: var(--whitecolor);
		padding: 0.5em 1em;
	}
	header #NavWrap {
		justify-content: flex-end;
	}
	header #switch~label {
		top: 0.5em;
		right: 0.5em;
		width: 3.25em;
	}
	header #NavWrap ul li.drop_wrap ul a i::before {
		opacity: 0;
		visibility: hidden;
		scale: 0;
	}
	header #NavWrap ul li.drop_wrap ul a i::after {
		opacity: 1;
		visibility: visible;
	}
}
@media screen and (max-width:370px) {
	:is(header #site_ttl, #footer .copy_style) a .logo-text_ja {
		font-size: 1.2em;
	}
}
/* contents
-------------------------------------------------------------------*/
.section,
section {
	position: relative;
}
/* footer
-------------------------------------------------------------------*/
#footer {
	position: relative;
	z-index: 10;
	background: var(--fontcolor);
	padding-block: 6.25em 0;
}
#footer .footer-menu {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 6.25em 1.25em;
}
#footer .foot_left {
	display: flex;
	justify-content: flex-start;
	align-items: stretch;
	flex-direction: column;
}
:is(#footer .copy_style) a {
	gap: 1.25em;
	font-size: 0.875rem;
	padding-right: 0;
}
:is(#footer .copy_style) a .logo-text_ja {
	font-size: 1.71428571429em;
}
#footer .address p {
	font-size: 1rem;
	line-height: 1.8;
	margin-block: 2em 1em;
}
#footer .btn {
	border-color: var(--whitecolor);
}
#footer .foot_links {
	flex: 1;
}
#footer .foot_links>ul {
	width: fit-content;
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	gap: 1.25em 2.5em;
	padding: 0;
	margin: 0 0 0 auto;
}
#footer :is(a:not([class]), p, small) {
	color: var(--whitecolor);
}
#footer .foot_links>ul>li>a {
	display: inline-block;
	min-width: 6.66666666667em;
	font-size: 1.125rem;
	font-weight: bold;
	border-bottom: solid 1px var(--whitecolor);
	padding-bottom: 0.5em;
	margin-bottom: 0.75em;
}
#footer .foot_links .drop_wrap .drop_child {
	display: flex;
	align-items: flex-start;
	flex-direction: column;
	flex-wrap: wrap;
	gap: 0.625em;
}
#footer .foot_links .drop_wrap .drop_child a {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 0.75em;
	font-size: 0.875rem;
}
#footer .foot_links .submenu {
	width: 100%;
	justify-content: flex-end;
	font-size: var(--f14);
}
#footer .foot_bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1em;
	width: 100%;
	border-top: 1px solid var(--whitecolor);
	padding-block: 1em;
}
aside:has(.pagetop) {
	position: absolute;
	bottom: 7.25em;
	right: -3em;
	z-index: 101;
	rotate: 90deg;
}
a.pagetop {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	font-size: 1.125rem;
	font-weight: bold;
	color: var(--whitecolor);
	gap: 0.5em;
	padding: 0.5em;
	padding-left: 5.125em;
	transition: var(--hover);
	letter-spacing: 0.3em;
	line-height: 1;
}
a.pagetop::before,
a.pagetop::after {
	position: absolute;
	z-index: 10;
	top: 50%;
	left: 0;
	display: inline-block;
	content: "";
	width: 4.445em;
	height: 4px;
	background: var(--whitecolor);
	translate: 0 -50%;
	box-shadow: 0 0 2px var(--keycolor);
}
a.pagetop::after {
	scale: 0.5 1;
	background: var(--keycolor);
	transform-origin: left;
	transition: var(--hover);
}
a.pagetop span {
	display: block;
}
@media (any-hover: hover) {
	a.pagetop:hover {
		transform: translateX(-0.5em);
		text-decoration-color: transparent;
	}
	a.pagetop:hover::after {
		scale: 1 1;
	}
}
@media screen and (max-width:767px) {
	#footer {
		padding-block: 2em 4em;
	}
	#fixed-requirements_wrap:has(#fixed-requirements_btn:checked)~#footer {
		padding-bottom: 11em;
	}
	#footer .footer-menu {
		gap: 2.5em;
	}
	#footer .foot_left {
		width: 100%;
		text-align: center;
	}
	:is(#footer .copy_style) a .logo-text_ja {
		font-size: 1.4em;
	}
	#footer .address p {
		margin-block:1em 0;
	}
	#footer .submenu {
		position:fixed;
		z-index:100;
		inset:auto 0 0;
	}
	#footer .submenu .btn{
		width:100%;
		font-size:1.25rem;
		border-color:var(--fontcolor);
		border-radius:0;
	}
	#footer .foot_bottom {
		flex-direction:column;
	}
	#footer .foot_links,
	a.pagetop {
		display: none;
	}
}
@media screen and (max-width:370px) {
	:is(#footer .copy_style) a .logo-text_ja {
		font-size: 1.2em;
	}
}
/* print
-------------------------------------------------------------------*/
*html body {
	zoom: 60%;
}