@charset "UTF-8";
/* CSS Document */

@import url('https://fonts.googleapis.com/css?family=M+PLUS+1p:700,800&display=swap');


#s_banner {
  padding-top: 0px;
}
#side,
#bottom,
#b_bottom {
	display: none;
}
#content {
  width: 940px;
}
#totop {
	margin-top: 0px !important;
}
.end {
	background-color: rgba(255,255,255,0.7);
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0px;
	top: 0px;
}
.end:after {
	content: "";
	background-image: url(../img/line/end.png);
	background-position: 50% 50%;
	background-repeat: no-repeat;
	width: 610px;
	height: 110px;
	margin: -55px 0px 0px -305px;
	position: absolute;
	left: 50%;
	top: 50%;
}
.pc {
	display: inline;
}
.sp {
	display: none;
}

/*flex
-------------------------------------------------------*/
.lineflex, .dl2 > div {
	display: -webkit-flex;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
}
.column3 > * {
  width: 32%;
}

/*共通
-------------------------------------------------------*/
#line_wrapper{
 background-color: 	 #fffbe1;
}
.line_bg_white{
    background: white;
}

.linebtn:hover {
    opacity: 0.5;
	transition: 3s;
}

#line_wrapper h3 {
    background: #ffef00;
    color: #000;
    margin: 0 auto;
    font-size: 2.7rem;
    font-weight: 500;
    line-height: 50px;
    border-radius: 5px;
    position: relative;
    z-index: 100;
}

.triangle {
width: 0;
height: 0;
border-style: solid;
border-width: 100px 470px 0 470px;
max-width: 940px;
border-color: #fff transparent transparent transparent;
}

#line_wrapper_bg{
	background-color: #fff;
	padding-bottom: 5px;
}

#line_wrapper_bg h2{
	text-align: center;
}

#line2 {
    margin: 100px;
}

#line2 .line2_flex{
	display: flex;
	position: relative;
}

#line2 .line2_flex img{
	width: 40%;
    position: absolute;
    bottom: 0;
    right: 0;
}


#line2 .line2_label li:not(:first-child){
    margin: 2em 0;
    color: #000;/*文字色*/
    background: #FFF;
    border: solid 3px #52b24d;/*線*/
    border-radius: 10px;/*角の丸み*/
}

#line2 .line2_label li{
    margin: 0px 0 2em 0;
    color: #000;/*文字色*/
    background: #FFF;
    border: solid 3px #52b24d;/*線*/
    border-radius: 10px;/*角の丸み*/
	position: relative;
}

#line2 .line2_label li img{
	position: absolute;
    top: -13px;
    left: -5px;
}

#line2 .line2_label li p {
	font-size: 20px;
    margin-left: 80px; 
    padding: 20px 0;
}

#line3 .line3_label {
	font-size: 18px;
	text-align: center;
	line-height: 30px!important;
    margin-bottom: 10px;
}

#line3 .line_estimate{
	padding-bottom: 30px;	
}

#line3 .line_bg_white h2 {
    padding-bottom: 10px;
}

#line2 .line2_label li span.textimpact {
    font-weight: bold;
    font-size: 25px;
    background: linear-gradient(transparent 50%, #fff44a 50%);
}




/*
#line4 .startline .step1 .step_desc {
    background: url("/img/line/startline_num1.png") no-repeat left top;
}
*/




#line4 .startline p.step_desc{
    padding-left: 50px;
    font-size: 16px;
    font-weight: bold;
}

.line_howto ul{
    list-style: none;
    display:flex;
	margin: 20px;
}

.line_howto ul li:not(:last-child){
	margin-right: 20px;
}

.line_howto p {
  color: black;/*文字は白に*/
  top: 0;
  left: 0;
  }

.line_howto img {
  width: 100%;
  }


.line_t_center{
    text-align: center;
	}


#line_wrapper .p_area {
  margin-top: 90px;
  padding-bottom: 0px;
}

#line_wrapper #line1 {
    margin-top: 50px;
}

