@charset "utf-8";

/*@import url("js/pc_fix_menu3/pc_fix_menu3.css");*/
/*@import url("/ts/wp-content/themes/base/js/pc_fix_menu3/pc_fix_menu3.css");*/
/* CSS Document */
/* #EC5504 オレンジ 　#009AE1 ブルー */

/*20200225 add*/
.w25 {
	width: 25%;
}
.container{
	width: 100%;
	background-repeat: no-repeat;
	background-position: center top;
	padding-top: 0;
	/*min-height: 600px;*/
  background-color: #f8f8f8;
}
.d-container{
	width: 100%;
}
.contents_wrap_all {
     overflow: hidden; 
}
.simulation-title{
	text-align: center;
	margin-bottom: 40px;
  /*padding-top:10px;*/
	padding:0;
}
.simulation-form{
	width: 1000px;
	margin: 0 auto;
}
.simulation-form .sidebar{
	width: 24%;
	border: 1px solid #ec5504;
	background-color: #fff;
	float: right;
	position: relative;
  transition: all 0.1s;
  border-radius:2px;
}

/* header
-------------------------------------*/
/*.header_aera {
  width:100%;
	background: #fff;
  margin:0 auto 0px;
  padding:0;
  border-bottom:1px solid #ccc;
}
.header_area_in {
	width: 1010px;
	height: 80px;
	text-align: center;
	background: #fff;
  margin:6px auto 0;
  display:flex;
  justify-content:space-between;
}
.header_logo{
margin:0;
padding:0;
flex-grow: 1;
text-align:left;
}
.header_btn {
  flex:0 0;
}
.header_tel {
  flex:0 0;
}*/


@media screen and (max-width:767px) {
.simulation-title{
	text-align: center;
	margin: 0 auto 40px;
	width:100%;
  border-radius: 2px;
}
.simulation-title img {
	width:100%;
}
.simulation-form{
	width:100%;
	margin: 0 auto;
}
.simulation-form .sidebar{
display:none;
}

}
/* @media END*/

.simulation-form .sidebar h3{
	background-color: #ec5504;
	color: #fff;
	font-size: 18px;
    font-weight: bold;
    line-height: 50px;
    text-align: center;
}
.js-side-column{
	padding: 10px;
    transition: all 0.5s
}  
.js-side-column + .js-side-column{
    display: none;
}
.js-side-column  + .js-side-column {
 	border-top: 1px solid #ddd;
} 

.js-side-column dt{
  text-align:center;
	padding-left: 0px;
	vertical-align: middle;
	font-size: 14px;
    letter-spacing: 0.05em;
    line-height: 1.5;
    font-weight: bold;
    background-repeat: no-repeat;
}
.js-side-column dd.value{
	padding: 15px 10px;
    background-color: #F0F0F0;
    margin-top: 10px;
  text-align:center;
  border-radius:4px;
}

/* 非表示 */
.js-side-column dt.home{
/*	background-image: url(../img/side-icon-house.png);*/
}
.js-side-column dt.phone{
/*	background-image: url(../img/side-icon-sp.png);*/
}
.js-side-column dt.telephone{
/*	background-image: url(../img/side-icon-tel.png);*/
}
.js-side-column dt.tv{
/*	background-image: url(../img/side-icon-tv.png);*/
}
.js-side-column dt.service{
/*	background-image: url(../img/side-icon-security.png);*/
}


.simulation-form .form-right {
	width: 71%;
    float:left;
    margin-bottom: 0;
}
.simulation-form .form-right2{
	width: 71%;
    float:left;
    margin-bottom: 0px;
}


@media screen and (max-width:767px) {
.simulation-form .form-right {
	width: 96%;
  margin: 0 2% 200px;
}
	.simulation-form .form-right2{
	width: 96%;
    /*float:left;*/
    margin: 0 2% 40px;
}
}
/* @media END*/


/*step-form*/
.step-wrap{
  position: relative;
	background-color: #fff;
  margin-bottom: 100px;
  transition: all 1.5s;
}
.step-wrap + .step-wrap{
  opacity: 0;
  display: none;
}
.step-wrap::after{
    content: '';
    display: inline-block;
    width: 120px;
    height: 40px;
    background: url(../img/next-arrow.png) no-repeat center center;
    background-size: contain;
    position: absolute;
    left: 50%;
    bottom: -60px;
    margin-top: -30px;
    margin-left: -60px;
}
.step-wrap .step-content{
	padding: 49px;
	border: 1px solid #ccc;
  border-radius: 5px;
}

@media screen and (max-width:767px){
	.step-wrap .step-content{
	padding: 15px;
	border: 1px solid #ddd;
}
}
/* @media END*/


.step-wrap .step-content .step-num{
	 font-family: Helvetica, Arial, sans-serif;
    font-size: 20px;
    font-weight: bold;
    line-height: 40px;
    color: #fff;
    width: 100%;
    margin: 0 auto 20px;
    text-align: center;
    border-radius: 4px;
    background-color: #ec5504;
}
.step-wrap .step-content .step-ttl {    
	font-size: 23px;
    font-weight: bold;
    line-height: 1.5;
    text-align: center;
    margin-bottom: 30px;
}
.step-wrap .step-content .step-ttl span{
    color: #ec5504;
}
.step-wrap .step-content .step-btn{
}
.step-wrap .step-content .step-btn li:first-child{
	margin: 0;
}
.step-wrap .step-content .step-btn li{
	 width: 290px;
    height: 250px;
    margin-left: 30px;
    float: left;
    background-color: #fff;
}

@media screen and (max-width:767px){
.step-wrap .step-content .step-btn li{
  width: 46%;
  height:160px;
  margin-left: 20px;
  float: left;
  background-color: #fff;
/*display:inline-block;*/
}
}
/* @media END*/

.step-wrap .step-content .step-btn li label{
	width: 100%;
    height: 100%;
    padding-top: 20px;
    display: block;
    box-sizing: border-box;
    text-align: center;
    border: 4px solid #ddd;
    cursor: pointer;
    position: relative;
    border-radius: 5px;
}
.step-wrap .step-content .step-btn li label .img img{
	position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
}

.step-wrap .step-content .step-btn li label:hover img.on,
.step-wrap .step-content .step-btn li input[type="radio"]:checked+label  img.on
 {
	display: inline;
} 

.step-wrap .step-content .step-btn li label:hover,
.step-wrap .step-content .step-btn li input[type="radio"]:checked+label{
	border-color: #ec5504;
}

.step-wrap .step-content .step-btn li label .img
{    height: 70%;
    position: relative;}

.step-wrap .step-content .step-btn li label img.on{
	display: none;
}
.step-wrap .step-content .step-btn li label img.off{

}

.step-wrap .step-content .step-btn li label .text {
    font-size: 24px;
    font-weight: bold;
    line-height: 1;
    color: #ddd;
    height: 30%;
}

@media screen and (max-width:767px){
	.step-wrap .step-content .step-btn li label .text {
    font-size: 16px;
    font-weight: bold;
    line-height: 1.1;
    color: #ddd;
    height: 30%;
}
}
/* @media END*/


.step-wrap .step-content .step-btn li input[type="radio"]:checked+label .text {
    color: #333;
}
.step-wrap .step-content .step-btn li input[type="radio"]{
	display: none;
}


/*选择电话号码*/
.phone_num-select li input[type="radio"] {
    display: none;
    opacity: 0;
    width: 0;
    height: 0;
    margin: 0;
    padding: 0;
}
.js-toggle-contents {
    display: none;
    margin: 40px auto;
}
.step-wrap .step-content .js-toggle-contents .step-ttl{
    font-size: 14px;
}
.step-wrap .step-content .js-toggle-contents .step-ttl span{
    font-size: 18px;
}

.phone_num-select li{
    float: left;
   
}
.phone_num-select li+li{
     margin-left: 10px;
}
.phone_num-select li label {
    display: block;
    background: url(../img/sprite-phone.png);
    cursor: pointer;
    height: 89px;
    width: 52px;
    box-sizing: content-box;
}
.phone_num-select li label.phone_num-1 {
    background-position: 0 0;
}
.phone_num-select li label.phone_num-1:hover,
.phone_num-select li #phone_num-1:checked+label
{
     background-position: 0 -90px;
}

