/* ----------------------------
reset
------------------------------- */
body,
h1,h2,h3,h4,h5,h6,p,
ul,ol,li,dl,dt,dd,
form,fieldset,legend,pre,blockquote {
	margin:0px;
	padding:0px;
}

ul,li {
	list-style:none;
}

img {
	margin:0px;
	padding:0px;
	border:0px;
	vertical-align:top;
}

html { font-size: 62.5%;} 

body {
	color: #424242;
	font-family: "Helvetica Neue",
    Arial,
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    Meiryo,
    sans-serif;
    font-size: 2.0rem;;
    line-height: 1.9;
	-webkit-text-size-adjust: 100%;
    background-color: #ffffff;
    text-align: left;
}

a,
a:link,
a:visited {
	color: #484848;
	text-decoration: none;
}

a:hover,
a:active {
	color: #333;
	text-decoration:none;
}

a img {
	margin:0;
	padding:0;
	border-style:none;
}

/**************************************************************
【配置設定】
**************************************************************/
.img_c{text-align:center; margin: 20px auto;}
.img_c img{width: 100%;}
.img_c2{text-align:center; margin: 20px auto;}
.img_c2 img{width: 70%;}
.img_c5{text-align:center; margin: 20px auto;}



/* バナー */
.banner{}
.banner img:hover{opacity:0.9; filter: alpha(opacity=90);}


/* 共通 */
#wrapper{
width: 100%;
margin: 0 auto;
}

.inner{
    width: 1150px;
	margin:0 auto;
}
.inner2{
    width: 900px;
	margin:0 auto;
}

.back_line{
background-image: url("../images/back_line2.png");
background-repeat: repeat-x;
background-size: auto 40%;
background-position: left bottom;
}

.banner_pc{display: block;}
.banner_sp{display: none;}

.pcbr {display:inline;}
.spbr {display:none;}

/* ヘッダー */
header{
width: 1100px;
margin: 0 auto;
padding: 10px 0 10px;
background-color: #ffffff;
clear: both;
}

#header_pc{
width:100%;
margin: 0 auto;
}

.header_inner{
width: 100%;
margin: 0 auto;
}

#header_pc h2{
text-align: center;
}

#header_pc img{
width: 100%;
vertical-align: top;
}

#header_pc{display: block;}
#header_sp{display: none;}


/* ////ch1//// */
.ch1{
padding: 70px 0 50px;
}

.ch1 h2 {
  position: relative;
  padding: 1rem 2rem calc(1rem + 10px);
  background: #deedff;
  text-align: center;
  width: 60%;
  margin: 0 auto 30px;
  color: #1a5fb1;
  line-height: 160%;
}

.ch1 h2:before {
  position: absolute;
  top: -10px;
  left: -10px;
  width: 100%;
  height: 100%;
  content: '';
  border: 3px solid #1a5fb1;
}

.cs{
background-color: #fff;
padding: 30px 40px;
margin: 30px 0 0px;
border: 1px solid #ccc;
}

.cs_left{
float: left;
width: 30%;
}
.cs_left img{
width: 100%;
}

.cs_right{
float: right;
width: 65%;
}

.ch1 h3{
font-size: 20px;
line-height: 160%;
margin: 0 0 5px;
}

.ch1 h4{
font-size: 18px;
line-height: 160%;
margin: 0 0 10px;
}

.ch1 p{
font-size: 0.9em;
line-height: 160%;
}

.price{
display: inline-flex;
border: 1px solid #1a5fb1;
padding: 2px 10px;
color: #1a5fb1;
}

/* ////ch2//// */
.ch2{
padding: 40px 0 60px;
background-color: #e5e5e5;
}

.ch2_wp{
width: 75%;
margin: 0 auto;
}

.ch2 h2 {
  position: relative;
  padding: 1.5rem 1rem;
  text-align: center;
  margin: 0 0 30px;
}

.ch2 h2:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 10px;
  content: '';
  background-image: -webkit-repeating-linear-gradient(135deg, #000, #000 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #000, #000 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.fukidashi1 {
  position: relative;
  margin-bottom: 1.5em;
  padding: 1.5rem 2rem;
  border-radius: 10px;
  background: #fff;
  line-height: 160%;
}

.fukidashi1:before,
.fukidashi1:after {
  position: absolute;
  content: '';
  border-radius: 50%;
  background: #fff;
}

.fukidashi1:before {
  bottom: -15px;
  left: 30px;
  width: 30px;
  height: 30px;
}

.fukidashi1:after {
  bottom: -30px;
  left: 50px;
  width: 15px;
  height: 15px;
}

.fukidashi2 {
 position: relative;
  margin-bottom: 1.5em;
  padding: 1.5rem 2rem;
  border-radius: 10px;
  background: #fff;
  line-height: 160%;
}

.fukidashi2:before,
.fukidashi2:after {
  position: absolute;
  content: '';
  border-radius: 50%;
  background: #fff;
}

.fukidashi2:before {
  right: 30px;
  bottom: -15px;
  width: 30px;
  height: 30px;
}

.fukidashi2:after {
  right: 50px;
  bottom: -30px;
  width: 15px;
  height: 15px;
}

.ch2_img{
width: 90%;
margin: 0 auto 20px;
}
.ch2_img img{
width: 100%;
}

.ch2 li{
background-image: url("../images/icon1.png");
background-repeat: no-repeat;
background-position: left 2px;
background-size: 26px auto;
font-size: 20px;
line-height: 30px;
padding: 0 0 10px 36px;
margin: 0 0 10px 0;
font-weight: bold;
border-bottom: 1px solid #cccccc;
}

/* ////ch3//// */
.ch3{
padding: 70px 0 80px;
}

.ch3 h2{
font-size: 38px;
margin: 0px auto 20px;
text-align: center;
}

.ch3 h3{
font-size: 30px;
line-height: 160%;
margin: 0px auto 0px;
padding: 5px 20px;
text-align: center;
background-color: #1a5fb1;
color: #ffffff;
}

.ch3_box{
background-color: #ffffff;
padding: 30px 40px;
margin: 20px 0 20px;
box-shadow: 0px 4px 8px 0px rgba(0,0,0,0.3);
}

.ch3 p{
font-size: 0.9em;
}

.no1{
background-image: url("../images/no1.png");
background-repeat: no-repeat;
background-position: left top;
background-size: 45px auto;
font-size: 26px;
line-height: 34px;
padding: 5px 0 8px 60px;
margin: 0px 0 15px 0;
}

.no2{
background-image: url("../images/no2.png");
background-repeat: no-repeat;
background-position: left top;
background-size: 45px auto;
font-size: 26px;
line-height: 34px;
padding: 5px 0 8px 60px;
margin: 0px 0 15px 0;
}

