@charset "utf-8";

.ec-layoutRole .ec-layoutRole__contents {
	max-width: 100% !important;
}

#page_homepage .ec-layoutRole__main ,
#page_confirm .ec-layoutRole__main {
	margin: 0 !important;
	max-width: 100%;
}

/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .textImg {
    margin: 48px 0 -3px;
    text-align: center;
}
#main .bgBox {
    padding-top: 44px;
    background: url("../img/shared/bg.jpg") repeat left top;
}
#main .mailForm {
    padding: 73px 50px 80px;
    border-radius: 40px 40px 0 0;
    background-color: #FFF;
    box-shadow: 0 0 30px rgba(0,0,0,0.2);
}
#main .sec01 {
    margin-bottom: 80px;
}
#main .tabUl li {
    width: 498px;
}
#main .tabUl li a {
    padding: 11px 10px 13px;
    display: block;
    font-size: 2.4rem;
    font-weight: 700;
    text-align: center;
    background-color: #D2D2D2;
}
#main .tabUl li.on a {
    color: #FFF;
    background-color: #8EBE55;
}
#main .tabUl li.on .subarea_input {
    color: #000000;
}
#main .tabBox .photo {
    margin-bottom: 29px;
}
#main .tabBox .areaList:not(:last-child) {
    margin-bottom: 20px;
}
#main .tabBox .areaList > li {
    margin: -1px -1px 0 0;
    width: calc(100% / 3);
    position: relative;
    border: 1px solid #8FBE56;
    box-sizing: border-box;
}
#main .tabBox .areaList > li label {
    display: block !important;
}

#main .tabBox .areaList .subarea_input_wrapper {
    padding: 6px 12px; margin-top: -6px;
}

#main .tabBox .areaList .subarea_input {
    width: 60px; font-weight: normal;
    color: black; float: right;
    /*display: none;*/
}

/*#main .tabBox .areaList .subarea_input_wrapper .subarea_checked {*/
/*    display: block;*/
/*}*/



#main .tabBox .areaList li input[type="checkbox"] {
    display: none;
}
#main .tabBox .areaList li input[type="checkbox"] + span {
    padding: 12px 10px 12px 37px;
    display: block;
    background: url("../img/shared/icon04.png") no-repeat left 10px center;
    transition: .3s;
	-webkit-transition: .3s;
}

#main .tabBox .areaList li span.num {
	background-color: #8FBE56;
    color: #fff;
    font-size: .8em;
    border-radius: 30px;
    display: inline-block;
    margin-right: .5em;
    width: 22px;
    text-align: center;
    padding: 2px 0px;
}

#main .tabBox .areaList.taishi li span.num {
	background-color: #D93B54;
}

#main .tabBox .areaList.kakogawa li span.num {
	background-color: #EDA841;
}

#main .tabBox .areaList.takasago li span.num {
	background-color: #D4050B;
}

#main .tabBox .areaList.harima li span.num {
	background-color: #268D3A;
}

#main .tabBox .areaList.inami li span.num {
	background-color: #0563AB;
}

#main .tabBox .areaList.inami li span.all ,
#main .tabBox .areaList.inami li span.kodate ,
#main .tabBox .areaList.inami li span.syugo {
	display: none;
}

#main .tabBox .areaList.akashi li span.num {
    background-color: #F196A4;
}