.phone_num-select li label.phone_num-2 {
    background-position: 0 -360px;
}
.phone_num-select li label.phone_num-2:hover,
.phone_num-select li #phone_num-2:checked+label
{
    background-position: 0 -450px;
}
.phone_num-select li label.phone_num-3 {
    background-position: 0 -540px;
}
.phone_num-select li label.phone_num-3:hover,
.phone_num-select li #phone_num-3:checked+label
{
    background-position: 0 -630px;
}
.phone_num-select li label.phone_num-4 {
    background-position: 0 -720px;
}
.phone_num-select li label.phone_num-4:hover,
.phone_num-select li #phone_num-4:checked+label
{
    background-position: 0 -810px;
}
.phone_num-select li label.phone_num-5 {
    background-position: 0 -900px;
}
.phone_num-select li label.phone_num-5:hover,
.phone_num-select li #phone_num-5:checked+label
{
    background-position: 0 -990px;
}
.phone_num-select li label.phone_num-6 {
    background-position: 0 -1080px;
}
.phone_num-select li label.phone_num-6:hover,
.phone_num-select li #phone_num-6:checked+label
{
    background-position: 0 -1170px;
}
.phone_num-select li label.phone_num-7 {
    background-position: 0 -1260px;
}
.phone_num-select li label.phone_num-7:hover,
.phone_num-select li #phone_num-7:checked+label
{
    background-position: 0 -1350px;
}
.phone_num-select li label.phone_num-8 {
    background-position: 0 -1440px;
}
.phone_num-select li label.phone_num-8:hover,
.phone_num-select li #phone_num-8:checked+label
{
    background-position: 0 -1530px;
}
.phone_num-select li label.phone_num-9 {
    background-position: 0 -1620px;
}
.phone_num-select li label.phone_num-9:hover,
.phone_num-select li #phone_num-9:checked+label
{
    background-position: 0 -1710px;
}
.phone_num-select li label.phone_num-10 {
    background-position: 0 -180px;
}
.phone_num-select li label.phone_num-10:hover,
.phone_num-select li #phone_num-10:checked+label
{
    background-position: 0 -270px;
}
.btn-detail{}

.btn-detail dt{
    font-size: 16px;
    font-weight: bold;
    line-height: 40px;
    color: #ec5504;
    max-width: 72%;
    margin: 0px auto 20px;
    background-color: #fff;
    border-radius: 4px;
    border: 1px solid #ec5504;
    display: block;
    text-align: center;
    box-sizing: border-box;
    position: relative;
    text-decoration: none;
    cursor: pointer;
}
.btn-detail dt:hover{
    background-color: #ec5504;
    color: #fff;  
}
.btn-detail dt::after
{
    content: '';
    margin: auto;
    vertical-align: middle;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 10px;
    width: 5px;
    height: 5px;
    border-bottom: 2px solid #ec5504;
    border-right: 2px solid #ec5504;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.btn-detail dt.open::after{
    -webkit-transform: rotate(225deg);
    transform: rotate(225deg);
}

.btn-detail.js-detail{
    margin: 30px auto 24px;
    text-align: center;
}

.btn-detail  dd
{
  
}
.btn-detail  dd .text
{
    font-size: 13px;
    line-height: 1.9;
    padding: 20px 25px;
    background-color: #f2f2f2;
}
.step-wrap .step-content .step-btn li label .balloon-text {
    position: relative;
    display: inline-block;
    padding: 5px 10px;
    background: #ddd;
    font-size: 16px;
    font-weight: bold;
    color: #fff;
}

.step-wrap .step-content .step-btn li label:hover .balloon-text,
.step-wrap .step-content .step-btn li input[type="radio"]:checked+label .balloon-text{
    background-color: #ec5504;
}

#step-mail_result .step-content .step-btn li:nth-child(1) label .img{
    height: 56%;
}

.mail-detail{
        margin-top: 20px;
    text-align: left;
    border: 1px dotted #333;
    box-sizing: border-box;
}
.mail-detail .mail-inner{
        padding: 28px;
    background: #f2f2f2;
}
.mail-detail .mail-inner .text-box input{
    border: 1px solid #cbcbcb;
    border-radius: 5px;
    box-sizing: border-box;
    font-size: 18px;
    padding: 10px;
    width: 100%;
}
.mail-detail .mail-inner .consent-cont label{
    padding-left: 5px;
}
.mail-detail .mail-inner .consent-cont label a{
        text-decoration: underline;
    color: #222;
}
.mail-detail .mail-inner .consent-cont label a{
    text-decoration: underline;
    color: #222;
}
.mail-detail .consent-cont{
    text-align: center;
}
.mail-detail .mail-inner .btn-next a{
    -moz-box-shadow: 0 3px 0 0 #666;
    -webkit-box-shadow: 0 3px 0 0 #666;
    box-shadow: 0 3px 0 0 #666;
    display: block;
    position: relative;
    width: 350px;
    margin: 25px auto 0;
    padding: 14px 0 10px;
    text-align: center;
    text-decoration: none;
    background: #999;
    font-size: 18px;
    font-weight: bold;
    color: #fff;
    cursor: pointer;
}
#modal .modal-inner {
    padding: 35px 40px 0;
    display: block;
    min-height: 1%;
    position: relative;
    font-size: 14px
}

#modal .modal-inner:after {
    clear: both;
    content: ".";
    display: block;
    height: 0;
    visibility: hidden
}

#modal .modal-inner .tit-modal {
    font-size: 30px;
    font-weight: bold
}

#modal .modal-inner h2 {
    margin: 30px 0 20px 0;
    padding-left: 5px;
    font-size: 20px;
    line-height: 140%;
    color: #333;
    font-weight: bold;
    border-bottom: 1px solid #ec5504
}

#modal .modal-inner h3 {
    margin: 20px 0 14px 0;
    font-size: 1.3em;
    line-height: 120%;
    color: #303331
}

#modal .modal-inner p {
    margin: 20px 0;
    font-size: 0.95em;
    line-height: 140%;
    text-align: justify
}

#modal .modal-inner ul li {
    font-size: 0.95em;
    line-height: 140%;
    margin: 10px 0 0 0
}

#modal .modal-inner dl {
    padding: 18px 0 0 330px;
    line-height: 2
}

#modal .modal-inner dl dt {
    font-size: 16px;
    font-weight: bold
}

.modal-exit {
    cursor: pointer;
    width: 120px;
    margin: 40px auto 20px;
    padding: 5px 10px;
    background: #505050;
    font-size: 13px;
    font-weight: bold;
    color: #fff;
    text-align: center
}

.js-result {
    display: none;
    margin-bottom: 50px;
    background-color: #f8f8f8;
    position: relative;
    padding-top: 40px;
    background-color: #fff;
}


/*.js-result:before {
    content: '';
    border: 70px solid transparent;
    border-top: 50px solid #f8f8f8;
    display: inline-block;
    box-sizing: border-box;
    position: absolute;
    left: 50%;
    bottom: -120px;
    margin-left: -70px
}*/
/*.js-result:after {
    top: 0;
    bottom: auto
}*/


/* kekka
--------------------------*/
.container-1 {
  width: 1000px;
  margin-left: auto;
  margin-right: auto;
  padding:0;
}

#result {
    margin-top: 30px
}

#result .result-ttl {
    text-align: center;
    margin-bottom: 10px
}

#result .result-ttl span {
    font-size: 40px;
    font-weight: bold;
    color: #ec5504;
    padding-left: 48px;
    position: relative;
    display: inline-block;
    padding-top:4px;
}

#result .result-ttl span:before {
    content: '';
    width: 35px;
    height: 40px;
    background: url('../img/calculator.png?1505792198') no-repeat center center;
    background-size: contain;
    display: block;
    position: absolute;
    left: 0;
}

#result .result-ttl span:before {
    top: 50%;
    margin-top: -20px
}

#result .result-ttl+.result-ttl-text {
    font-size: 17px;
    margin-bottom: 40px;
    text-align: center
}

/****/
#result .result-wrap {
    border: 2px solid #EC5504;
    box-sizing: border-box;
    z-index: 1;
    border-radius:2px;
}

#result .result-wrap .result-contents {
    padding: 24px 40px;
    padding-bottom: 16px;
    background-color: #fff
}

#result .result-wrap .result-contents .result-caption {
    font-size: 23px;
    font-weight: bold;
    line-height: 50px;
    color: #fff;
    margin-bottom: 20px;
    text-align: center;
    background-color: #ec5504
}

#result .result-wrap .result-contents .plan-contents {
    overflow: hidden;
    *zoom:1}
#result .result-wrap .result-contents .plan-contents li {
    width: 160px;
    margin-left: 25px;
    float: left
}
#result .result-wrap .result-contents .plan-contents li:first-child {
    margin-left: 0
}

#result .result-wrap .result-contents .plan-contents li dl {
    width: 100%;
    text-align: center;
    border: 3px solid #d8dadc;
    border-top: none;
    display: table
}
#result .result-wrap .result-contents .plan-contents li dl dt {
    font-size: 13px;
    line-height: 30px;
    background-color: #d8dadc;
    display: table-row
}
#result .result-wrap .result-contents .plan-contents li dl dd {
    font-size: 14px;
    height: 67px;
    position: relative;
    display: table-row
}
#result .result-wrap .result-contents .plan-contents li dl dd>* {
    display: table-cell;
    vertical-align: middle
}



/* result-price
-------------------------------------------------------------*/
#result .result-wrap .result-contents .result-price {
    margin-top: 20px;
}
#result .result-wrap .result-contents .result-price ul {
    font-size: 0;
    letter-spacing: 0
}
#result .result-wrap .result-contents .result-price ul li {
    margin-left: 55px;
    display: inline-block;
    text-align: center;
    position: relative
}