#line_wrapper .icon {
  font-family: 'M PLUS 1p', sans-serif;
  justify-content: center;
  text-align: center;
}
#line_wrapper .icon li {
  background: #ffffff;
  border: #004ea2 2px solid;
	color: #004ea2;
  margin-bottom: 10px;
  padding: 2px 15px;
  font-size: 24px;
  font-weight: 700;
  border-radius: 5px;
  box-shadow: rgba(0,0,0,0.3) 2px 2px 0px;
}
#line_wrapper .icon li.i1 {
  background: #ff2255;
  border-color: #ff2255;
	color: #ffffff;
}
#line_wrapper .icon li:not(:first-of-type) {
  margin-left: 10px;
}
#line_wrapper h1 {
  font-family: 'M PLUS 1p', sans-serif;
　color: #000;
  height: inherit;
  margin-bottom: 50px;
  padding-top: 10px;
  font-size: 50px;
  line-height: 66px;
  font-weight: 800;
  text-align: left;
  /*
  text-shadow: rgba(0,0,0,0.3) 2px 2px 0px;
  */
}

#line2 .line2_flex span.textimpact{
	color: #21b515;
}


#line_wrapper h2 {
  font-family: 'M PLUS 1p', sans-serif;
  height: inherit;
  padding-top: 10px;
  font-size: 33px;
  line-height: 66px;
  font-weight: 800;
  text-align: center;
  /*
  text-shadow: rgba(0,0,0,0.3) 2px 2px 0px;
  */
}

#line_wrapper .linebtn h3{
    margin: 2em 0;
    color: #fff;
    background: #2cab26;
    border: solid 3px #2cab26;
    border-radius: 10px;
	text-decoration:none; 
}
#line_wrapper h2 p {
  margin-top: 10px;
  font-size: 26px;
  line-height: 36px;
  text-align: center;
  font-weight: 700;
}
#line_wrapper h2.flex {
  justify-content: center;
  text-align: center;
}
#line_wrapper h2.flex span {
  margin-left: 10px;
  font-size: 26px;
  line-height: 30px;
  text-align: left;
  position: relative;
  left: 0px;
  top: 2px;
}
#line_wrapper h3 {
  font-family: 'M PLUS 1p', sans-serif;
/*	color: #ffffff;*/
	margin: 0px;
	padding: 5px;
/*	border-radius: 0;*/
	font-size: 20px;
	text-align: center;
}

#line_wrapper .p_area .icon_triangle{
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 25px 20px 0 20px;
	border-color: #ffee00 transparent transparent transparent;
	 margin: 0 auto;
}

	#line_wrapper .linebtn a{
  text-decoration: none;
		
}

