/* 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;
	--inner:4%;
	--container:1200px;
	--fontcolor: #282828;
	--whitecolor: #fff;
	--bgcolor: #f7fafc;
	--bgcolor02: #f0f3f5;
	--keycolor: #0082f1;
	--accent01: #4599e0;
	--accent02: #183672;
	--accent03: #9ca7bd;
	--accent04: #b81f32;
	--accent05: #00c0fa;
	--foot-color: #313e51;
	--reverse: invert(1);
	--white: brightness(0) invert(1);
}
:root img {
	transition: var(--hover);
}
:root :is(ul, ol, li) {
	margin: 0;
	padding: 0;
	line-height: 1.4;
}
:root .site-body * + *{
	margin-top:1em;
}
body.home p {
	margin-bottom: 0;
	line-height: 1.4;
}
:root :is(h1, h2, h3, h4, h5) {
	margin-block: 0;
}
:root i{
	margin: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);
}
html {
	background: var(--whitecolor);
	color: var(--fontcolor);
	font-family: "Zen Kaku Gothic New", 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;
}
html :is([lang="en"], .eng) {
	font-family: "Roboto", sans-serif;
}
html .roboto {
	font-family: "Roboto", sans-serif;
}
html .zenkaku {
	font-family: "Zen Kaku Gothic New", sans-serif;
}
html .min {
	font-family: "Zen Old Mincho", serif;
}
body {
	width: 100%;
	font-size: 100%;
	text-align: center;
	min-width: var(--container);
	position: relative;
	z-index: 2;
	background: var(--whitecolor);
	font-family: "Zen Kaku Gothic New", sans-serif;
}
main {
	overflow: clip;
	max-width: 1590px;
	width: calc(100% - 330px);
	margin-left: 330px;
}
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 screen and (max-width:1600px) {
	:root {
		--container: 100%;
	}
	body,
	.sitewrap {
		width: 100%;
		min-width: 0;
	}
	.sitewrap>* {
		padding-inline: var(--inner);
	}
}
@media screen and (max-width:1300px) {
	main {
		width: calc(100% - 260px);
		margin-left: 260px;
	}
}
@media screen and (max-width:1200px) {
	main {
		max-width:100%;
		width:100%;
		margin-left:0;
		margin-top: 80px;
	}
}
@media screen and (max-width:767px) {
	:root {
		--inner: 15px;
		--header: 60px;
	}
	html {
		font-size: 14px;
	}
	main {
		margin-top:60px;
	}
	:root .wp-block-list.list_col02 li,
	:root .wp-block-list.list_col03 li{
		width: 100%;
	}
}
/* header
-------------------------------------------------------------------*/
header{
	position:fixed;
	z-index:1000;
	width: 330px;
	height:100%;
	background:#fff;
	border-right: 1px solid #f1f1f1;
	top:0;
	left:0;
	bottom:0;
	margin:auto;
	box-shadow: 10px 0px 16px rgba(0, 0, 0, 0.1);
	overflow-y: auto;
	scrollbar-width: thin;
}
header:-webkit-scrollbar {
	height: 6px;
	width: 6px;
}
header::-webkit-scrollbar-track {
	border-radius: 10px;
	background: #f1f1f1;
}
header::-webkit-scrollbar-thumb {
	border-radius: 10px;
	background: var(--accent01);
}
header .menu_top {
	position:relative;
	z-index:100;
	max-height: 100%;
	padding: 1.375em 0 0;
}
header .menu_top #site_ttl{
	padding-bottom: 1em;
}
header .menu_top #site_ttl a{
	display:flex;
	justify-content:center;
	align-items:center;
	flex-direction:column;
	gap: 0.35em;
	text-decoration: none;
	transition:var(--hover);
}
header .menu_top #site_ttl a.sp-btn{
	display:none;
}
header .menu_top #site_ttl a span{
	font-size: 1.2rem;
	font-weight: 800;
	letter-spacing:-0.01em;
	color:var(--accent02);
}
header .menu_top .menu_fix{
	height: 100%;
	padding-bottom: 0.5em;
	overscroll-behavior: contain;
}
header .menu_top .menu_fix::-webkit-scrollbar {
	height: 6px;
	width: 6px;
}
header .menu_top .menu_fix::-webkit-scrollbar-track {
	border-radius: 10px;
	background: #f1f1f1;
}
header .menu_top .menu_fix::-webkit-scrollbar-thumb {
	border-radius: 10px;
	background: var(--accent01);
}
header #NavWrap .nav-list{
	text-align:left;
}
header #NavWrap .drop_wrap i{
	display:none;
}
header #NavWrap .nav-list > li > a{
	position:relative;
	z-index:10;
	display:flex;
	justify-content:center;
	align-items:flex-start;
	flex-direction:column;
	width:100%;
	height: 2.875em;
	font-size:1rem;
	font-weight:500;
	color:var(--keycolor);
	border-bottom: 1px solid #e0e0e0;
	padding: 0.5em 1em 0.5em 1.75em;
	text-decoration:none;
	transition:var(--hover);
	letter-spacing: 0;
}
header #NavWrap .nav-list .drop_child{
	border-bottom: 1px solid #e0e0e0;
	padding-block: 0.5em;
}
header #NavWrap .nav-list .drop_child a{
	position:relative;
	z-index:10;
	width:100%;
	font-size: 0.975rem;
	color:var(--accent01);
	padding: 0.25em 1em 0.25em 2.75em;
	text-decoration:none;
	transition:var(--hover);
	display:inline-block;
	letter-spacing: -0.04em;
}
header #NavWrap .nav-list .drop_child a span{
	position:relative;
}
header #NavWrap .nav-list .drop_child a span:after{
	content:"";
	width:100%;
	height:1px;
	background:var(--accent01);
	position:absolute;
	inset:auto 0 -0.25em 0;
	transition:var(--hover);
	transform:scale(0,1);
	transform-origin:right top;
}
header #NavWrap .nav-other_list{
	text-align:left;
	padding: 0.75rem 1.25rem;
}
header #NavWrap .nav-other_list li{
	line-height:1.2;
}
header #NavWrap .nav-other_list a{
	position:relative;
	z-index:10;
	display:inline-block;
	font-size:0.75rem;
	text-decoration:none;
}
header #switch {
	position: absolute;
	width: 0;
	opacity: 0;
}
header .sp-btn_box{
	display:none;
}
.header-btn{
	margin:1em auto 0;
	max-width: 290px;
}
.header-btn a.btn{
	font-size: 1.2rem;
	min-width: 0;
	min-height: 3.0em;
	width: 100%;
	padding: 0;
	font-weight: 500;
	letter-spacing: 0;
}
.header-btn a.btn span{
	position:relative;
	padding-left:1.5em;
}
.header-btn a.btn span:before{
	content:"";
	width:25px;
	height:18px;
	background:url(../img/common/icon-mail.svg) no-repeat center / contain;
	position:absolute;
	inset:0 auto 0 0;
	transition:var(--hover);
	filter: brightness(0) invert(1);
	margin:auto;
}
.header-btn a.btn:after{
	display:none;
}
@media (any-hover: hover) {
	header .menu_top #site_ttl a:hover{
		opacity:0.7;
	}
	header .menu_top #site_ttl a img{
		opacity:1;
	}
	header #NavWrap .nav-list > li > a:hover{
		color:var(--whitecolor);
		background:var(--keycolor);
	}
	header #NavWrap .nav-list .drop_child a:hover span:after{
		transform:scale(1,1);
		transform-origin:left top;
	}
	.header-btn a.btn:hover span:before{
		filter:none;
	}
}
@media screen and (max-width:1300px) {
	header{
		width: 260px;
	}
	header #NavWrap .nav-list > li > a{
		height: 3em;
		padding: 0.5em 0.5em 0.5em 0.75em;
		font-size: 0.925rem;
	}
	header #NavWrap .nav-list .drop_child{

	}
	header #NavWrap .nav-list .drop_child a{
		font-size: 0.875rem;
		padding: 0.375em 1em 0.375em 1.5em;
	}
	.header-btn{
		max-width: 230px;
	}
	.header-btn a.btn{
		font-size:1.125rem;
	}	
}