#main .tabBox .areaList li input[type="checkbox"]:checked + span {
    background-image: url("../img/shared/icon04_on.png");
}
#main .tabBox .areaList .detailList {
    margin-left: -1px;
    padding: 12px 12px 14px;
    width: calc(100% + 2px);
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    border: 3px solid #8FBE56;
    border-top-width: 6px;
    background-color: #DAE8C5;
    box-sizing: border-box;
    z-index: 10;
	list-style-type: disc;
	padding-left: 2em;
}
#main .tabBox .areaList .detailList li:not(:last-child) {
    margin-bottom: 8px;
}
#main .tabBox .areaList > li:hover input[type="checkbox"] + span {
    color: #FFF;
    background-color: #8FBE56;
}
#main p {
    margin-bottom: 36px;
}
#main .radioList li {
    margin-right: 15px;
    display: inline-block;
    font-size: 1.8rem;
}
#main .radioList li input[type="radio"] ,
#main .sec01 .areaList li input[type="radio"] {
    display: none;
}
#main .radioList li input[type="radio"] + span ,
#main .sec01 .areaList li input[type="radio"] + span {
	padding-left: 15px;
    display: inline-block;
    background: url(../img/shared/icon05.png) no-repeat left top 8px;
    background-size: 10px;
}
#main .radioList li input[type="radio"]:checked + span ,
#main .sec01 .areaList li input[type="radio"]:checked + span {
    background-image: url("../img/shared/icon05_on.png");
}
#main .sec01 .areaList li {
    min-width: 200px;
    text-align: center;
    margin-right: 15px;
    border: 1px solid #a1ce72;
    display: inline-block;
    font-size: 1.8rem;
}
#main .sec02 {
    margin-bottom: 84px;
    display: none;
}
#main .sec02 h2 {
    margin-bottom: 25px;
    border-color: #ff9dac;
    background-color: #FFEFF1;
}
#main .sec02 h2 span {
    background-image: url("../img/shared/h2_bg02.png");
}
#main .sec02 .radioList li {
    min-width: 200px;
    text-align: center;
}
#main .radioList li {
    margin-right: 15px;
    border: 1px solid #ff9dac;
}
#main .radioList li label ,
#main .sec01 .areaList li label {
    padding: 15px 10px;
    display: block;
    cursor: pointer;
}
#main .sec03 {
    margin-bottom: 95px;
    display: none;
}
#main .sec03 h2 {
    margin-bottom: 25px;
    border-color: #5cc5f2;
    background-color: #EDFAFF;
}
#main .sec03 h2 span {
    background-image: url("../img/shared/h2_bg03.png");
}
#main .sec03 p {
    margin-bottom: 28px;
}
#main .sec03 .comSub {
    margin-bottom: 80px;
}
#main .sec03 .radioList {
    margin: 0 0 20px;
    display: flex;
    flex-wrap: wrap;
}
#main .sec03 .radioList:nth-of-type(2) {
    margin-right: 4px;
}
#main .sec03 .radioList li {
    margin-right: 0;
    width: 218px;
    display: block;
    text-align: center;
    border: 1px solid #20A2D9;
    border-left: none;
    box-sizing: border-box;
}
#main .sec03 .radioList li.text {
    padding: 15px;
    width: 85px!important;
    color: #FFF;
    border-left: 1px solid #20A2D9;
    background-color: #20A2D9;
}
#main .sec03 .radioList li.text .all,
#main .sec03 .radioList li.text .kodate,
#main .sec03 .radioList li.text .syugo{
	display: none;
}
#main .sec03 .selectBox li {
    width: 193px;
    font-size: 1.6rem;
}
#main .sec03 .selectBox .radioList01 li {
    width: 97px;
    font-size: 1.8rem;
    border-color: #577AC7;
}
#main .sec03 .selectBox .radioList01 li.text {
    background-color: #577AC7;
}
#main .sec03 h3 {
	margin-bottom: 10px;
}

#main .sec03 .catalog-list .radioList li.text {
    width: 110px!important;
}

#main .sec03 .selectBox .catalog-list .radioList li {
    width: 110px;
}

#main .sec04 {
    display: none;
}
#main .sec04 h2 {
    margin-bottom: 32px;
    border-color: #F37DC5;
    background-color: #FFF4FB;
}
#main .sec04 h2 span {
    background-image: url("../img/shared/h2_bg04.png");
}
#main .sec04 .tableBox {
    padding: 50px 50px 65px;
    border: 3px solid #F37DC5;
}
#main .sec04 .tableBox table {
    margin-bottom: 50px;
    width: 100%;
    border-collapse: collapse;
    word-break:break-all;
}
#main .sec04 .tableBox th,
#main .sec04 .tableBox td {
    padding-bottom: 20px;
    width: 81.5%;
    font-size: 1.6rem;
    font-weight: 500;
    text-align: left;
    vertical-align: middle;
}
#main .sec04 .tableBox tr:last-child th,
#main .sec04 .tableBox tr:last-child td {
    padding-bottom: 0;
}
#main .sec04 .tableBox th {
    width: 19.5%;
}
#main .sec04 .tableBox input[type="text"],
#main .sec04 .tableBox input[type="tel"],
#main .sec04 .tableBox select {
    padding: 10px 25px;
    width: 100%;
    height: 60px;
    font-size: 1.6rem;
    font-weight: 500;
    border: 1px solid #CCC;
    background-color: #FDFDFD;
    box-sizing: border-box;
    border-radius: 0;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}