#line_wrapper h4 {
  background: none;
	color: #004ea2;
  margin: 0px;
  padding: 0px;
  font-weight: bold;
}
#line_wrapper dd > h4 {
  margin-top: 20px;
}
#line_wrapper dd > h4 + p {
  margin-top: 10px;
}
#line_wrapper .outline {
  font-family: 'M PLUS 1p', sans-serif;
  background: #fff;
  color: #000;
  padding: 10px 30px 60px 30px;
  font-weight: 700;
	position: relative;
  border-radius: 10px 10px 0px 0px;
}
#line_wrapper .outline > p {
  font-size: 18px;
  line-height: 28px;
}
#line_wrapper p.catch {
  font-size: 30px;
  font-weight: bold;
  text-align: center;
}
#line_wrapper .outline .sub {
  background: #ffff66;
  color: #000000;
  margin-top: 30px;
  padding: 20px;
  border-radius: 5px;
  align-items: center;
  box-shadow: rgba(0,0,0,0.3) -2px -2px 0px;
}
#line_wrapper .outline .sub > * {
  box-sizing: border-box;
  text-align: center;
}
#line_wrapper .outline .sub > * p {
  text-align: center;
}
#line_wrapper .outline .sub .limit {
  width: 56%;
  margin-right: 4%;
}
#line_wrapper .outline .sub .limit p {
  color: #ff0000;
  font-size: 30px;
  line-height: 40px;
  font-weight: 800;
}
#line_wrapper .outline .sub .limit p strong {
  font-size: 50px;
  line-height: 50px;
  font-weight: 800;
  position: relative;
  left: 0px;
  top: 3px;
}
#line_wrapper .outline .sub .limit p.flex {
  align-items: center;
}
#line_wrapper .outline .sub .limit p > span:first-of-type {
  color: #000000;
  font-weight: 700;
  text-align: left;
}
#line_wrapper .outline .sub .limit p > span.row2 {
  font-size: 20px;
  line-height: 24px;
}
#line_wrapper .outline .sub .limit > span {
  font-size: 14px;
}
#line_wrapper .outline .sub .period {
  background: #ffffff;
  flex: 1;
  padding: 10px;
  border-radius: 5px;
  box-shadow: rgba(0,0,0,0.3) 2px 2px 0px;
}
#line_wrapper .outline .sub .period h5 {
  background: #ff2255;
  color: #ffffff;
  padding: 5px !important;
}
#line_wrapper .outline .sub .period h6 {
  background: #004ea2;
  color: #ffffff;
  margin-bottom: 10px;
  padding: 5px !important;
  font-size: 14px;
}
#line_wrapper .outline .sub .period p {
  font-size: 22px;
  line-height: 26px;
  font-weight: bold;
}
#line_wrapper .cont {
	border: #004ea2 4px solid;
	padding: 26px;
	color: #000000;
	position: relative;
  border-radius: 0px 0px 10px 10px;
}
#line_wrapper .p_area p {
	padding-left: 0px;
	padding-right: 0px;
}
/*
#line_wrapper .p_area p + p, #line_wrapper .p_area dl + p {
  margin-top: 15px;
}
*/
#line_wrapper .cont > p + dl, #line_wrapper .cont .dl1 > dt:not(:first-of-type) {
  margin-top: 30px;
}
#line_wrapper .cont .dl1 > dt {
	background: #ccdcec;
	padding: 10px;
	font-size: 16px;
	font-weight: bold;
  border-radius: 3px;
}
#line_wrapper .cont .dl1 > dt span {
	font-size: 13px;
}
#line_wrapper .cont .dl1 > dd {
	margin-top: 20px;
  padding-left: 10px;
  padding-right: 10px;
	font-size: 14px;
}
#line_wrapper .cont .dl2 > div {
  width: 100%;
}
#line_wrapper .cont .dl2 div > dt {
  width: 160px;
  margin-right: 20px;
}
#line_wrapper .cont .dl2 div > dt span {
  background: #004ea2;
  color: #ffffff;
  padding: 5px 0px;
  border-radius: 30px;
  text-align: center;
  display: block;
}
#line_wrapper .cont .dl2 div > dd {
  flex: 1;
}
#line_wrapper .cont .dl2 div {
  margin-top: 20px;
}
#line_wrapper .cont .dl2 div:first-of-type {
}
#line_wrapper .cont ul {
	margin-top: 15px;
}
#line_wrapper .cont ul li {
	padding-left: 15px;
	position: relative;
}
#line_wrapper .cont ul li:before {
	content: "●";
	color: #004ea2;
	font-size: 10px;
	position: absolute;
	left: 0px;
	top: 0px;
}
#line_wrapper .cont dd ul > li:not(:first-of-type) {
	margin-top: 10px;
}
#line_wrapper .cont dd ol {
  margin: 0px;
	padding-left: 0px;
  counter-reset: list-count; 
  list-style: none; 
}
#line_wrapper .cont .ol1 > li {
  padding-left: 25px;
  position: relative;
}
#line_wrapper .cont .ol1 > li::before {
  content: counter(list-count) ".";
  counter-increment: list-count;
	color: #004ea2;
  font-size: 20px;
  font-weight: bold;
  position: absolute;
  left: 0px;
  top: -2px;
}
#line_wrapper .cont ol > li:not(:first-of-type) {
	margin-top: 15px;
}
#line_wrapper .cont .ol2 > li {
  padding-left: 30px;
  position: relative;
}
#line_wrapper .cont .ol2 > li::before {
  content: "（" counter(list-count) "）";
  counter-increment: list-count;
  position: absolute;
  left: -5px;
  top: 0px;
}
#line_wrapper .cont .ol2 > li:not(:first-of-type) {
	margin-top: 5px;
}
#line_wrapper .cont .ol3 {
  padding-left: 25px;
  counter-reset: my-counter;
  list-style: none;
}
#line_wrapper .cont .ol3 > li {
  position: relative;
}
#line_wrapper .cont .ol3 > li:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  border: #000000 1px solid; 
  border-radius: 50%;
  height: 16px;
  width: 16px;
  margin-left: -25px;
  line-height: 16px;
  text-align: center;
  display: block;
  float: left;
}
#line_wrapper .cont ul + ol, #line_wrapper .cont ol + p, #line_wrapper .cont p + ol {
	margin-top: 20px !important;
}
#line_wrapper table, #line_wrapper table tr > * {
  border: #004ea2 1px solid;
}
#line_wrapper table {
  border-bottom: none;
  border-right: none;
  margin-top: 10px;
}
#line_wrapper table tr > * {
  border-top: none;
  border-left: none;
  padding: 10px 5px;
}
#line_wrapper table thead tr > th {
  text-align: center;
}
#line_wrapper table tbody tr > th {
  padding: 10px 10px;
}
#line_wrapper table tr > td {
  padding: 10px 10px;
  text-align: center;
}
#line_wrapper table thead tr > *, #line_wrapper table.side tbody tr > th {
	background: #E5EDF6;
}
#line_wrapper table.side tbody tr > td {
  text-align: left;
}
#line_wrapper .cont .scroll + p {
	margin-top: 20px;
}
#line_wrapper .cont p.caution {
	color: #888888;
	margin-top: 5px;
	font-size: 12px;
	line-height: 20px;
}
#line_wrapper .cont .border {
	border-top: #888888 1px dotted;
	margin-top: 10px;
  padding-top: 10px;
}
#line_wrapper .cont dl.border {
	margin-top: 30px;
  padding-top: 30px;
}
#line_wrapper .square {
  background: #004ea2;
  color: #ffffff;
  min-width: 20px;
  margin: 2px 3px;
  padding: 0px 1px;
  line-height: 20px;
  box-sizing: border-box;
  text-align: center;
  display: inline-block;
}
#line_wrapper .caution .square {
  min-width: 18px;
  margin: 1px 2px;
  padding: 1px;
  line-height: 16px;
}
#line_wrapper .cont .price {
  text-align: center;
}
#line_wrapper .cont .price > p {
  font-family: 'M PLUS 1p', sans-serif;
  color: #ff0000;
  margin-bottom: 5px;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}