@media screen and (max-width:1200px) {
	header{
		width:100%;
		height:80px;
		border-right:none;
		right:0;
		bottom:auto;
	}
	header .menu_top {
		padding: 0;
		border-bottom: 1px solid var(--keycolor);
		height: auto;
	}
	header .menu_top #site_ttl{
		text-align: left;
		width: auto;
		padding: 0;
	}
	header .menu_top #site_ttl *{
		display:inline-block;
	}
	header .menu_top #site_ttl a{
		width:auto;
		padding: 0.625em 1em;
		flex-direction: row;
		justify-content: flex-start;
	}
	header .menu_top #site_ttl a img{
		width: auto;
		height: 60px;
	}
	header #switch~.menu_fix label {
		position: fixed;
		z-index: 1100;
		display: block;
		width: 80px;
		height: 80px;
		text-align: center;
		padding: 15px;
		top: 0;
		right: 0;
		box-sizing: border-box;
		cursor: pointer;
	}
	header #switch~.menu_fix label b {
		display: block;
		width: 100%;
		margin-bottom: 0;
	}
	header #switch~.menu_fix label span {
		position: absolute;
		z-index: 10;
		display: block;
		width: 48px;
		height: 3px;
		background: var(--keycolor);
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		margin: auto;
		transition:var(--hover);
		cursor:
		-webkit-grabbing;
	}
	header #switch~.menu_fix label span:before,
	header #switch~.menu_fix label span:after {
		position: absolute;
		z-index: 10;
		display: block;
		content: "";
		width: 48px;
		height: 3px;
		background: var(--keycolor);
		left:0;
		margin: auto;
		transition: background .4s .2s;
	}
	header #switch~.menu_fix label span:before {
		top: -16px;
	}
	header #switch~.menu_fix label span:after {
		top: 15px;
		width: 48px;
	}
	header #switch:checked~.menu_fix label span {
		transform: rotate(225deg);
		width: 3px;
		height: 3px;
	}
	header #switch:checked~.menu_fix label span:before,
	header #switch:checked~.menu_fix label span:after {
		width: 36px;
		border-radius: 0;
		left: 50%;
		top: 50%;
	}
	header #switch:checked~.menu_fix label span:before {
		transform: translate(-50%, -50%);
	}
	header #switch:checked~.menu_fix label span:after {
		transform: translate(-50%, -50%) rotate(270deg);
	}
	header .menu_top .menu_fix{
	overflow: visible;
	height: auto;
	padding: 0;
	overflow-y: auto;
	}
	header .menu_top .menu_fix::-webkit-scrollbar {
		height: 6px;
		width: 6px;
	}
	header .menu_top .menu_fix::-webkit-scrollbar-track {
		border-radius: 10px;
		background: #f1f1f1;
	}
	header .menu_top .menu_fix::-webkit-scrollbar-thumb {
		border-radius: 10px;
		background: var(--accent01);
	}
	header .menu_top .menu_fix #NavWrap{
		position: fixed;
		z-index: 1200;
		width: 300px;
		/* height: 100%; */
		background:#fff;
		top: 80px;
		left:auto;
		right:-100%;
		bottom: 0;
		/* padding-bottom: 6em; */
		transition:right .4s;
		overflow-y: auto;
		overscroll-behavior: contain;
	}
	header #switch:checked~.menu_fix #NavWrap{
		right:0;
	}
	header .menu_top .menu_fix #NavWrap::-webkit-scrollbar {
		height: 6px;
		width: 6px;
	}
	header .menu_top .menu_fix #NavWrap::-webkit-scrollbar-track {
		border-radius: 10px;
		background: var(--whitecolor);
	}
	header .menu_top .menu_fix #NavWrap::-webkit-scrollbar-thumb {
		border-radius: 10px;
		background: var(--keycolor);
	}
	.header-btn{
		margin: 1em 1em;
		max-width: 290px;
	}
}
@media screen and (max-width:767px) {
	header{
		height: inherit;
		/* inset: 0 0 auto 0; */
		background: transparent;
	}
	header:has(#switch:checked){
		height:100%;
	}
	header .menu_top #site_ttl{
		background:#fff;
		box-shadow: 0 0 8px rgba(0,0,0,0.1);
		display: flex;
		border-bottom: 1px solid var(--keycolor);
		justify-content: space-between;
		padding-right: 60px;
		height: 60px;
	}
	header .menu_top #site_ttl a{
		padding: 0.715em 1em;
		flex-direction: row;
		justify-content: flex-start;
		min-height: 60px;
		align-items: flex-end;
	}
	header .menu_top #site_ttl a img{
		height: 31px;
		position: relative;
	}
		header .menu_top #site_ttl a:has(.min) img{
			bottom: 0.25em;
		}
	header .menu_top #site_ttl a span{
		font-size: min(5.4vw,1.43rem);
	}
	header .menu_top #site_ttl a.sp-btn{
		flex-direction:column;
		padding: 0;
		width: 60px;
		height: 60px;
		display: flex;
		justify-content: center;
		align-items: center;
		gap: 0.125em;
	}
	header .menu_top #site_ttl a.sp-btn img{
		height: 18px;
	}
	header .menu_top #site_ttl a.sp-btn span{
		font-size:0.715em;
		color:var(--keycolor);
	}
	header #switch~.menu_fix label {
		width: 60px;
		height: 60px;
		padding: 5px;
	}
	header #switch~.menu_fix label span,
	header #switch~.menu_fix label span:before,
	header #switch~.menu_fix label span:after {
		width: 28px;
		height: 2px;
	}
	header #switch~.menu_fix label span:before {
		top: -12px;
	}
	header #switch~.menu_fix label span:after {
		top: 12px;
		width: 28px;
	}
	header #switch:checked~.menu_fix label span {
		width: 1px;
		height: 1px;
	}
	header #switch:checked~.menu_fix label span:before,
	header #switch:checked~.menu_fix label span:after {
		width: 32px;
	}
	header .menu_top .menu_fix #NavWrap{
		width: 100%;
		top: 61px;
		height: auto;
	}
	 header #NavWrap .nav-list > li > a{
		font-size:1.29rem;
		height: 2.492em;
	}
	header #NavWrap .nav-list .drop_child a{
	 font-size:1.14rem;
	}
	header #NavWrap .nav-list .drop_child{
		background:#f1f9ff;
	}
	.header-btn{
		max-width:330px;
		margin-inline: auto;
	}
	.header-btn a.btn{
		font-size:1.29rem;
		text-decoration: none;
	}
}
/* contents
-------------------------------------------------------------------*/
/* footer
-------------------------------------------------------------------*/
footer:has(.sitewrap){
	position: relative;
	z-index: 100;
	background: var(--foot-color);
	padding-block: 4rem 1.5em;
	max-width: 1590px;
	width: calc(100% - 330px);
	margin-left: 330px;
	color: var(--whitecolor);
}
footer .footer-menu{
	display:flex;
	justify-content:space-between;
	align-items:flex-start;
	flex-wrap: wrap;
	gap: 2em 1em;
	margin-bottom: 3em;
}
footer .foot_left{
	width:40%;
}
footer .foot_left .copy_style{
	margin-bottom:1em;
}
footer .foot_left .copy_style a{
	display:flex;
	justify-content:flex-start;
	align-items:flex-end;
	gap:1em;
	margin-bottom: 1.875em;
	transition:var(--hover);
	text-decoration: none;
}
footer .foot_left .copy_style address{
	margin-bottom:3em;
	white-space: nowrap;
}
footer .foot_left .copy_style address a{
	display: inline-block;
	margin: 0;
	pointer-events: none;
}
footer .foot_left .copy_style a img{
	filter:var(--white);
}
footer .foot_left .copy_style a span{
	font-size:1.75rem;
	font-weight: 700;
}
footer .foot_left .btn{
	--bgcolor: var(--whitecolor);
	--fontcolor: var(--foot-color);
	font-size: 1.25rem;
	max-width: 313px;
	min-height: 3.3em;
	min-width: 0;
	width: 100%;
	padding:0;
	letter-spacing:0;
}
footer .foot_left .btn img{
	filter: brightness(0) saturate(100%) invert(19%) sepia(7%) saturate(2763%) hue-rotate(177deg) brightness(99%) contrast(84%);
	transition:var(--hover);
}
footer .foot_left .btn:after{
	display:none;
}
footer .foot_links{
	width: calc(60% - 1em);
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	/* flex-wrap: wrap; */
	gap: 2em 0.5em;
	gap: 2em 3em;
	color: #fff;
}
footer .foot_links .nav-list{
	margin: 0;
	padding: 0;
	/* height: 500px; */
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	gap: 0em 3em;
	width: 100%;
}
footer .foot_links .nav-list li{
	margin:0;
	line-height: 1;
}
footer .foot_links .nav-list li a{
	position:relative;
	z-index:10;
	display: block;
	line-height: 1.4;
	margin-bottom: 0.75em;
	text-decoration: none;
}
footer .foot_links .nav-list > li > a{
	font-weight:500;
	border-bottom:1px solid var(--whitecolor);
	padding-block: 1em;
	transform:var(--hover);
}
footer .foot_links .nav-list > li > a span{
	display: block;
}
footer .foot_links .nav-list .drop_child li a span{
	display:inline-block;
	position:relative;
}
footer .foot_links .nav-list > li > a:before{
	content: "";
	position: absolute;
	inset: 0 2em 0 auto;
	z-index: 10;
	transition:var(--hover);
	width: 7px;
	height:7px;
	border-top: solid 2px var(--keycolor);
	border-right: solid 2px var(--keycolor);
	transform: rotate(45deg);
	margin:auto;
}
footer .foot_links .nav-list > li > a:after,
footer .foot_links .nav-list .drop_child li a span:after{
	content:"";
	width:100%;
	height:1px;
	background:var(--keycolor);
	position:absolute;
	inset:auto 0 -1px 0;
	margin:auto;
	transition: var(--hover);
	transform:scale(0,1);
	transform-origin:right top;
}
footer .foot_links .nav-list .drop_child li a span:after{
	background:var(--whitecolor);
}
footer .copyright{
	text-align:center;
}
footer .copyright small{
	display:block;
	width:100%;
	font-size:0.875rem;
}


