﻿/* 全ページ共通スタイル */
* {
  box-sizing: border-box;
}
body {
	font-family: 'Roboto' , 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3',  "Helvetica Neue", Arial, "メイリオ", Meiryo, sans-serif;
  line-height: 1.5;
  color: rgb(79, 79, 79);
  height: 100%;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
/*main */
.ivr-pages-body {
  max-width: 1024px;
  width: calc(100% - 1em);
  height: auto;
  margin: 0 auto;
  padding: 1em 0;
}

.br-sp{
	display: none;
}

/*Header Design*/
.ivr_header {
 font-size: 1.25em;
}
.ivr_header a{
  background: #004098;
  font-weight: 700;
  padding: 1.25em 1em;
  margin-bottom: 2em;
  width: auto;
}

.ivr_header a{
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  text-decoration: none;
}
.ivr_header a:link , .ivr_header a:hover , .ivr_header a:visited{
  color: #fff;
  text-decoration: none;
}
.ivr_header p{
  font-family: "游ゴシック","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo;
  font-size: 15px;
  font-weight: bold;
  color: white;
  margin: 0 .5em;
  }
.ivr_header img {
 vertical-align: middle;
}
a {
 color: #3b71ca;
 text-decoration: none;
}

@media screen and (min-width:1024px) {
body {
 overflow-x: clip!important;
}
.ivr_header {
 width: calc(100% + 20px);
}
}
/*Header Design ここまで*/

/*Footer Design*/
.button_footer_flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	margin-top:2em;
	margin-bottom: 2em;
}
.button_footer_flex > p{
width: calc(100% / 3);
position: relative;
}
.button_footer_flex > p:first-child:before{
    content: "";
    position: absolute;
    margin: auto;
    border-top: solid 3px #333;
    border-right: solid 3px #333;
    width: 6px;
    height: 6px;
    transform: rotateZ(225deg);
    top: -.1em;
    bottom: 0;
    left: -2.5em;
    right: 0;
}
.button_footer_flex > p:nth-child(2):before{
    content: "";
    position: absolute;
    margin: auto;
    border-top: solid 3px #333;
    border-right: solid 3px #333;
    width: 6px;
    height: 6px;
    transform: rotateZ(-45deg);
    top: .2em;
    bottom: 0;
    left: -2.5em;
    right: 0;
}
.button_footer_flex > p:nth-child(3):before{
    content: "≡";
    position: absolute;
    margin: auto;
    font-weight: bold;
    font-size: 20px;
    width: 6px;
    height: 6px;
    top: 0;
    bottom: 1.3em;
    left: -2.5em;
    right: 0;
}
.button_footer a{
 display: block;
 background-color: inherit;
 border: solid 2px #fff;
 color: #202020;
 font-weight: bold;
 margin: .5em 0;
 padding: .25em 1em;
 text-align: center;
 box-sizing: border-box;
 text-indent: 1em;
}
.button_footer a:link, .button_footer a:visited {
 text-decoration: none;
 color: #202020;
}
.button_footer a:hover {
 background-color: #fff;
 text-decoration: none;
 cursor: pointer;
 opacity: .5;
 border-color: #cecece;
 box-shadow: 0px 0px 2px #cecece;
}

.ivr_footer{
  text-align: center;
  border-top: solid 1px #cecece;
  padding: 1em;
  background-color: var(--footer-bg);
  margin-top: auto;
  width:100%;
}
.ivr_footer p{
  color: var(--footer-text);
  font-size: 12px;
}
.ivr_footer a{
  color: var(--footer-text);
  text-decoration: none;
}
.ivr_footer a:hover{
  color: var(--primary);
}
.ivr_footer a:visited{
  color: var(--footer-text);
}
.ivr_footer p.copy {
  padding: 10px;
  font-size: 12px;
  color: var(--footer-text);
  }
/*Footer Design ここまで*/