/* result-price*********2*********
-------------------------------------------------------------*/
#result .result-wrap .result-contents .result-price2{
    margin-top: 20px;
}
#result .result-wrap .result-contents .result-price2 ul {
    font-size: 0;
    letter-spacing: 0
}
#result .result-wrap .result-contents .result-price2 ul li {
    margin-left: 55px;
    display: inline-block;
    text-align: center;
    position: relative
}


/* result-price
-------------------------------------------------------------*/
#result .result-wrap .result-contents .result-price ul li:before {
    content: '';
    display: inline-block;
    width: 15px;
    height: 35px;
    background: url('../img/price-arrow.png?1505792198') no-repeat center center;
    background-size: contain;
    box-sizing: border-box;
    position: absolute;
    top: 50%;
    left: -27px;
    margin-top: -17.5px;
    margin-left: -7.5px
}
#result .result-wrap .result-contents .result-price ul li:first-child {
    margin-left: 0
}
#result .result-wrap .result-contents .result-price ul li:first-child:before {
    content: none
}
#result .result-wrap .result-contents .result-price ul li dl {
    text-align: center;
    border-top: none;
    display: table;
    box-sizing: border-box
}
#result .result-wrap .result-contents .result-price ul li dl.price-before {
    width: 270px;
    border: 1px dotted #333
}
#result .result-wrap .result-contents .result-price ul li dl.price-before dt {
    font-size: 17px;
    line-height: 40px;
    background-color: #f2f2f2;
    display: table-row
}
#result .result-wrap .result-contents .result-price ul li dl.price-before dd {
    font-size: 26px;
    height: 85px;
    position: relative;
    display: table-row
}
#result .result-wrap .result-contents .result-price ul li dl.price-before dd>* {
    display: table-cell;
    vertical-align: middle
}
#result .result-wrap .result-contents .result-price ul li dl.price-before dd .num {
    font-size: 46px;
    font-weight: bold;
    font-family: Helvetica, Arial, sans-serif;
		vertical-align:40%;
}
#result .result-wrap .result-contents .result-price ul li dl.price-before dd .yen {
    font-weight: bold
}
#result .result-wrap .result-contents .result-price ul li dl.price-before dd .tax {
    font-size: 13px;
    font-weight: normal
}



#result .result-wrap .result-contents .result-price ul li dl.price-after {
    width: 850px;/*545px;*/
    border: 4px solid #ec5504;
    border-top: none;
}

#result .result-wrap .result-contents .result-price ul li dl.price-after dt {
    font-size: 22px;
    font-weight: bold;
    line-height: 42px;
    color: #fcff00;
    background-color: #ec5504;
    display: table-row;
    position: relative
}


/* result-price*********2*********
-------------------------------------------------------------*/
#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 {
    width: 850px;
    border: 4px solid #009AE1;
    border-top: none;
}
#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 dt {
    font-size: 22px;
    width: 850px;
    font-weight: bold;
    line-height: 42px;
    color: #fcff00;
    background-color: #009AE1;
    display: table-row;
    position: relative;
}



/* result-price
-------------------------------------------------------------*/
#result .result-wrap .result-contents .result-price ul li dl.price-after dd {
    font-size: 26px;
    height: 85px;
    position: relative;
    display: table-row
}
#result .result-wrap .result-contents .result-price ul li dl.price-after dd>* {
    display: table-cell;
    vertical-align: middle;
    padding-left: 15px;
    padding-right: 15px;
    *zoom:1;text-align: left;
    font-size: 0
}
#result .result-wrap .result-contents .result-price ul li dl.price-after dd>*:after {
    content: "";
    display: table;
    clear: both
}
#result .result-wrap .result-contents .result-price ul li dl.price-after dd .good_value {
    width: 230px;/*190px;*/
    font-size: 15px;
    font-weight: bold;
    line-height: 1.3;
    margin-right: 25px;
    padding-top: 13px;
    padding-bottom: 13px;
    text-align: center;
    background-color: #f2f2f2;
    display: inline-block;
    vertical-align: middle
}
#result .result-wrap .result-contents .result-price ul li dl.price-after dd .price-fee {
    display: inline-block;
    vertical-align: middle
}
#result .result-wrap .result-contents .result-price ul li dl.price-after dd .price-fee .fee {
    font-size: 32px;
    font-weight: bold;
    line-height: 1.1;
    color: #333333;
    width: 4em;
    margin-right: 15px;
    display: inline-block;
    /*word-break: break-word*/
	vertical-align:10%;
}

/* result-price*********2*********
-------------------------------------------------------------*/
#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 dd {
    font-size: 26px;
    height: 85px;
    position: relative;
    display: table-row
}
#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 dd>* {
    display: table-cell;
    vertical-align: middle;
    width: 850px;
    padding-left: 15px;
    padding-right: 15px;
    *zoom:1;text-align: left;
    font-size: 0
}
#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 dd>*:after {
    content: "";
    display: table;
    clear: both
}
#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 dd .good_value {
    width: 230px;/*190px;*/
    font-size: 15px;
    font-weight: bold;
    line-height: 1.3;
    margin-right: 25px;
    padding-top: 13px;
    padding-bottom: 13px;
    text-align: center;
    background-color: #f2f2f2;
    display: inline-block;
    vertical-align: middle
}
#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 dd .price-fee2 {
    display: inline-block;
    vertical-align: middle;
}
#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 dd .price-fee2 .fee2 {
    font-size: 32px;
    font-weight: bold;
    line-height: 1.1;
    color: #333333;
    width: 4em;
    margin-right: 15px;
    display: inline-block;
    /*word-break: break-word*/
	vertical-align:10%;
}



/* result-price
-------------------------------------------------------------*/
#result .result-wrap .result-contents .result-price ul li dl.price-after dd .price-fee .fee2 {
    font-size: 32px;
    font-weight: bold;
    line-height: 1.1;
    color: #333333;
    width: 2.2em;
    margin-right: 15px;
    display: inline-block;
    /*word-break: break-word*/
	vertical-align:10%;
}
#result .result-wrap .result-contents .result-price ul li dl.price-after dd .price-fee .num {
    font-size: 64px;
    font-weight: bold;
    line-height: 1;
    color: #ec5504;
    font-family: Helvetica, Arial, sans-serif
}
#result .result-wrap .result-contents .result-price ul li dl.price-after dd .price-fee .yen {
    font-size: 33px;
    font-weight: bold;
    line-height: 1;
    color: #444444;
    position: relative;
    display: inline-block;
	vertical-align:10%;
}
#result .result-wrap .result-contents .result-price ul li dl.price-after dd .price-fee .tax {
	font-size: 14px;
	font-weight: bold;
	color: #333;
	width: 4em;
	position: absolute;
	top: 14px;
	left: 30px
}

/* result-price*********2*********
-------------------------------------------------------------*/
#result .result-wrap .result-contents .result-price2 ul li dl.price-afte2 dd .price-fee2 .fee2 {
    font-size: 32px;
    font-weight: bold;
    line-height: 1.1;
    color: #333333;
    width: 2.2em;
    margin-right: 15px;
    display: inline-block;
    /*word-break: break-word*/
	vertical-align:10%;
}


#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 dd .price-fee2 .num2 {
    font-size: 64px;
    font-weight: bold;
    line-height: 1;
    color: #ec5504;
    font-family: Helvetica, Arial, sans-serif
}

#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 dd .price-fee2 .yen2 {
    font-size: 33px;
    font-weight: bold;
    line-height: 1;
    color: #444444;
    position: relative;
    display: inline-block;
	vertical-align:10%;
}

#result .result-wrap .result-contents .result-price2 ul li dl.price-after2 dd .price-fee2 .tax2 {
	font-size: 14px;
	font-weight: bold;
	color: #333;
	width: 4em;
	position: absolute;
	top: 14px;
	left: 30px
}



/*limit 調整
----------------*/
.limit,
.limit2
{
  font-size:22px;
  line-height:45px !important;
  padding-top:10px;
  letter-spacing: 0.1em;
}


/*********************************************************/


