@charset "UTF-8";
@media print, screen and (min-width: 1025px) {
#hed {
	width: 100%;
	position: fixed;
	height: 95px;
	left: 0px;
	top: 0px;
	right: 0px;
	z-index: 30;
    mix-blend-mode:difference;
}
.change-color1 #hed {
    /*background: rgba(255 255 255 / 90%);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);*/
	
}

.sptel a {color: #fff;}
.sptel {
	width: 28px;
	position: fixed;
	right: 15px;
	z-index: 5001;
	text-align: center;
	top: 14px;
	
	color: #fff;
}
.sptel .mysvg {
	width: 23px;
	color: #fff;
	fill: currentColor;
}

/*.change-color1 .sptel a {color: #333;}*/
.sptel span {
	font-style: normal;
	font-size: 7pt;
	text-align: center;
	color: #fff;
	line-height: 15px;
	font-weight: 500;
	font-variant: normal;
	display: block;
}

.fgnav{
    /*background: #2c303a;*/
    display: none;
    height: 100%;
    position: fixed;
    width: 100%;
    z-index: 300;
}
.fmenu-box {}
.fmenu{
	top: 40px;
	right: 40px;
	position: fixed;
	width: 50px;
	z-index: 350;
	cursor: pointer;
	height: 12px;
    /*transition: all .5s;*/
    mix-blend-mode:difference;
}
.fmenu:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 45px;
	height: 45px;
	margin-top: -10px;
	margin-left: -7px;
   
}

/*.change-color1 .fmenu{
	top: 25px;
	right: 40px;
	position: fixed;
	width: 50px;
	z-index: 350;
	cursor: pointer;
	height: 12px;
	transition: all .5s;
}*/

/*.fmenu:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 45px;
	height: 45px;
	margin-top: -10px;
	margin-left: -7px;
}*/

.menu__line{
    background: #fff;
    display: block;
    height: 2px;
    position: absolute;
    transition:transform .3s;
    width: 100%;
    mix-blend-mode:difference;
}