/*TOPページ*/
.flexbox_depth1 {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	margin-bottom: 2em;
}
.flexbox_depth1 > a:link, 
.flexbox_depth1 > a:hover, 
.flexbox_depth1 > a:visited {
	text-decoration: none;
	color: #202020;
}
.category_panel{
	width: calc((100% / 2) - .75em);
	min-height: 160px;
	margin: 0 .35em .75em;
	position: relative;
	border: solid 1px #cecece;
	border-radius: 5px;
	padding: 2.5em 1em;
	font-weight: bold;
	box-sizing: border-box;
	background: #fff;
	cursor: pointer;
	background-size: 134px;
	background-position: 5% 50%;
	background-repeat: no-repeat;
	box-shadow: 2px 2px 4px 0 #cecece;
	transition: 0.3s border-color;
}
.category_panel div{
	position: absolute;
	top: 50%;
	left: 42%;
	transform: translateY(-50%);
	-webkit- transform: translateY(-50%);
}
.category_panel p{
	position: relative;
	margin: .1em 0;
	text-shadow: -1px -1px 0px #ffffff, 1px 1px 0px #ffffff, -1px 1px 0px #ffffff, 1px -1px 0px #ffffff, -1px 0px #fff, 1px 0px #fff, 0px 1px #fff, 0px -1px #fff;
	transition: 0.3s color;
}
.category_panel:not(:last-child) div > p:before{
	content: "・";
	display: inline-block;
	position: absolute;
	margin: auto;
	top: 0;
	bottom: 0;
	left: -1.25em;
	transition: .1s;
	filter: drop-shadow(-2px -3px 0px #fff) drop-shadow(2px 2px 0px #fff) drop-shadow(-2px 0px 0px #fff);
}
.category_panel:hover{
	border-color: #004098;
}
.category_panel:hover div > p{
	color: #004098;
}

@media screen and (max-width:781px) { 
  .category_panel{
		width: 100%;
		margin: 0 0.1em 1em;
	}
}
@media screen and (max-width:501px) {
	.faqbox{
		padding: 1em .1em;
	}
	.category_panel div{
		left: 43%;
	}
	.category_panel{
		background-size: 116px;
		background-position: 4%;
	}
	.category_panel div > p:before{
		left: -1.25em;
	}
	.longlength{
    	font-size: 14px;
	}
	.category_panel div > p{
		font-size: 14px;
	}
	.sphide{
		display: none;
	}
	.br-sp{
		display: block;
	}
}
/*TOPページここまで*/

/*ナビダイヤルのご案内ページ　ここから*/
.ivr-area-body-header,
.ivr-area-body-footer {
  padding: 0;
}

.faqbox_navi{
	box-sizing: border-box;
	padding: 1em;
	background: #fff;
	margin-bottom: 1em;
}
.flexbox2.navidial > a,
.flexbox2.chat >a{
  display: flex;
  flex-direction: column;
  background: #fff;
  border: solid 1px #cecece;
  border-radius: 8px;
  padding: 1em;
  box-sizing: border-box;
  margin: 0 0 1em;
  position: relative;
	box-shadow: 2px 2px 4px 2px rgba(0,0,0,0.2);
}
.flexbox2.navidial > a:hover, .flexbox2.chat >a:hover{
	box-shadow: 2px 2px 8px 4px rgba(0,0,0,0.1);
}
.flexbox2.navidial > a{
	width: calc(100% / 3 - 0.5em);
}
.flexbox2.chat > a{
	width: calc(100% / 2 - 0.5em);
}
.flexbox2.navidial > a:link, 
.flexbox2.navidial > a:visited, 
.flexbox2.navidial > a:hover,
.flexbox2.chat > a:link, 
.flexbox2.chat > a:visited, 
.flexbox2.chat > a:hover {
	text-decoration: none;
	color: inherit;
}
.navi_title{
	display: flex;
	width: fit-content;
	margin: 1em 0;
	align-content: center;
}
.navi_title > p:first-child {
	margin: auto 1em auto 0.5em;
}
.navi_title > p{
	margin: 0;
}
.button_navidial .heightcontrol > p:first-child{
	margin: 0 0 0.5em;
}
.sec_title{
	position: relative;
	text-align: center;
	font-weight: bold;
	font-size: 22px;
	margin-bottom: 1em;
}
.sec_title:before{
	content: '';
 	position: absolute;
 	left: 50%;
 	bottom: -10px;/*線の上下位置*/
 	display: inline-block;
 	width: 120px;/*線の長さ*/
 	height: 5px;/*線の太さ*/
 	-webkit-transform: translateX(-50%);
 	transform: translateX(-50%);/*位置調整*/
 	background-color: #004098;/*線の色*/
 	border-radius: 2px;/*線の丸み*/
}
@media screen and (max-width:800px) {
	.flexbox2.navidial > a{
		width: calc((100% / 2) - .5em);
	}
}
@media screen and (max-width:500px) {
	.flexbox2.navidial > a,
  .flexbox2.chat > a{
		width: 100%;
	}
}
/*ナビダイヤルのご案内ページ　ここまで*/

/* 各製品カテゴリ用スタイル */
.faqbox {
  box-sizing: border-box;
	padding: 1em;
	background: #fff;
	margin-bottom: 2em;
}
.faqbox > p {
	margin-bottom: 2em;
}
.flexbox {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	margin-bottom: 2em;
}
.flexbox > div {
	display: flex;
	align-items: center;
	width: calc((100% / 3) - .5em);
	margin-right: .5em;
	margin-bottom: .5em;
	box-sizing: border-box;
}
.flexbox2{
 	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-bottom: 2em;
	padding: 1em 1em 2em;
}
.flexbox2 > div{
	display: flex;
	flex-direction: column;
	background: #fff;
	border: solid 1px #cecece;
	border-radius: 8px;
	padding: 1em;
	box-sizing: border-box;
	margin: 0 0 1em;
	width: calc(100% / 2 - 0.5em);
	position: relative;
}
.flexbox2 > div:last-child{
	width: 100%;
}
.flexbox2.otherpage > div{
	width: calc(100% / 2 - 0.5em);
}
.flexbox2.otherpage > div:nth-child(n+5){
	width: 100%;
}
.flexbox2.nwpage > div{
	width: calc(100% / 3 - 0.5em);
}
.flexbox2.nwpage > div:last-child{
	width: 100%;
}
.flexbox2 > div > p,
.heightcontrol > p{
	margin-bottom: 1em;
}
.heightcontrol > p:first-child {
	margin: 30px; /* LINEアイコンのアイソレーションエリア確保 */
}
.heightcontrol{
	flex-grow: 1;
	width: fit-content;
	margin: 0 auto;
}
.formarea{
	padding: 1em;
	margin-bottom: 1em;
}
.formarea > p{
	text-align: center;
	margin-bottom: 1em;
}
.button_link{
	margin-top: 2em;
}
.button_link a{
	display: block;
	background-color: #004098;
	border: solid 1px #004098;
	border-radius: 50px;
	color: #fff;
	font-weight: bold;
	margin: .5em auto;
	padding: .7em 1em;
	text-align: center;
	width: 85%;
	max-width: 420px;
	box-sizing: border-box;
	transition: 0.3s background-color;
}
.button_link a:link, .button_link a:visited {
	text-decoration: none;
	color: #fff;
}
.button_link a:hover {
	background-color: #fff;
	color: #004098;
	text-decoration: none;
	cursor: pointer;
}
.link-text a {
	display: block;
	line-height: normal;
	position: relative;
	padding-left: 1.2em;
	width: fit-content;
}
.link-text a:link, .link-text a:visited {
	color: #202020;
	text-decoration: none;
}
.link-text a:hover {
	color: #004098;
	text-decoration: underline #004098;
}
.link-text a:before {
	content: "";
	display: inline-block;
	position: absolute;
	border-top: 2px solid #004098;
	border-right: 2px solid #004098;
	box-sizing: border-box;
	top: .5em;
	left: 0;
	transform: rotateZ(45deg) translateY(-.1em);
	width: .5em;
	height: .5em;
}
.link-box {
background-color: #f3f3f3;
box-sizing: border-box;
border-radius: 5px;
margin: 20px auto;
padding: 20px;
width: 100%;
max-width: 500px;
}
#top3menu {
	position: fixed;
	top: 0;
	left: 0;
	bottom:	0;
	right: 0;
	background-color: rgba(0, 0, 0, 0.7);
	overflow: auto;
	display: none;
	animation: modalopen 0.7s ease;
	z-index: 99999;
}
.button-close {
	display: block;
	background-color: #004098;
	border: solid 1px #004098;
	border-radius: 100px;
	color: #fff;
	font-weight: bold;
	font-size: .9em;
	line-height: 120%;
	margin: 1.5em auto 0em;
	padding: .7em 4em;
	text-align: center;
	width: fit-content;
	transition: 0.3s background-color;
}
.button-close:hover {
	background-color: #fff;
	color: #333;
	text-decoration: none;
	cursor: pointer;
}
.faqscreen{
  position: absolute;
  inset: 0;
  box-sizing: border-box;
  display: none;
  width: 95%;
  max-width: 800px;
  margin: auto;
  border-radius: 5px;
  height: fit-content;
}
.menu_title{
	position: relative;
	min-height: 90px;
	border: solid 1px #cecece;
	border-radius: 5px;
	padding: 1.5em 1em;
	font-size: 1.2em;
	font-weight: bold;
	box-sizing: border-box;
	background: #fff;
	cursor: pointer;
	background-size: 200px;
	background-position: right;
	background-repeat: no-repeat;
	box-shadow: 2px 2px 4px 0 #cecece;
	transition: 0.3s border-color;
}
.menu_title > span {
	position: absolute;
	top: 50%;
	left: 1.5em;
	transform: translateY(-50%);
	-webkit- transform: translateY(-50%);
	text-shadow: -1px -1px 0px #ffffff, 1px 1px 0px #ffffff, -1px 1px 0px #ffffff, 1px -1px 0px #ffffff, -1px 0px #fff, 1px 0px #fff, 0px 1px #fff, 0px -1px #fff;
	transition: 0.3s color;
}
.menu_title:hover{
	border-color: #004098;
	color: #004098;
}
.menu_title_inner {
	border: solid 2px #004098;
	padding: .5em 1em;
	box-sizing: border-box;
	margin: 0 auto -2px;
	background: #004098;
	color: white;
	font-size: 20px;
	font-weight: bold;
	border-radius: 5px 5px 0 0;
}
.menubox{
	background: #fff;
	border: solid 2px #004098;
	padding: 1.5em 2em;
	box-sizing: border-box;
	border-radius: 0 0 5px 5px;
}
.tab {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	margin-top: 1em;
}
/* タブメニュー */
.tab__menu {
	display: flex;
	justify-content: flex-start;
	flex-flow: wrap;
	min-height: 50px; /* メニュー切替時にタブがズレないように */
	padding: 0;
	margin: 0;
	margin-bottom: 8px;
}
.tab__menu-item {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 15px;
	box-sizing: border-box;
	list-style: none;
	width: calc(100% / 3 - 4px);
	padding: 8px 5px; /* メニューに高さを付ける */
	text-align: center;
	margin-right: 4px;
	margin-bottom: 4px;
	background-color: #fff;
	border: solid 1px #004098;
	border-radius: 5px;
	font-weight: bold;
	cursor: pointer;
	transition: all .3s; /* アニメーション */
}
.tab__menu-item:nth-child(3n){
	width: calc(100% / 3);
	margin-right: 0px;
}
/* is-activeがついている時のスタイル */
.tab__menu-item.is-active {
	background-color: #004098;
	color: #ffffff;
	font-weight: bold;
}
/* タブパネル */
.tab__panel {
	width: 100%;
}
.tab__panel-box {
	min-height: calc(3em + 7em);
	padding: 1.5em 1em;
}
.tab__panel-box_style {
	background-color: #fff;
	border: solid 1px #cecece;
	border-radius: 8px;
	display: none;
	margin-top: -1px;
}
/* is-showがついている時のスタイル */
.tab__panel-box.is-show {
	display: block;
}