.no3{
background-image: url("../images/no3.png");
background-repeat: no-repeat;
background-position: left top;
background-size: 45px auto;
font-size: 26px;
line-height: 34px;
padding: 5px 0 8px 60px;
margin: 0px 0 15px 0;
}

.ch3_img{
float: right;
width: 45%;
margin: 0 0 5px 40px;
}
.ch3_img img{
width: 100%;
}

.crown{
background-image: url("../images/icon2.png");
background-repeat: no-repeat;
background-position: left 5px;
background-size: 30px auto;
font-size: 26px;
line-height: 34px;
padding: 0px 0 3px 40px;
margin: 0px 0 0px 0;
font-weight: bold;
}

.table {
      display: grid;
      grid-template-columns: 120px 1fr 1fr;
      border: 1px solid #ccc;
      margin: 40px 0 0;
    }

    .header {
      background-color: #f0f0f0;
      font-weight: bold;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 10px;
      border-bottom: 1px solid #ccc;
      border-right: 1px solid #ccc;
    }

    .label {
      background-color: #3fa3d1;
      color: white;
      font-weight: bold;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 10px;
      border-bottom: 1px solid #ccc;
    }

    .shinyou {
      background-color: #0054a6;
      color: white;
      font-weight: bold;
      padding: 10px;
      border-bottom: 1px solid #ccc;
      border-right: 1px solid #ccc;
      text-align: center;
    }

    .jisya {
      background-color: #999;
      color: white;
      font-weight: bold;
      padding: 10px;
      border-bottom: 1px solid #ccc;
      text-align: center;
    }

    .cell {
      padding: 10px;
      border-bottom: 1px solid #ccc;
      border-right: 1px solid #ccc;
    }
    
    .check{background-color: #FFEDED;font-weight: bold;}

    .check::before {
      content: "◎ ";
      color: #fb4461;
      font-weight: bold;
    }

    .cross::before {
      content: "✕ ";
      color: #0077cc;
    }
    
.ch3_img2{
width: 80%;
margin: 50px auto 0;
}
.ch3_img2 img{
width: 100%;
}

/* ////ch4//// */
.ch4{
padding: 70px 0 40px;
background-color: #e1eefe;
}

.ch4 h2 {
  font-size: 38px;
margin: 0 auto 45px;
text-align: center;
/* text-shadow */
text-shadow: 0px 2px 0px rgba(255,255,255,0.3), 0px 2px 0px rgba(255,255,255,0.9), 0px 4px 3px rgba(203,203,203,0.8);
}

.cs{
background-color: #fff;
padding: 30px 40px;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
margin: 0 0 30px;
}

.cs_img{
float: left;
width: 14%;
margin: 0 0px 20px 0;
}
.cs_img img{
width: 100%;
}

.cs h3{
font-size: 20px;
line-height: 160%;
}

.cs h4{
font-size: 18px;
font-weight: normal;
margin: 0 0 20px;
}

.cs p{
font-size: 18px;
}

.cs_wp_pc{
float: right;
width: 80%;
padding: 0 0 0 20px;
border-left: 1px dotted #ccc;
}

.cs_wp_pc{display: block;}
.cs_wp_sp{display: none;}

/* ////ch5//// */
.ch5{
padding: 70px 0 60px;
}

.ch5 h2 {
  position: relative;
  padding: 1rem 2rem calc(1rem + 10px);
  background: #deedff;
  text-align: center;
  width: 70%;
  margin: 0 auto 30px;
  color: #1a5fb1;
  line-height: 160%;
}

.ch5 h2:before {
  position: absolute;
  top: -10px;
  left: -10px;
  width: 100%;
  height: 100%;
  content: '';
  border: 3px solid #1a5fb1;
}

.flow_wp{
width: 60%;
margin: 0 auto 20px;
}

.ch5 h3{
background-color: #1a5fb1;
color: #f1ea2d;
text-align: center;
border-radius: 10px 10px 0px 0px;	
-webkit-border-top-left-radius: 10px;
-webkit-border-top-right-radius: 10px;
-webkit-border-bottom-right-radius: 0px;
-webkit-border-bottom-left-radius: 0px;
-moz-border-radius-topleft: 10px;
-moz-border-radius-topright: 10px;
-moz-border-radius-bottomright: 0px;
-moz-border-radius-bottomleft: 0px;

margin: 10px 0 0;
padding: 3px 0 0;
}

.flow_box{
margin: 0px auto 10px;
border: 3px solid #1a5fb1;
padding: 15px 20px 20px;
}

.flow_icon{
width: 15%;
margin: 0 auto;
}
.flow_icon img{
width: 100%;
}

.flow_text{
font-size: 0.9em;
line-height: 160%;
}

.container {
  display: flex;
  justify-content: center;
}

.arrow-down {
  width: 0;
  height: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  border-top: 20px solid #1a5fb1;
}

/* ////ch6//// */
.ch6{
padding: 60px 0 60px;
background-color: #1a5fb1;
}

.ch6_box{
width: 700px;
margin: 0 auto;
padding: 50px 70px;
background-color: #ffffff;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
}

.ch6 h2 img{
width: 100%;
}

/* CTA */
.cta{
padding: 50px 0 50px;
background-color: #EDEDED;
}

.cta_box{
margin: 0 auto;
padding: 50px 70px;
background-color: #ffffff;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
}

.cta h2{
width: 85%;
margin: 0 auto 10px;
text-align: center;
}
.cta h2 img{
width: 100%;
}

.cta h3{
text-align: center;
font-size: 24px;
margin: 0 0 20px;
}

.cta_img{
float: right;
width: 30%;
margin: 0 0 10px 40px;
}
.cta_img img{
width: 100%;
}

.image-container {
      display: flex;
      justify-content:space-between;
      margin: 30px 0;
    }

.item{
      width: 49%;
    }
.item img{
width: 100%;
}

.cta1{
text-align: center;
font-weight: bold;
line-height: 160%;
}

.cta2{
line-height: 160%;
}

.tel{width: 45%; margin: 0 auto 30px;}
.tel img{width: 100%;}

.gentei{width: 75%; margin: 20px auto 20px;}
.gentei img{width: 100%;}

/* ////CORP//// */
.corp{
padding: 30px 0 60px;
text-align: center;
}

.company-info {
      width: 60%;
      border-collapse: collapse;
      margin: 30px auto;
      font-family: "Helvetica Neue", sans-serif;
      box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    }

    .company-info th,
    .company-info td {
      padding: 12px 16px;
      border: 1px solid #ddd;
      text-align: left;
    }

    .company-info th {
      background-color: #f5f5f5;
      width: 30%;
      font-weight: bold;
    }

    .company-info tr:nth-child(even) td {
      background-color: #fafafa;
    }

    .company-info caption {
      caption-side: top;
      font-size: 1.4em;
      margin-bottom: 10px;
      font-weight: bold;
    }
    
.corp_text{
font-size: 0.9em;
line-height: 160%;
}

/* ////END//// */
.end{
padding: 60px 0 60px;
text-align: center;
background-image: url("../images/end_back.jpg");
background-repeat: no-repeat;
background-position: center top;
background-size: 100% 100%;
}

.end_box{
margin: 0 auto;
background-color: #ffffff;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;

padding: 40px 0;
}

.end_wp{
width: 90%;
margin: 0 auto;
}

.end h2 {
  position: relative;
  padding: 1rem 2rem calc(1rem + 10px);
  background: #deedff;
  text-align: center;
  width: 60%;
  margin: 0 auto 30px;
  color: #1a5fb1;
  line-height: 160%;
}

.end h2:before {
  position: absolute;
  top: -10px;
  left: -10px;
  width: 100%;
  height: 100%;
  content: '';
  border: 3px solid #1a5fb1;
}

.end_img{
width: 100%;
margin: 30px 0;
}
.end_img img{
width: 100%;
}

.end p{
font-size: 0.9em;
}


/************
フロートボタンPC
*************/
.floating {
  position: fixed;
  bottom: 0px;
width: 100%;
  display: none;
  padding: 10px 0 10px;
  background-color: rgba(0,0,0,0.6);
}

.fl_pc {
    display: block;
    margin-left: auto;
}

.fl_sp {
    display: none;
    margin-left: auto;
}

 .button-container {
      display: flex;
      gap: 20px; /* ボタンの間隔 */
      justify-content: center; /* 中央寄せ */
      margin: 0;
}

.contact-button1 {
      padding: 10px 50px;
      background-color: #22bc5e;
      color: white;
      border: none;
      border-radius: 6px;
      font-size: 16px;
      cursor: pointer;
      transition: background-color 0.3s;
      text-decoration: none;
}
.contact-button2 {
      padding: 10px 50px;
      background-color: #f6aa08;
      color: white;
      border: none;
      border-radius: 6px;
      font-size: 16px;
      cursor: pointer;
      transition: background-color 0.3s;
      text-decoration: none;
}

.contact-button1:hover {
      background-color: #5fc788;
}
.contact-button2:hover {
      background-color: #efbc50;
}

.button-container a,
.button-container a:link,
.button-container a:visited {
	color: #ffffff;
	text-decoration: none;
}

.button-container a:hover,
.button-container a:active {
	color: #ffffff;
	text-decoration:none;
}


/* footer */
footer{
    background-color: #fff;
	padding:30px 0px 30px;
	width:100%;
}

.footer_inner{
width: 980px;
margin: 0 auto;
}

.copy{
text-align: center;
font-size: 1.4rem;
margin: 0px 0 0;
padding: 10px 0;
}

footer a,
footer a:link,
footer a:visited {
font-size: 1.2rem;
	color: #888;
	text-decoration: underline;
}

footer a:hover,
footer a:active {
	color: #888;
	text-decoration:none;
}


/*ここからタブレット用（600px～1054px）環境の設定
---------------------------------------------------------------------------*/
@media (min-width:600px) and (max-width:1054px){
body { font-size: 1.6rem;
	line-height: 1.7;
background-image:none;}

/* イメージ */
.img_c img{width:100%;}
.img_c2 img{width:90%; margin: 20px auto;}
.img_c5 img{width:80%; margin: 20px auto;}

/* 共通 */
#wrapper{
width: 100%;
margin: 0 auto;
background-color: #ffffff;
}

.inner{
	width:92%;
	margin:0 auto;
}

.inner2{
	width:92%;
	margin:0 auto;
}

.banner_pc{display: block;}
.banner_sp{display: none;}

.pcbr {display:inline;}
.spbr {display:none;}

/* ヘッダー */
header{
width: 92%;
margin: 0 auto;
padding: 5px 0 2px;
background-color: #ffffff;
clear: both;
}

#header_sp{
width:100%;
margin: 0 auto;
background-image: none;
background-repeat: no-repeat;
background-position: center top;
}