.menu__line--bottom{bottom: 0;}
.menu__line--top.active{
    top: 4px;
    transform: rotate(45deg);
    background: #fff;
    mix-blend-mode:difference;
}
.menu__line--bottom.active{
    bottom: 6px;
    transform: rotate(135deg);
    background: #fff;
    mix-blend-mode:difference;
}
.menu__title {
	font-weight: 500;
	position: absolute;
	font-size: 7pt;
	line-height: 9px;
	text-align: center;
	bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.menu__title {color: #000;}
.change-color1 .menu__title {color:#fff;}
.menu__title.active {color:#fff;}



/*gnav*/

.gnav__wrap{
	background: #fff;
	position: relative;
	width: 100%;
	height: 100%;
	overflow: scroll;
    
    background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	background-image: url(../img/body/spbk.webp);
}
.fspace {
	width: 100%;
	height: auto;
	margin-right: auto;
	margin-left: auto;
	padding-top:20px;
	/*position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);*/
}


.fmenuspace{
	box-sizing: border-box;
	padding-top: 5%;
	padding-right: 5%;
	padding-left: 5%;
	margin-bottom:15px;
    
}

.add {
	color: #333;
	box-sizing: border-box;
	padding-right: 5%;
	padding-bottom: 5%;
	padding-left: 5%;
}
.add h3{
	font-size: 10pt;
	line-height: 22px;
	font-weight: normal;
	margin-bottom: 5px;
	/*padding-bottom: 10px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #fff;*/
}
.add p{
	font-size: 9pt;
	line-height: 18px;
	font-weight: normal;
	font-variant: normal;
}
.hedlogos {
    position: relative;
	z-index: 10;
    
}
.sp-logo{
	width: 150px;
	margin-top: 30px;
	margin-left: 40px;
}
.sp-logo .mysvg{}

/* 濃背景 */

/*.change-color1 .sp-logo {
	width: 150px;
	margin-top:18px;
    margin-left: 40px;
    transition: all .5s;
}*/

.fspace h2 {
	width: 150px;
	margin-top:35px;
    display: table;
    margin-left: auto;
    margin-right: 0;
    transition: all .5s;
}

.gnav__menu {
    width: 60%;
    margin-left: 40%;
	/*display: flex;
	flex-direction: row-reverse;*/
	padding-top: 30px;
	/*text-orientation: upright;*/
}
.gnav__menu li{
	position:relative;
	
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #596872;
}
.gnav__menu ul{
	/*padding-top:10px;
	padding-bottom:10px;*/
}
.gnav__menu ul li{
	font-size: 9pt;
	line-height: 21px;
	font-weight: 500;
	position:relative;
}

.gnav__menu ul li span{
	/*background-color: #333;
	height: 15px;
	width: 1px;
	margin-right: auto;
	margin-left: auto;
	display: block;
	position: absolute;
	left: 0px;
	top: 0px;
	right: 0px;*/
}
.gnav__menu ul li a{
	color: #fff;
	-webkit-transition: all .3s;
	transition: all .3s;
	box-sizing:border-box;
	
}
.gnav__menu ul li a:hover{
	color: #fff;
	-webkit-transition: all .3s;
	transition: all .3s;
}

.gnav__menu__item {
    font-family: hiragino-mincho-pron, sans-serif;
	font-size: 14pt;
	line-height: 35px;
	font-weight: normal;
    position: relative;
}

.gnav__menu__item span{
    position: absolute;
    right: 0;
    top: 24%;
    display: block;
    font-family: hiragino-mincho-pron, sans-serif;
	font-size: 10pt;
	line-height: 35px;
	font-weight: normal;
}
.gnav__menu__item h5{
	padding-top:15px;
	
	font-size: 11pt;
	line-height: 25px;
	font-weight: 500;
}
.gnav__menu a{
	padding-top: 20px;
	padding-bottom: 20px;
	color: #fff;
	display:block;
	-webkit-transition: all .3s;
	transition: all .3s;
}
/*.gnav__menu a:hover{
	color: #fff;
}*/
.gnav__menu a:hover,
.gnav__menu a:focus {}
.gnav__menu a::after {
	position: absolute;
	left: 0;
	content: '';
	width: 100%;
	height: 1px;
	bottom: -0px;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: transform 0.3s;
	background-color: #fff;
}
.gnav__menu a:hover::after {transform: scale(1, 1);}

.gnav__menu h5 a{
	padding-top:5px;
	padding-bottom:5px;
	color: #333;
	display:block;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.gnav__menu h5 a:hover{
	color: #333;
}





.fs-accordion summary{
	padding-top:10px;
	padding-bottom:10px;
	position: relative;
	list-style: none;
	cursor: pointer;
	font-size: 11pt;
	line-height: 25px;
	font-weight: 500;
	box-sizing: border-box;
}
.fs-accordion summary::-webkit-details-marker {display: none;}
.fsicon {
  display: block;
  position: absolute;
  right: 10px;
  top: 50%;
  width: 15px;
  margin-left: 6px;
  flex-shrink: 0;
  transform-origin: center 43%;
  transition: transform 0.5s;
}
/* アイコンの三角矢印 */
.fsicon::before,
.fsicon::after {
  content: "";
  position: absolute;
  display: block;
  width: 10px;
  height: 3px;
  background-color: #000;
}

.fsicon::before {
  left: 0;
  transform: rotate(45deg);
}

.fsicon::after {
  right: 0;
  transform: rotate(-45deg);
}

/* アコーディオン表示の際に回転する */
.fs-accordion details[open] .fsicon {
  transform: rotate(180deg);
}
/*.fs-accordion summary::-webkit-details-marker {display: none;}
.fs-accordion summary::after{
	position: absolute;
	width: 10px;
	height: 10px;
	top: calc(50% - 15px);
	right: 13px;
	box-sizing: border-box;
	content: "+";
	font-size: 22pt;
	color: #67C413;
	-webkit-transition: all .3s;
	transition: all .3s;
}*/
.fs-accordion .contents{
	margin-left:20px;
	box-sizing: border-box;
	padding-bottom:10px;
}
.fs-accordion p{
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #ccc;
}
.fs-accordion p:last-child {border: 0px;}





/*モーダル*/
.modal_wrap input{display: none;}
.modal_overlay{
    display: flex;
    justify-content: center;
    overflow: auto;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.7);
    opacity: 0;
    transition: opacity 0.5s, transform 0s 0.5s;
    transform: scale(0);
}
.modal_trigger{position: absolute;width: 100%;height: 100%;}
.modal_content{
	position: relative;
	align-self: center;
	width: 90%;
	max-width: 640px;
	box-sizing: border-box;
	background: #fff;
	line-height: 1.4em;
	transition: 0.5s;
	padding-top: 38px;
	padding-right: 15px;
	padding-bottom: 15px;
	padding-left: 15px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;
}
.close_button{
	position: absolute;
	top: 12px;
	right: 10px;
	font-size: 24px;
	cursor: pointer;
	color: #333;
}
.close_button span {color: #FFF;}
.modal_wrap input:checked ~ .modal_overlay{
    opacity: 1;
    transform: scale(1);
    transition: opacity 0.5s;
}
.open_button{}
.fspacer h4{
	font-size: 10pt;
	margin-bottom: 5px;
	font-weight: normal;
	padding-top:5px;
}
.button-sp span{font-size: 11pt; margin-right:5px;}
.button-sp {
	font-weight: 600;
	font-size: 15pt;
	display: block;
	text-decoration: none;
	outline: none;
	margin-right: auto;
	margin-left: auto;
	line-height: 25px;
	padding: 15px;
	box-sizing: border-box;
	margin-bottom:10px;
}
.button-sp::before,
.button-sp::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.button-sp,
.button-sp::before,
.button-sp::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.button-sp {color: #fff; background-color: #CCCCCC;}
.button-sp:hover {color: #fff; background-color: #CCCCCC;}

}






@media screen and (min-width: 0px) and (max-width: 1024px)  {
#hed {
	width: 100%;
	position: fixed;
	height: 95px;
	left: 0px;
	top: 0px;
	right: 0px;
	z-index: 30;
    mix-blend-mode:difference;
}
.change-color1 #hed {
    /*background: rgba(255 255 255 / 90%);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);*/
	
}



/*.change-color1 .sptel a {color: #333;}*/


.fgnav{
    /*background: #2c303a;*/
    display: none;
    height: 100%;
    position: fixed;
    width: 100%;
    z-index: 300;
}
.fmenu-box {}
.fmenu{
	top: 25px;
	right: 20px;
	position: fixed;
	width: 40px;
	z-index: 350;
	cursor: pointer;
	height: 12px;
    /*transition: all .5s;*/
    mix-blend-mode:difference;
}
.fmenu:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 45px;
	height: 45px;
	margin-top: -10px;
	margin-left: -7px;
   
}

/*.change-color1 .fmenu{
	top: 25px;
	right: 40px;
	position: fixed;
	width: 50px;
	z-index: 350;
	cursor: pointer;
	height: 12px;
	transition: all .5s;
}*/

/*.fmenu:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 45px;
	height: 45px;
	margin-top: -10px;
	margin-left: -7px;
}*/

.menu__line{
    background: #fff;
    display: block;
    height: 2px;
    position: absolute;
    transition:transform .3s;
    width: 100%;
    mix-blend-mode:difference;
}

.menu__line--bottom{bottom: 0;}
.menu__line--top.active{
    top: 4px;
    transform: rotate(45deg);
    background: #fff;
    mix-blend-mode:difference;
}
.menu__line--bottom.active{
    bottom: 6px;
    transform: rotate(135deg);
    background: #fff;
    mix-blend-mode:difference;
}
.menu__title {
	font-weight: 500;
	position: absolute;
	font-size: 7pt;
	line-height: 9px;
	text-align: center;
	bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.menu__title {color: #000;}
.change-color1 .menu__title {color:#fff;}
.menu__title.active {color:#fff;}



/*gnav*/

.gnav__wrap{
	background: #fff;
	position: relative;
	width: 100%;
	height: 100%;
	overflow: scroll;
    
    background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	background-image: url(../img/body/spbk.webp);
}
.fspace {
	width: 100%;
	height: auto;
	margin-right: auto;
	margin-left: auto;
	padding-top:20px;
	/*position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);*/
}


.fmenuspace{
	box-sizing: border-box;
	padding-top: 5%;
	padding-right: 5%;
	padding-left: 5%;
	margin-bottom:15px;
    
}

.add {
	color: #333;
	box-sizing: border-box;
	padding-right: 5%;
	padding-bottom: 5%;
	padding-left: 5%;
}
.add h3{
	font-size: 10pt;
	line-height: 22px;
	font-weight: normal;
	margin-bottom: 5px;
	/*padding-bottom: 10px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #fff;*/
}
.add p{
	font-size: 9pt;
	line-height: 18px;
	font-weight: normal;
	font-variant: normal;
}
.hedlogos {
    position: relative;
	z-index: 10;
    
}
.sp-logo{
	width: 120px;
	margin-top: 20px;
	margin-left: 20px;
}
.sp-logo .mysvg{}

/* 濃背景 */

/*.change-color1 .sp-logo {
	width: 150px;
	margin-top:18px;
    margin-left: 40px;
    transition: all .5s;
}*/

.fspace h2 {
	width: 120px;
	margin-top:20px;
    display: table;
    margin-left: auto;
    margin-right: 0;
    transition: all .5s;
}

.gnav__menu {
    /*width: 60%;
    margin-left: 40%;*/
	/*display: flex;
	flex-direction: row-reverse;*/
	padding-top: 30px;
	/*text-orientation: upright;*/
}
.gnav__menu li{
	position:relative;
	
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #596872;
}
.gnav__menu ul{
	/*padding-top:10px;
	padding-bottom:10px;*/
}
.gnav__menu ul li{
	font-size: 9pt;
	line-height: 21px;
	font-weight: 500;
	position:relative;
}

.gnav__menu ul li span{
	/*background-color: #333;
	height: 15px;
	width: 1px;
	margin-right: auto;
	margin-left: auto;
	display: block;
	position: absolute;
	left: 0px;
	top: 0px;
	right: 0px;*/
}
.gnav__menu ul li a{
	color: #fff;
	-webkit-transition: all .3s;
	transition: all .3s;
	box-sizing:border-box;
	
}
.gnav__menu ul li a:hover{
	color: #fff;
	-webkit-transition: all .3s;
	transition: all .3s;
}

.gnav__menu__item {
    font-family: hiragino-mincho-pron, sans-serif;
	font-size: 12pt;
	line-height: 35px;
	font-weight: normal;
    position: relative;
}

.gnav__menu__item span{
    position: absolute;
    right: 0;
    top: 24%;
    display: block;
    font-family: hiragino-mincho-pron, sans-serif;
	font-size: 8pt;
	line-height: 35px;
	font-weight: normal;
}
.gnav__menu__item h5{
	padding-top:15px;
	
	font-size: 11pt;
	line-height: 25px;
	font-weight: 500;
}
.gnav__menu a{
	padding-top: 15px;
	padding-bottom: 15px;
	color: #fff;
	display:block;
	-webkit-transition: all .3s;
	transition: all .3s;
}
/*.gnav__menu a:hover{
	color: #fff;
}*/
.gnav__menu a:hover,
.gnav__menu a:focus {}
.gnav__menu a::after {
	position: absolute;
	left: 0;
	content: '';
	width: 100%;
	height: 1px;
	bottom: -0px;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: transform 0.3s;
	background-color: #fff;
}
.gnav__menu a:hover::after {transform: scale(1, 1);}

.gnav__menu h5 a{
	padding-top:5px;
	padding-bottom:5px;
	color: #333;
	display:block;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.gnav__menu h5 a:hover{
	color: #333;
}





.fs-accordion summary{
	padding-top:10px;
	padding-bottom:10px;
	position: relative;
	list-style: none;
	cursor: pointer;
	font-size: 11pt;
	line-height: 25px;
	font-weight: 500;
	box-sizing: border-box;
}
.fs-accordion summary::-webkit-details-marker {display: none;}
.fsicon {
  display: block;
  position: absolute;
  right: 10px;
  top: 50%;
  width: 15px;
  margin-left: 6px;
  flex-shrink: 0;
  transform-origin: center 43%;
  transition: transform 0.5s;
}
/* アイコンの三角矢印 */
.fsicon::before,
.fsicon::after {
  content: "";
  position: absolute;
  display: block;
  width: 10px;
  height: 3px;
  background-color: #000;
}

.fsicon::before {
  left: 0;
  transform: rotate(45deg);
}

.fsicon::after {
  right: 0;
  transform: rotate(-45deg);
}

/* アコーディオン表示の際に回転する */
.fs-accordion details[open] .fsicon {
  transform: rotate(180deg);
}
/*.fs-accordion summary::-webkit-details-marker {display: none;}
.fs-accordion summary::after{
	position: absolute;
	width: 10px;
	height: 10px;
	top: calc(50% - 15px);
	right: 13px;
	box-sizing: border-box;
	content: "+";
	font-size: 22pt;
	color: #67C413;
	-webkit-transition: all .3s;
	transition: all .3s;
}*/
.fs-accordion .contents{
	margin-left:20px;
	box-sizing: border-box;
	padding-bottom:10px;
}
.fs-accordion p{
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #ccc;
}
.fs-accordion p:last-child {border: 0px;}





/*モーダル*/
.modal_wrap input{display: none;}
.modal_overlay{
    display: flex;
    justify-content: center;
    overflow: auto;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.7);
    opacity: 0;
    transition: opacity 0.5s, transform 0s 0.5s;
    transform: scale(0);
}
.modal_trigger{position: absolute;width: 100%;height: 100%;}
.modal_content{
	position: relative;
	align-self: center;
	width: 90%;
	max-width: 640px;
	box-sizing: border-box;
	background: #fff;
	line-height: 1.4em;
	transition: 0.5s;
	padding-top: 38px;
	padding-right: 15px;
	padding-bottom: 15px;
	padding-left: 15px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;
}
.close_button{
	position: absolute;
	top: 12px;
	right: 10px;
	font-size: 24px;
	cursor: pointer;
	color: #333;
}
.close_button span {color: #FFF;}
.modal_wrap input:checked ~ .modal_overlay{
    opacity: 1;
    transform: scale(1);
    transition: opacity 0.5s;
}
.open_button{}
.fspacer h4{
	font-size: 10pt;
	margin-bottom: 5px;
	font-weight: normal;
	padding-top:5px;
}
.button-sp span{font-size: 11pt; margin-right:5px;}
.button-sp {
	font-weight: 600;
	font-size: 15pt;
	display: block;
	text-decoration: none;
	outline: none;
	margin-right: auto;
	margin-left: auto;
	line-height: 25px;
	padding: 15px;
	box-sizing: border-box;
	margin-bottom:10px;
}
.button-sp::before,
.button-sp::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.button-sp,
.button-sp::before,
.button-sp::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.button-sp {color: #fff; background-color: #CCCCCC;}
.button-sp:hover {color: #fff; background-color: #CCCCCC;}

}

@media print, screen and (min-width: 1025px) { 
  /*#hed {display: none;}*/
  .sponly {display: none;}
  .pconly {}
}
@media screen and (min-width: 0px) and (max-width: 1024px) {
  #hed {}
  .sponly {}
  .pconly {display: none;}
}
