@charset "utf-8";
/* ------------------------------------------------------------ common */
#case { margin: 120px 0 0; }
#work-type.section { padding-bottom: 0; }


/* bnr ------------------------------------------------------------ */
#bnr{ padding: 20px 0;}
#bnr p{ margin-bottom: 0;}
#bnr a{ display: block; width: 100%; max-width: 1100px; margin: 0 auto;}
#bnr a:hover{ opacity: 0.8;}
#bnr img{ width: 100%;}
#bnr .sp_only{ display: none;}


/* ------------------------------------------------------------ error */
.contact { padding: 100px 0 80px; text-align: center; }
.contact h3 { font-size: 24px; }
.contact .alert span { display: block; }
.contact .btn a { display: block; width: 300px; margin: 0 auto; background: #8f8f8f; color: #fff; line-height: 60px; text-decoration: none; font-size: 20px; }

/* ------------------------------------------------------------ confirm */
.confirm { padding: 100px 0 80px; text-align: center; }
.confirm h3 { font-size: 24px; }
.confirm table { width: 650px; margin: 30px auto 60px; }
.confirm table th { text-align: left; width: 200px; font-size: 20px; padding: 10px 0; }
.confirm table td { text-align: left; font-size: 18px; padding: 10px 0; }
.confirm .btn a { display: block; width: 300px; margin: 0 auto; background: #8f8f8f; color: #fff; line-height: 60px; text-decoration: none; font-size: 20px; }
.confirm .btn input[type="submit"] { display: block; width: 300px; margin: 40px auto 0; background: #af2b2b; color: #fff; line-height: 60px; text-decoration: none; font-size: 20px; border: none; -webkit-appearance: none; border-radius: 0; }

/* ------------------------------------------------------------ thanks */
#thanks { padding: 100px 0 80px; text-align: center; }
#thanks h3 { font-size: 24px; }
#thanks .page_top { padding: 40px 0 0; }
#thanks .page_top a { display: block; width: 300px; margin: 0 auto; background: #8f8f8f; color: #fff; line-height: 60px; text-decoration: none; font-size: 20px; }

/* ------------------------------------------------------------ schedule */
#schedule .box { text-align: center; margin: 0; }
#schedule .box dt { color: #fff; background: #213a2c; font-size: 24px; padding: 5px 0; }
#schedule .box dd { background: #fff; padding: 25px; margin: 0; }
#schedule .box dd.cfx ul { width: calc(100% / 7); float: left; font-size: 17px; padding: 0 0 0 30px; position: relative; }
#schedule .box dd.cfx ul:before { position:absolute; content: ""; display: block; width: 14px; height: 7px; border-left: 12px solid #b3b3b3; border-top: 20px solid transparent; border-bottom: 20px solid transparent; box-sizing: border-box; right: -15px; top: -30px; bottom: 0; margin: auto 0; }
#schedule .box dd.cfx ul:last-of-type::before { display: none; }
#schedule .box dd ul:first-of-type { padding: 0; }
#schedule .box dd ul:first-of-type .icn { background: url(../images/no_01.png) no-repeat center top; }
#schedule .box dd ul:nth-of-type(2) .icn { background: url(../images/no_02.png) no-repeat center top; }
#schedule .box dd ul:nth-of-type(3) .icn { background: url(../images/no_03.png) no-repeat center top; }
#schedule .box dd ul:nth-of-type(4) .icn { background: url(../images/no_04.png) no-repeat center top; }
#schedule .box dd ul:nth-of-type(5) .icn { background: url(../images/no_05.png) no-repeat center top; }
#schedule .box dd ul:nth-of-type(6) .icn { background: url(../images/no_06.png) no-repeat center top; }
#schedule .box dd ul:nth-of-type(7) .icn { background: url(../images/no_07.png) no-repeat center top; }
#schedule .box dd li { list-style: none; }
#schedule .box dd .icn { min-height: 70px; padding: 50px 0 0; }
#schedule .box.bottom { margin: 0 0 40px; }
#schedule .box.bottom dd { font-size: 24px; }
#schedule .box.bottom .text,
#schedule .box.bottom .text li { display: flex; justify-content: center; align-items: center; }
#schedule .box.bottom .text img { padding: 0 30px 0 0; text-align: left; }
#schedule .box.bottom .text small { display: block; font-size: 16px; text-align: left; }
#schedule .box.bottom .text .plus svg { margin: 0 30px; }
#schedule .fz28.text-center.mt-50.mb-30 u { text-decoration: none; border-bottom: solid 2px; padding: 0 0 10px; }
#schedule .box.bottom .border { position: relative; display: inline-block; padding: 0 30px; }
#schedule .box.bottom .border:before {  content: ""; position: absolute; display: block; width: 2px; height: 100%; background: #213a2c; top: 0; left: 0; transform: rotate(-30deg); -moz-transform: rotate(-30deg); -webkit-transform: rotate(-30deg); }
#schedule .box.bottom .border:after {  content: ""; position: absolute; display: block; width: 2px; height: 100%; background: #213a2c; top: 0; right: 0; transform: rotate(30deg); -moz-transform: rotate(30deg); -webkit-transform: rotate(30deg); }

/* ------------------------------------------------------------ mobile */
@media only screen and (max-width: 640px) {
.PC { display: none; }
.list-check li { width: 100%; float: none; margin: 0; }
.list-check li:nth-last-child(2) { border-bottom: 1px solid #a7a5a4; }
#case { margin: 50px 0 0; }
#subsidy ul,
#subsidy .cardbox { width: 100%; }

/* bnr ------------------------------------------------------------ */
#bnr .pc_only{ display: none;}
#bnr .sp_only{ display: block;}
#bnr a { max-width: inherit; width: 96%;}
#bnr p{ margin-bottom: -50px;}

/* ------------------------------------------------------------ error */
.contact h3 { font-size: 24px; }
.contact .alert span { display: block; }
.contact .btn a { width: 240px; line-height: 50px; font-size: 16px; }

/* ------------------------------------------------------------ confirm */
.confirm h3 { font-size: 24px; }
.confirm table { width: 90%; margin: 30px auto 60px; }
.confirm table th { display: block; border-bottom: 1px solid #ddd; width: 100%; font-size: 18px; }
.confirm table td { display: block; width: 100%; padding: 10px 0 20px; font-size: 16px; }
.confirm .btn a { width: 240px; line-height: 50px; font-size: 16px; }
.confirm .btn input[type="submit"] { width: 240px; line-height: 50px; font-size: 16px; }

/* ------------------------------------------------------------ thanks */
#thanks h3 { font-size: 24px; }
#thanks .page_top { padding: 40px 0 0; }
#thanks .page_top a { width: 240px; line-height: 50px; font-size: 16px; }

/* ------------------------------------------------------------ schedule */
#schedule .box dd.cfx ul { width: 50%; font-size: 16px; padding: 0 0 25px; }
#schedule .box dd ul:first-of-type .icn,
#schedule .box dd ul:nth-of-type(2) .icn,
#schedule .box dd ul:nth-of-type(3) .icn,
#schedule .box dd ul:nth-of-type(4) .icn,
#schedule .box dd ul:nth-of-type(5) .icn,
#schedule .box dd ul:nth-of-type(6) .icn,
#schedule .box dd ul:nth-of-type(7) .icn { background-size: 20% auto; }
#schedule .box dd ul:first-of-type { padding: 0; }
#schedule .box dd .icn { min-height: auto; padding: 30% 0 0; }
#schedule .fz28.text-center.mt-50.mb-30 u { padding: 0 0 5px; font-size: 20px; line-height: 200%; }
#schedule .box dt { font-size: 19px; }
#schedule .box.bottom dd { font-size: 16px; }
#schedule .box.bottom dd .border { margin: 0 0 25px; }
#schedule .box.bottom .text,
#schedule .box.bottom .text li { display: block; }
#schedule .box.bottom .text span { display: block; padding: 5px 0 0; }
#schedule .box.bottom .text img { padding: 0; text-align: center; }
#schedule .box.bottom .text .plus svg { margin: 25px auto; display: block; }
#schedule .box.bottom .text small { display: block; font-size: 14px; text-align: center; padding: 5px 0 0; }
#schedule .box.bottom .border { display: block; }
#schedule .box.bottom .border:before {  content: ""; width: 1px; }
#schedule .box.bottom .border:after {  content: ""; width: 1px; }
#schedule .box dd.cfx ul:before { content: ""; right: -5%; top: -30%; }

}