#header_sp h2{
text-align: center;
}
#header_sp h2 img{width: 100%;}


#header_pc{display: none;}
#header_sp{display: block;}

/* ////ch1//// */
.ch1{
padding: 40px 0 40px;
}

.ch1 h2 {
  position: relative;
  padding: 0.5rem 1rem calc(1rem + 10px);
  background: #deedff;
  text-align: center;
  width: 70%;
  margin: 0 auto;
  color: #1a5fb1;
  line-height: 120%;
}

.ch1 h2:before {
  position: absolute;
  top: -10px;
  left: -10px;
  width: 100%;
  height: 100%;
  content: '';
  border: 2px solid #1a5fb1;
}

.wrap{
width: 96%;
margin: 0 auto;
}

.cs{
background-color: #fff;
padding: 30px 30px;
margin: 20px auto 0px;
border: 1px solid #ccc;
width: 88%;
}

.cs_left{
float: none;
width: 30%;
margin: 0 auto 10px;;
}
.cs_left img{
width: 100%;
}

.cs_right{
float: none;
width: 100%;
}

.ch1 h3{
font-size: 18px;
line-height: 160%;
margin: 0 0 0px;
}

.ch1 h4{
font-size: 16px;
line-height: 160%;
margin: 0 0 5px;
}

.ch1 p{
font-size: 0.9em;
line-height: 160%;
}

.price{
display: inline-flex;
border: 1px solid #1a5fb1;
padding: 2px 10px;
color: #1a5fb1;
}

/* ////ch2//// */
.ch2{
padding: 30px 0 40px;
background-color: #e5e5e5;
}

.ch2_wp{
width: 90%;
margin: 0 auto;
}

.ch2 h2 {
  font-size: 32px;
margin: 0 auto 30px;
text-align: center;
/* text-shadow */
text-shadow: 0px 2px 0px rgba(255,255,255,0.3), 0px 2px 0px rgba(255,255,255,0.9), 0px 4px 3px rgba(203,203,203,0.8);
}

.ch2 h2:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 10px;
  content: '';
  background-image: -webkit-repeating-linear-gradient(135deg, #000, #000 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #000, #000 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.fukidashi1 {
  position: relative;
  margin-bottom: 2em;
  padding: 1.0rem 1.5rem;
  border-radius: 10px;
  background: #fff;
  line-height: 160%;
}

.fukidashi1:before,
.fukidashi1:after {
  position: absolute;
  content: '';
  border-radius: 50%;
  background: #fff;
}

