@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');
/* CSS Document */

*{margin:0;padding:0;box-sizing: border-box;}
html {font-size: 62.5%;overflow-x: hidden}
body {font-size: 1.8rem;font-family: 'Noto Sans JP', sans-serif, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;line-height: 1.6;position: relative;overflow: hidden;color:#231815;text-align: center;letter-spacing: 2px}
table {border-collapse:collapse;border-spacing:0;}

figure {text-align: center}
ul, ol { list-style:none; }
a { color: #000; text-decoration: none; }
img {vertical-align: top;max-width: 100%;}
figure img {}
p {color: #000000;}

.is-invalid {border: solid 2px red !important;}

@media screen and (max-width: 767px) {
  body {font-size: 1.4rem;}
}

/* inner */
.inner {width: 980px;max-width: 100%; margin: 0 auto;padding: 0 40px;}

@media screen and (max-width: 1024px) {
  .inner {padding: 0 10px;}
}

/* Header */
header {background: #fff;box-shadow: 0px 0px 7px 9px rgba(0,0,0,0.2);padding: 15px 0}
header .inner {display: flex;justify-content: space-between;align-items: flex-end;flex-wrap: wrap; width: 1160px;}
header .btn {display: flex;}
header .btn li {border-radius: 5px;margin: 0 10px 0 0}
header .btn li:last-child{margin: 0;}
header .btn li a {padding: 0.4em;display: block;font-size: 1.8rem;font-weight: 700;letter-spacing: 2px;width: 200px;}
header .btn li:nth-child(1) {background: linear-gradient(#cdf98a, #69bb2b);}
header .btn li:nth-child(2) {background: linear-gradient(#f67792, #df0134);}
header .btn li:nth-child(2) a {color: #fff;}
header .btn li:nth-child(3) {background: linear-gradient(#f67792, #df0134);}
header .btn li:nth-child(3) a {color: #fff;}

@media screen and (max-width: 1024px) {
  .logo {width: 300px;}
}
@media screen and (max-width: 767px) {
  .logo {width: 200px;}
  header .btn {justify-content: space-between; width: 100%;margin: 20px 0 0}
  header .btn li {width: 48%}
  header .btn li a {font-size: 1.2rem;width: 100%}
	footer .logo {margin: 0 auto;}
}
/* alert */
.alert-danger {color: #842029;background-color: #f8d7da;border-color: #f5c2c7;}
.alert {position: relative;padding: 1rem 1rem;margin-bottom: 1rem;border: 1px solid transparent;border-radius: .25rem;}

/* kv */
.kv {background: url("../img/kv.png") no-repeat center;background-size: cover;height: 200px;display: flex;align-items: center;justify-content: center;margin: 0 0 70px}
.kv h1 {font-size: 3.5rem;color: #fff;font-weight: 700}

@media screen and (max-width: 767px) {
  .kv {height: 150px;margin: 0 0 40px}
  .kv h1 {font-size: 2.4rem;}
}

/* Footer */
footer {font-size: 1.2rem;margin: 33px 0 0}
footer > .inner > p {font-weight: 700;margin: 40px 0 0}
footer .copyright {background: #4f4f4f;margin: 40px 0 0;padding: 0 0 3px}
footer .copyright p {color: #fff;letter-spacing: 0;}

@media screen and (max-width: 767px) {
  footer {font-size: 1.0rem;}
  footer > .inner > p {margin: 20px}
  footer .copyright {margin: 20px 0 0;}
}

/* Title */
h2 {margin: 0 0 40px;font-size: 3.2rem}
.form h3:first-of-type{margin: 0;}
.form h3 {background: #ededed;font-size: 2.3rem;border-left: 10px solid #00a6de;padding: 15px 30px;text-align: left;margin: 90px 0 0}
.form h3 span {color: #00a6de;float: right;}

@media screen and (max-width: 767px) {
  h2 {margin: 0 0 30px;font-size: 2.0rem}
  .form h3 {font-size: 1.6rem;border-left: 5px solid #00a6de;padding: 10px 15px;margin: 50px 0 0}
}

/* Botton */
main .btn {display: flex;justify-content: center;flex-wrap: wrap; margin: 60px 0 100px}
main .btn li {width: 27%;margin: 0 3% 0 0}
main .btn li:last-child {margin: 0;}
main .btn li a {background: linear-gradient(#0aa8d8, #007ebd);box-shadow: 0px 3px 10px 2px rgba(0,0,0,0.2);border-radius: 5px;color: #fff;font-size: 2.0rem;font-weight: 700;display: block;padding: 10px 0}

@media screen and (max-width: 767px) {
  main .btn {margin: 30px 0 50px}
  main .btn li {width: 100%;margin: 0 0 20px;}
}

/* From */
.customerform {text-align: left}
.customerform dt {font-size: 2.3rem;font-weight: 700;padding: 0 0 10px;margin: 35px 0 0}
.customerform dt span {color: #00a6de;float: right;}
input[type="text"] {width: 100%;font-size: 2.0rem;padding: 16px 20px;border-radius: 5px;border: 2px solid #b1b1b1;outline: 0;}
input[type="email"] {width: 100%;font-size: 2.0rem;padding: 16px 20px;border-radius: 5px;border: 2px solid #b1b1b1;outline: 0;}
input::placeholder {color: #9e9e9e}

@media screen and (max-width: 767px) {
  .customerform dt {font-size: 1.6rem;margin: 30px 0 0}
  input[type="text"] {font-size: 1.4rem;padding: 10px 10px;}
  input[type="email"] {font-size: 1.4rem;padding: 10px 10px;}
}

/*タブ切り替え*/
.tabs {width: 100%;display: flex;justify-content: space-between;flex-wrap: wrap;}
.tabs label {width: 48.5%;background: #fff;border: 2px solid #b1b1b1;color: #cccccc;border-radius: 5px;font-size: 2.3rem;text-align: center;display: block;font-weight: 700;transition: all 0.2s ease;padding: 10px 0}
.tabs input[type=radio]:hover {opacity: 0.75;}
.tabs input[type=radio] {display: none;}
.tabs .content {width: 100%;display: none;clear: both;overflow: hidden;}
.tabs > #individual:checked ~ #individual_content,
.tabs > #corporation:checked ~ #corporation_content {display: block;}
.tabs > #same:checked ~ #same_content,
.tabs > #different:checked ~ #different_content {display: block;}

.tabs > #necessary:checked ~ #necessary_content,
.tabs > #necessary:checked ~ #necessary_content {display: block;}

.tabs > input[type=radio]:checked + label {background-color: #00a6de;border: 2px solid #00a6de;color: #fff;}

@media screen and (max-width: 767px) {
  .tabs label {font-size:1.4rem;padding: 5px 0}
}

.number {}
.number .numbertable {width: 100%;margin: 45px 0 0}
.number .numbertable .ttl01 {background: #00a6de;display: flex;}
.number .numbertable .ttl01 p {color: #fff;text-align: center;padding: 8px;border-left: 2px solid #fff;font-weight: bold;}
.number .numbertable .ttl01 p:first-child{border: none}

.number .numbertable .ttl01 p.type {width: 19%;}
.number .numbertable .ttl01 p.times {width: 19%;}
.number .numbertable .ttl01 p.price {width: 19%;}
.number .numbertable .ttl01 p.books {width: 19%;}
.number .numbertable .ttl01 p.total {width: 24%;}

.number .numbertable .ttlsp {display: none}
.number .numbertable .tablecontents .ttl01 {display: none}
.number .numbertable .ttlsp .car {background: #00a6de;padding: 15px 20px;color: #fff;font-weight: bold;text-align: left;border-bottom: 2px solid #fff;}

.number .numbertable .tablecontents {display: flex;flex-wrap: wrap;border-bottom: 3px solid #b1b1b1;}
.number .numbertable .tablecontents .type {width: 19%;font-weight: bold;background: #ededed;display: flex;align-items: center;justify-content: center}
.number .numbertable .tablecontents .contents {width:81%;}
.number .numbertable .tablecontents .contents .box {display: flex;flex-wrap: wrap;border-bottom: 2px solid #dcdcdc;}
.number .numbertable .tablecontents .contents .box:last-child{border-bottom: none}
.number .numbertable .tablecontents .contents .box > div {padding: 8px 10px;border-left: 2px solid #b1b1b1;display: flex;align-items: center;}
.number .numbertable .tablecontents .contents .box > div p {color: #757575;}
.number .numbertable .tablecontents .contents .times {width: 23.5%;}
.number .numbertable .tablecontents .contents .price {width: 23.5%;}
.number .numbertable .tablecontents .contents .books {width: 23.5%;justify-content:flex-end}
.number .numbertable .tablecontents .contents .total {width: 29.5%;justify-content:flex-end}

.number .numbertable .tablecontents .contents .times p {width: 4.5em;display: inline-block;text-align: right;margin: 0 auto;}
.number .numbertable .tablecontents .contents .price p {width: 5.5em;display: inline-block;text-align: right;margin: 0 auto;}
.number .numbertable .tablecontents .contents input[type="text"] {font-weight: normal;font-size: 1.8rem;width: calc(100% - 1.5em);padding: 12px 15px;margin: 0 0.5em 0 0}
.number .numbertable .tablecontents .contents input[type="number"] {font-weight: normal;font-size: 1.8rem;width: calc(100% - 1.5em);padding: 12px 15px;margin: 0 0.5em 0 0}

.number .numbertable .tabletotal {display: flex;border-bottom: 3px solid #b1b1b1;}
.number .numbertable .tabletotal .amount{width: 57%;font-weight: bold;text-align: right;font-size: 2.0rem;padding: 15px 25px}
.number .numbertable .tabletotal .books {width: 19%;text-align: right;border-left: 2px solid #b1b1b1;display: flex;align-items: center;padding: 15px 10px;justify-content:flex-end}
.number .numbertable .tabletotal .total {width: 24%;text-align: right;border-left: 2px solid #b1b1b1;display: flex;align-items: center;padding: 15px 10px;justify-content:flex-end}

.number .numbertable .tablepostage {margin: 0 0 0 57%;display: flex;border-bottom: 3px solid #b1b1b1;}
.number .numbertable .tablepostage .postage {width: 44.2%;display: flex;align-items: center;justify-content: center;padding: 15px 25px;border-left: 2px solid #b1b1b1;font-size: 2.0rem;font-weight: 700;}
.number .numbertable .tablepostage .noburden {width: 55.8%;display: flex;align-items: center;justify-content: center;padding: 15px 25px;border-left: 2px solid #b1b1b1;font-size: 2.0rem;font-weight: 700;color: #e70034;}



@media screen and (max-width: 767px) {
  .number .numbertable .ttlsp {display: block;cursor:pointer;margin: 20px 0 0;position: relative}
  .number .numbertable .ttlsp::before {content: '';display: block;background: #fff;position: absolute;height: 2em;width: 0.25em; right: 1.9em;top: 0;bottom: 0;margin: auto;transition: all .15s;}
  .number .numbertable .ttlsp::after {content: '';display: block;background: #fff;position: absolute;width: 2em;height: 0.25em;right: 1em;top: 0;bottom: 0;margin: auto;transition: all .15s;}
  .number .numbertable .ttlsp.isactive::before {-webkit-transform: rotate(90deg);transform: rotate(90deg);}
  .number .numbertable .ttlsp.isactive::after {content:none}



  .number .numbertable .ttlsp .car {border-bottom: 1px solid #fff;}
  .number .numbertable > .ttl01 {display: none}
  .number .numbertable .tablecontents .ttl01 {width: 100%;display: flex;}
  .number .numbertable .tablecontents .ttl01 > p {display: flex;align-items: center;justify-content: center}
  .number .numbertable .ttl01 p {padding: 8px 5px;border-left: 1px solid #fff;font-size: 1.4rem;letter-spacing: 0}
  .number .numbertable .ttl01 p.times {width: 25%;}
  .number .numbertable .ttl01 p.price {width: 25%;}
  .number .numbertable .ttl01 p.books {width: 25%;}
  .number .numbertable .ttl01 p.total {width: 25%;}

  .number .numbertable .tablecontents {border-bottom: 2px solid #b1b1b1;display:none;}
  .number .numbertable .tablecontents .type {display: none;}
  .number .numbertable .tablecontents .contents .box > div {padding: 8px 5px;border-left: 1px solid #b1b1b1;}
  .number .numbertable .tablecontents .contents .box > div:first-child{border:none}
  .number .numbertable .tablecontents .contents {width:100%;}
  .number .numbertable .tablecontents .contents .times {width: 25%;}
  .number .numbertable .tablecontents .contents .price {width: 25%;}
  .number .numbertable .tablecontents .contents .books {width: 25%;}
  .number .numbertable .tablecontents .contents .total {width: 25%;}

  .number .numbertable .tablecontents .contents input[type="text"] {font-size: 1.4rem;padding: 12px 5px;margin: 0 0.5em 0 0}

  .number .numbertable .tabletotal {margin: 20px 0 0}
  .number .numbertable .tabletotal .amount {width: 50%;font-size: 1.6rem;text-align: left;}
  .number .numbertable .tabletotal .books {width: 25%;padding: 10px 5px;}
  .number .numbertable .tabletotal .total {width: 25%;padding: 10px 5px;}

  .number .numbertable .tablepostage {margin: 0 0 0 50%;}
  .number .numbertable .tablepostage .postage {width: 50%;font-size: 1.6rem;padding: 10px 5px;}
  .number .numbertable .tablepostage .noburden {width: 50%;font-size: 1.6rem;padding: 10px 5px;}
}




.number dl {display: flex;flex-wrap: wrap;align-items: center;margin: 70px 0 0;border:none !important}
.number dl dt {text-align: right;width: 57%;font-size: 2.5rem;font-weight: 700;padding: 0 45px 0 0}
.number dl dd {width: 43%;text-align: left;font-size: 2.5rem;}
.number dl dd span {border-bottom: 3px solid #b1b1b1;width: calc(100% - 2.0em);display: inline-block;margin-right: 1em;text-align: right;font-size: 3.0rem;font-weight: 700;padding-bottom: 10px}
.number dl + p {text-align: right;font-size: 1.8rem;color: #ff0000;margin: 10px 0 0}

@media screen and (max-width: 767px) {
  .number dl {margin: 40px 0 0}
  .number dl dt {width: 45%;padding: 0 20px 0 0;font-size: 1.4rem;padding: 0 ;text-align: left;}
  .number dl dd {width: 55%;font-size: 1.4rem;}
  .number dl dd span {font-size: 2.2rem;}
  .number dl + p {font-size: 1.2rem;}
}

.number .flame {border: 3px solid #00a6de;border-radius: 10px;margin: 75px 0 0}
.number .flame h4 {background: #00a6de;color: #fff;font-size: 3.0rem;padding: 18px 0}
.number .flame p {font-size: 2.5rem;font-weight: 700;padding: 40px 100px;text-align: left;}

@media screen and (max-width: 767px) {
  .number .flame {margin: 40px 0 0}
  .number .flame h4 {font-size: 1.8rem;padding: 15px 0}
  .number .flame p {font-size: 1.4rem;padding: 20px 20px;}
}

.schedule ul {display: flex;margin: 45px 0 0}
.schedule ul li {width: calc(100% / 3);text-align: left}
.schedule ul li select {width: 100%; font-size: 2.0rem;padding: 16px 20px;}
.schedule ul li .select {display: inline-block;vertical-align: middle; width: 80%;position: relative;border: 2px solid #b1b1b1;border-radius: 5px;overflow: hidden;margin: 0 5px 0 0}
.schedule ul li .select::before {content: '';position: absolute;top: 0;bottom: 0;right: 18px;margin: auto;width: 0;height: 0;border-left: 9px solid transparent;border-right: 9px solid transparent;border-top: 12px solid #b1b1b1;pointer-events: none;}
.schedule ul li select::-ms-expand {display: none;}
.schedule ul li .select select {width: 100%;cursor: pointer;border: none;outline: none;background: transparent;background-image: none;box-shadow: none;-webkit-appearance: none;appearance: none;}

@media screen and (max-width: 767px) {
  .schedule ul li select {font-size: 1.4rem;padding: 10px}
  .schedule ul li .select {width:calc(100% - 2em);margin: 0;}
  .schedule ul li .select::before {right: 5px;border-left: 4px solid transparent;border-right: 4px solid transparent;border-top: 6px solid #b1b1b1;}
}

.schedule p {text-align: right;font-size: 1.8rem;color: #adadad;margin: 10px 0 0}

@media screen and (max-width: 767px) {
  .schedule p {font-size: 1.2rem}
}

.btnsubmit {}
.btnsubmit button[type="submit"] {background: linear-gradient(#0aa8d8, #007ebd);color: #fff;font-weight: 700;font-size: 3.0rem;border: 2px solid #007fbe;letter-spacing: 3px;border-radius: 10px;padding: 40px 20px 35px;width: 590px;max-width: 100%;}
.btnsubmit button[type="submit"] span {font-size: 1.8rem;font-size: 500;display: block;margin: 10px 0 0}
.btnsubmit button[type="button"] {background: linear-gradient(#0aa8d8, #007ebd);color: #fff;font-weight: 700;font-size: 3.0rem;border: 2px solid #007fbe;letter-spacing: 3px;border-radius: 10px;padding: 40px 20px 35px;width: 590px;max-width: 100%;}
.btnsubmit button[type="button"] span {font-size: 1.8rem;font-size: 500;display: block;margin: 10px 0 0}

@media screen and (max-width: 767px) {
  .btnsubmit button[type="submit"] {font-size: 2.0rem;padding: 20px 10px 20px;}
  .btnsubmit button[type="submit"] span {font-size: 1.4rem;}
  .btnsubmit button[type="button"] {font-size: 2.0rem;padding: 20px 10px 20px;}
  .btnsubmit button[type="button"] span {font-size: 1.4rem;}
}

.btncomfirm {display: flex;justify-content: space-between;flex-wrap: wrap; margin: 90px 0}
.btncomfirm li {width: 49%;}
.btncomfirm li button[type="submit"] {color: #fff;font-weight: 700;font-size: 2.5rem;border-radius: 10px;padding: 40px 20px 35px;width: 100%;letter-spacing: 3px;}
.btncomfirm li:nth-child(1) button[type="submit"] {background: #626262;border: 2px solid #626262;}
.btncomfirm li:nth-child(2) button[type="submit"] {background: linear-gradient(#0aa8d8, #007ebd);border: 2px solid #007fbe;}
.btncomfirm li button[type="button"] {color: #fff;font-weight: 700;font-size: 2.5rem;border-radius: 10px;padding: 40px 20px 35px;width: 100%;letter-spacing: 3px;}
.btncomfirm li:nth-child(1) button[type="button"] {background: #626262;border: 2px solid #626262;}
.btncomfirm li:nth-child(2) button[type="button"] {background: linear-gradient(#0aa8d8, #007ebd);border: 2px solid #007fbe;}

@media screen and (max-width: 767px) {
  .btncomfirm {margin: 40px 0}
  .btncomfirm li {width: 100%;}
  .btncomfirm li button[type="submit"] {font-size: 1.8rem;padding:20px 10px 20px;}
  .btncomfirm li:nth-child(1) button[type="submit"] {margin: 0 0 20px}
  .btncomfirm li button[type="button"] {font-size: 1.8rem;padding:20px 10px 20px;}
  .btncomfirm li:nth-child(1) button[type="button"] {margin: 0 0 20px}
}

.contact {background: #ededed;padding: 90px 0;}
.contact .box {background: #fff;border-radius: 10px;padding: 40px 75px;margin: 35px 0 0}
.contact .box h3 {font-size: 3.0rem;color: #626262;margin: 0 0 20px}
.contact .box p {color: #626262;text-align: left}
.contact .box .tel {font-size: 4.0rem;color: #00a6de;font-weight: 700;position: relative;display: inline-block;margin: 45px 0 0}
.contact .box .tel::before{content: '';position: absolute;top: 0.45em;left: -1.1em;background: url("../img/icon_tel.jpg") no-repeat;width: 50px;height: 1.0em;background-size: auto 100%}
.contact .box .tel span {font-size: 2.5rem;color: #626262;display: block;}

@media screen and (max-width: 767px) {
  .contact {padding: 40px 0;}
  .contact .box {padding: 20px 20px;}
  .contact .box h3 {font-size: 2.0rem;}
  .contact .box .tel {font-size: 2.5rem;margin: 20px 0 0}
  .contact .box .tel::before {width: 1.0em;height: 1.0em;left: -0.9em;}
  .contact .box .tel span {font-size: 1.8rem;}
}

.comfirm .tabscontent {width: 100%;}
.comfirm dl {border-top: 2px solid #dcdcdc;margin: 30px 0 0}
.comfirm table + dl {border: none}

.comfirm dd {color: #757575}
.comfirm dt {color: #000000 }
.comfirm .customerform > dl:first-child{border: none;margin: 0;}
.comfirm .schedule ul li {width: auto;}

.verification {border: 3px solid #b1b1b1;border-radius: 10px;padding:0 60px 60px;margin: 50px 0 0}
.verification h4 {font-size: 2.4rem;margin: -1.0em 0 45px;}
.verification h4 span {background: #fff;}
.verification li {font-size: 1.8rem;text-align: left;position: relative;padding: 0 0 0 0;font-weight: 500;margin: 0 0 35px}
/* .verification li::before{content: '';position: absolute;top: 0.15em;left: 0; width: 1.2em;height: 1.2em;border: 2px solid #757575;} */
.verification li:last-child{margin: 0;}
.verification li .note {color: #626262;}

@media screen and (max-width: 767px) {
  .verification {padding:0 20px 20px}
  .verification h4 {font-size: 1.8rem;margin: -1.0em 0 20px;}
  /* .verification li {font-size: 1.2rem;padding: 0 0 0 2.2em;margin: 0 0 20px} */
  .verification li {font-size: 1.2rem;padding: 0 0 0 0;margin: 0 0 20px}
}

.thanks .application_no {background: #ededed;font-size: 3.2rem;padding: 10px 0;font-weight: 700;margin: 0 0 50px}
.thanks .payee {width: 620px;margin: 50px auto;max-width: 100%;border: 1px solid #9c9c9c;padding: 30px;border-radius: 10px;}
.thanks .note {font-size: 1.6rem;}
.thanks .btnthanks .btn a {box-shadow: 0px 3px 10px 2px rgba(0,0,0,0.2);background: linear-gradient(#fe7194, #ed002e);color: #fff;font-size: 2.7rem;width: 365px;max-width: 100%; border-radius: 10px;display: block;font-weight: 700; padding: 15px }

@media screen and (max-width: 767px) {
  .thanks .application_no {font-size: 2.0rem;margin: 0 0 30px}
  .thanks .payee {padding: 15px;}
  .thanks .note {font-size: 1.2rem;}
  .thanks .btnthanks .btn a {font-size: 1.8rem;}
}

.visually-hidden {
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
  overflow: hidden;
  border: 0;
  padding: 0;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  margin: -1px;
}
.verification label {
  cursor: pointer;
  padding-left: 50px;
  position: relative;
	display: block;
}


.verification label::before,
.verification label::after {
  content: "";
  display: block;
  position: absolute;
}

.verification label::before {
  background-color: #fff;
  border-radius: 0%;
  border: 2px solid #ddd;
  width: 20px;
  height: 20px;
  top: 5px;
  left: 0;
	box-sizing: border-box;
}

.verification label::after {
  border-bottom: 2px solid #f00;
  border-left: 2px solid #f00;
  opacity: 0;
  height: 8px;
  width: 16px;
  transform: rotate(-45deg);
  top: 8px;
  left: 3px;
	box-sizing: border-box;
}

.verification input:checked + label::after {
  opacity: 1;
}
#button03:disabled {
	opacity: .2;
}

button:hover {
	cursor: pointer;
}

.notice {
	margin-bottom: 20px;
	color: #f00;
}
.kukan {
	font-size: 2.4rem;
	margin-top: 20px;
	text-align: left;
}

@media screen and (max-width: 767px) {
	.verification label {
		padding-left: 30px;
	}
}

.faq_box {
	margin-bottom: 30px;
}
.faq_box .question {
	cursor: pointer;
	position: relative;
}
.faq_box .answer {
	padding: 10px;
	text-align: left;
}
.faq_box .answer a {
	text-decoration: underline;
	color: blue;
	display: inline-block;
}
.faq_box .question::before {
  content: '';
  display: block;
  background: #fff;
  position: absolute;
  height: 1.25em;
  width: 0.25em;
  right: 1.5em;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: all .15s;
}

.faq_box .question::after {
  content: '';
  display: block;
  background: #fff;
  position: absolute;
  width: 1.25em;
  height: 0.25em;
  right: 1em;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: all .15s;
}

.faq_box .question.isactive::before {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

.faq_box .question.isactive::after {
  content: none
}
.form .faq_box .question {
	background: #00a6de;
	border-left: none;
	color: #fff;
}

@media screen and (max-width: 767px) {
  .form .faq_box .question {
		padding-right: 3.0em;
	}
	.number .numbertable .tablecontents .contents input[type="number"] {
	    font-weight: normal;
	    font-size: 1.6rem;
	    width: calc(100% - 1.0em);
	    padding: 12px 5px;
	    margin: 0 0.2em 0 0
	}
	.number .numbertable .tablecontents .contents .box>div {
    padding: 8px 5px;
    border-left: 1px solid #b1b1b1;
		word-break: break-all
}
.number .numbertable .tabletotal .total {
	word-break: break-all;
}
}

.attention {
	color: #adadad;
}
.ttl_item {
	padding-top: 40px;
}
dl.postal_code dd {
	display:-webkit-box;
	display: -webkit-flex;
	display:-ms-flexbox;
	display: flex;
}
dl.postal_code dd input[type="text"] {
	width: 40%;
}

dl.postal_code .btnsubmit button[type="button"] {
	font-size: 1.0em;
	width: 40%;
	padding: 15px 20px;
	margin-left: 20px;
	display: block;
	border-radius: 5px;
	font-size: 2.3rem;
	background: none;
	background-color: #00a6de;
	border: 2px solid #00a6de;
}

@media screen and (max-width: 767px) {
	dl.postal_code dd {
		display: block;
	}

	dl.postal_code dd input[type="text"] {
		width: 100%;
	}
	dl.postal_code .btnsubmit button[type="button"] {
		width: 48.5%;
		margin-left: 0;
		margin-top: 20px;
		padding: 5px 0;
		font-size: 1.4rem;
	}
}

.cautions {
	text-align: left;
	font-size: 1.6rem;
	margin: 0 45px 50px;
}
.cautions .ttl {
	margin-bottom: 24px;
}
.cautions ul > li {
	text-indent: -1.0em;
	padding-left: 1.0em;
}
.cautions ul > li + li {
	padding-top: 16px;
}
.u_red {
	color: #f00;
	text-decoration: underline;
}
.emphasis {
	font-weight: bold;
	font-size: 2.0rem;
	/* background:linear-gradient(transparent 60%, #ff6 60%); */
}

@media screen and (max-width: 767px) {
	.cautions {
		margin: 0 10px 50px;
		font-size: 1.4rem;
	}
	.emphasis {
		font-weight: bold;
		font-size: 1.4rem;
		display: block;
	}
}

.office_info + .office_info {
	margin-top: 20px;
}
.office_info .item {
	display:-webkit-box;
	display: -webkit-flex;
	display:-ms-flexbox;
	display: flex;

	padding: 8px;
	border-bottom: 1px dotted;
	box-sizing: border-box;
}
.office_info .item > dt {
	width: 120px;
	-webkit-flex: 0 0 auto;
	-ms-flex: 0 0 auto;
	flex: 0 0 auto;
}
.calender{
  text-align: center;
}
.calender h4{
  margin: 40px 0 20px;
  font-weight: bold;
  text-align: center;
  font-size: 1.4em;
}
.calender ul {
	padding-left: 0;
	list-style: none;
	display: inline-block;
}
.calender ul li {
	text-align: left;
  color: #adadad;
}
.calender_img_box{
  display: flex;
  flex-wrap: wrap;
}
.calender_img_box img{
  width: 48%;
  margin: 0 auto 20px;
}
.calender_mark_img_box {
  text-align: right;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
	.office_info .item {
		padding: 5px;
	}
	.office_info .item > dt {
		text-align-last: inherit;
		width: 80px;
	}
  .calender h4{
    font-size: 0.9em;
  }
  .calender ul li {
    letter-spacing: 0.1em;
    font-size: 0.5em;
  }
    .calender_img_box{
        display: block;
    }
    .calender_img_box img{
        width: 98%;
        margin: 0 auto 40px;
    }
}