#line_wrapper .cont .price > p span {
	font-size: 200%;
}

.line_b {
  margin-top: 40px;
  margin-bottom: 80px;
}
.line_b a {
	display: block;
}
.line_b li.text {
  font-family: 'M PLUS 1p', sans-serif;
	background-color: #ffff00;
  width: 100%;
  padding: 20px;
  font-size: 30px;
  line-height: 36px;
  font-weight: 700;
	text-align: center;
	border-radius: 10px;
  box-sizing: border-box;
}
.line_b li:not(:first-of-type) {
  width: 48%;
  margin-top: 30px;
}

.linebottom_space{
	padding-bottom: 80px	
}


/*pc
-------------------------------------------------------*/
@media screen and (min-width: 740px) {
	
 
#line3 .line3_gideimg{
	margin: 10px 50px 40px 50px;
    padding-bottom: 80px;
}
	
#line4 .lineflex.startline {
    padding: 0 43px 0 0;
}	
 #line4 .startline .step1 {
    padding-right: 20px;
    background: url(/img/line/linearrow_right.png) no-repeat top 55% right 0px;
}
	
	
 #line4 .startline .step2 {
    padding-right: 60px;
    background: url(/img/line/linearrow_right.png) no-repeat top 55% right 0px;
}
	
#line1 h3 {
    margin: 0;
}