.fukidashi1:before {
  bottom: -15px;
  left: 30px;
  width: 30px;
  height: 30px;
}

.fukidashi1:after {
  bottom: -30px;
  left: 50px;
  width: 15px;
  height: 15px;
}

.fukidashi2 {
 position: relative;
  margin-bottom: 2em;
  padding: 1.0rem 1.5rem;
  border-radius: 10px;
  background: #fff;
  line-height: 160%;
}

.fukidashi2:before,
.fukidashi2:after {
  position: absolute;
  content: '';
  border-radius: 50%;
  background: #fff;
}

.fukidashi2:before {
  right: 30px;
  bottom: -15px;
  width: 30px;
  height: 30px;
}

.fukidashi2:after {
  right: 50px;
  bottom: -30px;
  width: 15px;
  height: 15px;
}

.ch2_img{
width: 100%;
margin: 0 auto 20px;
}
.ch2_img img{
width: 100%;
}

.ch2 li{
background-image: url("../images/icon1.png");
background-repeat: no-repeat;
background-position: left 3px;
background-size: 20px auto;
font-size: 18px;
line-height: 26px;
padding: 0 0 10px 28px;
margin: 0 0 10px 0;
border-bottom: 1px solid #cccccc;
}

/* ////ch3//// */
.ch3{
padding: 40px 0 40px;
}

.ch3 h2{
font-size: 28px;
margin: 0px auto 20px;
text-align: center;
}

.ch3 h3{
font-size: 22px;
line-height: 160%;
margin: 0px auto 0px;
padding: 5px 20px;
text-align: center;
background-color: #1a5fb1;
color: #ffffff;
}

.ch3_box{
background-color: #ffffff;
padding: 20px 20px;
margin: 20px 0 20px;
box-shadow: 0px 4px 8px 0px rgba(0,0,0,0.3);
}

.ch3 p{
font-size: 0.9em;
}

.no1{
background-image: url("../images/no1.png");
background-repeat: no-repeat;
background-position: left top;
background-size: 30px auto;
font-size: 18px;
line-height: 24px;
padding: 2px 0 5px 42px;
margin: 0px 0 8px 0;
}

.no2{
background-image: url("../images/no2.png");
background-repeat: no-repeat;
background-position: left top;
background-size: 30px auto;
font-size: 18px;
line-height: 24px;
padding: 2px 0 5px 42px;
margin: 0px 0 8px 0;
}

.no3{
background-image: url("../images/no3.png");
background-repeat: no-repeat;
background-position: left top;
background-size: 30px auto;
font-size: 18px;
line-height: 24px;
padding: 2px 0 5px 42px;
margin: 0px 0 8px 0;
}

.ch3_img{
float: right;
width: 35%;
margin: 5px 0 10px 30px;
}
.ch3_img img{
width: 100%;
}

.crown{
background-image: url("../images/icon2.png");
background-repeat: no-repeat;
background-position: left 5px;
background-size: 20px auto;
font-size: 16px;
line-height: 24px;
padding: 0px 0 3px 25px;
margin: 0px 0 0px 0;
font-weight: bold;
}

.item{
margin: 0 0px 0 10px;
text-align: center;
}
.item img{
margin: 0 auto;
text-align: center;
width: 100%;
}

.wrap{
width: 100%;
margin: 0 auto;
}

/* ////ch4//// */
.ch4{
padding: 30px 0 30px;
background-color: #e1eefe;
}

.ch4 h2 {
font-size: 32px;
margin: 0 auto 30px;
text-align: center;
/* text-shadow */
text-shadow: 0px 2px 0px rgba(255,255,255,0.3), 0px 2px 0px rgba(255,255,255,0.9), 0px 4px 3px rgba(203,203,203,0.8);
}

.cs{
background-color: #fff;
padding: 30px 30px;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
margin: 0 0 20px;
}

.cs_img{
float: left;
width: 15%;
margin: 0 auto 0;
}
.cs_img img{
width: 100%;
}

.cs h3{
font-size: 20px;
line-height: 160%;
}

.cs h4{
font-size: 18px;
font-weight: normal;
margin: 0 0 20px;
}

.cs p{
font-size: 18px;
}

.cs_wp_pc{
float: right;
width: 78%;
padding: 0 0 0 20px;
border-left: 1px dotted #ccc;
}

.cs_wp_pc{display: block;}
.cs_wp_sp{display: none;}

/* ////ch6//// */
.ch6{
padding: 30px 0 30px;
background-color: #1a5fb1;
}

.ch6_box{
width: 70%;
margin: 0 auto;
padding: 30px 40px;
background-color: #ffffff;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
}

.ch6 h2 img{
width: 100%;
}

/* CTA */
.cta{
padding: 40px 0 40px;
background-color: #EDEDED;
}

.cta_box{
margin: 0 auto;
padding: 30px 30px;
background-color: #ffffff;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
}

.cta h2{
width: 85%;
margin: 0 auto 5px;
text-align: center;
}
.cta h2 img{
width: 100%;
}

.cta h3{
text-align: center;
font-size: 22px;
margin: 0 0 10px;
line-height: 160%;
}

.cta_img{
float: right;
width: 30%;
margin: 0 0 10px 15px;
}
.cta_img img{
width: 100%;
}

.image-container {
      display: flex;
      justify-content:space-between;
      margin: 20px 0;
    }

.item{
      width: 49%;
    }
.item img{
width: 100%;
}

.cta1{
text-align: center;
font-weight: bold;
line-height: 160%;
}

.cta2{
line-height: 160%;
}

.tel{width: 50%; margin: 0 auto 20px}
.tel img{width: 100%;}

.gentei{width: 75%; margin: 20px auto 20px;}
.gentei img{width: 100%;}

/* ////CORP//// */
.corp{
padding: 30px 0 30px;
text-align: center;
}

.company-info {
      width: 80%;
      border-collapse: collapse;
      margin: 30px auto;
      font-family: "Helvetica Neue", sans-serif;
      box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    }

    .company-info th,
    .company-info td {
      padding: 12px 16px;
      border: 1px solid #ddd;
      text-align: left;
    }

    .company-info th {
      background-color: #f5f5f5;
      width: 30%;
      font-weight: bold;
    }

    .company-info tr:nth-child(even) td {
      background-color: #fafafa;
    }

    .company-info caption {
      caption-side: top;
      font-size: 1.4em;
      margin-bottom: 10px;
      font-weight: bold;
    }
    
.corp_text{
font-size: 1em;
line-height: 160%;
}

/* ////END//// */
.end{
padding: 40px 0 40px;
text-align: center;
background-image: url("../images/end_back.jpg");
background-repeat: no-repeat;
background-position: center top;
background-size: 100% 100%;
}