#main .sec04 .tableBox select {
    background: #F8F8F8 url("../img/shared/icon06.png") no-repeat right 16px center;
}
#main .sec04 .tableBox .submit {
	text-align: center;
}
#main .sec04 .tableBox .submit li {
    margin-bottom: 10px;
	display: block;
}
#main .sec04 .tableBox .submit li:last-child {
    margin-bottom: 0;
}
#main .sec04 .tableBox .submit li input {
	min-width: 500px;
    height: 90px;
	color: #FFF;
	font-size: 2.4rem;
    text-align: center;
    background-color: #910782;
	border-radius: 0;
	border: none;
    appearance: none;
    -moz-appearance: none;
	-webkit-appearance: none;
	cursor: pointer;
}
#main .sec04 .tableBox .submit li input:hover {
	opacity: 0.7;
}


#main .sec07 {
    display: none;
}
#main .sec07 h2 {
    margin-bottom: 32px;
    border-color: #F37DC5;
    background-color: #FFF4FB;
}
#main .sec07 h2 span {
    background-image: url("../img/shared/h2_bg04.png");
}
#main .sec07 .tableBox {
    padding: 50px 50px 65px;
    border: 3px solid #F37DC5;
}
#main .sec07 .tableBox table {
    margin-bottom: 50px;
    width: 100%;
    border-collapse: collapse;
    word-break:break-all;
}
#main .sec07 .tableBox th,
#main .sec07 .tableBox td {
    padding-bottom: 20px;
    width: 81.5%;
    font-size: 1.6rem;
    font-weight: 500;
    text-align: left;
    vertical-align: middle;
}
#main .sec07 .tableBox tr:last-child th,
#main .sec07 .tableBox tr:last-child td {
    padding-bottom: 0;
}
#main .sec07 .tableBox th {
    width: 19.5%;
}
#main .sec07 .tableBox input[type="text"],
#main .sec07 .tableBox input[type="tel"],
#main .sec07 .tableBox input[type="number"],
#main .sec07 .tableBox select {
    padding: 10px 25px;
    width: 100%;
    height: 60px;
    font-size: 1.6rem;
    font-weight: 500;
    border: 1px solid #CCC;
    background-color: #FDFDFD;
    box-sizing: border-box;
    border-radius: 0;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

#main .sec07 .tableBox textarea {
    padding: 20px 15px;
    width: 100%;
    font-size: 1.6rem;
    font-weight: 500;
    border: 1px solid #CCC;
    background-color: #FDFDFD;
    box-sizing: border-box;
    border-radius: 0;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    line-height: 1.6;
}
#main .sec07 .tableBox select {
    background: #F8F8F8 url("../img/shared/icon06.png") no-repeat right 16px center;
}
#main .sec07 .tableBox .submit {
    text-align: center;
}
#main .sec07 .tableBox .submit li {
    margin-bottom: 10px;
    display: block;
}
#main .sec07 .tableBox .submit li:last-child {
    margin-bottom: 0;
}
#main .sec07 .tableBox .submit li input {
    min-width: 500px;
    height: 90px;
    color: #FFF;
    font-size: 2.4rem;
    text-align: center;
    background-color: #910782;
    border-radius: 0;
    border: none;
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
}
#main .sec07 .tableBox .submit li input:hover {
    opacity: 0.7;
}

#main .sec05 {
	display: none;
	margin-bottom: 45px;
}

