@charset "utf-8";

/*
+++++++++++++++++++++++++++++++

contact-con01

+++++++++++++++++++++++++++++++
*/

.contact-con01{
    margin: auto;
    margin-bottom: 40px;
    width: 92%;
}

@media screen and (min-width: 768px),
print {
  .contact-con01{
    margin:0 auto 110px;
    max-width:900px;
  }
}


form .formbottom {
	text-align: center;
  width:250px;
  margin:40px auto 0;
  height:70px;
    

} 
form .btns{
	display: inline-block;
	vertical-align: middle;
	margin: 0 auto;
	padding:10px 25px 40px;
	color:#C7560C;
	font-weight: bold;
	letter-spacing: 0.5pt;
	text-decoration: none;
	background-color: #ffffff;
	border: 1px solid #C7560C;
	cursor: pointer;
	transition-duration:0.3s;
    -webkit-transition-duration:0.3s;
    -moz-transition-duration:0.3s;
    -o-transition-duration:0.3s;
    -ms-transition-duration:0.3s;
    border-radius: 10px;
    
} 
form .btns:hover{
    color: #ffffff;
    background-color: #F15A24;
}

.check{
    margin:30px 0;
}

.form-name{
    margin-bottom:15px;
}

.form-area li{
    margin-bottom:30px;
}

.con-tel{
    font-size:25px;
    color:#EB4E15;
}

.con-t{
    margin-bottom:40px;
}

.con-area{
    padding:0 20px;
    margin: 40px 0;
}

@media screen and (min-width: 992px),
print {
    .con-area{
    padding:0;
        max-width:750px;
        margin:60px auto;
        line-height: 1.6;
}
    
    
}


/*
++++++++++++++++++++++++++++++++++++++

@media screen and (min-width: 992px),
print {
    
}

@media screen and (min-width: 768px) and (max-width:991px)
{
}

+++++++++++++++++++++++++++++++++++++++++
*/



.contact-txt{
  padding:0 10px;
  margin-bottom: 30px;
}
@media screen and (min-width:768px),
print {
 .contact-txt{
  padding:0 30px;
  margin:0 auto 50px;
     max-width: 900px;
}
  
}

.con-tel{
font-size:25px;
color:#E40C10;
}

@media screen and (min-width:768px),
print {
.con-tel{
font-size:35px;
color:#E40C10;
}
}

.con-tel a{
color:#E40C10;
}

.con-tel a:visited{
color:#E40C10;
}

.con-tel2{
font-size:19px;
color:#E40C10;
}

.con-tel2 a{
color:#E40C10;
}

.con-tel2 a:visited{
color:#E40C10;
}

#form{

}

#form .con-form{
  max-width:900px;
  margin:auto;
}

#form .con-form li{
 margin-bottom: 30px;
  display: flex;
  flex-direction: column;
  width:100%;
}


@media screen and (min-width: 992px),
print {
#form .con-form li{
  flex-direction:row;
  align-items: center;
}
}

#form .con-order{
  padding:0 10px;
}

#form .con-order{
  padding:0 30px;
  max-width:900px;
  margin:auto;
}

#form .con-order li{
 margin-bottom: 30px;
  display: flex;
  flex-direction: column;
  width:100%;
}


@media screen and (min-width: 992px),
print {
#form .con-form{
  padding-left:0;
  padding-right:0;
}
#form .con-order li{
  flex-direction:row;
}
}

#form .con-order li:nth-child(8) {
 margin-bottom: 30px;
  display: block;
  width:100%;
}


@media screen and (min-width: 992px),
print {
#form .con-order li{
  flex-direction:row;
}
}

#form .shiharai{
  display: block;
}

#form .shiharai-con{
 margin-bottom: 30px;
  display: flex;
  flex-direction: column;
  width:100%;
}


@media screen and (min-width: 992px),
print {
#form .shiharai-con{
  flex-direction:row;
}
}

#form .con-siharai{
  margin:20px 0 40px;
}


#form .con-form-name{
  margin-bottom: 7px;
  text-align: left;
}

@media screen and (min-width: 992px),
print {
#form .con-form-name{
  margin-bottom:0;
     margin-right: 50px;
     width:25%;
} 
}

@media screen and (min-width: 992px),
print {
#form .con-form-right{
  width:70%;
} 
}

#form input[type="text"] {
width:100%;
padding: 22px 24px;
border-radius: 8px;
border:#ccc 1px solid;
}

#form input[type="email"] {
border:#ccc 1px solid;
width:100%;
padding: 22px 24px;
border-radius: 8px;
border:#ccc 1px solid;
font-size: 100%;
}

#form input[type="tel"] {
border:#ccc 1px solid;
width:100%;
padding: 22px 24px;
border-radius: 8px;
border:#ccc 1px solid;
font-size: 100%;
}
#form input#post_code {
width: 10em;
}
#form textarea { 
width:100%;
height:auto;
padding: 22px 24px;
border:#ccc 1px solid;
border-radius: 8px;
font-size: 100%;
}

