@charset "utf-8";


/* all
-------------------------------------------------------------------*/
html {
	background: #FFFFFF;
	color: #282828;
	font-family: 'Noto Sans JP', "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-size: 16px;
	line-height: 1.4;
	font-weight: 500;
}
html .goti,
html .goti form * {
	font-family: 'Noto Sans JP', "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}
html .min,
html .min form * {
	font-family: "Noto Serif JP", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "Times New Roman", "HG明朝B", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
body {
	width: 100%;
	font-size: 100%;
	text-align: center;
	min-width: 1200px;
	color: #282828;
	font-family: 'Noto Sans JP', "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}
main {
	overflow: hidden;
	width: 100%;
	margin-top: 120px;
}
main img{
	max-width: 100%;
	max-height: 100%;
	height:auto;
}
.sitewrap {
	width: 1200px;
	min-width: 1200px;
	margin: 0 auto;
	text-align: left;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
@media screen and (max-width:1220px) {
	body,
	.sitewrap {
		width: 100%;
		min-width: 0;
	}
	.sitewrap>* {
		padding-left: 2%;
		padding-right: 2%;
	}
}
@media screen and (max-width:767px) {
	main {
		margin-top: 60px;
	}
	html {
		font-size: 14px;
	}
	.sitewrap>* {
		padding-left: 15px;
		padding-right: 15px;
	}
}
/* header
-------------------------------------------------------------------*/
header#fix_menu {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 999;
	background: #fff;
	height: 120px;
}
.menu_top {
	position: relative;
	z-index: 10;
}
.menu_top #site_ttl {
	float: left;
	padding: 43px 25px;
	white-space: nowrap;
}
.menu_top #site_ttl a {
	display: inline-block;
	vertical-align: middle;
}
.menu_top #site_ttl img {
	max-height: 34px;
}
.drop_menu #NavWrap {
	padding: 0;
	display: flex;
	justify-content: flex-end;
	align-items: stretch;
}
.drop_menu #NavWrap ul {
	margin: 0;
	max-width: 468px;
	padding: 0 26px;
	width: 100%;
	box-sizing: border-box;
	display: flex;
}
.drop_menu #NavWrap ul::after {
	display: none;
}
.drop_menu #NavWrap ul li {
	position: relative;
	z-index: 1;
	flex-grow: 1;
}
.drop_menu #NavWrap ul li::before {
	position: absolute;
	z-index: 1;
	display: inline-block;
	content: "";
	width: 1px;
	height: 1rem;
	background: #000;
	top: 0;
	left: 0;
	bottom: 0;
	margin: auto;
}
.drop_menu #NavWrap ul li:first-child::before,
.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns li::before {
	display: none;
}
.drop_menu #NavWrap li a,
.drop_menu #NavWrap li p{
	padding: 52px 10px;
	display: block;
	box-sizing: border-box;
	text-decoration: none;
	font-size: 1rem;
	font-weight: 500;
	width: auto;
	line-height: 1;
	position: relative;
	z-index: 1;
	color: #000;
	text-align: center;
	transition: opacity 0.5s, color 0.5s;
	cursor: pointer;
	margin: 0;
}
.drop_menu #NavWrap li.drop-wrap {
	padding: 52px 10px;
	line-height: 1.4;
}
.drop_menu #NavWrap li.drop-wrap a,
.drop_menu #NavWrap li.drop-wrap p {
	padding: 0;
}
.drop_menu #NavWrap li.drop-wrap i{
	display:none;
}
.drop_menu #NavWrap li a:hover {
	opacity: 1;
	color: #f63e3e;
}
.drop_menu #NavWrap li a span,
.drop_menu #NavWrap li p span {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	white-space: normal;
	position: relative;
}
.drop_menu #NavWrap li.drop-wrap dl {
	position: fixed;
	background: rgba(246, 62, 62, 0.9);
	top: 120px;
	left: 0;
	right: 0;
	color: #fff;
	pointer-events: none;
	overflow: hidden;
	padding: 50px 0;
	opacity: 0;
	z-index: -100;
	transition: opacity .4s;
	margin: 0;
}
.drop_menu #NavWrap li.drop-wrap:hover dl {
	opacity: 1;
	pointer-events: auto;
	z-index: 1;
}
.drop_menu #NavWrap li.drop-wrap dl .drop-inner {
	max-width: 1200px;
	margin: auto;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-direction: column;
}
.drop_menu #NavWrap li.drop-wrap dl dt {
	font-size: 2rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	margin-bottom: 3%;
}
.drop_menu #NavWrap li.drop-wrap dl dd {
	width:100%;
}
.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns {
	max-width: 100%;
	padding: 0;
	justify-content: flex-start;
	align-items: stretch;
	flex-wrap: wrap;
}
.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns li {
	flex-grow: inherit;
	margin-right: 1%;
	margin-bottom: 1.5%;
}
.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns li a {
	min-width: 288px;
	font-size: 1.125rem;
	font-weight: bold;
	color: #f63e3e;
	line-height: 1.2;
	border: 3px solid #f63e3e;
	border-radius: 50px;
	background: #fff;
	padding: 32px 30px;
	transition:transform .8s;
}
.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns li a:hover{
	transform:translateY(5px);
	text-decoration:none;
}
.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns li a::after {
	position: absolute;
	z-index: 1;
	display: inline-block;
	content: "";
	width: 8px;
	height: 8px;
	border-top: 2px solid #f63e3e;
	border-right: 2px solid #f63e3e;
	top: 0;
	bottom: 0;
	right: 20px;
	margin: auto;
	transform: rotate(45deg) skew(10deg, 10deg);
}
.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns li a span {
	align-items: flex-start;
}
.drop_menu .header-btn a {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	min-width: 120px;
	height: 100%;
	background: #f63e3e;
	color: #fff;
	font-size: 0.875rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	padding: 0.25em;
	transition: background .4s, color .4s;
}
.drop_menu .header-btn.contact-btn a {
	border-color: #fff;
	background: #fff;
	color: #000000;
}
.drop_menu .header-btn a:hover {
	background: #ff7070;
}
.drop_menu .header-btn.contact-btn a:hover {
	color: #fff;
}
#fix_menu #switch {
	position: absolute;
	display: none;
	opacity: 0;
}
@media screen and (max-width: 1250px) {
	.drop_menu #NavWrap li.drop-wrap dl {
		padding-left:2%;
		padding-right:2%;
	}
}
@media screen and (max-width: 1125px) {
	.menu_top #site_ttl {
		padding: 46px 15px;
	}
	.menu_top #site_ttl img {
		width: 100%;
		max-height: 22px;
	}
}
@media screen and (max-width: 995px) {
	header#fix_menu,
	header#fix_menu.fixedMenu {
		position: fixed;
		transition: none;
		top: 0;
		background: #fff;
		height: 60px;
	}
	header .menu_top {
		padding: 0;
		z-index: 700;
	}
	header .menu_top::before {
		position: absolute;
		display: inline-block;
		content: "";
		width: 300px;
		height: 100vh;
		background: #fff;
		left: auto;
		right: 0;
		top: -100vh;
		z-index: -10;
		transition: top .2s;
	}	
	header .menu_top::after {
		position: absolute;
		display: inline-block;
		content: "";
		width: 100%;
		height: 120px;
		background: #fff;
		left: 0;
		right: 0;
		top: 0;
		z-index: 10;
		visibility: visible;
	}
	header #switch:checked+.menu_top::before {
		top: 60px;
	}
	header .menu_top #site_ttl {
		padding: 35px 10px;
		position: relative;
		z-index: 800;
		width: auto;
	}
	.menu_top #site_ttl a {
		position: relative;
		display: inline-flex;
		justify-content: center;
		align-items: center;
		height: 50px;
		z-index: 100;
	}	
	.menu_top #site_ttl img {
		max-height: 100%;
		max-width:100%;
		width: 100%;
	}
	.menu_fix {
		text-align: right;
		margin-left: 0;
	}
	#fix_menu #switch+.menu_top label[for="switch"] {
		display: block;
		cursor: pointer;
		position: fixed;
		top: 0;
		right: 0;
		z-index: 900;
		transition: 0.5s transform, right 0.2s;
		padding: 12px;
		width: 120px;
		height: 120px;
		box-sizing: border-box;
		background: #f63e3e;
		text-align: center;
		z-index: 12;
	}
	#fix_menu #switch+.menu_top label[for="switch"] b {
		width: 100%;
		display: block;
		margin-bottom: 0;
	}
	#fix_menu #switch+.menu_top label[for="switch"] span {
		cursor: -webkit-grabbing;
		display: block;
		width: 100%;
		height: 0;
		position: absolute;
		top: 60px;
		left: 0;
		right: 0;
		margin: auto;
	}
	#fix_menu #switch+.menu_top label[for="switch"] span::before,
	#fix_menu #switch+.menu_top label[for="switch"] span::after {
		content: "";
		display: block;
		width: 65px;
		height: 2px;
		background: #ffffff;
		position: absolute;
		left: 0;
		right: 0;
		margin: auto;
		transition: 0.2s transform;
	}
	#fix_menu #switch+.menu_top label[for="switch"] span::before {
		top: -6px;
	}
	#fix_menu #switch+.menu_top label[for="switch"] span::after {
		top: 6px;
	}
	#fix_menu #switch:checked+.menu_top label[for="switch"] span::before {
		transform: rotate(-200deg);
		top: 0;
	}
	#fix_menu #switch:checked+.menu_top label[for="switch"] span::after {
		transform: rotate(200deg);
		top: 0;
		margin-top: 0;
	}
	.drop_menu #NavWrap {
		position: fixed;
		top: 0;
		bottom: 0;
		width: 300px;
		z-index: 5;
		max-height: 100vh;
		overflow-y: auto;
		visibility: hidden;
		padding: 130px 10px 60px;
		box-sizing: border-box;
		transition: transform 0.25s;
		flex-direction: column;
		left: auto;
		right: 0;
		transform: translateY(-100%);
		display: block;
	}
	.drop_menu #NavWrap::-webkit-scrollbar {
		height: 10px;
		width: 10px;
	}
	.drop_menu #NavWrap::-webkit-scrollbar-track {
		border-radius: 10px;
		background: #b3b3b3;
	}
	.drop_menu #NavWrap::-webkit-scrollbar-thumb {
		border-radius: 10px;
	}
	#fix_menu #switch:checked+.menu_top label+#NavWrap {
		visibility: visible;
		transform: translateY(0);
	}
	.drop_menu #NavWrap>ul {
		width: 100%;
		max-width: 100%;
		margin-right: 0;
		flex-direction: column;
		padding: 0;
		margin-bottom: 1.5em;
		overflow:hidden;
	}
	.drop_menu #NavWrap ul li,
	.drop_menu #NavWrap li.drop-wrap a,
	.drop_menu #NavWrap li.drop-wrap a:hover,
	.drop_menu #NavWrap li.drop-wrap p{
		position: relative;
		display: block;
		padding: 1em 1.25em;
		border-bottom: 1px solid #d3d3d3;
	}
	.drop_menu #NavWrap li.drop-wrap a:hover{
		border:none;
	}
	.drop_menu #NavWrap ul li::before {
		display:none;
	}
	.drop_menu #NavWrap ul li:not(.drop-wrap)::after {
		position: absolute;
		z-index: 1;
		display: inline-block;
		content: "";
		width: 6px;
		height: 6px;
		border-top: 2px solid #000;
		border-right: 2px solid #000;
		top: 0;
		bottom: 0;
		right: 10px;
		margin: auto;
		transform: rotate(45deg) skew(10deg, 10deg);
	}
	.drop_menu #NavWrap li.drop-wrap{
		padding:0;
		border-bottom:none;
	}
	.drop_menu #NavWrap ul li.drop-wrap li::after {
		display:none;
	}
	.drop_menu #NavWrap li a,
	.drop_menu #NavWrap li p,
	.drop_menu #NavWrap li a:hover {
		font-size: 1rem;
		padding: 0;
		margin: auto;
		text-decoration: none;
		background: none;
		border: none;
		text-align: left;
	}
	.drop_menu #NavWrap li a:hover {
		background: none;
	}
	.drop_menu #NavWrap li.drop-wrap a,
	.drop_menu #NavWrap li.drop-wrap p{
		width:fit-content;
		margin-left: 0;
		border-bottom: none;
	}
	.drop_menu #NavWrap li.drop-wrap > a::before,
	.drop_menu #NavWrap li.drop-wrap p::before{
		position:absolute;
		display:inline-block;
		content:"";
		width: calc(100vw - 30px);
		height:1px;
		background:#d3d3d3;
		left:0;
		right:0;
		bottom:0;
	}
	.drop_menu #NavWrap li a span,
	.drop_menu #NavWrap li p span{
		display: block;
		border-left: none;
		white-space: normal;
		font-size: 1rem;
		background: none;
		line-height: 1.4;
		margin: 0;
		width: 100%;
	}
	.drop_menu #NavWrap li.drop-wrap i{
		position:absolute;
		display:inline-block;
		z-index:10;
		width: 2em;
		height: 2em;
		top: 0.75em;
		right: 0;
		background:#f63e3e;
		border-radius:50%;
		margin:0;
	}
	.drop_menu #NavWrap li.drop-wrap i::before,
	.drop_menu #NavWrap li.drop-wrap i::after{
		position:absolute;
		z-index:100;
		display:inline-block;
		content:"";
		width:0.85em;
		height:2px;
		background:#fff;
		top:0.95em;
		right:0.55em;
	}
	.drop_menu #NavWrap li.drop-wrap i::after{
		transform:rotate(270deg);
		transition:transform .2s;
	}
	.drop_menu #NavWrap li.drop-wrap.opened i::after{
		transform:rotate(0deg);
	}
	.drop_menu #NavWrap li.drop-wrap dl,
	.drop_menu #NavWrap li.drop-wrap:hover dl{
		position: static;
		background: #fff;
		color: #fff;
		overflow: hidden;
		padding: 0;
		opacity: 1;
		pointer-events: auto;
		z-index: 1;
		max-height: 0;
		visibility: hidden;
		overflow: hidden;
		transition:opacity .4s,visibility .4s, max-height .4s;
	}
	.drop_menu #NavWrap li.drop-wrap.opened dl,
	.drop_menu #NavWrap li.drop-wrap.opened:hover dl{
		max-height: 100vh;
		visibility: visible;
		overflow: visible;
	}
	.drop_menu #NavWrap li.drop-wrap dl .drop-inner {
		max-width: 100%;
		justify-content: flex-start;
		align-items: flex-start;
		flex-direction: column;
	}
	.drop_menu #NavWrap li.drop-wrap dl dt {
		display:none;
	}
	.drop_menu #NavWrap li.drop-wrap dl dd{
		width: 100%;
	}
	.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns {
		max-width: 100%;
		padding: 0;
		flex-direction: column;
	}
	.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns li {
		flex-grow: inherit;
		margin-right: 0;
		margin-bottom: 0;
		padding: 0;
	}
	.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns li a {
		min-width: 0;
		width: 100%;
		font-size: 1rem;
		border: none;
		border-radius: 0;
		padding: 1em 1.25em;
	}
	.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns li a:hover{
		transform:none;
	}
	.drop_menu #NavWrap li.drop-wrap dl dd .drop-btns li a::after {
		width: 6px;
		height: 6px;
		right: 10px;
	}
	.drop_menu .header-btn a,
	.drop_menu .header-btn a:hover{
		max-width:260px;
		min-width: 0;
		margin:0.5em auto;
		height: 3em;
		font-size: 1rem;
		background:#f63e3e;
		border:1px solid #f63e3e;
	}
	.drop_menu .header-btn.contact-btn a,
	.drop_menu .header-btn.contact-btn a:hover{
		border-color: #f63e3e;
		background: #fff;
		color: #000000;
	}
}
@media screen and (max-width: 767px) {
	header#fix_menu,
	header#fix_menu.fixedMenu {
		height: 60px;
	}
	header .menu_top::before {
		width: 100%;
		left: 0;
	}	
	header .menu_top::after {
		height: 60px;
	}
	header #switch:checked+.menu_top::before {
		top: 60px;
	}
	header .menu_top #site_ttl {
		padding: 5px 10px;
		width: 60%;
	}
	#fix_menu #switch+.menu_top label[for="switch"] {
		width: 60px;
		height: 60px;
	}
	#fix_menu #switch+.menu_top label[for="switch"] span {
		top: 30px;
	}
	#fix_menu #switch+.menu_top label[for="switch"] span::before,
	#fix_menu #switch+.menu_top label[for="switch"] span::after {
		width: 25px;
		height: 1px;
	}
	#fix_menu #switch+.menu_top label[for="switch"] span::before {
		top: -3px;
	}
	#fix_menu #switch+.menu_top label[for="switch"] span::after {
		top: 3px;
	}
	.drop_menu #NavWrap {
		width: 100%;
		padding: 60px 10px;
		left: 0;
		right: 0;
	}
}
/* footer
-------------------------------------------------------------------*/
#pageTop {
	position: fixed;
	bottom: 15px;
	right: 5%;
	width: 18px;
	z-index: 500;
}
footer {
	padding: 100px 0 40px;
	background: #e9e9e9;
}
footer .foot-top .logo{
	display:block;
	height:33px;
	margin-bottom:4em;
}
footer .foot-top .logo img{
	height:100%;
}
footer .foot-center{
	display:flex;
	justify-content:space-between;
	align-items:stretch;
	flex-wrap:wrap;
	margin-bottom:6em;
}
footer .foot-center a{
	text-decoration:none;
}
footer .foot-center a span{
	position:relative;
	z-index:1;
	padding-bottom:1px;
}
footer .foot-center a span::before{
	position:absolute;
	z-index:1;
	display:inline-block;
	content:"";
	width:100%;
	height: 1px;
	background:#f63e3e;
	bottom:0;
	transform:scale(0,1);
	transform-origin:right;
	transition:transform .4s;
	border-radius: 4em;
}
footer .foot-center a:hover span::before{
  transform:scale(1,1);
  transform-origin:left;
}
footer .foot-center dl,
footer .foot-center dt,
footer .foot-center p,
footer .foot-bottom p {
	margin-bottom:0;
	line-height:1.4;
}
footer .foot-center dt a,
footer .foot-center dt p,
footer .foot-center p a{
	display:inline-block;
	font-size:1rem;
	font-weight:bold;
	color:#f63e3e;
	margin-bottom:1.25em;
}
footer .foot-center li {
	margin-top: 0;
	margin-bottom:0.5em;
}
footer .foot-center li a{
	position:relative;
	z-index:1;
	display: block;
	font-size:0.875rem;
	padding-left:0.75em;
	color: #282828;
}
footer .foot-center li a::before{
	position:absolute;
	z-index:1;
	display:inline-block;
	content:"";
	width:0.35em;
	height:1px;
	background:#282828;
	top:0.75em;
	left:0;
}
footer .foot-center li.service-nam span{
	display:block;
	font-size:0.75rem;
}
footer .foot-center li em{
	font-weight:500;
}
footer .foot-center .flex-links{
	display:flex;
	justify-content:space-between;
	align-items:stretch;
	min-width: 410px;
}
footer .foot-center ul{
	padding:0;
	margin: 0;
}
footer .foot-bottom {
	display:flex;
	justify-content:space-between;
	align-items:stretch;
	flex-wrap:wrap;
}
footer .foot-bottom a{
	color: #282828;
	display:inline-block;
	font-size:0.875rem;
	font-weight:500;
	text-decoration:underline;
	text-underline-offset:7px;
}
footer .foot-bottom a:hover{
	text-decoration:none;
}
footer .foot-bottom small{
	font-size:0.875rem;
	font-weight:500;
}
main a.page_link,
.site-body a.page_link{
	margin-top: -120px;
	padding-top: 120px;
	display: block;
	position: relative;
	z-index: -10;
}
main a.page_link:focus,
.site-body a.page_link:focus{
	outline:none;
}
@media screen and (max-width:767px) {
	#pageTop {
		width: 12px;
		right: 10px;
		bottom: 10px;
	}
	.post-name-contact #pageTop,
	.post-name-confirm #pageTop {
		bottom: 80px;
	}
	footer {
		padding: 40px 0 20px;
	}
	footer .foot-top .logo{
		text-align:center;
		max-width:240px;
		height:auto;
		margin:auto;
		margin-bottom:2em;
	}
	footer .foot-top .logo img{
		width:100%;
	}
	footer .foot-center{
		flex-direction:column;
		flex-wrap: nowrap;
		margin-bottom:1em;
	}
	footer .foot-center a span::before{
		display:none;
	}
	footer .foot-center dt a,
	footer .foot-center dt p,
	footer .foot-center p a{
		margin-bottom:0.5em;
	}
	footer .foot-center ul{
		display:flex;
		justify-content:space-between;
		align-items:stretch;
		flex-wrap:wrap;
	}
	footer .foot-center li {
		width:49%;
		margin-bottom:0.5em;
	}
	footer .foot-center li a::before{
		position:absolute;
		z-index:1;
		display:inline-block;
		content:"";
		width:0.35em;
		height:1px;
		background:#282828;
		top:0.75em;
		left:0;
	}
	footer .foot-center li em{
		font-weight:500;
	}
	footer .foot-center .flex-links{
		min-width: 0;
		margin-bottom: 0.5em;
	}
	footer .foot-center .flex-links ul{
		display:block;
		width:49%;
	}
	footer .foot-center .flex-links ul li{
		font-size: 0.875rem;
		width:100%;
		margin-bottom: 0.25em;
	}
	footer .foot-center .flex-link_sp{
		display:flex;
		justify-content:flex-start;
		align-items: flex-start;
	}
	footer .foot-center .flex-link_sp > *{
		width: 33.333%;
		margin: 0;
	}
	footer .foot-bottom a{
		text-underline-offset:4px;
		margin-bottom:1em;
	}
	footer .foot-bottom a:hover{
		text-decoration:underline;
	}
	main a.page_link,
	.site-body a.page_link{
		margin-top: -60px;
		padding-top: 60px;
	}
}