.pcimg {
    width: 100%;
}
	
.example ul{
    list-style: none;
    display:flex;
	margin: 15px 0;
}

.example ul li{/*親div*/
	position: relative;/*相対配置*/
}

.example ul li:not(:last-child){
	margin-right: 20px;
}


.example p {
    position: absolute;
    color: black;
    top: 23px;
    left: 50px;
    text-align: center;
    font-size: 16px;
}

.example p span.textimapct{
	font-weight: bold;
	color: #023689;
	font-size: 22px;
}

.example li.example_textlayout03 p span.textimapct, .example li.example_textlayout01 p span.textimapct{
	    line-height: 30px;
	
}

.example li.example_textlayout02 p {
  left: 40px;
    top: 28px;
}

.example li.example_textlayout03 p {
  left: 50px;
	top: 30px;
}

.example li.example_textlayout04 p {
 	top: 45px;
    left: 40px;
}

.example img {
  width: 100%;
  }
.pcbr { display:none;  }
  .spbr { display:block;}

.line_bg_white {
    margin: 30px;
}
#line_wrapper #line4 .lineflex .step1 img{
    width: 95%;
}	
 	.lineflex .step2 img{
    width: 110%;
} 
	.lineflex .step3 img{	
	    width: 118%;
}	
	#line2 img.line_man {
    position: absolute;
    top: -63px;
    right: 0;
}
	
	#line4 .startline .step1 .step_desc {
    background: url("/img/line/startline_num1.png") no-repeat left top;
}
#line4 .startline .step2 .step_desc {
    background: url("/img/line/startline_num2.png") no-repeat left top;
}
	#line4 .startline .step3 .step_desc {
    background: url("/img/line/startline_num3.png") no-repeat left top;
}
	#line_wrapper .linebtn h3{
width: 70%;
    /* text-align: center; */
    margin: 0 auto;
		margin-top: 50px;
}
	 .line_spbr { display:none; }	

}


/*sphone
-------------------------------------------------------*/
@media screen and (min-width: 0px) and (max-width: 739px) {
	

#line3 section.line_estimate{
		    margin: 0 10px;
	}
.spimg {
    display: block;
    text-align: center;
    margin: 0 auto;
	 margin: 10px;
    width: 95%;
}
#line4	.lineflex {	
	    flex-direction: column;
}
	
.line_bg_white {
    margin: 3%;
}
	
#line3 .line_bg_white {
    margin: 3%;
	margin-top: 0;
}	
  #content {
    width: auto;
    padding-bottom: 0;
  }
  #totop {
    padding-top: 0px;
  }
	
.example li.example_textlayout01 p {
	    top: 25px;
    left: 55px;
}	
	
.example li.example_textlayout02 p {	
	    top: 28px;
    left: 30px;	
}	
	
.example li.example_textlayout01 p span.textimapct{
	    line-height: 30px;
}	
	
li.example_textlayout02,li.example_textlayout04 {
    text-align: right;
}
	
.example li.example_textlayout02 p,.example li.example_textlayout04 p {
  right: -110px;
}

.example li.example_textlayout03 p {
 	left: 50px;
}
	
	
	
.example li.example_textlayout04 p {
 	top: 45px;
	left: 30px;
}
	
	#line_wrapper h1 {
  font-family: 'M PLUS 1p', sans-serif;
　color: #000;
  height: inherit;
  margin-bottom: 40px;
  padding-top: 50px;
/*  font-size: 35px;*/
  line-height: 55px;
  font-weight: 800;
  text-align: center;
	margin-right: auto;
    margin-left: auto;
  /*
  text-shadow: rgba(0,0,0,0.3) 2px 2px 0px;
  */
}
	
  .triangle {
	border-width: 100px 48vw 0 48vw;
	}
	