#main .sec05 table {
    padding: 25px 38px 35px;
    width: 100%;
    border: 3px solid #fd5266;
    box-sizing: border-box;
    word-break:break-all;
    display: none;
    border-collapse: separate;
}
#main .sec05 th,
#main .sec05 td {
    padding-bottom: 25px;
    font-weight: 500;
    text-align: left;
    vertical-align: middle;
    box-sizing: border-box;
}
#main .sec05 th {
    width: 12%;
}
#main .sec05 td {
    width: 40%;
}
#main .sec05 td.pad01 {
    padding-right: 20px;
}
#main .sec05 th.pad02 {
    padding-left: 30px;
}
#main .sec05 td input[type="text"] {
    height: 60px;
    width: 100%;
    display: block;
    font-size: 1.6rem;
    border: none;
    border-radius: 0;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    border-bottom: 3px solid #333;
    padding: 6px 12px 0 12px;
}
#main .sec06 {
    margin-bottom: 84px;
    display: none;
}
#main .sec06 h2 {
    margin-bottom: 25px;
    border-color: #FFBF9D;
    background-color: #FFEFEE;
}
#main .sec06 h2 span {
    background-image: url(../img/shared/h2_bg06.png);
}
#main .sec06 select {
	margin: 0 20px;
    padding: 10px 25px;
    width: calc(100% - 40px);
    height: 60px;
    font-size: 1.6rem;
    font-weight: 500;
    border: 1px solid #CCC;
    background-color: #FDFDFD;
    box-sizing: border-box;
    border-radius: 0;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background: #F8F8F8 url(../img/shared/icon06.png) no-repeat right 16px center;
}

@media all and (-ms-high-contrast:none) {
    select::-ms-expand{
        display: none;
    }
}

#main .confirm-item {
    border-left: 2px solid #E4005A;
    padding: 6px 10px;
    margin-bottom: 10px;
    font-size: 16px;
}

.confirm-conts {
    margin: 0 0 24px;
}

area:hover {
    background-color: red;
}

p.headline {
    margin-bottom: 0 !important; font-size: 18px; font-weight: bold;
	border-left: 3px solid #8FBE56;
    padding: 10px 0 10px 10px;
    margin-bottom: 10px !important;
}
body.fixed {
	overflow: hidden;
}
.policy-overlay{
    display:none;
	width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.6);
    position: fixed;
    z-index: 1000000;
    top: 0;
    left: 0;
	font-size: 16px;
}
.policy-overlay .btn_area{
	text-align: center;
    width: 80%;
	max-height: 90vh;
	overflow-y: scroll;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10000;
    box-sizing: border-box;
	padding: 60px 50px;
    background-color: #FFF;
    box-shadow: 0 0 30px rgba(0, 0, 0, 0.2);
}
.policy-overlay .btn_area .layer_borad_title {
	font-size: 1.2rem;
	color: #c00;
	margin: 0 0 20px;
}
.policy-overlay .btn_area .overlay-title {
	font-size: 28px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 20px;
}
.policy-overlay .btn_area .comSub {
	margin: 0 0 20px;
}
.policy-overlay .btn_area p{
	text-align: left;
}
.policy-overlay .btn_area p.title{
	font-size: 22px;
	font-weight: bold;
	margin-bottom: 15px;
	position: relative;
}

.policy-overlay .btn_area p.title:before {
	content: "● ";
	color: #a1ce72;
}
.policy-overlay .btn_area p .red{
	color: #c00;
}

.policy-overlay .btn_area dl{
	display: flex;
    flex-wrap: wrap;
    text-align: left;
}

.policy-overlay .btn_area dt {
	width: 17em;
	padding-bottom: 8px;
	margin-bottom: 8px;
	border-bottom: 1px solid #ccc;
}

.policy-overlay .btn_area dt span.num {
	background-color: #FFBF9D;
	color: #fff;
	border-radius: 30px;
	text-align: center;
	display: inline-block;
	width: 24px;
	height: 24px;
	line-height: 24px;
	margin-right: 5px;
}

.policy-overlay .btn_area dd {
	width: calc(100% - 17em);
	padding-bottom: 8px;
	margin-bottom: 8px;
	border-bottom: 1px solid #ccc;
}

@media all and (max-width: 896px) {
	.policy-overlay .btn_area dt {
		border-bottom: 0;
	}
	.policy-overlay .btn_area dt ,
	.policy-overlay .btn_area dd {
		width: 100%;
	}
}

.policy-overlay .btn_area button{
    display: block;
    margin: 0 auto;
    appearance: none;
    padding: 1em 2em;
    background-color: #FD5266;
    color: #fff;
    box-shadow: none;
    border: 0;
    margin-top: 16px;
	font-size: 24px;
}