aside:has(.pagetop){
	position: absolute;
	bottom: 4.25em;
	right: -2em;
	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) {
	footer .foot_left .btn:hover{
		--bgcolor: var(--foot-color);
		--fontcolor: var(--whitecolor);
	}
	footer .foot_left .btn:hover img{
		filter: brightness(0) invert(1);
	}
	footer .foot_left .copy_style a:hover{
		opacity:0.7;
	}
	footer .foot_links .nav-list li a:hover{
		color: var(--keycolor);
		background:var(--whitecolor);
	}
	footer .foot_links .nav-list li a:hover > *{
		transform:translateX(1rem);
	}
	footer .foot_links .nav-list .drop_child li a:hover{
		background:none;
		color:var(--whitecolor);
	}
	footer .foot_links .nav-list > li > a:hover:after,
	footer .foot_links .nav-list .drop_child li a:hover span:after{
		transform:scale(1,1);
		transform-origin:left top;
	}
	a.pagetop:hover {
		transform: translateX(-0.5em);
		text-decoration-color: transparent;
	}
	a.pagetop:hover::after {
		scale: 1 1;
	}
}

@media screen and (min-width: 1000px) and (max-width: 1500px) {
	#top footer .foot_links .nav-list > li > a br.display_sp{
		display: block;
	}
}