.example ul li{/*親div*/
	position: relative;/*相対配置*/
	overflow: hidden;
	    display: inline;
}
	
	.example p {
  position: absolute;/*絶対配置*/
  color: black;/*文字は白に*/
  top: 35px;
  left: 30px;
  text-align: center;
  font-size: 16px;
 }

.example p span.textimapct{
	font-weight: bold;
	color: #023689;
	font-size: 22px;
}
	
.example ul {
    margin-top: 30px;
}
	
#line2 .line2_flex img {
    width: 60%;
    position: absolute;
    bottom: -750px;
    right: 0;
}
	
  .end:after {
    background-image: url(../img/line/end_s.png);
    width: 210px;
    height: 210px;
    margin: -105px 0px 0px -105px;
  }
  .pc {
		display: none;
	}
	.sp {
		display: inline;
	}
  .column3 > * {
    width: 100%;
  }
  .cont .column3 > *:not(:first-of-type) {
    margin-top: 15px;
  }

  #line_wrapper .p_area {
	margin: 30px 0 0 0;
  }
   #line_wrapper #line3 {
	margin-top: 0;
  }	
	#line_wrapper #line2 .line_man{
		text-align: left;
	}
	
	
	#line_wrapper  #line2 {
	margin: 30px 0 0 0;
  }
  #line_wrapper .line_t {
    margin-left: -10px;
    margin-right: -10px;
  }
 #line_wrapper .line_t img{
    width: 100%;
  }
  #line_wrapper .icon li {
    border-width: 1px;
    margin-bottom: 15px;
    padding: 1px 10px;
    font-size: 15px;
    border-radius: 3px;
  }
  #line_wrapper .icon li:not(:first-of-type) {
    margin-left: 5px;
  }
  #line_wrapper h2 {
    margin-bottom: 15px;
    padding: 0px;
    font-size: 30px;
    line-height: 32px;
    font-weight: 700;
    text-align: center;
  }
	#line3 h2 {
    padding-top: 20px;
  }
  #line_wrapper h2 p {
    margin-top: 5px;
    font-size: 18px;
    line-height: 24px;
  }
  #line_wrapper h2.flex {
    flex-direction: column;
  }
  #line_wrapper h2.flex span {
    margin-top: 5px;
    margin-left: 0px;
    font-size: 18px;
    line-height: 24px;
    text-align: center;
    top: 0px;
  }
  #line_wrapper h3 {
    font-size: 20px;
  }
  #line_wrapper dd > h4 {
    margin-top: 15px;
    font-size: 15px;
  }
  #line_wrapper .outline {
    padding: 15px;
  }
  #line_wrapper .outline > p {
    font-size: 14px;
    line-height: 22px;
  }
  #line_wrapper p.catch {
    font-size: 20px;
  }
  #line_wrapper .outline .sub {
    margin-top: 15px;
    padding: 10px;
  }
  #line_wrapper .outline .sub > * {
    width: 100%;
  }
  #line_wrapper .outline .sub .limit {
    width: 100%;
    margin-right: 0%;
  }
  #line_wrapper .outline .sub .limit p {
    font-size: 20px;
    line-height: 30px;
  }
  #line_wrapper .outline .sub .limit p > span {
    width: 100%;
    font-size: 13px !important;
    line-height: 16px !important;
    text-align: center !important;
    display: block !important;
  }
  #line_wrapper .outline .sub .limit > span {
    font-size: 11px;
  }
  #line_wrapper .outline .sub .period {
    margin-top: 10px;
    padding: 5px;
  }
  #line_wrapper .outline .sub .period h5 {
    margin-bottom: 5px;
    padding: 1px !important;
    font-size: 12px;
  }
  #line_wrapper .outline .sub .period h6 {
    margin-bottom: 5px;
    padding: 1px !important;
  }
  #line_wrapper .outline .sub .period p {
    font-size: 18px;
    line-height: 24px;
  }
  #line_wrapper .outline .sub .period .flex > *:not(:first-of-type) {
    margin-top: 10px;
  }
  #line3 .outline .sub .period {
    margin-top: 0px;
  }
  #line_wrapper .cont {
    border-width: 2px;
    padding: 13px;
  }
  #line_wrapper .cont > p + dl, #line_wrapper .cont .dl1 > dt:not(:first-of-type) {
    margin-top: 15px;
  }
  #line_wrapper .cont .dl1 > dt {
    font-size: 14px;
  }
  #line_wrapper .cont .dl1 > dt span {
    font-size: 11px;
  }
  #line_wrapper .cont .dl1 > dd {
    margin-top: 15px;
    padding-left: 0px;
    padding-right: 0px;
  }
  #line_wrapper .cont .dl2 div {
    flex-direction: column;
  }
  #line_wrapper .cont .dl2 div > dt {
    width: 100%;
    margin-right: 0px;
  }
  #line_wrapper .cont .dl2 div > dt span {
    padding: 2px 0px;
  }
  #line_wrapper .cont .dl2 div {
    margin-top: 15px;
  }
  #line_wrapper .cont .dl2 div > dd {
    margin-top: 10px;
  }
  #line_wrapper .cont ul {
    margin-top: 10px;
  }
  #line_wrapper .cont .ol1 > li::before {
    font-size: 18px;
    top: 0px;
  }
  #line_wrapper .cont ol > li:not(:first-of-type) {
    margin-top: 15px;
  }
  #line_wrapper table tr > *, #line_wrapper table tr > td {
    padding: 5px;
  }
  #line_wrapper .cont table {
    width:100%;
    font-size: 12px;
    line-height: 14px;
  }
  .scroll{
    padding-bottom: 10px;
    overflow: auto;
    white-space: nowrap;
  }
  .scroll::-webkit-scrollbar {
    height: 5px;
  }
  .scroll::-webkit-scrollbar-track {
    background: #eeeeee;
  }
  .scroll::-webkit-scrollbar-thumb {
    background: #aaaaaa;
  }


  #line_wrapper .cont .scroll + p {
    margin-top: 15px;
  }
  #line_wrapper .cont p.caution {
    font-size: 11px;
  }
  #line_wrapper .cont dl.border {
    margin-top: 15px;
    padding-top: 15px;
  }
  #line_wrapper .cont .price > p span {
    font-size: 160%;
  }

  .line_b {
    margin-top: 30px;
    margin-bottom: 40px;
  }
  .line_b li.text {
    padding: 15px 10px;
    font-size: 14px;
    line-height: 20px;
  }
  .line_b li:not(:first-of-type) {
    width: inherit;
    margin-top: 15px;
    padding: 0px 15px;
  }
	#line2 .line2_label li p {
	margin-left: 80px;
    margin-right: 30px;
    line-height: 35px;
}
	