/*メールフォームモーダル用*/
#mailModal{
	position: fixed;
	top: 0;
	left: 0;
	bottom:	0;
	right: 0;
	background-color: rgba(0, 0, 0, 0.2);
	overflow: auto;
	display: none;
	animation: modalopen 0.3s ease;
	z-index: 999;
}
#mailInfo{
	position: relative;
	top: 30%;
	box-sizing: border-box;
	display: none;
	background-color: #fff;
	border: solid 1px #cecece;
	border-radius: 8px;
	padding: 1em;
	box-sizing: border-box;
	margin: 0 auto;
	max-width: 540px;
	width: 90%;
}
#js-mail-closeButton{
	cursor: pointer;
	position: absolute;
	font-weight: bold;
	font-size: 22px;
	width: fit-content;
	right: 1.5em;
}


/*電話窓口モーダル用*/
#telModal{
	position: fixed;
	top: 0;
	left: 0;
	bottom:	0;
	right: 0;
	background-color: rgba(0, 0, 0, 0.2);
	overflow: auto;
	display: none;
	animation: modalopen 0.3s ease;
	z-index: 999;
}
#telInfo{
	position: relative;
	top: 30%;
	box-sizing: border-box;
	display: none;
	background-color: #fff;
	border: solid 1px #cecece;
	border-radius: 8px;
	padding: 1em;
	box-sizing: border-box;
	margin: 0 auto;
	max-width: 540px;
	width: 90%;
}
#js-closeButton{
	cursor: pointer;
	position: absolute;
	font-weight: bold;
	font-size: 22px;
	width: fit-content;
	right: 1.5em;
}