#result .result-wrap .result-contents .result-price ul li dl.price-after dd .balloon {
    position: absolute;
    z-index: 0;
    top: -35px;
    right: -65px
}
#result .result-wrap .result-contents .result-note {
    margin-top: 20px
}
#result .result-wrap .result-contents .price-breakdown {
    margin-bottom: 30px;
}
#result .result-wrap .result-contents .price-breakdown dd {
    border: none
}
#result .result-wrap .result-contents .price-breakdown dd .price-breakdown-table {
    width: 850px;
    border: 1px solid #ddd;
  margin:auto;
}
#result .result-wrap .result-contents .price-breakdown dd .price-breakdown-table+.text-link {
    margin-top: 15px;
    text-align: right
}
#result .result-wrap .result-contents .price-breakdown dd .price-breakdown-table tr {
    border-top: 1px solid #ddd
}
#result .result-wrap .result-contents .price-breakdown dd .price-breakdown-table tr:first-child {
    border-top: none
}
#result .result-wrap .result-contents .price-breakdown dd .price-breakdown-table tr th,#result .result-wrap .result-contents .price-breakdown dd .price-breakdown-table tr td {
    height: 40px;
    text-align: center;
    vertical-align: middle;
    border-right: 1px solid #ddd
}
#result .result-wrap .result-contents .price-breakdown dd .price-breakdown-table tr th:last-child,#result .result-wrap .result-contents .price-breakdown dd .price-breakdown-table tr td:last-child {
    border-right: none
}
#result .result-wrap .result-contents .price-breakdown dd .price-breakdown-table tr th {
    background-color: #f2f2f2
}
#result .result-wrap .result-contents .price-breakdown dd .price-breakdown-table tr td {
    width: 22%
}
#result .result-wrap .result-contents .result-campaign ul {
    font-size: 0;
    letter-spacing: 0
}
#result .result-wrap .result-contents .result-campaign ul li {
    width: 18.72%;
    margin-left: 1.6%;
    display: inline-block
}
#result .result-wrap .result-contents .result-campaign ul li:first-child {
    margin-left: 0
}
#result .result-wrap .result-contents .result-campaign ul li img {
    max-width: 100%
}
#result .result-wrap .result-contents .result-campaign .text-link {
    margin-top: 30px;
    text-align: right
}
#result .result-wrap .btn-result {
    width: 540px;
    margin: 0 auto 60px
}
#result .result-wrap .btn-result .btn {
    font-size: 0;
    width: 540px;
    height: 70px;
    padding-bottom: 3px;
    display: inline-block;
    text-align: center;
    vertical-align: bottom;
    position: relative;
    box-sizing: border-box
}
#result .result-wrap .btn-result .btn a {
    font-size: 25px;
    font-weight: bold;
    line-height: 70px;
    height: 100%;
    padding-top: 0px;
    padding-bottom: 0px;
    display: block;
    text-decoration: none;
    outline: none;
    box-sizing: border-box;
    position: relative;
    color: #fff;
    background-color: #ec5504;
    box-shadow: 0 3px 0 #bd4403
}
#result .result-wrap .btn-result .btn a:hover {
    box-shadow: 0 1px 0 #bd4403
}
#result .result-wrap .btn-result .btn a:after {
    right: 10px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg)
}
#result .result-wrap .btn-result .btn a:hover {
    top: 2px
}
#result .result-wrap .btn-result .btn a:before,#result .result-wrap .btn-result .btn a:after {
    content: '';
    margin: auto;
    vertical-align: middle;
    position: absolute;
    top: 0;
    bottom: 0
}
#result .result-wrap .btn-result .btn a span {
    font-size: 0px;
    line-height: 0px;
    width: 100%;
    display: block;
    text-align: center;
    position: absolute
}
#result .result-wrap .btn-result .btn a:after {
    right: 20px;
    width: 6px;
    height: 6px;
    border-top: none;
    border-bottom: solid 2px #fff
}
#result .result-wrap .btn-repeat {
    width: 500px;
    margin: 20px auto 0
}
#result .result-wrap .btn-repeat .btn {
    font-size: 0;
    width: 500px;
    height: 40px;
    padding-bottom: 3px;
    display: inline-block;
    text-align: center;
    vertical-align: bottom;
    position: relative;
    box-sizing: border-box
}
#result .result-wrap .btn-repeat .btn a {
    font-size: 13px;
    font-weight: bold;
    line-height: 40px;
    height: 100%;
    padding-top: 0px;
    padding-bottom: 0px;
    display: block;
    text-decoration: none;
    outline: none;
    box-sizing: border-box;
    position: relative;
    color: #fff;
    background-color: #909090;
    box-shadow: 0 3px 0 #737373
}
#result .result-wrap .btn-repeat .btn a:hover {
    box-shadow: 0 1px 0 #737373
}
#result .result-wrap .btn-repeat .btn a:after {
    right: 10px;
    width: 5px;
    height: 5px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg)
}
#result .result-wrap .btn-repeat .btn a:hover {
    top: 2px
}
#result .result-wrap .btn-repeat .btn a:before,#result .result-wrap .btn-repeat .btn a:after {
    content: '';
    margin: auto;
    vertical-align: middle;
    position: absolute;
    top: 0;
    bottom: 0
}
#result .result-wrap .btn-repeat .btn a span {
    font-size: 0px;
    line-height: 0px;
    width: 100%;
    display: block;
    text-align: center;
    position: absolute
}
#result .result-wrap .btn-repeat .btn a:before {
    content: url('../img/repeat.png?1505792198');
    margin-top: 2px;
    margin-left: -20px
}
#result .result-wrap .btn-repeat .btn a:after {
    display: none
}
#result .result-wrap .result-contents .price-breakdown dd .Text-Table tr td{
	text-align:left;
}
#result .v16{
  font-size: 14px;
  padding:0
}
.js-htmlmeilsend{
    width: 350px;
    margin: 0 auto;
}
.js-htmlmeilsend.active{
    background-color: #ec5504;

}
#form {
    margin-top: 80px;
    background-color: #f5f5f5;
    *zoom:1}

#form:after {
    content: "";
    display: table;
    clear: both
}

#form .fd {
    font-family: Helvetica, Arial, sans-serif;
    font-size: 34px;
    font-weight: bold;
    color: #333;
    letter-spacing: 0;
    line-height: 1;
    padding-left: 34px;
    position: relative;
    display: inline-block
}
#form .fd:before {
    content: '';
    width: 24px;
    height: 16px;
    background: url('../img/fd-green.png?1505792198') no-repeat center center;
    background-size: contain;
    display: block;
    position: absolute;
    left: 0
}
#form .fd:before {
    bottom: 15%
}
#form .form-ttl {
    font-size: 37px;
    font-weight: bold;
    line-height: 120px;
    color: #fff;
    text-align: center;
    background-color: #ec5504;
    margin-bottom: 77px;
    background-color: #ec5504;
    position: relative
}
#form .form-ttl:before {
    content: '';
    border: 70px solid transparent;
    border-top: 50px solid #ec5504;
    display: inline-block;
    box-sizing: border-box;
    position: absolute;
    left: 50%;
    bottom: -120px;
    margin-left: -70px
}
#form #form-header {
    padding: 0;
    margin-bottom: 50px;
    background-color: #f5f5f5;
    border: none;
    overflow: hidden;
    *zoom:1}
#form #form-header .header-logo {
    float: left
}
#form #form-header .header-logo .logo {
    font-size: 23px;
    font-weight: bold;
    line-height: 1;
    margin-top: 0;
    margin-bottom: 20px;
    float: none
}
#form #form-header .header-logo .logo span {
    margin-left: 10px;
    vertical-align: bottom
}
#form #form-header .header-logo .logo-text {
    font-size: 13px;
    line-height: 1.9
}
#form-header .header-info {
    float: right
}
#form #form-header .header-info .header-info-left {
    float: none
}
#form #form-header .header-info .header-info-left .text {
    font-size: 13px;
    font-weight: bold;
    margin-bottom: 5px
}
#form #form-header .header-info .time {
    font-size: 11px;
    line-height: 1;
    float: none;
    background: none;
    margin: 0;
    margin-top: 10px;
    padding: 0;
    text-align: left
}
#form .ssl {
    margin-top: 80px
}
.form-flow-list {
    font-size: 0;
    font-weight: bold;
    letter-spacing: 0;
    margin-bottom: 30px;
    text-align: center;
    overflow: hidden
}

.form-flow-list li {
    font-size: 12px;
    line-height: 40px;
    color: #fff;
    letter-spacing: 0.05em;
    width: 33.333333%;
    padding-right: 15px;
    padding-left: 15px;
    display: inline-block;
    background-color: #909090;
    box-sizing: border-box;
    position: relative;
    z-index: 2
}

.form-flow-list li:first-child {
    z-index: 3
}
.form-flow-list li:first-child:before {
    content: none
}
.form-flow-list li:last-child {
    z-index: 1
}
.form-flow-list li:last-child:after {
    content: none
}

.form-flow-list li:before {
    content: '';
    border-top: 30px solid transparent;
    border-left: 15px solid #f5f5f5;
    border-right: 15px solid transparent;
    border-bottom: 30px solid transparent;
    position: absolute;
    left: 0px;
    top: 50%;
    margin-top: -30px
}

.form-flow-list li:after {
    content: '';
    border-top: 20px solid transparent;
    border-left: 10px solid #909090;
    border-right: 10px solid transparent;
    border-bottom: 20px solid transparent;
    position: absolute;
    right: -20px;
    top: 50%;
    margin-top: -20px
}

.form-flow-list li.active {
    color: #fff;
    background-color: #ec5504
}

.form-flow-list li.active:after {
    border-left-color: #ec5504
}

.contract-tbl {
    width: 100%;
    font-size: 12px;
    color: #333;
    margin-bottom: 50px;
    border: 1px solid #ccc
}

.contract-tbl tr {
    border-top: 1px solid #ccc
}

.contract-tbl tr:first-child {
    border-top: none
}