#line2 .line2_label li img {
    left: -8px;
}
	
/*
#line4 .startline p.step_desc {
    line-height: 45px;
}
*/
.pcbr { display:block; }
  .spbr { display:none; }
 
#line4 .outline img{
	display: block;
	margin: 0 auto;
}
#line4 .child {
    padding-bottom: 40px;
	width: 100%;
}

.flex, .dl2 > div {
	display: -webkit-flex;
	display: flex;
	flex-direction: row;
  flex-wrap: wrap;
	justify-content: space-between;
}

#line_wrapper #line2 {
    margin-left: 3%;
	margin-right: 3%;
	text-align: right;
}
	
.example img.sp {
    width: 50%;
}
/*
.example img{
		width: 90%;
    height: 100px;
	}
*/
#line1 img.sp {
    width: 100%;
}	
	
	
	 #line4 .startline .step_desc{
    position:relative;
	line-height:2em;
	padding-left:3em;
}
 #line4 .startline .step1 .step_desc:before{
    position:absolute;
	left:0;
	content:"";
	display:inline-block;
	width:3em;
	height:3em;
	background:url(/img/line/startline_num1.png) no-repeat;
	background-size:contain;
}	

 #line4 .startline .step2 .step_desc:before{
    position:absolute;
	left:0;
	content:"";
	display:inline-block;
	width:3em;
	height:3em;
	background:url(/img/line/startline_num2.png) no-repeat;
	background-size:contain;
}
 #line4 .startline .step3 .step_desc:before{
    position:absolute;
	left:0;
	content:"";
	display:inline-block;
	width:3em;
	height:3em;
	background:url(/img/line/startline_num3.png) no-repeat;
	background-size:contain;
}
	
		#line_wrapper .linebtn {