.end_box{
margin: 0 auto;
background-color: #ffffff;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;

padding: 40px 0 30px;
}

.end_wp{
width: 90%;
margin: 0 auto;
}

.ch1 h2 {
  position: relative;
  padding: 0.5rem 1rem calc(1rem + 10px);
  background: #deedff;
  text-align: center;
  width: 70%;
  margin: 0 auto 30px;
  color: #1a5fb1;
  line-height: 120%;
}

.ch1 h2:before {
  position: absolute;
  top: -10px;
  left: -10px;
  width: 100%;
  height: 100%;
  content: '';
  border: 2px solid #1a5fb1;
}
.end_img{
width: 100%;
margin: 30px 0;
}
.end_img img{
width: 100%;
}

.end p{
font-size: 1em;
}

/************
フロートボタンPC
*************/
.floating {
  position: fixed;
  bottom: 0px;
  width: 100%;
  display: none;
  padding: 10px 0 10px;
}

.fl_pc{

}
.fl_pc img{
width: 100%;
}

.fl_pc {
    display: block;
    margin-left: auto;
}

.fl_sp {
    display: none;
    margin-left: auto;
}


/* footer */
footer{
    background-color: #fff;
	padding:20px 0px 20px;
	width:100%;
}

.footer_inner{
width: 100%;
margin: 0 auto;
}

.copy{
text-align: center;
font-size: 1.4rem;
margin: 0px 0 0;
padding: 10px 0;
}

footer a,
footer a:link,
footer a:visited {
font-size: 1.2rem;
	color: #888;
	text-decoration: underline;
}

footer a:hover,
footer a:active {
	color: #888;
	text-decoration:none;
}
}

/*ここからスマートフォン用（599px以下）環境の設定
---------------------------------------------------------------------------*/
@media only screen and (max-width:599px){
body { font-size: 1.4rem; 
background-image:none;
line-height:1.7;
margin: 0 auto 0;}

/* イメージ */
.img_c img{width:100%;}
.img_c2 img{width:100%; margin: 20px auto;}
.img_c5 img{width:100%; margin: 20px auto;}

/* バナー */
.banner{}
.banner img:hover{opacity:1.0; filter: alpha(opacity=100);}

/* 共通 */
#wrapper{
width: 100%;
margin: 0 auto;
background-color: #ffffff;
}

.inner{
	width:92%;
	margin:0 auto;
}

.inner2{
	width:92%;
	margin:0 auto;
}

.banner_pc{display: none;}
.banner_sp{display: block;}

.pcbr {display:none;}
.spbr {display:inline;}

/* ヘッダー */
header{
width: 92%;
margin: 0 auto;
padding: 5px 0 2px;
background-color: #ffffff;
clear: both;
}

#header_sp{
width:100%;
margin: 0 auto;
background-image: none;
background-repeat: no-repeat;
background-position: center top;
}

#header_sp h2{
text-align: center;
}
#header_sp h2 img{width: 100%;}


#header_pc{display: none;}
#header_sp{display: block;}

/* ////ch1//// */
.ch1{
padding: 30px 0 30px;
}

.ch1 h2 {
  position: relative;
  padding: 0.5rem 1rem calc(1rem + 10px);
  background: #deedff;
  text-align: center;
  width: 70%;
  margin: 0 auto 20px;
  color: #1a5fb1;
  line-height: 120%;
}

.ch1 h2:before {
  position: absolute;
  top: -10px;
  left: -10px;
  width: 100%;
  height: 100%;
  content: '';
  border: 2px solid #1a5fb1;
}

.wrap{
width: 90%;
margin: 0 auto;
}
.cs{
background-color: #fff;
padding: 20px 20px;
margin: 20px auto 0px;
border: 1px solid #ccc;
width: 86%;
}

.cs_left{
float: none;
width: 50%;
margin: 0 auto 10px;;
}
.cs_left img{
width: 100%;
}

.cs_right{
float: none;
width: 100%;
}

.ch1 h3{
font-size: 16px;
line-height: 160%;
margin: 0 0 0px;
}

.ch1 h4{
font-size: 16px;
line-height: 160%;
margin: 0 0 5px;
}

.ch1 p{
font-size: 1em;
line-height: 160%;
}

.price{
display: inline-flex;
border: 1px solid #1a5fb1;
padding: 2px 10px;
color: #1a5fb1;
font-weight: bold;
}

/* ////ch2//// */
.ch2{
padding: 20px 0 30px;
background-color: #e5e5e5;
}

.ch2_wp{
width: 100%;
margin: 0 auto;
}

.ch2 h2 {
  position: relative;
  padding: 1.5rem 0rem;
  text-align: center;
  margin: 0 0 20px;
  line-height: 160%;
  font-size: 20px;
}

.ch2 h2:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 10px;
  content: '';
  background-image: -webkit-repeating-linear-gradient(135deg, #000, #000 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #000, #000 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.fukidashi1 {
  position: relative;
  margin-bottom: 2em;
  padding: 1.0rem 1.5rem;
  border-radius: 10px;
  background: #fff;
  line-height: 160%;
}

.fukidashi1:before,
.fukidashi1:after {
  position: absolute;
  content: '';
  border-radius: 50%;
  background: #fff;
}

.fukidashi1:before {
  bottom: -15px;
  left: 30px;
  width: 30px;
  height: 30px;
}

.fukidashi1:after {
  bottom: -30px;
  left: 50px;
  width: 15px;
  height: 15px;
}

.fukidashi2 {
 position: relative;
  margin-bottom: 2em;
  padding: 1.0rem 1.5rem;
  border-radius: 10px;
  background: #fff;
  line-height: 160%;
}

.fukidashi2:before,
.fukidashi2:after {
  position: absolute;
  content: '';
  border-radius: 50%;
  background: #fff;
}

.fukidashi2:before {
  right: 30px;
  bottom: -15px;
  width: 30px;
  height: 30px;
}

.fukidashi2:after {
  right: 50px;
  bottom: -30px;
  width: 15px;
  height: 15px;
}

.ch2_img{
width: 100%;
margin: 0 auto 20px;
}
.ch2_img img{
width: 100%;
}

.ch2 li{
background-image: url("../images/icon1.png");
background-repeat: no-repeat;
background-position: left 3px;
background-size: 16px auto;
font-size: 15px;
line-height: 23px;
padding: 0 0 5px 22px;
margin: 0 0 5px 0;
border-bottom: 1px solid #cccccc;
}

/* ////ch3//// */
.ch3{
padding: 30px 0 30px;
}

.ch3 h2{
font-size: 22px;
line-height: 160%;
margin: 0px auto 20px;
text-align: center;
}