.contract-tbl tr th,.contract-tbl tr td {
    padding: 20px 15px;
    font-size: 13px;
    vertical-align: top;
    border-left: 1px solid #ccc
}

.contract-tbl tr th:first-child,.contract-tbl tr td:first-child {
    border-left: none
}

.contract-tbl tr th {
    width: 20%;
    font-weight: bold;
    background: #eee;
    overflow: hidden;
    *zoom:1}

.contract-tbl tr th span {
    float: right;
    font-size: 11px;
    font-weight: normal;
    padding: 2px 6px;
    border-radius: 3px
}

.contract-tbl tr th span.require {
    color: #fff;
    background-color: #ec5504
}

.contract-tbl tr th span.optional {
    color: #000;
    background-color: #fff
}

.contract-tbl tr td {
    width: 80%;
    background: #fff
}

.contract-tbl tr td:nth-child(2):nth-last-child(3),.contract-tbl tr td:nth-child(4):nth-last-child(1) {
    width: 30%
}

.contract-tbl tr td .note {
    margin-left: 10px;
    display: inline-block;
    vertical-align: middle
}

.contract-tbl tr td .note.aside {
    margin-left: 0
}

.contract-tbl tr td .form-label {
    font-size: 12px;
    width: 120px;
    display: inline-block;
    text-align: right;
    vertical-align: middle
}

.contract-tbl tr td .form-label+.input-box {
    margin-left: 10px
}

.contract-tbl tr td .input-box {
    font-size: 12px;
    margin-left: 130px;
    display: inline-block;
    vertical-align: middle;
    position: relative
}

.contract-tbl tr td .row {
    font-size: 0;
    margin-top: 10px;
    *zoom:1}

.contract-tbl tr td .row:after {
    content: "";
    display: table;
    clear: both
}

.contract-tbl tr td .row:first-child {
    margin-top: 0
}

.contract-tbl tr td .row .col {
    width: 100%;
    display: inline-block;
    float: left;
    box-sizing: border-box
}

.contract-tbl tr td .row .col:first-child:nth-last-of-type(2),.contract-tbl tr td .row .col:first-child:nth-last-of-type(2)+.col {
    width: 330px
}


#input-btn {
    *zoom:1;text-align: center
}

#input-btn:after {
    content: "";
    display: table;
    clear: both
}
#input-btn input[type="submit"].btn-disable {
    background-image: url('../img/arrow-btn-w.png?1506304173');
    background-color: #909090;
    color: #fff;
    box-shadow: 0 3px 0 #737373
}

.ssl {
    font-size: 14px;
    font-weight: bold;
    line-height: 1;
    padding-top: 50px;
    padding-bottom: 50px;
    text-align: center;
    background-color: #fff
}

.ssl p {
    text-align: left;
    padding-left: 48px;
    position: relative;
    display: inline-block
}

.ssl p:before {
    content: '';
    width: 38px;
    height: 50px;
    background: url('../img/ssl.png?1505792198') no-repeat center center;
    background-size: contain;
    display: block;
    position: absolute;
    left: 0
}

.ssl p span {
    font-size: 10px;
    font-weight: normal
}
.contract-tbl input[type="text"],.contract-tbl input[type="tel"],.contract-tbl input[type="email"],.contract-tbl select,.contract-tbl textarea {
    font-size: 12px;
    line-height: 1.5;
    min-width: 190px;
    padding: 5px;
    border: 1px solid #ddd;
    border-radius: 3px;
    box-sizing: border-box;
}

.contract-tbl input[type="text"].js_is_error,.contract-tbl input[type="tel"].js_is_error,.contract-tbl input[type="email"].js_is_error,.contract-tbl select.js_is_error,.contract-tbl textarea.js_is_error {
    border-color: #333;
    background-color: #fffbd5;
}

.contract-tbl input[type="text"].min_w-a,.contract-tbl input[type="tel"].min_w-a,.contract-tbl input[type="email"].min_w-a,.contract-tbl select.min_w-a,.contract-tbl textarea.min_w-a {
    margin-right: .5em;
    min-width: auto
}

.contract-tbl input[type="text"].full,.contract-tbl input[type="tel"].full,.contract-tbl input[type="email"].full,.contract-tbl select.full,.contract-tbl textarea.full {
    width: 450px
}

.contract-tbl textarea {
    width: 100%;
    resize: vertical
}

.contract-tbl .pop-require {
    font-size: 12px;
    min-width: 100px;
    color: #fff;
    text-align: left;
    display: none;
    padding: 5px 10px;
    background: #333;
    position: absolute;
    top: -30px;
    left: 20px;
    z-index: 100
}

.contract-tbl .pop-require:after {
    content: url('../../img/icon/arrow-require.png?1506304173');
    width: 14px;
    height: 7px;
    position: absolute;
    bottom: -2px;
    left: 25px
}

.contract-tbl .pop-require.long {
    width: 220px
}

.contract-tbl .image-list {
    width: 560px;
    *zoom:1}

.contract-tbl .image-list:after {
    content: "";
    display: table;
    clear: both
}

.contract-tbl .image-list li {
    margin-bottom: 10px;
    float: left
}

.contract-tbl .image-list li:first-child {
    margin-left: 0
}

.contract-tbl .image-list li.active label:before {
    content: '';
    display: block;
    position: absolute;
    top: -1px;
    left: -1px;
    right: -1px;
    bottom: -1px;
    border: 2px solid #999
}

.contract-tbl .image-list li label {
    font-size: 0;
    letter-spacing: 0;
    padding: 5px 15% 5px 0;
    border: 1px solid #ddd;
    display: block;
    position: relative;
    box-sizing: border-box
}

.contract-tbl .image-list li label p:not(.pop-require) {
    display: inline-block;
    text-align: center;
    vertical-align: middle
}

.contract-tbl .image-list li label p:not(.pop-require).input {
    width: 30%
}

.contract-tbl .image-list li label p:not(.pop-require).img {
    width: 70%
}

.contract-tbl .image-list li label p:not(.pop-require).img img {
    width: auto;
    max-width: 100%
}

.contract-tbl #credit li {
    width: 19%;
    margin-left: 1%
}

.contract-tbl #credit li:first-child,.contract-tbl #credit li:nth-child(5n+1) {
    margin-left: 0
}

.contract-tbl #terminal li {
    width: 49%;
    margin-left: 2%
}

.contract-tbl #terminal li:first-child,.contract-tbl #terminal li:nth-child(2n+1) {
    margin-left: 0
}

.contract-tbl #terminal li label {
    padding: 5px
}

.contract-tbl #terminal li label p:not(.pop-require).input {
    width: 10%
}

.contract-tbl #terminal li label p:not(.pop-require).img {
    width: 32%
}

.contract-tbl #terminal li label p:not(.pop-require).text {
    font-size: 12px;
    font-weight: bold;
    width: 55%;
    margin-left: 3%;
    text-align: left
}

.contract-tbl #color li {
    width: 24%;
    margin-left: 1%
}

.contract-tbl #color li:first-child,.contract-tbl #color li:nth-child(4n+1) {
    margin-left: 0
}

.contract-tbl #color li label {
    padding: 5px
}

.contract-tbl #color li label p:not(.pop-require).input {
    width: 20%
}

.contract-tbl #color li label p:not(.pop-require).img {
    width: 25%;
    text-align: center
}

.contract-tbl #color li label p:not(.pop-require).img .color {
    width: 30px;
    height: 30px;
    border: 1px solid #ddd;
    border-radius: 3px;
    display: inline-block;
    box-sizing: border-box
}

.contract-tbl #color li label p:not(.pop-require).img .color.color-1 {
    background-color: #333
}

.contract-tbl #color li label p:not(.pop-require).img .color.color-2 {
    background-color: #333
}

.contract-tbl #color li label p:not(.pop-require).img .color.color-3 {
    background-color: #333
}

.contract-tbl #color li label p:not(.pop-require).img .color.color-4 {
    background-color: #333
}

.contract-tbl #color li label p:not(.pop-require).img .color.color-5 {
    background-color: #333
}

.contract-tbl #color li label p:not(.pop-require).img .color.color-6 {
    background-color: #333
}

.contract-tbl #color li label p:not(.pop-require).img .color.color-7 {
    background-color: #333
}

.contract-tbl #color li label p:not(.pop-require).img .color.color-8 {
    background-color: #333
}

.contract-tbl #color li label p:not(.pop-require).text {
    font-size: 12px;
    font-weight: bold;
    width: 52%;
    margin-left: 3%;
    text-align: left
}

.contract-tbl .accordion-content {
    display: none
}


/**********************************************************/
/* STEP1
------------------------------------------*/
.selectWrap{
  width: 80%;
  position: relative;
  display: inline-block;
  margin:auto 10%;
}

.selectWrap::after {
  content: '';
  width: 6px;
  height: 6px;
  border: 0px;
  border-bottom: solid 2px #454545;
  border-right: solid 2px #454545;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 14px;
  margin-top: -4px;
}
.select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 100%;
  height: 50px;
  background: transparent;
  position: relative;
  z-index: 1;
  padding: 0 40px 0 20px;
  border: 2px solid #EC5504;
  border-radius: 6px;
  font-size:20px;
  font-weight:normal;
}

