@charset "utf-8";
/* ------------------------------------------------------------ common */

body{ margin: 0 auto; font-family: 'Noto-Sans-JP-Regular'; }
a{ display: block; color: #fff; text-decoration: none; }

.inner{ width: 1100px; margin: 0 auto; padding: 0 30px; }
.s_inner{ width: 710px; margin: 0 auto; }

.SP{ display: none; }

.w_box{ background: #fff; border-radius: 10px; box-shadow: 4.95px 4.95px 7px 0px rgba(0, 0, 0, 0.15); }
.orange{ background: linear-gradient(90deg, rgba(253,100,79,1) 0%, rgba(242,141,41,1) 100%); }
.green{ background: linear-gradient(90deg, rgba(41,184,51,1) 0%, rgba(84,201,93,1) 100%); }

.btn{ position: relative; border-radius: 50px; font-size: 14px; width: 100%; height: 40px; text-align: center; line-height: 280%; }
.btn:after{ position: absolute; content: ""; top: 15px; right: 20px; width: 7px; height: 7px; border-top: 2px solid #fff; border-right: 2px solid #fff; transform: rotate(45deg); }

.dot{ position: relative; padding: 7px 0 0; }
.dot:before{ position: absolute; content: ""; top: 0; left: 50%; transform: translate(-50%,0); width: 7px; height: 7px; border-radius: 50px; background: #fff; }


/* font */
.futura{ font-family: futura-pt,sans-serif; font-weight: 500; font-style: normal; }
.din{ font-family: din-2014,sans-serif; font-weight: 400; font-style: normal; }

h3.center{ font-size: 50px; font-family: 'Noto-Sans-JP-Bold'; text-align: center; }
h3.center span{ padding: 0 0 15px; display: block; font-size: 20px; font-family: futura-pt,sans-serif; font-weight: 500;  }

section{ position: relative; }
section:before{ position: absolute; z-index: 50; content: ""; top: 30px; left: 50%; transform: translate(-50%,0); width: 4px; height: 80px; background: #000; }

main{ width: 100%; }

/* ------------------------------------------------------------ header */
header{ padding: 20px 5% 25px; }
header .flex{ display: flex; justify-content: space-between; }

header .left{ display: flex; align-items: center; }
header .left p{ width: 200px; padding: 0 12px 0 0; }
header .left h1{ font-size: 13px; }

/* header .right{ width: 255px; } */
header .right a{ padding: 0 0 0 50px; color: #000; font-weight: 600; font-size: 34px; background: url(../images/icn_01.svg) left center/42px no-repeat; }
header .right small{ font-size: 13px; padding: 13px 0 0; }

/* ------------------------------------------------------------ main */

#contact { padding: 50px 0 100px; background-color: #EAEAEA;}
#contact .top { display: flex; justify-content: center; align-items: flex-end; margin-bottom: 35px;}
#contact .top .circle { width: 114px; font-size: 26px; font-weight: 700; letter-spacing: 0.1em; line-height: 1.154; text-align: center; color: #FFE400; background: #000; border-radius: 50%; padding: 27px 0;}
#contact .top .right { width: 760px; text-align: center; margin-left: 20px; padding-bottom: 10px;}
#contact .top .right p { display: inline-block; font-size: 30px; font-weight: 700; margin-bottom: 8px;}
#contact .top .right p:before,
#contact .top .right p:after { display: inline-block; content: ""; width: 25px; height: 35px; vertical-align: -0.15em;}
#contact .top .right p:before { margin-right: 5px; background: url(../images/deco_L.png) center bottom/100% no-repeat;}
#contact .top .right p:after { margin-left: 5px; background: url(../images/deco_R.png) center bottom/100% no-repeat;}
#contact .top .right p span { font-weight: 700; padding-top: 0.1em; background-position: top left; background-repeat: repeat-x; background-size: 1em .3em; background-image: radial-gradient(.1em .1em at center center,#000,#000 100%,transparent,transparent);}
#contact .top .right h2 { font-size: 30px; font-weight: 700;}
#contact .top .right h2 .y_line { display: inline-block; background: linear-gradient(transparent 65% , #ffe939 65%); font-weight: 700; padding-bottom: 8px; margin-bottom: -8px;}
#contact .top .right h2 .y_line span { font-size: 36px; font-weight: 700;}

#contact .form { width: 100%; background: #fff; border-radius: 20px; }
#contact .form .step { background: #4CB5B3; display: flex; flex-wrap: wrap; align-items: center; border-radius: 20px 20px 0 0; padding: 20px 110px; }

#contact .form .step span.text { font-size: 36px; color: #fff; letter-spacing: 3px; font-family: 'din-2014',sans-serif; }

#contact .form .step ul { width: calc(100% - (150px + 92px + 30px)); display: flex; justify-content: space-between; align-items: center; padding: 0 15px; }
#contact .form .step ul li { width: 50px; height: 50px; line-height: 50px; text-align: center; font-size: 26px; background: #B2E2E1; border-radius: 8px; -webkit-border-radius: 8px; }
#contact .form .step ul li.active { width: 250px; background: #fff; display: flex; justify-content: flex-start; align-items: center; }
#contact .form .step ul li.active span { padding: 0 13px 0 20px; line-height: 35px; border-right: 2px solid #4CB5B3; }
#contact .form .step ul li.active p { padding-left: 15px; font-size: 16px; }
#contact .form .step .badge { width: 150px; height: 40px; display: flex; align-items: center; justify-content: center; border: 1px solid #fff; color: #fff; border-radius: 25px; -webkit-border-radius: 25px; box-sizing: border-box; }
#contact .form .step .badge strong { font-size: 30px; padding: 0 4px; }

#contact .form .bottom { padding: 50px 30px 0; margin-bottom: 45px;}
#contact .form .bottom.step1 { padding: 50px 175px 0; }

#contact .form .bottom .choise { margin-bottom: 50px;}
#contact .form .bottom .choise:last-child { margin-bottom: 0;}
#contact .form .bottom .choise h3 { font-size: 30px; font-weight: 700; margin-bottom: 28px;}
#contact .form .bottom .choise h3 .required { display: inline-block; text-align: center; width: 37px; line-height: 21px; font-size: 12px; font-weight: 700; color: #D10000; border: 2px solid #D10000; border-radius: 8px; margin-right: 14px; vertical-align: 0.5em;}
#contact .form .bottom .choise .flex { display: flex; flex-wrap: wrap;}
#contact .form .bottom .choise .flex label { position: relative; width: 330px; height: 120px; background: #EAEAEA; border-radius: 20px; margin: 20px 24px 0 0;}
#contact .form .bottom .choise .flex label p { position: absolute; font-size: 24px; font-weight: 700; line-height: 1.5; top: 50%; left: 50%; transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); white-space: nowrap; text-align: center;}
#contact .form .bottom .choise .flex input[type="radio"]:checked + label, #contact .form .bottom .choise .flex input[type="checkbox"]:checked + label { color: #fff; background-color: #4CB5B3;}
#contact .form .bottom .choise .flex label:nth-of-type(-n+3) { margin-top: 0;}
#contact .form .bottom .choise .flex label:nth-child(3n) { margin-right: 0;}
#contact .form .bottom .choise .flex input[type="radio"], #contact .form .bottom .choise .flex input[type="checkbox"] { display: none;}

#contact .form .bottom .choise .flex select { -webkit-appearance: none; appearance: none; }
#contact .form .bottom .choise .flex select::-ms-expand { display: none; }
#contact .form .bottom .choise .flex select { width: 330px; border: none; font-size: 24px; padding: 10px 0 10px 20px; background: #EAEAEA; border-radius: 20px; -webkit-border-radius: 20px; color: #000; }

#contact .form .bottom .choise .flex .select_wrap { position: relative; }
#contact .form .bottom .choise .flex .select_wrap:after { border-left: 2px solid #000; border-top: 2px solid #000; content: ""; position: absolute; right: 20px; top: 42%; bottom: 50%; transform: translate(0, -50%); -webkit-transform: translate(0, -50%); -ms-transform: translate(0, -50%); width: 7px; height: 7px; transform: rotate(225deg); }

/* ------------------------------------------------------------ upload */
#contact .form .bottom .txt{ padding: 0 0 33px; font-size: 14px; line-height: 190%; }

#contact .form .bottom .upload { padding-top: 12px; }
#contact .form .bottom .upload p:first-of-type{ position: relative; width: 500px; height: 330px; margin: 0 auto; background: #F2F2F2; border: 1px dotted #707070; text-align: center; }
#contact .form .bottom .upload p:first-of-type span{ position: absolute; width: 100%; top: 50%; left: 50%; transform: translate(-50%,-50%); display: block; font-size: 16px; color: #707070; line-height: 160%; pointer-events: none; }
#contact .form .bottom .upload p:first-of-type span img{ display: block; margin: 0 auto; padding: 0 0 15px; }
#contact .form .bottom .upload input[type=file]{ cursor: pointer; opacity: 0; width: 100%; height: 100%; }

#contact .form .bottom .upload p.note_text{ padding: 20px 0 20px; font-size: 14px; font-family: 'Noto-Sans-JP-Light'; text-align: center; }

#contact .form .bottom .upload p.note_text { text-align: center; }
#contact .form .bottom .upload button{ display: block; appearance: none; -webkit-appearance: none; width: 320px; margin: 40px auto 0; padding: 13px 0; background: #BEBEBE; color: #fff; font-size: 16px; text-align: center; border: none; border-radius: 50px; }

#contact .form .bottom .upload .up_pic li{ position: relative; float: left; width: 230px; height: 153px; overflow: hidden; margin: 0 10px 20px; }
#contact .form .bottom .upload .up_pic li .del { cursor: pointer; position: absolute; content: ""; width: 33px; height: 34px; top: 10px; right: 10px; background: url(../images/contact/icn_02.svg) center/cover no-repeat; }

#contact .form .bottom .upload .up_pic img { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); width: 100%; height: auto; }


#contact .form .upload ul.up_pic .loader { width: 230px; height: 153px; line-height: 125px; text-align: center; border: 1px solid #dedede; box-sizing: border-box; }
#contact .form .upload ul.up_pic .loader img { width: 50px; height: 50px; }

#contact .form .upload p.error_msg { text-align: center; padding-bottom: 20px; }
#contact .form .upload p.error_msg span { color: red; }



/* ------------------------------------------------------------ caution */
#contact .form .bottom .caution{ padding: 80px 0 0; }
#contact .form .bottom .caution h4{ width: 331px; margin: 0 auto; box-sizing: border-box; padding: 14px 0 15px; border: 1px solid #D10000; text-align: center; color: #D10000; font-size: 20px; font-family: 'Noto-Sans-JP-Bold'; border-radius: 10px; }
#contact .form .bottom .caution h5{ padding: 20px 0; font-size: 20px; font-family: 'Noto-Sans-JP-Bold'; text-align: center; }
#contact .form .bottom .caution p{ padding: 30px 0 0; font-size: 14px; line-height: 200%; }

#contact .form .bottom .caution div img{ padding: 0 20px 0 0; }
#contact .form .bottom .caution div img:last-of-type{ padding: 0; }


#contact .form .end{ display: flex; align-items: center; justify-content: center; }
#contact .form .end a.back{ width: 270px; margin: 0 20px 0 0; background: #707070; }
#contact .form .end a{ margin: 0; }


#contact .form .bottom .choise .flex.jusbe { justify-content: space-between;}
#contact .form .bottom .choise .flex .condition { width: 330px; border: 1px solid #707070; border-radius: 10px; padding: 38px 30px 40px; text-align: center; box-sizing: border-box;}
#contact .form .bottom .choise .flex .condition p { font-size: 24px; font-weight: 700; margin-bottom: 15px; }
#contact .form .bottom .choise .flex .condition img { margin-bottom: 20px;}
#contact .form .bottom .choise .flex .condition label { position: relative; display: block; width: 100%; height: 60px; background: #EAEAEA; border-radius: 10px; margin: 0 0 10px;}
#contact .form .bottom .choise .flex .condition label:last-child { margin-bottom: 0;}
#contact .form .bottom .choise .flex .condition label p { position: absolute; font-size: 24px; font-weight: 700; line-height: 1.5; top: 50%; left: 50%; transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); white-space: nowrap;}

/* step1 ご希望の見積もり */
#contact .form .bottom .choise .desired_quote label { padding: 25px 0 25px 50px; background: #fff; width: 100%; height: auto; border-top: 1px solid #B1B1B1; border-radius: inherit; -webkit-border-radius: inherit; }
#contact .form .bottom .choise .desired_quote label:last-child { border-bottom: 1px solid #B1B1B1; }
#contact .form .bottom .choise .desired_quote label p { font-size: 18px; font-weight: inherit; position: static; transform: inherit; -webkit-transform: inherit; text-align: left; padding-bottom: 2px; }
#contact .form .bottom .choise .desired_quote label small { font-size: 12px; }

#contact .form .appear_photo { padding: 30px; margin: 0 175px; border: 1px solid #000; border-radius: 16px; -webkit-border-radius: 16px; }
#contact .form .appear_photo h4 { font-size: 24px; padding: 0 0 15px 15px; }
#contact .form .appear_photo small { display: block; padding-bottom: 5px; }
#contact .form .appear_photo ul { padding-top: 35px; display: flex; align-content: center; justify-content: space-between; text-align: center; }
#contact .form .appear_photo ul li p { padding: 0 0 12px; }
#contact .form .appear_photo ul.border li img { border: 1px solid #B1B1B1; }
#contact .form .appear_photo .description { font-size: 18px; padding: 0 0 0 15px; margin: 35px 0 0; }

#contact .form .appear_photo h4, #contact .form .appear_photo .description { position: relative; }
#contact .form .appear_photo h4:before, #contact .form .appear_photo .description:before { content: ''; display: inline-block; width: 5px; height: 22px; background: #000; position: absolute; top: -2px; bottom: 50%; left: 0; transform: translate(-50%, 0); -webkit-transform: translate(-50%, 0); -ms-transform: translate(-50%, 0); border-radius: 5px; -webkit-border-radius: 5px; }
#contact .form .appear_photo h4:before { top: 0; height: 27px; }

/* check layout */
#contact .form .bottom .choise .desired_quote label:before, #contact .form .bottom .choise .desired_quote label:after { position: absolute; content: ""; }
#contact .form .bottom .choise .desired_quote label:before { top: 25px; left: 6px; width: 25px; height: 25px; border: 1px solid #707070; border-radius: 5px; transform: inherit; -webkit-transform: inherit; }
#contact .form .bottom .choise .desired_quote label:after { top: 32px; left: 13px; background: #4CB5B3; width: 13px; height: 13px; opacity: 0; border-radius: 3px; -webkit-border-radius: 3px; }
#contact .form .bottom .choise .desired_quote input[type="radio"]:checked + label, #contact .form .bottom .choise .desired_quote input[type="checkbox"]:checked + label { color: #000; background: inherit; }
#contact .form .bottom .choise .desired_quote input[type="radio"]:checked + label:after { opacity: 1; }

#contact .form .bottom #personal table { width: 575px; margin: 0 auto;}
#contact .form .bottom #personal th,
#contact .form .bottom #personal td { display: block;}
#contact .form .bottom #personal th { text-align: left;}
#contact .form .bottom #personal th h3 { font-size: 18px; font-weight: 700; margin-bottom: 12px;}
#contact .form .bottom #personal th h3 small { font-size: 10px; font-weight: 500;}
#contact .form .bottom #personal th h3 .required { display: inline-block; text-align: center; width: 41px; line-height: 25px; font-size: 12px; font-weight: 700; color: #D10000; border: 1px solid #D10000; border-radius: 8px; margin-right: 14px; vertical-align: middle; box-sizing: border-box;}
#contact .form .bottom #personal th h3 .any { display: inline-block; text-align: center; width: 41px; line-height: 25px; font-size: 12px; font-weight: 700; color: #707070; border: 1px solid #707070; border-radius: 8px; margin-right: 14px; vertical-align: middle; box-sizing: border-box;}

#contact .form .bottom #personal td { margin-bottom: 30px;}
#contact .form .bottom #personal td input { width: 100%; padding: 6.75px 15px; border: 1px solid #707070; border-radius: 5px; box-sizing: border-box;}
#contact .form .bottom #personal td textarea { width: 100%; height: 16em; line-height: 1.8; padding: 8px 15px; border: 1px solid #707070; border-radius: 5px; box-sizing: border-box;}
#contact .form .bottom #personal td input[type="radio"] { display: none;}

#contact .form .bottom #personal .slect td { display: flex; justify-content: space-between; flex-wrap: wrap;}
#contact .form .bottom #personal .slect td input { width: 30%; margin-bottom: 10px;}
#contact .form .bottom #personal .slect td .btn_wrap { width: 69%; display: flex; align-items: flex-start; }
#contact .form .bottom #personal .slect td #postal_btn, #contact .form .bottom #personal .slect td #address_btn { cursor: pointer; display: block; font-size: 14px; font-weight: 700; background: #000; color: #fff; border-radius: 35px; text-align: center; padding: 12px 10px; margin-right: 5px; }
#contact .form .bottom .slect td select { width: 30%; -webkit-appearance: none;	-moz-appearance: none; appearance: none; padding: 6.75px 15px; font-size: 16px; color: #707070; font-weight: 300; border-radius: 5px; border: solid 1px #707070; background: #fff url(../images/contact/arrow.svg) no-repeat 95% center / 10px;}
#contact .form .bottom #personal .slect td .input_city { width: 69%; margin: 0; }


#contact .form .bottom #personal .short td { }
#contact .form .bottom #personal .short td p { display: inline-block; width: 85px; text-align: left; vertical-align: 0.5em;}
#contact .form .bottom #personal .short td p:last-child { vertical-align: 0.2em;}
#contact .form .bottom #personal .short td input { width: 50%; margin-bottom: 20px;}
#contact .form .bottom #personal .short td input:last-child { margin-bottom: 0px;}

#contact .form .bottom #personal .contactus td { display: flex; justify-content: space-between;}
#contact .form .bottom #personal .contactus td label { position: relative; display: block; width: 49%; height: 66px; background: #EAEAEA; border-radius: 10px; margin: 0;}
#contact .form .bottom #personal .contactus td input[type="radio"]:checked + label { color: #fff; background-color: #4CB5B3;}
#contact .form .bottom #personal .contactus td label p { position: absolute; font-size: 16px; font-weight: 500; top: 50%; left: 50%; transform: translate(-50%,-50%); -webkit-transform: translate(-50%,-50%); }

#contact .form .bottom #personal .convenient th h3 { font-size: 16px;}
#contact .form .bottom #personal .convenient td { display: flex; justify-content: space-between; flex-wrap: wrap;}
#contact .form .bottom #personal .convenient td label { position: relative; display: block; width: 49%; height: 40px; border: 1px solid #707070; border-radius: 6px; margin: 0 0 20px;}
#contact .form .bottom #personal .convenient td label:nth-of-type(n+5) { margin-bottom: 0;}

#contact .form .bottom #personal .convenient td label:before, #contact .form .bottom #personal .convenient td label:after { position: absolute; content: "";}
#contact .form .bottom #personal .convenient td label:before { width: 25px; height: 25px; border: 1px solid #707070; border-radius: 5px; top: 50%; left: 6px; transform: translateY(-50%); -webkit-transform: translateY(-50%);}
#contact .form .bottom #personal .convenient td label:after { top: 7px; left: 13px; width: 8px; height: 16px; border-bottom: 4px solid #F05454; border-right: 4px solid #F05454;    transform: rotate(45deg); opacity: 0;}

#contact .form .bottom #personal .convenient td input[type="radio"]:checked + label:after { opacity: 1;}
#contact .form .bottom #personal .convenient td label p { position: absolute; font-size: 16px; font-weight: 500; color: #707070; top: 50%; left: 45px; transform: translateY(-50%); -webkit-transform: translateY(-50%); }


#contact .form .end { display: flex; align-items: center; justify-content: center; padding: 40px 0 50px; border-top: 1px solid #BCBCBC;}
#contact .form .end input[type="submit"] { appearance: none; -webkit-appearance: none; }
#contact .form .end a, #contact .form .end input[type="submit"] { cursor: pointer; width: 460px; font-size: 20px; font-weight: 700; color: #fff; background: #000; border-radius: 35px; padding: 25px 0; margin: 0; text-align: center; line-height: 20px; border: none; }
#contact .form .end a.back{ width: 270px; margin: 0 20px 0 0; background: #707070; }
#contact .form .end a.send, #contact .form .end input[type="submit"].send { background: #F15677; border: none; }

/* ------------------------------------------------------------ confirm */

#confirm { width: 750px; text-align: center; margin: 0 auto;}
#confirm h3 { font-size: 30px; font-weight: 700; margin-bottom: 20px;}
#confirm .attention { font-size: 13px; margin-bottom: 30px;}
#confirm dl {display: flex; justify-content: space-between; align-items: center; padding: 24px 0; border-top: 1px solid #B1B1B1;}
#confirm .flex:last-of-type { margin-bottom: 30px; border-bottom: 1px solid #B1B1B1;}
#confirm dt { font-size: 18px;  text-align: left;}
#confirm dd { font-size: 18px; font-weight: 500; text-align: right;}

#confirm .photo { display: block;}
#confirm .photo dt { margin-bottom: 12px;}
#confirm .photo dd { display: flex; flex-wrap: wrap;}

#confirm .img_wrap { width: calc(100% / 5 - 12px); height: 94px; position: relative; margin: 0 12px 12px 0; overflow: hidden; }

#confirm .photo dd img { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); width: 100%; height: auto; }
#confirm .photo dd img:nth-child(5n) { margin-right: 0;}
#confirm .photo dd img:nth-child(n+6) { margin-top: 12px;}

#confirm .flex { display: block;}
#confirm .flex dt { margin-bottom: 20px;}
#confirm .flex dd dl { padding: 9px 0; border: none; padding-left: 1em;}
#confirm .flex dd dt { margin-bottom: 0;}
#confirm .flex dd dd { }

#confirm .flex dd dl.confirm_teaxtarea { flex-direction: column; align-items: flex-start; }
#confirm .flex dd dl.confirm_teaxtarea dd { padding-top: 15px; }

#confirm .checkbox p { font-size: 16px; margin-bottom: 20px;}
#confirm .checkbox a { display: inline; color: #0027CB; border-bottom: 1px solid #0027CB;}
#confirm .checkbox #checkbox { display: none;}
#confirm .checkbox #checkbox + span { display: inline-block; position: relative; font-size: 16px; padding: 0 0 0 1.2em; margin: 0 .2em 0; cursor: pointer;}
#confirm .checkbox #checkbox + span::before { position: absolute; content: ""; top: 50%; left: -0.5em; transform: translateY(-50%); background: #F2F2F2; border: 2px solid #000; border-radius: 5px; width: 24px; height: 24px; display: block;}
#confirm .checkbox #checkbox:checked + span::after { position: absolute; content: ""; top: 50%; left: -0.2em; transform: translateY(-50%) rotate(-45deg); width: 1em; height: .6em; margin-top: -.2em; display: block; border-left: 3px solid #F44336; border-bottom: 3px solid #F44336;}


/* ------------------------------------------------------------ thanks */

#thanks { width: 600px; margin: 0 auto; padding: 50px 0 55px; text-align: center;}
#thanks img { margin-bottom: 32px;}
#thanks h3 { font-size: 40px; font-weight: 700; margin-bottom: 50px; font-feature-settings: "palt";}
#thanks h3:after { display: block; content: ""; width: 100%; height: 1px; background: #B1B1B1; margin-top: 45px;}
#thanks p { font-size: 20px; font-weight: 500; line-height: 1.8; margin-bottom: 50px;}
#thanks p:last-child { font-size: 13px; font-weight: 400; line-height: 2; margin-bottom: 0;}


/* ------------------------------------------------------------ footer */
footer{ padding: 30px 0; }
footer .f_inner{ padding: 0 5%; }
footer .flex{ display: flex; justify-content: space-between; align-items: center; }

footer .top{ padding: 0 0 30px; border-bottom: 1px solid #c9c9c9; }
footer .top h3{ width: 170px; font-size: 18px; font-family: 'Noto-Sans-JP-Medium'; }

footer .top .btns{ width: 575px; }
footer .top .btns .btn{ position: relative; float: left; width: 280px; height: 50px; padding: 6px 0 0 10px; box-sizing: border-box; margin: 0 12px 0 0; font-family: 'Noto-Sans-JP-Bold'; }
footer .top .btns .btn:last-of-type{ margin: 0; }
footer .top .btns .btn:after{ top: 20px; right: 24px; }

footer .top .btns .btn:before{ position: absolute; content: ""; width: 21px; height: 15px; top: 50%; left: calc(50% - 110px); transform: translate(0,-50%); background: url(../images/icn_pc.png) center/cover no-repeat; }
footer .top .btns .btn:last-of-type:before{ width: 21px; height: 19px; background: url(../images/icn_line.png) center/cover no-repeat; }


footer .bottom{ padding: 30px 0 0; }
footer .bottom .logo{ width: 430px; }
footer .bottom .logo a{ display: flex; flex-direction: row-reverse; align-items: center; }
footer .bottom .logo a p{ padding: 0 0 0 35px; color: #000; font-size: 13px; line-height: 160%; }

footer .bottom .f_nav{ width: 400px; }
footer .bottom .f_nav a{ display: inline; font-size: 13px; padding: 0 20px 0 0; color: #000; }
footer .bottom .f_nav a:last-of-type{ padding: 0; }

footer small{ display: block; font-size: 12px; padding: 60px 0 0; }


.pagetop{ position: fixed; bottom: 100px; left: 100px; width: 50px; z-index: 100; }
.pagetop img{ width: 100%; height: auto; }

.display_off { display: none; }
.display_on { display: block; }

/* ------------------------------------------------------------
	mobile 
------------------------------------------------------------ */
@media only screen and (max-width: 640px) {
	
	/* ------------------------------------------------------------ common */
	body{ min-width: 100%; }
	
	.inner{ width: 90%; padding: 0; }
	.s_inner{ width: 85%; }
	
	.PC{ display: none; }
	.SP{ display: block; }
	
	.dot{ padding: 3px 0 0; }
	.dot:before{ width: 4px; height: 4px; }
	
	section:before{ width: 3px; height: 70px; top: 30px; }
	
	h3.center{ font-size: 30px; line-height: 140%; }
	h3.center span{ padding: 0 0 15px; font-size: 15px; }
	
		
	
	
	/* ------------------------------------------------------------ header */
	header{ padding: 15px 2%; }
	
	header .right{ width: 160px; display: flex; align-items: center; }
	header .right img{ width: 100%; height: auto; }
	header .right a{ font-size: 14px; padding: 0; background: url(../images/icn_01.svg) left top/31px no-repeat; }
	header .right a p { font-size: 20px; padding-left: 35px; }
	header .right small { font-size: 12px; display: inline-block; padding-top: 2px; }
	
	header .left{ display: flex; flex-direction: column-reverse; align-items: baseline; }
	header .left h1{ font-size: 10px; }
	header .left p{ width: 190px; padding: 10px 0 0; }
	header .left p img{ width: 100%; height: auto; }
	

	
	/* ------------------------------------------------------------ fv */
	main{ width: 100%; }
	
	#contact { padding: 30px 0 50px;}
	#contact .top { margin-bottom: 15px;}
	#contact .top .circle { width: 70px; font-size: 16px; line-height: 1.125; padding: 17px 0;}
	#contact .top .right { width: 80%; margin-left: 5px; padding-bottom: 0;}
	#contact .top .right p { font-size: 15px; margin-bottom: 5px;}
	#contact .top .right p:before,
	#contact .top .right p:after { width: 12px; height: 17px; vertical-align: -0.15em;}
	#contact .top .right p:before { margin-right: 5px;}
	#contact .top .right p:after { margin-left: 5px;}
	#contact .top .right h2 { font-size: 14px; line-height: 1.5;}
	#contact .top .right h2 .y_line { padding-bottom: 4px; margin-bottom: -4px;}
	#contact .top .right h2 .y_line span { font-size: 18px;}

	#contact .form .step { padding: 0 12px; height: 60px; }
	#contact .form .step span.text { font-size: 18px; letter-spacing: 2px; }
	#contact .form .step ul { width: calc(100% - (55px + 50px + 15px)); padding: 0 7px; }
	#contact .form .step ul li, #contact .form .step ul li.active { width: 30px; height: 30px; line-height: 30px; font-size: 12px; }
	#contact .form .step ul li.active { display: block; }
	#contact .form .step ul li.active p { display: none; }
	#contact .form .step ul li.active span { border: none; padding: 0; line-height: 30px; }
	#contact .form .step p.badge { width: 58px; font-size: 12px; line-height: 150%; display: block; border-radius: 10px; -webkit-border-radius: 10px; text-align: center; }
	#contact .form .step p.badge strong { font-size: 16px; line-height: 100%; }
	
	#contact .form .bottom { padding: 20px 2% 0; margin-bottom: 20px;}
	#contact .form .bottom.step1 { padding: 20px 2% 0; }
	#contact .form .appear_photo { margin: 0 2%; }
	#contact .form .bottom .choise { margin-bottom: 20px;}
	#contact .form .bottom .choise h3 { font-size: 17px; margin-bottom: 15px; line-height: 1.5; -webkit-line-height: 1.5;}
	#contact .form .bottom .choise h3 .required { display: block; width: 32px; line-height: 20px; font-size: 9px; color: #D10000; border: 1px solid #D10000; border-radius: 4px; margin: 0 0 9px;}
	#contact .form .bottom .choise h3 .any { display: block; width: 32px; line-height: 20px; font-size: 9px; color: #707070; border: 1px solid #707070; border-radius: 4px; margin: 0 0 9px;}
	
	#contact .form .bottom .choise .flex { justify-content: space-between;}
	#contact .form .bottom .choise .flex label { width: 49%; height: 60px; border-radius: 10px; margin: 9px 0 0;}
	#contact .form .bottom .choise .flex label p { font-size: 14px; line-height: 1.6; text-align: center;}
	#contact .form .bottom .choise .flex input[type="radio"]:checked + label { color: #fff; background-color: #4CB5B3;}
	#contact .form .bottom .choise .flex label:nth-of-type(-n+3) { margin-top: 0;}
	#contact .form .bottom .choise .flex label:nth-of-type(3) { margin-top: 9px;}
	#contact .form .bottom .choise .flex label:nth-child(3n) { margin-right: 0;}
	#contact .form .bottom .choise.long .flex label { height: 80px;}
	
	#contact .form .bottom .choise .flex .select_wrap { width: 49%; }
	#contact .form .bottom .choise .flex .select_wrap:after { top: 40%; width: 5px; height: 5px; }

	#contact .form .bottom .choise .flex select { width: 100%; padding-left: 15px; font-size: 14px; border-radius: 10px; -webkit-border-radius: 10px; }
	
	::-webkit-full-page-media, :future, :root #contact .form .bottom .choise .safari { line-height: 0.7;}
	
	/* ------------------------------------------------------------ upload */
	#contact .form .bottom .txt{ padding: 0 0 43px; font-size: 13px; }
	
	#contact .form .bottom .upload p:first-of-type{ width: 90%; height: 200px; margin: 0 auto; }
	#contact .form .bottom .upload p:first-of-type span{ font-size: 14px; }
	
	#contact .form .bottom .upload p.note_text{ padding: 20px 0 10px; font-size: 10px;  }

	#contact .form .bottom .upload button{ width: 90%; margin: 30px auto 0; padding: 16px 0; font-size: 13px; }

	#contact .form .bottom .upload .up_pic li{ width: calc(50% - 4%); margin: 0 2% 10px; }
	#contact .form .bottom .upload .up_pic li:before{ width: 27px; height: 28px; top: 6px; right: 8px; }
	#contact .form .bottom .upload .up_pic li .del { top: 15px; }

	#contact .form .bottom .upload p:first-of-type span img { padding-bottom: 5px; }

	#contact .form .upload p.error_msg span { font-size: 10px; }


	/* ------------------------------------------------------------ caution */
	#contact .form .bottom .caution{ padding: 30px 0 0; }
	#contact .form .bottom .caution h4{ width: 90%; padding: 9px 0; font-size: 15px; border-radius: 5px; }
	#contact .form .bottom .caution h5{ padding: 15px 0 20px; font-size: 13px; }
	#contact .form .bottom .caution div img{ width: calc(50% - 5%); height: auto; margin: 0 2% 10px; padding: 0; }
	#contact .form .bottom .caution p{ padding: 20px 3% 0; font-size: 13px; line-height: 190%; }

	
	#contact .form .bottom .choise .flex .condition { width: 80%;  border-radius: 10px; padding: 25px 22px 30px; margin: 0 auto 20px;}
	#contact .form .bottom .choise .flex .condition:first-child { margin-top: 4px;}
	#contact .form .bottom .choise .flex .condition:last-child { margin-bottom: 0;}
	#contact .form .bottom .choise .flex .condition p { font-size: 18px; margin-bottom: 15px; }
	#contact .form .bottom .choise .flex .condition img { width: 100%; height: auto; margin-bottom: 20px;}
	#contact .form .bottom .choise .flex .condition label { position: relative; display: block; width: 100%; height: 45px; border-radius: 10px; margin: 0 0 7.5px;}
	#contact .form .bottom .choise .flex .condition label:last-child { margin-bottom: 0;}
	#contact .form .bottom .choise .flex .condition label p { font-size: 18px;}

	/* step1 ご希望の見積もり */
	#contact .form .bottom .choise .desired_quote label { width: 100%; height: auto; border-radius: inherit; -webkit-border-radius: inherit; }
	#contact .form .bottom .choise .desired_quote label p { text-align: left; }
	#contact .form .bottom .choise .desired_quote input[type="radio"]:checked + label { color: #000; background: inherit; }
	#contact .form .bottom .choise .desired_quote label { padding: 20px 0 20px 50px; }
	
	#contact .form .appear_photo { padding: 22px 12px; }
	#contact .form .appear_photo h4 { font-size: 16px; padding: 0 0 10px 10px; }
	#contact .form .appear_photo small { font-size: 12px; }
	#contact .form .appear_photo ul { flex-wrap: wrap; padding-top: 15px; }
	#contact .form .appear_photo ul li { width: calc(100% / 2 - 10px); }
	#contact .form .appear_photo ul li img { width: 100%; height: auto; aspect-ratio: 3 / 2; }
	#contact .form .appear_photo ul li:first-child, #contact .form .appear_photo ul li:nth-of-type(2) { padding-bottom: 16px; }
	#contact .form .appear_photo ul li p { font-size: 13px; padding: 0 0 6px; }
	#contact .form .appear_photo .description { font-size: 14px; line-height: 150%; }
	#contact .form .appear_photo h4:before, #contact .form .appear_photo .description:before { height: 40px; top: 0; }
	#contact .form .appear_photo h4:before { top: -4px; height: 22px; }

	#contact .form .bottom #personal table { width: 100%;}
	#contact .form .bottom #personal th { text-align: left;}
	#contact .form .bottom #personal th h3 { margin-bottom: 12px;}
	#contact .form .bottom #personal th h3 small { display: block;}
	#contact .form .bottom #personal th h3 .required { display: block; width: 32px; line-height: 20px; font-size: 10px; color: #D10000; border: 1px solid #D10000; border-radius: 4px; margin: 0 0 9px;}
	#contact .form .bottom #personal th h3 .any { display: block; width: 32px; line-height: 20px; font-size: 9px; color: #707070; border: 1px solid #707070; border-radius: 4px; margin: 0 0 9px;}
	
	#contact .form .bottom #personal td { margin-bottom: 25px;}
	#contact .form .bottom #personal tr:last-child td { margin-bottom: 5px;}
	#contact .form .bottom #personal td input { width: 100%; font-size: 13px; padding: 10px; border-radius: 5px;}
	#contact .form .bottom #personal td textarea { width: 100%; padding: 8px 15px; border: 1px solid #707070; border-radius: 5px; box-sizing: border-box;}
	
	#contact .form .bottom #personal .slect td { display: block;}
	#contact .form .bottom #personal .slect td input { width: 100%; margin-bottom: 10px;}
	#contact .form .bottom #personal .slect td .btn_wrap { width: 100%; justify-content: flex-start; }
	#contact .form .bottom #personal .slect td #postal_btn, #contact .form .bottom #personal .slect td #address_btn { font-size: 12px; border-radius: 35px; padding: 10px; }
	#contact .form .bottom #personal .slect td select { width: 100%;  margin: 0 0 10px;	padding: 10px; font-size: 13px;  border-radius: 5px; background: #fff url(../images/contact/arrow.svg) no-repeat 95% center / 10px; box-sizing: border-box;}
	#contact .form .bottom #personal .slect td select:last-child { margin: 0;}
	#select_pref { margin-top: 10px !important; }
	#contact .form .bottom #personal .slect td .input_city { width: 100%; }
	
	#contact .form .bottom #personal .short td { }
	#contact .form .bottom #personal .short td p { display: inline-block; width: 20%; font-size: 13px; text-align: left; vertical-align: 0.5em;}
	#contact .form .bottom #personal .short td p:last-child { vertical-align: 0.2em;}
	#contact .form .bottom #personal .short td input { width: 80%; margin-bottom: 20px;}
	#contact .form .bottom #personal .short td input:last-child { margin-bottom: 0px;}
	
	#contact .form .bottom #personal .contactus td { display: flex; justify-content: space-between;}
	#contact .form .bottom #personal .contactus td label { width: 49%; height: 60px; border-radius: 10px; margin: 0;}
	#contact .form .bottom #personal .contactus td label p { font-size: 15px;}
	
	#contact .form .bottom #personal .convenient th h3 { font-size: 18px; line-height: 1.5;}
	#contact .form .bottom #personal .convenient td { margin-bottom: 13px;}
	#contact .form .bottom #personal .convenient td label { position: relative; display: block; width: 48%; height: 40px; border: 1px solid #707070; border-radius: 6px; margin: 0 0 12px;}
	#contact .form .bottom #personal .convenient td label:before,
	#contact .form .bottom #personal .convenient td label:after { position: absolute; content: "";}
	#contact .form .bottom #personal .convenient td label:before { width: 20px; height: 20px; left: 6px;}
	#contact .form .bottom #personal .convenient td label:after { top: 7px; left: 13px; width: 8px; height: 16px; border-bottom: 4px solid #F05454; border-right: 4px solid #F05454;}
	#contact .form .bottom #personal .convenient td label p { font-size: 13px; left: 35px;}
	#contact .form .bottom #personal tr:last-child th h3 { line-height: 1.5;}
	
	
	/* ------------------------------------------------------------ confirm */

	#confirm { width: 100%; }
	#confirm h3 { font-size: 24px; margin-bottom: 10px;}
	#confirm .attention { font-size: 13px; line-height: 1.538; margin-bottom: 30px;}
	#confirm dl {display: block; padding: 10px 0; }
	#confirm .flex:last-of-type { margin-bottom: 20px;}
	#confirm dt { font-size: 12px;  text-align: left; margin-bottom: 5px;}
	#confirm dd { font-size: 14px; font-weight: 500; text-align: left; padding-left: 1em;}
	
	#confirm .photo dt { margin-bottom: 6px;}
	#confirm .photo dd { justify-content: space-between; padding-right: 1em;}
	#confirm .photo dd img { margin-right: 0;}
	#confirm .photo dd img:nth-child(n+6) { margin-top: 0;}
	#confirm .photo dd img:nth-child(n+3) { margin-top: 10px;}
	
	#confirm .flex { display: block;}
	#confirm .flex dt { margin-bottom: 10px;}
	#confirm .flex dd dl { padding: 5px 0; border: none; padding-left: 0em;}
	#confirm .flex dd dt { font-size: 12px; margin-bottom: 5px;}
	#confirm .flex dd dd { font-size: 14px; padding-left: 0.5em;}
	
	#confirm .checkbox p { font-size: 12px; margin-bottom: 12px; line-height: 1.833;}
	#confirm .checkbox #checkbox + span { font-size: 12px; padding: 0 0 0 1.2em; margin: 0 .2em 0;}
	#confirm .checkbox #checkbox + span::before { border: 2px solid #000; border-radius: 4px; width: 17px; height: 17px;}
	#confirm .checkbox #checkbox:checked + span::after { width: 1em; height: .6em; margin-top: -.2em; border-left: 3px solid #F44336; border-bottom: 3px solid #F44336;}

	#confirm .img_wrap { width: calc(100% / 2 - 12px); }
	
	
	/* ------------------------------------------------------------ thanks */
	
	#thanks { width: 100%; margin: 0 auto; padding: 20px 0 10px; text-align: center;}
	#thanks img { width: 61px; height: auto; margin-bottom: 18px;}
	#thanks h3 { font-size: 24px; margin-bottom: 25px;}
	#thanks h3:after { margin-top: 25px;}
	#thanks p { font-size: 15px; line-height: 1.5; margin-bottom: 20px;}
	#thanks p:last-child { font-size: 12px; line-height: 1.667; margin-bottom: 0;}
		
	
	#contact .form .end { padding: 20px 0;}
	#contact .form .end a, #contact .form .end input[type="submit"] { width: 45%; padding: 19px 0; font-size: 12px; border-radius: 35px; }
	#contact .form .end .single { width: 80%; padding: 24px 0;}
	#contact .form .end a.back{ width: 45%; margin: 0 10px 0 0; }
	
	/* ------------------------------------------------------------ footer */
	footer{ padding: 40px 0 80px; }
	footer .flex{ flex-direction: column; }
	
	footer .top{ padding: 0 0 50px; }
	footer .top h3{ width: 100%; font-size: 14px; text-align: center; }
	footer .top .btns{ width: 100%; padding: 20px 0 0; font-size: 13px; }
	footer .top .btns .btn{ float: none; width: 80%; padding: 7px 0 0 15px; margin: 0 auto; box-sizing: border-box; }
	footer .top .btns .btn:before{ width: 23px; height: 17px; }
	footer .top .btns .btn:last-of-type:before{ width: 24px; height: 23px; }
	footer .top .btns .btn:last-of-type{ margin: 10px auto 0; }
	footer .top .btns .btn:after{ top: 21px; right: 20px; }
	
	
	footer .bottom{ padding: 50px 0 0; }
	footer .bottom .logo{ width: 100%; }
	footer .bottom .logo a{ flex-direction: column; }
	footer .bottom .logo a p{ padding: 0 0 25px; }
	footer .bottom .logo img{ width: 250px; height: auto; }
	
	footer .bottom .f_nav{ width: 50%; margin: 0 auto; padding: 40px 0 0; text-align: center; }
	footer .bottom .f_nav a{ display: block; padding: 0 0 30px; font-size: 15px;}

	footer small{ font-size: 10px; padding: 50px 0 0; text-align: center; }


	.pagetop{ display: none!important; }
	
	.sp_float{ position: fixed; left: 0; right: 0; bottom: 0; width: 100%; }
	.sp_float a{ float: left; position: relative; width: 50%; padding: 19px 0 19px 22px; box-sizing: border-box; font-size: 14px; color: #fff; border-radius: 0; font-family: 'Noto-Sans-JP-Medium'; text-align: center; }
	
	.sp_float a:before{ position: absolute; content: ""; width: 20px; height: 14px; top: 50%; left: calc(50% - 60px); transform: translate(0,-50%); background: url(../images/icn_pc.png) center/cover no-repeat; }
	.sp_float a:last-of-type:before{ width: 20px; height: 19px; background: url(../images/icn_line.png) center/cover no-repeat; }


	#confirm .flex dd dl.confirm_teaxtarea dd { padding-top: 0; }
}