margin: 0 3%;
}
	
.pcbr { display:block; }	

		#line_wrapper .linebtn h3{	
	    line-height: 30px;
    padding: 15px 0;
	}
	

#line4 .startline p.step_desc{
    padding-left: 50px;
    font-size: 15px;
    font-weight: bold;
}
	 .line_spbr { display:block; }
}

/*配色
-------------------------------------------------------*/
#line1 .icon li, #line1 .cont, #line1 table, #line1 table tr > * {
  border-color: #66cc00;
}
#line1 .outline, #line1 .square, #line1 .cont .dl2 div > dt span, #line1 h3, #line1 .outline .sub .period h6 {
  background: #ffef00;
}
#line1 .icon li, #line1 h2, #line1 h4, #line1 .cont dd ul li:before, #line1 .cont dd .ol1 > li::before  {
	color: #66cc00;
}
#line1 .cont .dl1 > dt {
	background: #e0f5cc;
}
#line1 table thead tr > *, #line1 table.side tbody tr > th {
	background: #f0fae5;
}

#line2 .icon li, #line2 .cont, #line2 table, #line2 table tr > * {
  border-color: #009922;
}
#line2 .outline, #line2 .square, #line2 .cont .dl2 div > dt span, #line2 h3, #line2 .outline .sub .period h6 {
  background: #009922;
}
#line2 .icon li, #line2 h2, #line2 h4, #line2 .cont dd ul li:before, #line2 .cont dd .ol1 > li::before  {
	color: #009922;
}
#line2 .cont .dl1 > dt {
	background: #ccebd3;
}
#line2 table thead tr > *, #line2 table.side tbody tr > th {
	background: #e5f5e9;
}

#line3 .icon li, #line3 .cont, #line3 table, #line3 table tr > * {
  border-color: #009999;
}
#line3 .outline, #line3 .square, #line3 .cont .dl2 div > dt span, #line3 h3, #line3 .outline .sub .period h6 {
  background: #ffef00;
}
#line3 .icon li, #line3 h2, #line3 h4, #line3 .cont dd ul li:before, #line3 .cont dd .ol1 > li::before  {
	color:  #000000;;
}
#line3 .cont .dl1 > dt {
	background: #ccebeb;
}
#line3 table thead tr > *, #line3 table.side tbody tr > th {
	background: #e5f5f5;
}

#line4 .icon li, #line4 .cont, #line4 table, #line4 table tr > * {
  border-color: #00abeb;
}
#line3 .line_bg_white, #line4 .outline, #line4 .line_bg_white, #line4 .square, #line4 .cont .dl2 div > dt span, #line4 .outline .sub .period h6 {
      background: #fff;
}
#line4 .icon li, #line4 h2, #line4 h4, #line4 .cont dd ul li:before, #line4 .cont dd .ol1 > li::before  {
	color:   #000000;
}
#line4 .cont .dl1 > dt {
	background: #daf0fc;
}
#line4 table thead tr > *, #line4 table.side tbody tr > th {
	background: #edf8fd;
}


/*期間終了
-------------------------------------------------------*/
#closed {
    background: #fff none repeat scroll 0 0;
    color: #cc0000;
    font-size: 30px;
    height: 100%;
    line-height: 10em;
    opacity: 0.7;
    position: absolute;
    width: 100%;
    text-align: center;
    z-index: 100;
}