select::-ms-expand {
    display: none;
}

/* form
------------------------------------*/
.moushikomi_wrap {
  width:100%;
  max-width:1060px;
  margin:60px auto;
}

/* campaign_title
----------------------------------*/
p.campaign_img {
  margin-top:60px;
  margin-bottom:-30px;
  text-align:center;
}

.campaign_img_text {
    font-size:12px;
    line-height:1.6;
    text-align:left;
    
  }
.campaign_img_text span {
	display:inline-block;
	text-indent: -0.5em !important;
}

 .camaign_img_text_wrap {
    width:100%;
    margin:1em auto;
    padding:0 1.8em;
    box-sizing:border-box;
  }
  .camaign_img_text_wrap h3 {
    font-size:13px;
    line-height:1.5;
    text-align:left;
    margin-top:.5em;
    letter-spacing: 0.1em;
  }  
 .camaign_img_text_wrap h3 span {
      color:#777777;
  }

/* accordion
------------------------------*/
.accord_text {
  text-align:justify;
}
.accord_text22 {
  text-align:justify;
	margin:-1em 1em 0 !important;
}
/* form subtitle
------------------------------*/
p.form_title_attention_p {
  text-align:center;
  margin:0 auto .4em;
  padding:0;
  box-sizing: border-box;
  font-weight: bold;
   color:#ff0000;
  font-size:1.3em;
}
p.form_title_attention_p a {
   color:#ff0000 !important;
  margin:.2em auto;
  padding:0;
}

p.form_title_attention_p2 {
  text-align:center;
  margin:1em auto .7em !important;
  padding:0;
  box-sizing: border-box;
  font-weight: bold;
   color:#ff0000;
  font-size:1.3em;
}
p.form_title_attention_p2 a {
   color:#ff0000 !important;
  margin:1em auto .7em !important;
  padding:0;
}




/*p.form_title_attention_p span.tokuten {
    color:#EB5505;
}*/

/*
.footer_c {
	font-size: 10px;
	line-height: 40px;
	margin:60px 0px 0px 0px;
	padding: 24px 0;
  width:100%;
  background:#F3F3F3;
  text-align:center;
}*/


/*表示切替
--------------------------*/

.pcpage{
display: block;
}
.smppage{
display: none;
}


/*20200708
--------------------------------------------------------------------*/
/*見出し*/
.top_cancel .midashi {
    margin: 0 auto 15px auto;
    background: #043786!important;
}
.kinou h2.midashi {
    margin: 40px auto;
    text-align: center;
    width: 1000px;
    background: #043786!important;
}
.midashi {
    background: #1092D6;
    color: #FFF;
    text-align: center;
    font-weight: bold;
    font-size: 32px;
    height: 80px;
    line-height: 80px;
    margin: 1em auto 0;
}


/*ご注意事項
--------------------------------------------*/
.acd label {
   display: block;
   margin:0 5px 10px;
   padding:15px;
   font-weight: bold;
   cursor :pointer;
	position:relative;
	box-sizing:border-box;
   text-align: center;
	border:1px solid #8F8F8F;
	font-size:15px;
	color:#8A8A8A;
	line-height: 1;
}
.acd label:after {
  content:"\f105";
	font-family:"Font Awesome 5 Free";
	font-size:25px;
	position:absolute;
	right:18px;
	top:9px;
}
/*チェックは隠す*/
.acd input {
    display: none;
}
/*中身を非表示にしておく*/
.acd .accshow {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
}

/*クリックで中身表示*/
.cssacc:checked + label + .accshow {
    height: auto;
    padding: 10px 20px;
    opacity: 1;
}

/*アイコンを入れ替える*/
.cssacc:checked + label:after {
    content: '\f107';
}
.chushaku {
    font-size: 11px!important;
    line-height: 1.5em!important;
    color: #575757!important;
    margin: 5px auto!important;
}

.chushaku10 {
    font-size: 10px!important;
    line-height: 1.5em!important;
    color: #575757!important;
    margin: 5px auto!important;
		/*text-align:center;*/
}

/*ご注意事項ここまで
--------------------------------------------*/


/*header
--------------------------*/
.d-header_content_left {
   padding: 15px 0 0;
    display: flex;
    position: relative;
}
.head_logo {
    width: 245px;
    height: 71px;
    background: url(../img/logo.png) 0 0 no-repeat;
    background-size: contain;
}
.head_logo a {
    display: block;
    width: 245px;
    height: 71px;
}
.head_logo h1 {
    display: none;
}
.d-header_content_left p{
    text-align: right;
    margin-top: -30px;
    font-size: 1.4em;
}
	
.d-header_content_right {
    padding: 15px 0 0px;
}
.d-header_content_right .spNone {
    letter-spacing: -.4em;
}
.d-header_content_right .spNone > * {
    display: inline-block;
}
.tel_area {
    width: 300px;
    float: right;
    margin-top: 7px;
    margin-right: 12px;
}
.tel_area p {
    margin: 0;
    line-height: initial;
    font-family: "Lucida Grande", "Lucida Sans Unicode", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", Helvetica, Arial, Verdana, sans-serif;
}
.tel_area p span:nth-child(1) {
    color: #FFFFFF;
    background: #FF0000;
    padding: 1px 6px 0 6px;
    border-radius: 3px;
    display: inline-block;
    margin-right: 5px;
    line-height: 18px;
    font-size: 12px;
    letter-spacing: 0.01em;
}
.tel_area p span:nth-child(2) {
    font-size: 14px;
    padding-top: 2px;
    letter-spacing: 0.01em;
}
.header_btn02 {
    width: 202px;
    float: right;
    margin: -5px 5px 0 0;
    padding: 0px;
    text-align: center;
}



/**************************************/
h2.midashi span.m_him{
	display:inline-block;
	background-color:#FC4679;
	border-radius: 24px;
	padding:0px 1em;
	font-size:24px;
	color:#FFED0D;
	margin-right:.5em;
	line-height:1.4;
	vertical-align: 2%;
	letter-spacing: 2%;
}
h2.midashi span.m_him i{
	font-family: "Roboto";
	font-size:30px;
	font-weight:700;
	color:#FFED0D;
	font-style:normal;
	padding:0 4px 0 6px;
	line-height:1.4;
	vertical-align: -2%;
}
div.bg_color_cloudwifi {
	background:#fff;
}
@media screen and (max-width:767px){
h2.midashi span.m_him{
	display:inline-block;
	background-color:#FC4679;
	border-radius: 24px;
	padding:1px .8em 0px;
	font-size:13px;
	color:#FFED0D;
	margin-right:.5em;
	line-height:1.8;
	vertical-align: 2%;
	letter-spacing: 2%;
}
h2.midashi span.m_him i{
	font-family: "Roboto";
	font-size:16px;
	font-weight:700;
	color:#FFED0D;
	font-style:normal;
	padding:0 4px 0 6px;
	line-height:1.1;
	vertical-align: -3%;
}
}

.main_acd{
	width: 1000px;
	margin: 0 auto;
    text-align: center;	
}
.pc_center{
	text-align: center;
}

@media screen and (max-width:767px){
.main_acd{
	width: 96%;
	margin: 0 auto;
}
.pc_center{
	text-align: left!important;
}
}

/*point
--------------------------*/

.box {
    position: relative;
}
.point_waku {
	display: table;
}
div.choosepoint div.box img.animate5 {
    margin: 0px auto;
    padding: 0 140px 15px;
    width: 100%;
}
.p5 {
	display: table-cell;
	text-align: center;
	width: 20%;
	}
.point_waku a img {
	/*transition-delay: .2s;*/
	border: 2px solid #DDF6FF;
	width:98%;
	opacity: 1;
}
.point_waku a:hover img {
	border: 2px solid #043786;
	width:98%;
	transition-delay: .1s;
	opacity: 1;
}
section#s-point1, section#s-point2, section#s-point3, section#s-point4, section#s-point5, section#s-point6 {
	margin-top: -60px !important;
	padding-top: 60px !important;
}

/*5つのポイント
---------------------------------------------- */
.choosepoint {
    background: #ddf6ff;
     padding: 0px 0px 20px; 
}
.choosepoint .box{
/*background:#FFF;*/
width: 1000px;
margin: 0 auto;
padding: 0 0 15px;
}
/****/
.point1{
background: #F5F5F7;
padding-bottom: 50px;
}
.point1 h2{
padding: 20px 0;
margin: 0;
text-align: center;
}
.point1 .box{
background:#FFF;
width: 1000px;
margin: 0 auto;
padding: 30px 15px 30px 15px;
}
.point1 .box h3{
}
.point1 p{
width: 900px;
margin: 40px auto 20px auto;
font-size: 14px;
}