.ch3 h3{
font-size: 19px;
line-height: 150%;
margin: 0px auto 0px;
padding: 5px 10px;
text-align: center;
background-color: #1a5fb1;
color: #ffffff;
}

.ch3 p{
font-size: 1em;
}

.ch3_box{
background-color: #ffffff;
padding: 15px 15px;
margin: 20px 0 20px;
box-shadow: 0px 4px 8px 0px rgba(0,0,0,0.3);
}

.no1{
background-image: url("../images/no1.png");
background-repeat: no-repeat;
background-position: left top;
background-size: 26px auto;
font-size: 18px;
line-height: 24px;
padding: 2px 0 0px 36px;
margin: 0px 0 8px 0;
}

.no2{
background-image: url("../images/no2.png");
background-repeat: no-repeat;
background-position: left top;
background-size: 26px auto;
font-size: 18px;
line-height: 24px;
padding: 2px 0 5px 36px;
margin: 0px 0 8px 0;
}

.no3{
background-image: url("../images/no3.png");
background-repeat: no-repeat;
background-position: left top;
background-size: 26px auto;
font-size: 18px;
line-height: 24px;
padding: 2px 0 5px 36px;
margin: 0px 0 8px 0;
}

.ch3_img{
float: none;
width: 65%;
margin: 20px auto 15px;
}
.ch3_img img{
width: 100%;
}

.crown{
background-image: url("../images/icon2.png");
background-repeat: no-repeat;
background-position: left 5px;
background-size: 15px auto;
font-size: 14px;
line-height: 22px;
padding: 0px 0 3px 20px;
margin: 0px 0 0px 0;
font-weight: bold;
}

.ch3_img2{
width: 95%;
margin: 30px auto 0;
}
.ch3_img2 img{
width: 100%;
}

/* ////ch4//// */
.ch4{
padding: 30px 0 30px;
background-color: #e1eefe;
}

.ch4 h2 {
  font-size: 22px;
margin: 0 auto 20px;
text-align: center;
/* text-shadow */
text-shadow: 0px 2px 0px rgba(255,255,255,0.3), 0px 2px 0px rgba(255,255,255,0.9), 0px 4px 3px rgba(203,203,203,0.8);
}

.cs{
background-color: #fff;
padding: 20px 20px;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
margin: 0 0 20px;
font-weight: bold;
}

.cs_img{
float: left;
width: 24%;
margin: 0 12px 15px 0;
}
.cs_img img{
width: 100%;
}

.cs h3{
font-size: 15px;
line-height: 160%;
}

.cs h4{
font-size: 14px;
font-weight: normal;
margin: 0 0 20px;
}

.cs p{
width: 100%;
clear: both;
font-size: 14px;
}

.cs_wp_pc{
float: none;
}

.cs_wp_pc{display: none;}
.cs_wp_sp{display: block;}

/* ////ch5//// */
.ch5{
padding: 30px 0 20px;
}

.ch5 h2 {
  position: relative;
  padding: 0.5rem 1rem calc(1rem + 10px);
  background: #deedff;
  text-align: center;
  width: 90%;
  margin: 0 auto 10px;
  color: #1a5fb1;
  line-height: 120%;
}

.ch5 h2:before {
  position: absolute;
  top: -10px;
  left: -10px;
  width: 100%;
  height: 100%;
  content: '';
  border: 2px solid #1a5fb1;
}

.flow_wp{
width: 84%;
margin: 0 auto 20px;
}

.ch5 h3{
background-color: #1a5fb1;
color: #f1ea2d;
text-align: center;
border-radius: 10px 10px 0px 0px;	
-webkit-border-top-left-radius: 10px;
-webkit-border-top-right-radius: 10px;
-webkit-border-bottom-right-radius: 0px;
-webkit-border-bottom-left-radius: 0px;
-moz-border-radius-topleft: 10px;
-moz-border-radius-topright: 10px;
-moz-border-radius-bottomright: 0px;
-moz-border-radius-bottomleft: 0px;

margin: 10px 0 0px;
padding: 3px 0 0;
}

.flow_box{
margin: 0px auto 10px;
border: 3px solid #1a5fb1;
padding: 10px 15px 10px;
line-height: 160%;
}

.flow_icon{
width: 15%;
margin: 0 auto 5px;
}
.flow_icon img{
width: 100%;
}

.flow_text{
font-size: 0.9em;
line-height: 160%;
}

.container {
  display: flex;
  justify-content: center;
}

.arrow-down {
  width: 0;
  height: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  border-top: 20px solid #1a5fb1;
}

/* ////ch6//// */
.ch6{
padding: 20px 0 20px;
background-color: #1a5fb1;
}

.ch6_box{
width: 80%;
margin: 0 auto;
padding: 20px 20px;
background-color: #ffffff;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
}

.ch6 h2 img{
width: 100%;
}

/* CTA */
.cta{
padding: 30px 0 30px;
background-color: #EDEDED;
}

.cta_box{
margin: 0 auto;
padding: 20px 15px;
background-color: #ffffff;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
}

.cta h2{
width: 95%;
margin: 0 auto 10px;
text-align: center;
}
.cta h2 img{
width: 100%;
}

.cta h3{
text-align: center;
font-size: 16px;
margin: 0 0 10px;
line-height: 160%;
}

.cta_img{
float: right;
width: 30%;
margin: 0 0 10px 15px;
}
.cta_img img{
width: 100%;
}

.image-container {
      display: block;
      justify-content:space-between;
      margin: 15px 0;
    }

.item{
      width: 85%;
      margin: 0 auto 10px;
    }
.item img{
width: 100%;
}

.cta1{
text-align: center;
font-weight: bold;
line-height: 160%;
}

.cta2{
line-height: 160%;
}

.tel{width: 85%; margin: 0 auto 20px}
.tel img{width: 100%;}

.gentei{width: 97%; margin: 20px auto 15px;}
.gentei img{width: 100%;}

/* ////CORP//// */
.corp{
padding: 30px 0 30px;
text-align: center;
}

.company-info {
      width: 90%;
      border-collapse: collapse;
      margin: 30px auto;
      font-family: "Helvetica Neue", sans-serif;
      box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    }

    .company-info th,
    .company-info td {
      padding: 12px 16px;
      border: 1px solid #ddd;
      text-align: left;
    }

    .company-info th {
      background-color: #f5f5f5;
      width: 30%;
      font-weight: bold;
    }

    .company-info tr:nth-child(even) td {
      background-color: #fafafa;
    }

    .company-info caption {
      caption-side: top;
      font-size: 1.4em;
      margin-bottom: 10px;
      font-weight: bold;
    }
    
.corp_text{
font-size: 1em;
line-height: 160%;
}

