.wrap {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    box-sizing: border-box;
}


.title_disc_text{
  font-size: 23px;
  line-height: 1.4;
  padding: 6px 0 40px 0px;
  text-align: center;
}

.partner_map {
  position: relative;
  padding: 50px;
  margin: 0 0 15px;
}

.partner_subtit_p{
  font-size: 18px;
  line-height: 1.6;
  color: #444444;
  padding: 32px !important;
}


.partner_link{
  font-size: 16px;
  line-height: 1.6;
  display: block;
}


.partner_subtit_city {
    font-size: 18px;
    line-height: 20pt;
    color: #333333;
}


.country_area{
		position: absolute;
		border: 1.5px solid #17477b;
		border-radius: 3px;
		box-shadow: 2px 2px 0px #00000042;
}


.whole_area {
    top: 2%;
    left: 7%;
    width: 53%;
}


.whole_area ul {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

.whole_area ul li{
  width:53%;
}

.whole_area ul li:nth-child(odd) {
  width:46%;
}


.kyushu_area {
    top: 36.5%;
    left: 7%;
}

.tyugoku_area{
	top: 36.5%;
	 left: 26%;
}

.kinki_area {
  bottom: 8%;
  left: 27%;
}

.chukyo_area {
    bottom: 3%;
    left: 46%;
}

.kantou_area {
    right: 6%;
    bottom: 27%;
}


.touhuku_area {
    top: 2%;
    right: 6%;
}


.area_title{
	background-color: #fff;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 400;
  color: #041b6f;
  padding: 4px 0;
  margin: 0;
  border-radius: 3px 3px 0 0;
  font-family: A-OTF Shin Go Pro;
}

.area_ul{
	text-align: left;
	font-size: 16.5px;
	padding: 18px;
	background-color: #eeeeee;
	box-sizing: border-box;
	border-radius: 0 0 3px 3px;
	line-height: 1.7;
}



.area_ul a{
	color: inherit;
	text-decoration: none;
}

.area_ul a:hover{
	color: inherit;
	text-decoration: none;
	color: #0f76cc;
}


.table_bottom_area {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    padding: 10px 8px;
}


.table_bottom_kome{
  font-size:14px;
}





.partner_program_title {
    padding: 13px 0 0px 0px;
    font-size: 20px;
    width: 100%;
    text-align: center;
    color: #040404;
    font-weight: bold;
    line-height: 25px;
    height: 65px;
}

.partner_program_txt {
    padding: 8px 0 20px;
    font-size: 15px;
    vertical-align: top;
    height: 140px;
    line-height: 1.5;
}



.contents_partner {
    font-size: 17px;
    color: #262626;
    line-height: 21px;
    font-family: "Lucida Grande","Hiragino Kaku Gothic Pro"," Pro W3","Meiryo","MS PGothic","Osaka",Verdana,Arial,Helvetica,sans-serif;
    padding: 19px 12px 15px;
}

.flow-point-s {
    font-size: 16px;
    color: #7F7F7F;
    line-height: 1.45;
    padding-left: 5px;
    display: block;
}


a.btn_partner {
    width: 100%;
    height: 74px;
    text-align: left;
    padding: 15px 0px 0px 30px;
    font-size: 26px;
    color: #ffffff;
    background: none repeat scroll 0% 0% #EB5215;
    border: 1px solid #EB5215;
    text-decoration: none;
    position: relative;
    border-radius: 3px;
}


a.btn_partner:hover {
  background: none repeat scroll 0% 0% #db3e00;
  border: 1px solid #d73d00;
}

.par_po {
  width: 4%;
  position: absolute;
  top: 18px;
  right: 17px;
}

.plan_contents_1 {
    font-size: 18px;
    color: #595959;
    line-height: 1.3;
    padding-left: 2px;
    margin-bottom: 8px;
    display: block;
}

.plan_contents_2 {
    font-size: 17px;
    color: #7F7F7F;
    line-height: 1.3;
    padding-left: 2px;
    display: block;
    padding-top: 5px;
}

.item_cont{

}


.partner_rec_contents {
    width: 100%;
}

.contens_group {
    margin-top: 50px;
}



.t05_partner_nor {
    border-left: 4px solid #5b9de8;
    line-height: 40px;
    margin-bottom: 10px;
    margin-top:45px;
    font-size: 32px;
    padding-left: 13px;
    color: #000;
    font-weight: normal;
}

.partner_contents_p {
    font-size: 20px;
    line-height: 1.6;
    padding: 10px 5px 0 20px;
}

.partner_program_area {
    width: 100%;
    max-width:1400px;
    margin: 0 auto;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-top: 30px;
}

.partner_program {
    width: 23%;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: center;
    align-content: space-between;
    justify-content: flex-start;
}

.partner_pro_img {
    width: 80%;
}


.partner_program_footer {
    padding-left: 13px;
    height: auto;
    color: #7F7F7F;
    text-indent: -13px;
    line-height: 1.4;
    margin: 0;
    font-size: 12.5px;
    letter-spacing: -0.1px;
    width:100%;
}

.partner_blue_bar_n {
  background: #2d6eb5;
  border: none;
  color: #fff;
  padding: 0.35em 0.8em 0.38em;
  font-size: 30px;
  margin: 70px 0 25px;
  font-weight: normal;
}




.chk_icon {
    width: 18px;
    padding-bottom: 2px;
}

.partner_subtit {
    font-size: 17px;
    line-height: 15pt;
    padding: 17px;
    color: #262626;
}


.unnecessary_icon {
    width: 12px;
    display: flex;
}


.partner_item_ul {
    display: flex;
}


.partner_item_ul_li {
    width: 55%;
    border: 1px solid #eaeaea;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-content: space-around;
    align-items: center;
    position: relative;
    padding: 25px;
}


.item_img {
    padding: 20px 0 20px;
    height: 110px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-evenly;
    flex-wrap: wrap;
}

.step_title {
    padding: 0;
    margin: 0;
    font-size: 20px;
    line-height: 1.25;
    font-weight: bold;
    color: #353C55;
    padding-bottom: 20px;
    text-align: center;
}

.step_span_num {
  display: block;
  font-size: 14px;
  color: #1982BF;
  background-color: #F1F8FF;
  width: 124px;
  padding: 5px 0 5px;
  margin-bottom: 8px;
  font-weight: 100;
  font-weight: bold;
  border-radius: 4px;
  margin:0 auto 13px;
}

.partner_step_txt {
    text-align: left;
    line-height: 1.45;
    font-size: 16px;
    margin: 0;
    padding: 0 0 10px 0;
}

.partner_step_ul {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    flex-wrap: wrap;
    text-align: left;
    font-size: 16px;
}

.partner_step_ul li:first-child {
    padding-top: 3px;
}

.partner_step_ul li {
    width: 100%;
    border: none;
    padding: 0;
    text-align: left;
    display: block;
    text-indent: -12px;
    padding-left: 13px;
}

.partner_step_txt_under {
    text-align: left;
    line-height: 1.3;
    font-size: 16px;
    margin: 0;
    padding: 0;
}

li.step_arrow {
    width: 2%;
    position: relative;
    margin: 0 10px;
}


.step_arrow::after {
    position: absolute;
    left: -10px;
    top: 50%;
    content: "";
    display: block;
    width: 16px;
    height: 16px;
    border-left: 1px solid #5a89c6;
    border-bottom: 1px solid #5a89c6;
    transform: rotate( -135deg);
    font-size: 15px;
    color: #1982BF;
}




.cont_txttit {
    font-size: 18px;
    line-height: 1.5;
    color: #595959;
}


.partner_url_link {
    font-size: 17px;
    color: #0054a6;
    font-weight: normal;
    line-height: 22px;
    vertical-align: middle;
    background: transparent url(/images/type_arrow_oran1.png) no-repeat scroll left center;
    padding-left: 21px;
    padding-top: 1px;
    text-decoration: none;
}



.partner_step_ser {
    font-size: 14px;
    line-height: 1.4;
    text-indent: -6px;
    color: #a2a2a2;
}


.partner_qna_area{
  padding:40px;
  border:1px solid #E8E8E8;
  background-color:#F4F5F6;
}

.qna_area_flex{
  display:flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  padding: 17px 0;
}

.partner_int_link{
  padding:15px 10px 0 0;
  text-align:right;
}


.qna_flex_item{
  width:49%;
}


.contents_partner1{
      font-size: 22px;
      font-weight: bold;
}



.bracket-text{
  font-size:16px;
}



@media screen and (max-width: 480px) {



.page_title h2{
  margin: 90px 0 0 0;
}


.title_disc_text{
  font-size: 18px;
  text-align: left;
  padding-bottom: 20px;
  line-height: 1.5;
}


.partner_map{
  padding:0;
}


.partner_sp_table {
}

.partner_sp_table dt {
    width: 100%;
    font-weight: bold;
    text-align: center;
    font-size: 17px;
}

.partner_sp_table dd {

}

.table_bottom_kome{
  font-size:13px;
}


.t05_partner_nor {
    font-size: 25px;
    line-height: 35px;
}

.partner_contents_p {
    font-size: 17px;
    line-height: 1.6;
    padding: 8px 5px 0 0;
}

.partner_program{
   width: 100%;
}


ul.partner_contents_p li {
    text-indent: -20px;
    padding-left: 14px;
}

.partner_pro_img {
    width: 60%;
}

.partner_program_txt {
    padding: 0px 0 17px;
    font-size: 16px;
    height: auto;
}

.partner_program_footer{
  padding-left:14px;
  line-height: 0.5;
  font-size:13px;
}

.partner_program{
  margin-bottom:80px;
}

.partnner_program_last{
  margin-bottom:0;
}


.partner_blue_bar_n{
  margin: 45px 0 20px;
  font-size: 22px;
}

.partner_item_ul {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.partner_item_ul_li{
  width:100%;
}

.item_img {
    height: 105px;
    padding-top: 0;
}

.step_span_num{
  font-size: 16px;
}

.step_title{
font-size: 20px;
padding-bottom: 14px;
}


.step_arrow::after{
  border-left: 2px solid #5a89c6;
  border-bottom: 2px solid #5a89c6;
}

li.step_arrow {
    width: 4%;
    position: relative;
    margin: 35px 10px;
    transform: rotate(90deg);
}

.qna_flex_item {
    width: 100%;
}


.a.btn_partner{
  font-size: 15px;
}

.partner_qna_area {
    padding: 24px;
}

a.btn_partner {
  width: 100%;
  height: 65px;
  text-align: left;
  padding: 10px 0px 0px 16px;
  font-size: 16px;
  color: #ffffff;
  background: none repeat scroll 0% 0% #EB5215;
  border: 1px solid #EB5215;
  text-decoration: none;
  position: relative;
  border-radius: 3px;
  line-height: 1.3;
}



.qna_flex_item {
    width: 100%;
    margin-bottom: 9px;
}




/* !!!!!!!!!!!!  アコーディオン css  start !!!!!!!!!!!!!!! */

.func_table_area {
    width: 100%;
    text-align: center;
    background-color: #fff;
    position: relative;
    font-size: 14px;
    border: 1px solid #c9d2dd;
    color: #202124;
    border-top:left;
}

.denshi_range_title {
    text-align: center;
    background: #3784d9;
    color: #fff;
    border-right: 1px solid #d8dee3;
    font-weight: bold;
    padding: 15px;
}

.denshi_range_gray_t {
    text-align: center;
    background: #f5f6f9;
    padding: 15px;
    /* font-weight: bold; */
}


ul.range_text_ul li {
    text-indent: -18px;
    padding-left: 17px;
    padding-bottom: 7px;
    line-height: 1.2;
}

.range_table_point_blue {
    border: 2px solid #0061D5;
    position: absolute;
    width: 66%;
    height: 60.2%;
    z-index: 5;
    left: 33%;
    top: 39%;
}

.range_table_point_orange {
    border: 2px solid #e30500;
    position: absolute;
    width: 66%;
    z-index: 5;
    left: 33%;
}



/* アコディアン */

.details_blue_box {
    /* border: 1px solid #d6d6d6; */
}

.details_orange_box {
    border: 2px solid #e30500;
}

.summary_blue{
    background-color: #fafafc;
    color:#2F3E46;
}

.summary_orange{
    background-color: #FFFCDA;
    color: #e30500;
}

.summary_gray{
    background-color: #F4F5F6;
}



.details-summary {
  position: relative;
  display: block;
  padding:14px 15px;
  font-size: 17px;
  font-weight: 100;
  text-align: left;
  line-height: 1.4;
  border: 1px solid #d6d6d6;
  border-bottom:none;

	&:hover {
		cursor: pointer;
		opacity: 0.8;
	}

  .details-summary:hover{

  }


	.btn {
		position: absolute;
        top: 39%;
        right: 5%;
        width: 18px;
        height: 18px;
        transform-origin: center center;
        transition-duration: 0.2s;

        &:before,
        &:after {
            content: "";
            background-color: #2F3E46;
            border-radius: 10px;
            width: 16px;
            height: 2px;
            position: absolute;
            top: 7px;
            left: 0;
            transform-origin: center center;
        }
        &:before {
            width: 2px;
            height: 16px;
            top: 0;
            left: 7px;
        }
    }


	&.is-active {
    border-bottom: 1px solid #d6d6d6;

		.btn {
			-webkit-transform: rotate(-180deg);
			transform: rotate(-180deg);
			&:before {
            	content: none;
        	}
		}
    }
}


.btn_orange::before,
.btn_orange::after{
 background-color: #e30500 !important;
}

.details-summary::-webkit-details-marker {
	display: none;
}

.details-content {
	padding: 0px;
	.close-btn {
		display: block;
		margin: 7px auto 30px;
		padding: 8px 32px;
		background: #00a5a0;
		color: #0061D5;
		text-align: center;
		border: none;
		border-radius: 5px;
		cursor: pointer;
		&:hover {
			opacity: 0.8;
		}
	}
	p {
		margin: 0 0 20px;
		color: #000;
		font-size: 18px;
		text-align: left;
		&:last-of-type {
			margin: 0 0 40px;
		}
	}
}

/* 以下の記述は不要です */


.details-content .close-btn {
    display: block;
    margin: 20px auto 40px;
    padding: 12px 70px 10px;
    background: #a7b4c2;
    color: #ffffff;
    text-align: center;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-size: 15px;
}


.sp_table_left{
  width: 50%;
  background: #fafafc;
  text-align: left;
  padding: 15px;
  border-bottom: 1px solid #c9d2dd;
  border-right: 1px solid #c9d2dd;
}

.sp_table_right{
  width: 50%;
  border-bottom: 1px solid #c9d2dd;
}


.comm_align {
    margin: 0;
    padding: 15px;
}

.comm_align li {
  text-indent: -28px;
  margin-left: 28px;
  line-height: 1.4;
  padding-bottom: 8px;
  list-style: none;
  font-size: 12px;
  color: #666666;
}


.sp_plan_title{
  margin:0;
    color: #262626;
}

.service_title_txt {
    color: #202124 !important;
    font-weight: bold;
    text-decoration: none;
    font-size: 17px;
    margin:0;
}

.plan_serve_name {
    font-size: 13.5px;
    margin: 3px 0 3px;
    line-height: 13px;
    color: #c0c0c0;
    padding: 0;
}

.cost_num_all {
    font-weight: bold;
    font-size: 23px;
}

.cost_comm {
    font-size: 15px;
    padding-left: 0px;
    color: inherit;
    text-shadow: 0px 0px 10px #bbbaba !important;
}

.all_btn_size {
    width: 100%;
    margin-top: 5px;
}

.btn_link_apply_red {
    height: 35px;
    font-size: 13px;
    color: #ffffff;
    text-align: center;
    background: #FF114A;
    line-height: 38px;
    border-radius: 4px;
    letter-spacing: -0.2pt;
}


.btn_link_apply_red:hover {
    background: #FF114A;
    box-shadow: 0px 2px 7px 0px rgba(0, 0, 0, 0.2);
    cursor: pointer;
    transform: scale(1.02,1.02);
    transition: transform .2s;
}


a.btn_link_a2 {
  font-size: 13px;
  color: #ffffff !important;
  text-align: center;
  text-decoration: none;
  display: block;
  line-height: 3;
}

.sp_price{
  margin-top:10px;
}

.purpose_title_all {
    margin-top: 0px;
    font-size: 14px;
    line-height: 18px;
    text-align: left;
}

.price_purpose_ul_all {
    margin: 0;
    padding: 0;
    padding: 0 0 0 8px;
    color: #6B6B6B;
    text-align: left;
}

.price_purpose_ul_all li {
    text-indent: -12px;
    margin-left: 0px;
    line-height: 1.4;
    padding-bottom: 6px;
    list-style: none;
    font-size: 13px;
    text-align: left;
}


.price_purpose_ul_all li:nth-last-child(1){
    padding-bottom: 0px;
}


.sp_table_oneline{
  background-color: #F4F5F6;
  color: #262626;
  padding: 17px 14px;
  font-size: 15px;
  text-align: left;
}

.chk_icon {
  width: 16px;
  padding-bottom: 5px;
}

.cross_icon {
    width: 12px;
    padding-bottom: 0px;
}

.triangle_icon {
    width: 17px;
    padding-bottom: 0px;
    padding-left: 20px;
}

.table_bg_color{
  background-color: #EBEDEF;
}


.icon_span_text {
    font-size: 12px;
    color: #818181;
    display: block;
    line-height: 1.4;
    padding-top: 3px;
}


.red_point {
    padding-left: 0px;
    line-height: 22px;
    font-size: 0.7em;
    color: red;
    vertical-align: text-bottom;
}

.sp_table_title{
  font-size: 16px;
  font-weight: 600;
  padding: 19px 0px 5px;
  color:#494949;
}




/* !!!!!!!!!!!!  アコーディオン css  end !!!!!!!!!!!!!!! */



.cont_txttit{
      font-size: 16px;
}

.partner_int_link {
    padding: 15px 0 50px;
}

a.partner_url_link{
  font-size: 15px;
}

.flow-point-s {
    font-size: 14px;
}

.par_po {
    width: 6%;
    position: absolute;
    top: 20px;
    right: 17px;
}

.plan_contents_1 {
    font-size: 16px;
}

.plan_contents_2 {
    font-size: 15px;
}



}