.point2{
background: #FCE5F1;
padding-bottom: 50px;
}
.point2 h2{
padding: 20px 0;
margin: 0;
text-align: center;
}
.point2 .box{
background:#FFF;
width: 1000px;
margin: 0 auto;
padding: 30px 15px 30px 15px;
}
.point2 .box h3{
}
.point2 p{
width:900px;
margin: 40px auto 20px auto;
font-size: 14px;
}

.point3{
background: #F5F5F7;
padding-bottom: 50px;
}
.point3 h2{
padding: 20px 0;
margin: 0;
text-align: center;
}
.point3 .box{
background:#FFF;
width: 1000px;
margin: 0 auto;
padding: 30px 15px;
}
.point3 h3{
}
.point3 div.img_area{
padding: 0;
}
.point3 p{
width: 900px;
margin: 30px auto 20px auto;
font-size: 14px;
}
.point3 div.btn{
margin-top:40px;
}

.point4{
background: #EFFBFF;
padding-bottom: 50px;
}
.point4 h2{
padding: 20px 0;
margin: 0;
text-align: center;
}
.point4 .box{
background:#FFF;
width: 1000px;
margin: 0 auto;
padding: 30px 15px;
}
.point4 .box h3{
}
.point4 p{
width: 900px;
margin: 10px auto 15px auto;
font-size: 14px;
}

.point5{
background: #F5F5F7;
padding-bottom: 50px;
}
.point5 h2{
padding: 20px 0;
margin: 0;
text-align: center;
}
.point5 .box{
background:#FFF;
width: 1000px;
margin: 0 auto;
padding: 30px 15px 15px;
}
.point5 .box h3{
}
.point5 p{
width: 900px;
margin: 10px auto;
font-size: 14px;
}



/*便利な機能紹介
----------------------------------*/
.kinou{
padding-bottom: 0;
}
.kinou h2.midashi{
margin: 40px auto;
text-align: center;
width: 1000px;
background: #043786!important;
}
.kinou .box{
background:#FFF;
width: 1000px;
margin: 0 auto;
padding: 0 15px 10px 15px;
}
.kinou .box ul li{
box-sizing: border-box;
vertical-align: top;
}
.kinou .box ul li:nth-child(1){
width: 100%;
padding: 0 20px 20px 20px;
}
.kinou .box ul li:nth-child(2){
width:50%;
display: inline-block;
padding: 20px;
}
.kinou .box ul li:nth-child(3){
width:50%;
display: inline-block;
padding: 20px;

}
.kinou .box ul li h3{
color: #043786;
font-weight: bold;
font-size: 20px;
border-bottom: 2px solid #043786;
margin-bottom: 20px;
padding: 5px 0;
text-align: center;
}
.kinou .box ul li p{
font-size: 14px;
padding: 1rem 0;	
}

/*料金・サービス
--------------------------*/
.price4{
	width: 96%;
	margin: 0 auto;
}
.top_price {
    width: 1000px;
    margin: 0 auto;
    text-align: inherit;
}

.speed_bg {
    margin-bottom: 1em;
    width: 96%;
    margin: 0 auto;
}
.speed_bg img {
    margin: 0px auto 1em;
    text-align: center;
    display: block;
    width: 100%;
}
.price1 h2{
border-bottom: 2px solid #FF5252;
margin: 0;
}
.price1 h3{
padding: 20px 0;
margin: 0;
}
.price1 div.bg_area{
background-image: url("../img/price/price1_bg.png");
height: 357px;
margin-bottom: 10px;
}
.price1 p{
width: 900px;
margin: 15px auto;
font-size: 14px;
}

.price2{
background: #F3F3F3;
}
.price2 h2{
border-bottom: 2px solid #FF5252;
margin: 0;
}
.price2 div{
padding: 25px 0;
}

.price3 {
padding-bottom: 25px;
}
.price3 h2{
border-bottom: 2px solid #FF5252;
margin: 0;
}
.price3 div{
padding: 25px 0 0 0;
}
.price3 p{
width: 900px;
margin: 0 auto;
}


/*U2s*/
.price4 div.u2s{
margin-top: 40px;
}
.price4 div.u2s p{
clear: both;
/*padding: 20px;*/
}
.price4 div.u2s .left{
width: 21%;
float: left;
}
.price4 div.u2s .right{
width:79%;
float: left;
padding-left: 30px;
}
.price4 div.u2s .right p{
padding: 0;
margin: 0;
}
.price4 div.u2s .right table{
margin: 0 auto 20px auto;
}
.price4 div.u2s .right table tr:nth-child(1) td{
background: #043786;
color: #FFF;
padding:  7px 10px 5px 10px;
font-weight: bold;
font-size: 20px;
width: 100%;
border: 1px solid #043786;
text-align: left!important;
}
.price4 div.u2s .right table tr:nth-child(1) td span{
border-left: 5px solid #FFF;
padding-left: 15px;
}
.price4 div.u2s .right table tr:nth-child(1) td span span{
border: none;
font-size: 14px;
font-weight: normal;
}
.price4 div.u2s .right table tr:nth-child(even) td{
background: #D5F2F6;
padding:  7px 10px 5px 30px;
font-size: 16px;
width: 100%;
border: 1px solid #CCC;
}
.price4 div.u2s .right table tr:nth-child(3) td{
background: #FFF;
padding:  7px 10px 5px 30px;
font-size: 16px;
width: 100%;
border: 1px solid #CCC;
}
.price4 div.u2s .right table:nth-child(3) tr td{
width: 50%;
text-align: center;
}

/*G4*/
.price4 div.g4{
margin-top: 40px;
}
.price4 div.g4 p{
clear: both;
padding: 20px;
}
.price4 div.g4 .left{
width: 27%;
float: left;
}
.price4 div.g4 .right{
width: 73%;
float: left;
padding-left: 30px;
}
.price4 div.g4 .right p{
padding: 0;
margin: 0;
}
.price4 div.g4 .right table{
margin: 0 auto 20px auto;
}
.price4 div.g4 .right table tr:nth-child(1) td{
background: #043786;
color: #FFF;
padding:  7px 10px 5px 10px;
font-weight: bold;
font-size: 20px;
width: 100%;
border: 1px solid #043786;
text-align: left!important;
}
.price4 div.g4 .right table tr:nth-child(1) td span{
border-left: 5px solid #FFF;
padding-left: 15px;
}
.price4 div.g4 .right table tr:nth-child(1) td span span{
border: none;
font-size: 14px;
font-weight: normal;
}
.price4 div.g4 .right table tr:nth-child(2) td{
background: #D5F2F6;
padding:  7px 10px 5px 30px;
font-size: 16px;
width: 100%;
border: 1px solid #CCC;
}
.price4 div.g4 .right table tr:nth-child(3) td{
background: #FFF;
padding:  7px 10px 5px 30px;
font-size: 16px;
width: 100%;
border: 1px solid #CCC;
}
.price4 div.g4 .right table:nth-child(3) tr td{
width: 295px !important;/*50%;*/
text-align: center;
}
.price4 div.g4 .right table tr:nth-child(4) td{
background: #D5F2F6;
padding:  7px 10px 5px 30px;
font-size: 16px;
width: 100%;
border: 1px solid #CCC;
}
.price4 div.g4 .right table tr:nth-child(5) td{
background: #FFF;
padding:  7px 10px 5px 30px;
font-size: 16px;
width: 100%;
border: 1px solid #CCC;
}

/*マージン*/
.m0 {
  margin: 0 !important;
}

