@charset "utf-8";

/*==================================================

online_banner

==================================================*/ 
.online_banner{
  display: block;
  margin: 20px auto 0;
  max-width: 250px;
  width: 100%;
}
.online_banner img{
  width: 100%;
}

/*==================================================

body

==================================================*/ 
:root {
  --white: #fff;
  --black: #000;
  --gray01: #F7F7F7;
  --gray02: #575757;
  --gray03: #606060;
  --gray04: #d0d0d0;
  --gray05: #6a6a6a;
  --gray06: #c3c3c3;
  --gray07: #808080;
  --blue01: #56C1F1;
  --blue02: #F7FCFF;
  --blue03: #005AAB;
  --blue04: #D9E7F1;
  --green01: #398025;
  --orange01: #ff6200;
}
.gnav{
  margin-bottom: 30px;
}
.gnav ul{
  display: flex;
  width: 100%;
  border: 1px solid var(--gray04);
  background-color: rgba(255, 255, 255, 0.8);
  border-radius: 3px;
}
.gnav li{
  flex: 1;
}
.gnav li a{
  display: block;
  text-align: center;
  text-decoration: none;
  position: relative;
  padding: 10px 0;
}
.gnav li a:hover{
  background-color: rgba(86, 192, 241, 0.4);
}
.gnav li:not(:last-child) a::after{
  content: "";
  display: inline-block;
  background: var(--gray04);
  height: 60%;
  width: 1px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
}
.gnav li a span{
  display: block;
}
.gnav li a .ja{
  color: var(--gray03);
  font-size: 18px;
}
.gnav li a .en{
  font-family: 'futura';
  color: var(--blue01);
  font-size: 10px;
}
.toptxt{
  text-indent: unset;
  font-size: 26px;
  line-height:1.7;
  text-align: center;
  margin: 100px 0;
  color: #595959;
  letter-spacing: 0.025em;
}
.clo-power-desc{
  font-size: 14px;
  line-height: 1.7;
}
a.service1{
  background-image: url(../images/menu01.png);
  background-size: 100%;
}
a.service2{
  background-image: url(../images/menu02.png);
  background-size: 100%;
}
a.service3{
  background-image: url(../images/menu03.png);
  background-size: 100%;
}
.clo-power-txt{
  font-size: 25px;
  color: var(--blue03);
  text-indent: unset;
}
.tab1 a{
  background-image: url(../images/tab_products.png);
  background-size: 231px 102px;
}
p.products_copy{
  background: none;
  text-indent: unset;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 10px;
  color: var(--gray03);
}
#Products_Lineup{
  background: none !important;
  text-indent: unset;
  font-size: 18px;
  height: unset !important;
  letter-spacing: 0.025em;
  color: var(--gray03);
}
#Products_Lineup span{
  color: var(--blue03);
  font-family: 'futura';
  font-weight: normal;
  font-size: 25px;
  margin-left: 10px;
}
#box_select_b strong{
  background-image: none;
  color: var(--white);
  font-size: 13px;
  text-indent: unset;
}
ul#All-select{
  min-height: unset;
}
.contact-btn{
  width: 300px;
  margin: 0 auto !important;
}
.contact-btn a{
  display: block;
  text-align: center;
  padding: 10px 0;
  border: 1px solid var(--gray04);
  background-color: var(--white);
  border-radius: 3px;
  color: var(--gray03);
  text-decoration: none;
}
.contact-btn a span{
  padding-left: 20px;
  position: relative;
}
.contact-btn a span::before{
  font-family: 'Font Awesome 5 Pro';
  content: '\f0e0';
  font-size: 16px;
  font-weight: 300;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.case_images,
.img_right{
  border-radius: 3px;
}
ul#tab{
  height: 40px;
}
.partner-ttl{
  text-indent: unset;
  font-size: 25px;
  color: var(--blue03);
  padding-top: 15px;
  margin-bottom: 10px;
}
.partner-intro{
  font-size: 18px;
  margin-bottom: 10px;
}
.partner-list li:not(:last-child){
  margin-bottom: 25px;
}
.partner-subttl{
  text-indent: unset;
  margin-bottom: 5px;
}
.partner-subttl span{
  background-color: var(--blue03);
  color: var(--white);
  display: inline-block;
  width: 120px;
  text-align: center;
  padding: 2px 0;
  border-radius: 3px;
}
.faq dt{
  color: var(--blue03);
  font-size: 15px;
  border-bottom: 1px dashed var(--gray03);
  position: relative;
  cursor: pointer;
  padding: 10px 0;
}
.faq dd{
  display: none;
  padding: 10px 0;
}
.faq-arrow{
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background-color: var(--blue03);
  border-radius: 50%;
}
.faq-arrow::before,
.faq-arrow::after{
	content: '';
	display: block;
	width: 10px;
	height: 2px;
	background: var(--white);
	position: absolute;
	right: 5px;
	top: 9px;
  z-index: 2;
}
.faq-arrow::after{
	top: 10px;
}
.faq-arrow::after{
	transform: translateY(-50%) rotate(90deg);
	transition: 0.5s;
}
.faq-arrow__active span::after {
	transform: rotate( 180deg);
	transition: 0.5s;
	top: 9px;
}
h1#ttl_products{
  background-image: url(../images/ttl_products.png);
  background-size: 138px 48px;
}
h2.case_copy01{
  background-image: url(../images/copy01.jpg);
  background-size: 100%;
}
.contact{
  margin-top: 30px;
}
.contact_copy{
  background: unset;
  text-indent: unset;
  text-align: center;
  width: unset;
  height: unset;
  font-size: 22px;
  margin-top: 0;
}
.contact-bg{
  width: 720px;
  box-sizing: border-box;
  border: 1px solid #ddd;
  background: #fff;
  border-radius: 10px;
  padding: 20px 30px 25px;
  margin-bottom: 20px;
}

#contents_right > div:last-child{
  display: none;
}
ul.solution li strong.ttl_product2{
  background-image: url(../images/ttl_product2.jpg);
}

a.footer_logo{
  background: url(../images/logo.svg) no-repeat;
}