#form input:has( + .year){
width:calc(100% - 1.25em);
margin-right:.25em;
}
#form input:has( + input),
#form input:has( + fieldset){
margin-bottom:8px;
}
#form .year{
font-size:110%;
}
#form input.flatpickr {
font-size: 100%;
}
#form .pl_f_min::placeholder{
font-size: 12px;
line-height:1.2;
}
@media screen and (max-width:768px),
print {
#form input[type="text"],#form input[type="tel"],#form input[type="email"],#form textarea {
  padding: 16px 10px;
  text-align: left!important;
}
}
/*
++++++++++++++++++++++++

セレクトボックス

++++++++++++++++++++++++
*/
.select_wrapper {
display: inline-block;
position: relative;
background-color:#fff;
border-radius: 8px;
}

.select_wrapper::after {
content: "";
margin: auto;
position: absolute;
top: 0;
bottom: 5px;
right: 16px;
width: 6px;
height: 6px;
border-right: 2px solid #333;
border-bottom: 2px solid #333;
transform: rotate(45deg);
}
.select_wrapper select,
.select_wrapper select:focus{
border:none;
border-radius:0;
}

#form select {
-webkit-appearance: none;
appearance: none;
}
#form .selectbox-001,
#form input[type=date] {
min-width: 10em;
height: 60px;
padding: 12px 24px;
border-radius: 8px;
font-size: 15px;
position: relative;
}
#form .select_wrapper .selectbox-001 {
padding: 12px 40px 12px 24px;
}

#form .selectbox-001::before,
#form .selectbox-001::after {
  position: absolute;
  content: '';
  pointer-events: none;
}

#form .selectbox-001::before {
  display: inline-block;
  right: 0;
  width: 2.8em;
  height: 2.8em;
  border-radius: 0 3px 3px 0;
  background-color: #2589d0;
}

#form .selectbox-001::after {
  position: absolute;
  top: 50%;
  right: 1.4em;
  transform: translate(50%, -50%) rotate(45deg);
  width: 6px;
  height: 6px;
  border-bottom: 3px solid #fff;
  border-right: 3px solid #fff;
}

#form .selectbox-001 select {
  appearance: none;
  min-width: 230px;
  height: 2.8em;
  padding: .4em 3.6em .4em .8em;
  border: none;
  border-radius: 3px;
  background-color: #e6edf3;
  color: #333;
  font-size: 1em;
  cursor: pointer;
}

#form .selectbox-001 select:focus {
  outline: 2px solid #2589d0;
}
@media screen and (max-width:768px),
print {
#form .selectbox-001,
#form input[type=date]  {
  min-width: 12em;
  padding: 16px 10px;
  text-align: left!important;
}
#form .select_wrapper .selectbox-001{
  padding: 16px 25px 16px 12px;
}
select {
  color: #000;
}

}
/*
++++++++++++++++++++++++

ラジオボタン

++++++++++++++++++++++++
*/

#form .radio-002 {
  display: flex;
  flex-wrap: wrap;
  gap: .3em 2em;
  border: none;
}

#form .radio-002 label {
  display: flex;
  align-items: center;
  gap: 0 .5em;
  position: relative;
  cursor: pointer;
}

#form .radio-002 label::before,
#form .radio-002 label::after {
  border-radius: 50%;
  content: '';
}

#form .radio-002 label::before {
  width: 18px;
  height: 18px;
  border: 2px solid #dee5eb;
  box-sizing: border-box;
}

#form .radio-002 label::after {
  position: absolute;
  top: 50%;
  left: 9px;
  transform: translate(-50%, -50%);
  width: 9px;
  height: 9px;
  background-color: #dee5eb;
}

#form .radio-002 label:has(:checked)::after {
  background-color: #2589d0;
  animation: anim-radio-002 .3s linear;
}

@keyframes anim-radio-002 {
  0% {
      box-shadow: 0 0 0 1px transparent;
  }
  50% {
      box-shadow: 0 0 0 10px #2589d033;
  }
  100% {
      box-shadow: 0 0 0 10px transparent;
  }
}

#form .radio-002 input {
  display: none;
}

#form .con-submit{
  margin: auto;
  width:80%;
}

@media screen and (min-width: 768px),
print {
#form .con-submit{
  width:200px;
}
}

#form .btns{
  background:#F1F1F1;
color:#000;
letter-spacing: 0.5pt;
text-decoration: none;
border: 1px solid #E6E6E6;
  border-radius:50px;
  font-size:17px;
  padding:17px 0;
  width:100%;
} 

@media screen and (min-width: 768px)
{
#form .btns{
width:250px;

} 
}



#form input[type="submit"] {
cursor: pointer;
}

#form input[type="submit"] + input[type="button"]{
display: inline-block;
margin-top: 10px;
}

/*
++++++++++++++++++++++++

お知らせ

++++++++++++++++++++++++
*/
#form .form_notice{
text-align: left;
font-size: 14px;
margin: 8px 0;
}
#form .form_notice::before{content:"●";display:inline-block;margin-right: 2px;}

/*
++++++++++++++++++++++++

エラーメッセージ

++++++++++++++++++++++++
*/
#form .error{
display: block;
margin-bottom: .2em;
text-align: left;
font-size: 14px;
color: #c70909;
font-weight: bold;
}
#form .error + input{
background-color: #fff;
border-width: 2px;
border-color: #c70909;
}
#form .error ~ input{
background-color: #fff;
border-width: 2px;
border-color: #c70909;
}
#form .error + textarea{
background-color: #fff;
border-width: 2px;
border-color: #c70909;
}
