@charset "UTF-8";

/*================================
contact
================================*/
.top_main{
   /*background-image: url(/images/contact/main.jpg);*/
}
@media screen and ( max-width:750px) {
   .top_main{
  /*background-image: url(/images/contact/main_sp.jpg);*/
}
}



.contents{
   margin-top: 30px;
   font-size: 1.6rem;
}



.info .boxFlex{
   display: flex;
   justify-content: space-between;
}
.info .boxFlex .boxCont{
   width: 33.33%;
   padding: 1.0em;
   text-align: center;
   border-right: 1px solid #3F6B73;
}
.info .boxFlex .boxCont:last-child{
   border: none;
}
.info h3{
   font-size: 1.6rem;
   margin-top: 1em;
   margin-bottom: 1em;
}
.info p{
   font-size: 1.4rem;
   margin-bottom: 1em;
}
.info .tel{
   font-size: 2.8rem;
   font-weight: bold;
   margin-bottom: .6em;
}
.info .tel .ico{
   font-size: 2.0rem;
   border: 1px solid #3F6B73;
   border-radius: 50%;
   padding: .4em;
   line-height: 1;
   display: inline-block;
}
.info small{
   font-size: 1.4rem;
}

section.contact {
   padding: 20px 2% 40px;
}
.contact .inner{
   margin: 3%;
   background: #FFFFFA;
   border: 1px solid #3F6B73;
   border-radius: 40px;
}

@media screen and ( max-width:1000px) {
.info .boxFlex{
   display: block;
   }
   .info .boxFlex .boxCont{
   width: 100%;
   border-right: none;
   border-bottom: 1px solid #3F6B73;
   }
}

@media screen and ( max-width:750px) {
   .contents{
   margin-top: 10px;
   font-size: 1.4rem;
}
   
}




/*================================
form
================================*/
form{
   background: none;
  min-width: 670px;
}
form a{
   color: #222;
   text-decoration: underline;
}
#formWrap h3{
   font-size: 2.4rem;
}
.detailTxt {
  font-size: 1.6rem;
}
#formWrap li {
   display: flex;
   flex-wrap: wrap;
   padding: 0;
}
#formWrap li .itemName {
  font-size: 1.6rem;
   width: 25%;
   font-weight: bold;
   margin-bottom: 1em;
}
#formWrap li .itemField span label {
  font-size: 1.6rem;
}
#formWrap li .required {
  font-size: 1.2rem;
   width: 10%;
    margin-bottom: 1em;
}
#formWrap li .required span {
   display: inline-block;
   background: #e33c0b;
   border-radius: 5px;
   color: #fff;
   padding: .2em .8em;
}
#formWrap li .itemField {
  font-size: 1.6rem;
   width: 65%;
}
#formWrap .privacy .itemField,
#formWrap .privacy .itemName{
   width: 100%;
}



@media only screen and (max-width: 750px) {
    
    form{
    margin: 1em 0;
    padding: 5%;
    width: 100%;
    min-width: 100%;
    }
   #formWrap li .itemName {
   width: 50%;
}
#formWrap li .required {
   width: 50%;
}
#formWrap li .itemField {
   width: 100%;
}
}


form input[type="text"], form input[type="email"], form input[type="password"], form select, form textarea {
  font-size: 1.6rem;
}
input::-webkit-input-placeholder {
 color: #999;
font-size: 12px;
}
input:-moz-placeholder {
 color: #999;
font-size: 12px;
}

.kakuninWrap{
    padding: 2em 0;
}

.error_messe{
    text-align: center;
    color: red;
    font-family: 'メイリオ', 'Meiryo', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', 'Osaka', 'ＭＳ Ｐゴシック', sans-serif;
    font-size: 1.4em;
    letter-spacing: 0.2em;
    line-height: 1.6em;
}

.formplate{
}

p.formCap, label.formCap{
    font-weight: bold;
    margin-top: 1.5em;
    font-size: 1.5em;
    line-height: 1.4em;
    letter-spacing: 0.2em;
}
p.formCap .jap{
    font-size: 0.8em;
    font-weight: normal;
    margin-left: 20px;
    color: #999;
}
label.formCap .jap{
    font-size: 0.8em;
    font-weight: normal;
    margin-left: 20px;
    color: #999;
}

.attTxt{
    font-size: 0.8em;
    font-weight: normal;
    display: block;
    color: red;
}
input[type="button"], input[type="submit"], input[type="reset"], .button, .formBtn {
   display: flex;
   background: #FFF9D8;
  color: #000;
  border: solid 2px #3F6B73;
   border-radius: 45px;
   padding: 18px 5px;
   font-size: 1.6rem;
   line-height: 1.2;
   font-weight: bold;
   justify-content: center;
   position: relative;
   max-width: 350px;
   min-width: 135px;
   width: 100%;
   margin: 0 4px;
}
.formBtn:hover{
opacity: .6;
  transition: .5s;
}
.formBtn::after{
   font-family: "Font Awesome 5 Free";
  content: "\f35a";
  position: absolute;
  font-weight: normal;
  right: .6em;
   top: 35%;
}
.formBtn.backBtn::before{
font-family: "Font Awesome 5 Free";
  content: "\f359";
  position: absolute;
  font-weight: normal;
  left: .6em;
   top: 35%;
}
.formBtn.backBtn::after{
   content: none;
}

/*.formBtn{
border:solid 1px #305960;
padding:15px 30px;
margin:0 auto 20px;
font-size:1.4em;
font-weight:normal;
letter-spacing: 0.1em;
color:#fff;
background: #305960;
cursor:pointer;
-webkit-border-radius: 3px; 
-moz-border-radius: 3px; 
border-radius: 3px;   
}*/

table.func_table{
    width: 90%;
    margin: 2em auto;
    font-size: 1.6rem;
    letter-spacing: 0.2em;
}

.func_table th, .func_table td{
    padding: 1em; 
    border: 1px solid #ddd; 
    background: #fff;
}

.func_table th{
    background: #f4f4f4; 
    width: 30%; 
    text-align: left;
    font-size: 0.85em;
}

.thanksBox{
    width: 100%;
    padding: 40px 0 30px;
}
.thanksBox h3{
    text-align: center;
    font-size: 3em;
    margin-bottom: 40px;
}


@media only screen and (max-width: 750px) {
    
 table.func_table { 
      margin: 0 auto 30px; 
      width: 90%;
    }
    
    .func_table th,
    .func_table td{
        width: 100%;
        display: block;
        border-top: none;
    }
    .func_table tr:first-child th { border-top: 1px solid #ddd; }  
    
}