/*NW製品終息モーダル用*/
#nwModal{
	position: fixed;
	top: 0;
	left: 0;
	bottom:	0;
	right: 0;
	background-color: rgba(0, 0, 0, 0.2);
	overflow: auto;
	display: none;
	animation: modalopen 0.3s ease;
	z-index: 999;
}
#nwInfo{
	position: relative;
	top: 30%;
	box-sizing: border-box;
	display: none;
	background-color: #fff;
	border: solid 1px #cecece;
	border-radius: 8px;
	padding: 1em;
	box-sizing: border-box;
	margin: 0 auto;
	max-width: 540px;
	width: 90%;
}
#js-nw-closeButton{
	cursor: pointer;
	position: absolute;
	font-weight: bold;
	font-size: 22px;
	width: fit-content;
	right: 1.5em;
}


/*NW障害情報*/
.infobox{
  display: block;
  background: #fff;
  border: solid 2px #004098;
  padding: 1.5em 2em;
  border-radius: 5px;
  width: 90%;
  box-sizing: border-box;
  text-align: center;
  margin: 0 auto;
}
.buttton_title{
	font-size: 20px;
  font-weight: bold;
  margin-bottom: 0.25em;
  color:#000;
}
.button_text{
  font-size: 15px;
}

.failureinfo{
  display: block;
  background: #fff;
  border: solid 2px #004098;
  padding: 1.5em 2em;
  border-radius: 5px;
  width: 90%;
  box-sizing: border-box;
  text-align: center;
  margin: 0 auto;
  color: darkred;
}