.mt0 {
  margin-top: 0 !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.ml0 {
  margin-left: 0 !important;
}

.mr0 {
  margin-right: 0 !important;
}

.m1 {
  margin: 1.0rem !important;
}

.mt1 {
  margin-top: 1.0rem !important;
}

.mb1 {
  margin-bottom: 1.0rem !important;
}

.ml1 {
  margin-left: 1.0rem !important;
}

.mr1 {
  margin-right: 1.0rem !important;
}

.m2 {
  margin: 2.0rem !important;
}

.mt2 {
  margin-top: 2.0rem !important;
}

.mb2 {
  margin-bottom: 2.0rem !important;
}

.ml2 {
  margin-left: 2.0rem !important;
}

.mr2 {
  margin-right: 2.0rem !important;
}

.m3 {
  margin: 3.0rem !important;
}

.mt3 {
  margin-top: 3.0rem !important;
}

.mb3 {
  margin-bottom: 3.0rem !important;
}

.ml3 {
  margin-left: 3.0rem !important;
}

.mr3 {
  margin-right: 3.0rem !important;
}

.m4 {
  margin: 4.0rem !important;
}

.mt4 {
  margin-top: 4.0rem !important;
}

.mb4 {
  margin-bottom: 4.0rem !important;
}

.ml4 {
  margin-left: 4.0rem !important;
}

.mr4 {
  margin-right: 4.0rem !important;
}

.m5 {
  margin: 5.0rem !important;
}

.mt5 {
  margin-top: 5.0rem !important;
}

.mb5 {
  margin-bottom: 5.0rem !important;
}

.ml5 {
  margin-left: 5.0rem !important;
}

.mr5 {
  margin-right: 5.0rem !important;
}

.m6 {
  margin: 6.0rem !important;
}

.mt6 {
  margin-top: 6.0rem !important;
}

.mb6 {
  margin-bottom: 6.0rem !important;
}

.ml6 {
  margin-left: 6.0rem !important;
}

.mr6 {
  margin-right: 6.0rem !important;
}
.mrauto{
	margin: 0 auto;
}
  

/*****************************************************
 * フッター
 *****************************************************/
.footer{
  background: #043786;
  margin:0 calc((100% - 100vw) / 2);
	padding: 14px 0 10px;
	margin-bottom: 10px;
}
.footer .contents{
  width: 1000px;
  margin: 0 auto;
}
.footer .contents div.btn_text{
  position: relative;
}
.footer .contents p{
  position: absolute;
  left: 250px;right:320px;
  top:13px;
  margin:0 auto;
  color: #FFF;
  font-size: 15px;
  text-align:center;
}
.footer .contents ul{
  margin:0;
  text-align: center;
}
.footer .contents ul li{
  color:#FFF;
  display: inline-block;
}

.footer .contents ul li:nth-child(1){
  width: 250px;
  padding: 0px 5px 0 5px;
}
.footer .contents ul li:nth-child(2),
.footer .contents ul li:nth-child(3){
  width: 190px;
  padding: 0px 5px 0 5px;
}
.footer .contents ul li:nth-child(4){
  width: 340px;
  margin-left: 15px;
  padding-left: 20px;
  border-left: 1px solid #86A3D1;
}
.footer .contents ul li img {
  margin-bottom:10px;
}

  
/*footer tel area2
------------------------------*/
.tel_area2{
  width:318px;
  margin-top:6px;
  margin-right: 0px;
}
.tel_area2 div{
  text-align:left;
  margin:0;
  padding:0;
  line-height: 1.3;
  font-family:"Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
}
.tel_area2 div span:nth-child(1){
  font-size: 12px !important;
  padding-top: 2px;
  line-height:2.2;
  letter-spacing: 0.03em;
}
.tel_area2 div span:nth-child(2){
  color:#FFFFFF;
  background:#FF0000;
  padding:2px 9px 1px 9px;
  border-radius: 99px;
  display:inline-block;
  margin-right:.7em;
  line-height:18px;
  font-size:12px;
  letter-spacing: 0.01em;
}
.tel_area2 div span:nth-child(3){
  font-size: 13px;
  padding-top: 2px;
  letter-spacing: 0.01em;
}
  .tel_area2 img {
    margin-top:3px;
  }


/*料金プラン
-----------------*/


/*U2s*/
.price4 div.u2s{
margin-top: 30px;
}
.price4 div.u2s p{
clear: both;
/*padding: 20px;*/
}
.price4 div.u2s .left{
width: 29%;
float: left;
}
.price4 div.u2s .right{
width: 71%;
float: left;
padding-left: 30px;
}
.price4 div.u2s .right p{
padding: 0;
margin: 0;
}
.price4 div.u2s .right table{
margin: 0 auto 20px auto;
}
.price4 div.u2s .right table tr:nth-child(1) td{
background: #043786;
color: #FFF;
padding:  7px 10px 5px 10px;
font-weight: bold;
font-size: 20px;
width: 100%;
border: 1px solid #043786;
text-align: left!important;
}
.price4 div.u2s .right table tr:nth-child(1) td span{
border-left: 5px solid #FFF;
padding-left: 15px;
}
.price4 div.u2s .right table tr:nth-child(1) td span span{
border: none;
font-size: 14px;
font-weight: normal;
}
.price4 div.u2s .right table tr:nth-child(even) td{
background: #D5F2F6;
padding:  7px 10px 5px 30px;
font-size: 16px;
width: 100%;
border: 1px solid #CCC;
}
.price4 div.u2s .right table tr:nth-child(3) td{
background: #FFF;
padding:  7px 10px 5px 30px;
font-size: 16px;
width: 100%;
border: 1px solid #CCC;
}
.price4 div.u2s .right table:nth-child(3) tr td{
width: 50%;
text-align: left;
}
/*G4*/
.price4 div.g4{
margin-top: 50px;
}
.price4 div.g4 p{
clear: both;
padding: 20px;
}
.price4 div.g4 .left{
width: 35%;
float: left;
}
.price4 div.g4 .right{
width: 65%;
float: left;
padding-left: 30px;
}
.price4 div.g4 .right p{
padding: 0;
margin: 0;
}
.price4 div.g4 .right table{
margin: 0 auto 20px auto;
}
.price4 div.g4 .right table tr:nth-child(1) td{
background: #043786;
color: #FFF;
padding:  7px 10px 5px 10px;
font-weight: bold;
font-size: 20px;
width: 100%;
border: 1px solid #043786;
text-align: left!important;
}
.price4 div.g4 .right table tr:nth-child(1) td span{
border-left: 5px solid #FFF;
padding-left: 15px;
}
.price4 div.g4 .right table tr:nth-child(1) td span span{
border: none;
font-size: 14px;
font-weight: normal;
}
.price4 div.g4 .right table tr:nth-child(2) td{
background: #D5F2F6;
padding:  7px 10px 5px 30px;
font-size: 15px;
width: 100%;
border: 1px solid #CCC;
}
.price4 div.g4 .right table tr:nth-child(3) td{
background: #FFF;
padding:  7px 10px 5px 30px;
font-size: 16px;
width: 100%;
border: 1px solid #CCC;
}
.price4 div.g4 .right table:nth-child(3) tr td{
width: 295px !important;
text-align: left;
}
.price4 div.g4 .right table tr:nth-child(4) td{
background: #D5F2F6;
padding:  7px 10px 5px 30px;
font-size: 15px;
width: 100%;
border: 1px solid #CCC;
}
.price4 div.g4 .right table tr:nth-child(5) td{
background: #FFF;
padding:  7px 10px 5px 30px;
font-size: 16px;
width: 100%;
border: 1px solid #CCC;
}


.price4 div.u2s p {
    clear: both;
    /*padding: 20px;*/
	    margin: 1.0rem 0;
}

.plan_ttl {
    background: #043786;
    color: #FFF;
    padding: 7px 10px 5px 10px!important;
    font-weight: bold;
    font-size: 20px;
    margin: 20px auto 0 auto!important;
    border: 1px solid #043786;
    text-align: left!important;
}
.plan_ttl span {
    border-left: 5px solid #FFF;
    padding-left: 15px;
}
.price4 .right table tr:nth-child(1) th {
    background: #043786;
    color: #FFF;
    padding: 7px 10px 5px 10px;
    font-weight: bold;
    font-size: 20px;
    width: 100%;
    border: 1px solid #043786;
    text-align: left!important;
}
.price4 .right table tr:nth-child(1) th span {
    border-left: 5px solid #FFF;
    padding-left: 15px;
}

.keiyaku_plan table{
	margin: 0 auto;
}
.keiyaku_plan table th{
	width: 20%;
	border: 1px solid #CCC;
	text-align: center;
	background: #D5F2F6;
	font-size: 16px;
	padding: 10px 0;
}

.keiyaku_plan table td{
	width: 20%;
	border: 1px solid #CCC;
	text-align: center;
	font-size: 16px;
	padding: 10px 0;
}

.plan_kikan{
	background: #043786;
    color: #FFF;
    padding: 7px 10px 5px 10px!important;
    font-weight: bold;
    font-size: 20px;
	margin: 30px auto 0 auto!important;
    border: 1px solid #043786;
    text-align: left!important;
}

.plan_kikan span {
    border-left: 5px solid #FFF;
    padding-left: 15px;
}

.price4 .left img{
	display: block;
margin-bottom: 0;
}

.clear {
    clear: both;
}
/*マージン*/
.mb05{
	margin-bottom: .5em;
}

/*PC表示・SMP表示切替
---------------------------*/
.pcNone2{
display: none;
}
.spNone2{
display: block;
}

.img_area img{
	margin:  auto;
}


/*簡易フォーム*/
.header_form_wrap {
    text-align: center;
    background: #FFED0D;
    height: auto;
    margin: 8px 0 0;
    width: 100%;
    clear: both;
}
.header_form_wrap_in {
    text-align: center;
    margin: 0 auto;
    padding: 10px 0 20px 0;
}
.header_form_wrap-2 {
    text-align: center;
    height: auto;
    margin: 0;
    width: 100%;
    clear: both;
}
.header_form_wrap_in-2 {
    text-align: center;
    margin: 0 auto;
    padding: 0;
}

button {
	outline: none;
}
/*viewn*/
.top_cancel {
    width: 1000px;
    margin: 0 auto;
    text-align: inherit;
}
.top_cancel p {
    marign: 0 auto;
    display: block;
    text-align: left;
    padding: 0 10px 10px;
}
#viewn_wrap .midashi {
    margin: 0 auto 15px auto;
    background: #043786!important;
}
.ta-c {
    text-align: center;
}
#viewn_wrap{
	margin: 4.0em 0;
}
.t_b{
	font-size: 1.6em;
	color: #043786;
	font-weight: bold;
	line-height: 2;
}