/* ////END//// */
.end{
padding: 30px 0 30px;
text-align: center;
background-image: url("../images/end_back.jpg");
background-repeat: no-repeat;
background-position: center top;
background-size: 100% 100%;
}

.end_box{
margin: 0 auto;
background-color: #ffffff;
border-radius: 10px;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;

padding: 40px 0 20px;
}

.end_wp{
width: 90%;
margin: 0 auto;
}

.end h2 {
  position: relative;
  padding: 0.5rem 1rem calc(1rem + 10px);
  background: #deedff;
  text-align: center;
  width: 86%;
  margin: 0 auto 20px;
  color: #1a5fb1;
  line-height: 120%;
}

.end h2:before {
  position: absolute;
  top: -10px;
  left: -10px;
  width: 100%;
  height: 100%;
  content: '';
  border: 2px solid #1a5fb1;
}


.end_img{
width: 100%;
margin: 30px 0;
}
.end_img img{
width: 100%;
}

.end p{
font-size: 1em;
font-weight: bold;
}

/************
フロートボタンSP
*************/
.floating {
  position: fixed;
  bottom: 0px;
  left: 0;
  right: 0;
  display: none;
  padding: 10px 0 10px;
  text-align: center;
  margin: 0 auto;
  width: 100%;
  background-color: rgba(0,0,0,0.6);
}


.fl_pc {
  display: none;
  margin-left: auto;
}

.fl_sp{
display: flex;
justify-content: space-between;
padding: 0 20px;
}

.cta_sp{
width: 30%;
}

.cta_sp img{
width: 100%;
}


/* footer */
footer{
    background-color: #fff;
	padding:10px 0px 10px;
	width:100%;
}

.footer_inner{
width: 100%;
margin: 0 auto;
}

.copy{
text-align: center;
font-size: 1.2rem;
margin: 0px 0 0;
padding: 10px 0;
}

footer a,
footer a:link,
footer a:visited {
font-size: 1.1rem;
	color: #888;
	text-decoration: underline;
}

footer a:hover,
footer a:active {
	color: #888;
	text-decoration:none;
}

}


/*************************************************************
【marginの設定】
*************************************************************/
.m0{margin:0 !important}
.mt0{margin-top:0 !important}
.mr0{margin-right:0 !important}
.mb0{margin-bottom:0 !important}
.ml0{margin-left:0 !important}

.m5{margin:5px !important}
.mt5{margin-top:5px !important}
.mr5{margin-right:5px !important}
.mb5{margin-bottom:5px !important}
.ml5{margin-left:5px !important}

.m10{margin:10px !important}
.mt10{margin-top:10px !important}
.mr10{margin-right:10px !important}
.mb10{margin-bottom:10px !important}
.ml10{margin-left:10px !important}

.m15{margin:15px !important}
.mt15{margin-top:15px !important}
.mr15{margin-right:15px !important}
.mb15{margin-bottom:15px !important}
.ml15{margin-left:15px !important}

.m20{margin:20px !important}
.mt20{margin-top:20px !important}
.mr20{margin-right:20px !important}
.mb20{margin-bottom:20px !important}
.ml20{margin-left:20px !important}

.m25{margin:25px !important}
.mt25{margin-top:25px !important}
.mr25{margin-right:25px !important}
.mb25{margin-bottom:25px !important}
.ml25{margin-left:25px !important}

.m30{margin:30px !important}
.mt30{margin-top:30px !important}
.mr30{margin-right:30px !important}
.mb30{margin-bottom:30px !important}
.ml30{margin-left:30px !important}

.m35{margin:35px !important}
.mt35{margin-top:35px !important}
.mr35{margin-right:35px !important}
.mb35{margin-bottom:35px !important}
.ml35{margin-left:35px !important}

.m40{margin:40px !important}
.mt40{margin-top:40px !important}
.mr40{margin-right:40px !important}
.mb40{margin-bottom:40px !important}
.ml40{margin-left:40px !important}

.m45{margin:45px !important}
.mt45{margin-top:45px !important}
.mr45{margin-right:45px !important}
.mb45{margin-bottom:45px !important}
.ml45{margin-left:45px !important}

.m50{margin:50px !important}
.mt50{margin-top:50px !important}
.mr50{margin-right:50px !important}
.mb50{margin-bottom:50px !important}
.ml50{margin-left:50px !important}

.m55{margin:55px !important}
.mt55{margin-top:55px !important}
.mr55{margin-right:55px !important}
.mb55{margin-bottom:55px !important}

.ml55{margin-left:55px !important}
.m60{margin:60px !important}
.mt60{margin-top:60px !important}
.mr60{margin-right:60px !important}
.mb60{margin-bottom:60px !important}
.ml60{margin-left:60px !important}

.m65{margin:65px !important}
.mt65{margin-top:65px !important}
.mr65{margin-right:65px !important}
.mb65{margin-bottom:65px !important}
.ml65{margin-left:65px !important}

.m70{margin:70px !important}
.mr70{margin-right:70px !important}
.mb70{margin-bottom:70px !important}
.ml70{margin-left:70px !important}

.m75{margin:75px !important}
.mt75{margin-top:75px !important}
.mr75{margin-right:75px !important}
.mb75{margin-bottom:75px !important}
.ml75{margin-left:75px !important}

.m80{margin:80px !important}
.mt80{margin-top:80px !important}
.mr80{margin-right:80px !important}
.mb80{margin-bottom:80px !important}
.ml80{margin-left:80px !important}


.mlrb30{margin:10px 30px 30px !important}
.ml90{margin-left:90px !important}

/**************************************************************
【paddingの設定】
**************************************************************/
.p0{padding:0 !important}		
.pt0{padding-top:0 !important}	
.pr0{padding-right:0 !important}
.pb0{padding-bottom:0 !important}
.pl0{padding-left:0 !important}	

.p5{padding:5px !important}
.pt5{padding-top:5px !important}
.pr5{padding-right:5px !important}
.pb5{padding-bottom:5px !important}
.pl5{padding-left:5px !important}

.p10{padding:10px !important}
.pt10{padding-top:10px !important}
.pr10{padding-right:10px !important}
.pb10{padding-bottom:10px !important}
.pl10{padding-left:10px !important}

.p20{padding:20px !important}
.pt20{padding-top:20px !important}
.pr20{padding-right:20px !important}
.pb20{padding-bottom:20px !important}
.pl20{padding-left:20px !important}

.p30{padding:30px !important}

.p4050{padding:40px 50px !important}

.pb30{padding-bottom:30px !important}
.pb40{padding-bottom:40px !important}
.pb50{padding-bottom:50px !important}
.pb80{padding-bottom:80px !important}