@keyframes modalopen {
  from {opacity: 0}
  to {opacity: 1}
}
@media screen and (max-width:800px) {
	.flexbox > div{
		width: calc((100% / 2) - .5em);
	}
	.flexbox2.nwpage > div,.flexbox2.nwpage > div:last-child{
	width: calc(100% / 2 - 0.5em);
  }
}
@media screen and (max-width:500px) {
  .br-pc{
  	display: none;
  }
  .br-sp{
  	display: block;
  }
  .flexbox > div, .flexbox2 > div, .flexbox2.otherpage > div {
    width: 100%;
  }
  .flexbox2.nwpage > div,.flexbox2.nwpage > div:last-child{
  	width: 100%;
  }
  .flexbox2 > div{
  	margin: 0 auto 1em;
  }
  .flexbox2 > div:last-child{
	  margin: 0 auto;
  }
  .menubox{
  	padding: 1.5em;
  }
  .tab__menu-item {
  	font-size: 13px;
  	line-height: 1.25em;
  	width: calc(100% / 2 - 4px);
  }
  .tab__menu-item:nth-child(3n){
  	width: calc(100% / 2 - 4px);
  	margin-right: 4px;
  }
  .tab__menu-item:nth-child(2n){
  	width: calc(100% / 2);
  	margin-right: 0px;
  }
  /*.faqscreen{
  	top: 15%;
  	margin: 0 auto 30em;
  }*/
}
@media screen and (max-width:376px) {
  .faqscreen{
  	top: 10%;
  }
  .button_link a{
  	font-size: 0.9em;
  }
}