@media screen and (max-width:1300px)	{
	footer:has(.sitewrap){
		width: calc(100% - 260px);
		margin-left:260px;
	}
}
@media screen and (min-width: 1200px) and (max-width: 1300px) {
	footer .foot_links .nav-list > li > a:before{
		inset: 0 0.75em 0 auto;
	}
}
@media screen and (max-width:1200px)	{
	footer:has(.sitewrap){
		width:100%;
		margin-left:0;
	}
}
@media screen and (max-width:1000px)	{
	footer .foot_left,
	footer .foot_links{
		width:100%;
	}
}
@media screen and (max-width:767px) {
	aside:has(.pagetop){
		inset: auto -3em 4em auto;
	}
	a.pagetop{
		width:auto;
	}
	footer:has(.sitewrap){
		padding-block: 1.5em;
	}
	footer .foot_links .nav-list,
	footer .foot_links .footer-btn_box,
	footer .foot_left .btn,
	footer .foot_links{
		display:none;
	}
	footer .foot_left .copy_style a{
		justify-content:center;
		gap: 0;
		margin-bottom: 1em;
	}
	footer .foot_left .copy_style address{
		text-align:center;
		margin-bottom: 1em;
		font-size: 0.86rem;
	}
	footer .foot_left .copy_style a img{
		height: 30px;
	}
	footer .foot_left .copy_style a span{
		font-size:1.36rem;
	}
	footer .footer-menu{
		margin-bottom:0;
	}
	footer .copyright small{
		font-size:0.71rem;
	}
}