/**************************************************************
【widthの設定】
**************************************************************/
.w50{width:50px;}
.w100{width:100px;}
.w130{width:130px;}
.w180{width:180px;}
.w200{width:200px;}
.w220{width:220px;}
.w250{width:250px;}
.w350{width:350px;}
.w400{width:400px;}
.w450{width:450px;}
.w500{width:500px;}
.w600{width:600px;}
.w700{width:700px;}
.w710{width:710px;}
.w876{width:876px;}

/**************************************************************
【heightの設定】
**************************************************************/
.h10{height:10px;}
.h30{height:30px;}
.h100{height:100px;}
.h200{height:200px;}


/**************************************************************
【配置設定】
**************************************************************/
.center{text-align:center;}
.left{text-align:left;}
.right{text-align:right;}

.f_left{float:left;}
.f_right{float:right;}

/**************************************************************
【文字装飾】
**************************************************************/
.red1{color:#fb4461;}/*明るい赤 */
.red2{color:#b00000;}/*暗い赤 */
.red1_b{color:#F00;font-weight:bold;}/*太字・明るい赤 */
.red2_b{color:#d13938;font-weight:bold;}/*太字・暗い赤 */
.blue{color:#00F;}/*青 */
.bl{color:#1a5fb1;}/*青 */
.or{color:#ff8a00;}/*オレンジ */
.or2{color:#ff6c00;}/*オレンジ2 */
.blk{color:#000;}/*黒 */
.gr{color:#999;}/*グレー */
.grn{color:#50A810;}/*みどり */
.pk{color:#FE48DA;}/*ピンク */
.gld{color:#d5b876;}/*ゴールド */
.kiiro{color:#E7DE04}/*きいろ */
.pp{color:#8A37BC;}/*むらさき */
.underline{text-decoration:underline;}/*アンダーライン */
strong{font-weight:bold;}/*太字 */
.bg_y{
    background-color:#F6BD15;
    padding:0px 5px 0px;}
.bg_k{
	background-color: #F8FF12;
	padding: 0px 5px 0px;}


.font0_5{font-size:0.5em;}
.font0_6{font-size:0.6em;}
.font0_7{font-size:0.7em;}
.font0_8{font-size:0.8em;}
.font0_9{font-size:0.9em;}
.font1{font-size:1em;}
.font1_1{font-size:1.1em;}
.font1_2{font-size:1.2em;}
.font1_3{font-size:1.3em;}
.font1_4{font-size:1.4em;}
.font1_5{font-size:1.5em;}
.font1_6{font-size:1.6em;}
.font1_7{font-size:1.7em;}
.font1_8{font-size:1.8em;}
.font1_9{font-size:1.9em;}
.font2{font-size:2em;}

.lh160{
line-height: 160%;
}

.font_M {
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN","HG明朝E","ＭＳ Ｐ明朝","ＭＳ 明朝",serif;
}


/* CLEAR FIX*/
.clearfix:after {content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;}
.clearfix {display: inline-block;}
/* Hides from IE-mac \*/
* html .clearfix { height: 1%;}
.clearfix {display: block;}
/* End hide from IE-mac */

/*Q&A */
.qa{
font-size: 20px;
line-height: 30px;
}
.qa-list dl {
    position: relative;
    margin: 20px 0 0;
    cursor: pointer;
    border: 1px solid #DDD;
}
.qa-list dl:first-child {
  margin-top: 0;
}
.qa-list dl::after {
    position: absolute;
    top: 30px;
    right: 26px;
    display: block;
    width: 7px;
    height: 7px;
    margin: auto;
    content: '';
    transform: rotate(135deg);
    border-top: 2px solid #000;
    border-right: 2px solid #000;
}
.qa-list .open::after {
    transform: rotate(-45deg);
}
.qa-list dl dt {
    position: relative;
    margin: 0;
    padding: 20px 20px 20px 20px;
    font-weight: bold;
    background: #fff;
}
.qa-list dl dt::before {
    font-size: 30px;
    line-height: 36px;
    position: absolute;
    top: 20px;
    left: 0px;
    display: block;
    content: '';
    color: #229395;
}
.qa-list dl dd::before {
    font-size: 30px;
    line-height: 1;
    position: absolute;
    left: 0px;
    display: block;
    content: '';
    font-weight: bold;
    color: #fa4a67;
}
.qa-list dl dd {
    position: relative;
    margin: 0;
    padding: 20px 20px 20px 20px;
    background: #eee;
}
.qa-list dl dd p {
    margin: 30px 0 0;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}

@media (min-width:600px) and (max-width:1024px){
.qa{
font-size: 18px;
line-height: 28px;
}

 .qa-list dl {
    margin: 10px 0 0;
    line-height: 160%;
}
.qa-list dl:after {
    top: 20px;
    right: 20px;
    width: 7px;
    height: 7px;
}
.qa-list dl dt {
    padding: 10px 40px 10px 15px;
    font-size: 18px;
}
.qa-list dl dt::before {
    font-size: 14px;
    top: 12px;
    left: 20px;
}
.qa-list dl dt::before {
    font-size: 18px;
    line-height: 28px;
    position: absolute;
    top: 10px;
    left: 0px;
    display: block;
    content: '';
    color: #229395;
}
.qa-list dl dd::before {
    font-size: 18px;
    line-height: 1;
    position: absolute;
    left: 0px;
    display: block;
    content: '';
    font-weight: bold;
    color: #fa4a67;
}
.qa-list dl dd {
    margin: 0;
    padding: 10px 10px 10px 15px;
}
.qa-list dl dd p {
    margin: 30px 0 0;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}
}

@media only screen and (max-width:599px){
.qa{
font-size: 14px;
line-height: 24px;
}

 .qa-list dl {
    margin: 10px 0 0;
    line-height: 160%;
}


.qa-list dl:after {
    top: 15px;
    right: 20px;
    width: 7px;
    height: 7px;
}
.qa-list dl dt {
    padding: 10px 40px 10px 15px;
    font-size: 16px;
}
.qa-list dl dt::before {
    font-size: 14px;
    top: 12px;
    left: 20px;
}

.qa-list dl dt::before {
    font-size: 16px;
    line-height: 20px;
    position: absolute;
    top: 10px;
    left: 0px;
    display: block;
    content: '';
    color: #229395;
}
.qa-list dl dd::before {
    font-size: 16px;
    line-height: 20px;
    position: absolute;
    left: 0px;
    display: block;
    content: '';
    font-weight: bold;
    color: #fa4a67;
}

.qa-list dl dd {
    margin: 0;
    padding: 10px 10px 10px 15px;
}
.qa-list dl dd p {
    margin: 30px 0 0;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}
}