@charset "UTF-8";
html {
  font-size: 62.5%;
}

.b_gray {
  border: 1.5px solid #CECECE;
  border-radius: 5px;
  background-color: #efefef;
  -webkit-box-shadow: inset 0 -3px 6px #D8D8D8;
          box-shadow: inset 0 -3px 6px #D8D8D8;
  margin-left: auto;
  color: #57595a;
  font-weight: bold;
}

.c_FC0707 {
  background-color: #FC0707;
}

body {
  font-size: 1.8rem;
}

body .inner {
  max-width: 1200px;
}

body .row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}

body header {
  width: 100%;
  background: #dadada;
  margin: auto;
}

body header h1 {
  font-size: 5.0rem;
  padding-bottom: 20px;
  padding-top: 20px;
}

body header h1 img {
  margin-left: 0;
  width: 200px;
}

body main {
  width: 100%;
  max-width: 1200px;
  margin: auto;
}

body main h2 {
  width: 100%;
  max-width: 1200px;
  margin: auto;
  font-size: 3.0rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 2.0rem;
  margin-top: 5rem;
}

body main #news {
  width: 60%;
  border: 2px solid #2d75b3;
  padding: 30px;
  margin-top: 30px;
  text-align: left;
  border-radius: 10px;
  font-size: 1.4rem;
}

body main #news h3 {
  border-bottom: 3px dotted #2d75b3;
  font-weight: 600;
  color: #2d75b3;
  margin-bottom: 10px;
}

body main form {
  width: 100%;
  max-width: 700px;
  margin: auto;
  padding: 5.0rem;
}

body main form dt {
  font-size: 1.8rem;
  margin-bottom: .8rem;
}

body main form dd {
  margin-bottom: 2rem;
}

body main form dd input[type="text"], body main form dd input[type="password"], body main form dd input[type="mail"] {
  border: solid 1px #dbdbdb;
  padding: 1.6rem;
  width: 100%;
}

body main form a.btn {
  display: block;
  width: 50%;
  margin: 4rem auto 2rem;
  text-align: center;
  padding: 2rem;
  color: #fff;
  border-radius: 4rem;
}

body main form span {
  padding-left: 10px;
  font-size: 1.4rem;
}

body main form a.btn.login {
  background: #52BCC8;
}

body main form a.btn.register {
  background: #FCA207;
}

body main form p {
  text-align: center;
}

body footer {
  margin-top: 4.0rem;
}

body footer ul {
  width: 100%;
  max-width: 700px;
  margin: auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  -webkit-justify-content: space-around;
      -ms-flex-pack: distribute;
          justify-content: space-around;
}

body footer small {
  display: block;
  text-align: center;
  margin-top: 6.0rem;
  font-size: 1.4rem;
}

@media screen and (max-width: 1000px) {
  body .inner {
    width: 98%;
  }
}

/*===========================================================
新規登録希望画面、お問合せフォーム
===========================================================*/
main#hos-entry form, main#TopContact form {
  background-color: #fff;
  padding-bottom: 50px;
  max-width: 1000px;
}

main#hos-entry form dl, main#TopContact form dl {
  -webkit-justify-content: space-around;
      -ms-flex-pack: distribute;
          justify-content: space-around;
}

main#hos-entry form dl dt, main#TopContact form dl dt {
  margin: 0;
}

main#hos-entry form dl dd, main#TopContact form dl dd {
  margin: 0;
}

main#hos-entry form .auto dl, main#TopContact form .auto dl {
  width: 80%;
  -webkit-box-pack: inherit;
  -webkit-justify-content: inherit;
      -ms-flex-pack: inherit;
          justify-content: inherit;
  margin-left: auto;
  margin-right: auto;
  padding-top: 20px;
}

main#hos-entry form .auto dl dt, main#TopContact form .auto dl dt {
  margin-right: 30px;
}

main#hos-entry form .input, main#TopContact form .input {
  margin-top: 20px;
}

main#hos-entry form .input dl.row, main#TopContact form .input dl.row {
  margin-bottom: 10px;
}

main#hos-entry form .input dl.row > dt, main#TopContact form .input dl.row > dt {
  width: 30%;
  padding-top: 30px;
  padding-bottom: 45px;
  padding-left: 2rem;
  background-color: #f0f0f0;
  font-size: 1.4rem;
  font-weight: bold;
  position: relative;
}

main#hos-entry form .input dl.row > dt::after, main#TopContact form .input dl.row > dt::after {
  content: '必須';
  color: #fff;
  background-color: #e94545;
  padding: 2px 5px;
  font-size: 1.2rem;
  border-radius: 3px;
  position: absolute;
  font-weight: normal;
  left: 2rem;
  top: 6rem;
}

main#hos-entry form .input dl.row > dd, main#TopContact form .input dl.row > dd {
  width: 80%;
  padding-top: 30px;
  padding-bottom: 30px;
  padding-left: 5rem;
}

main#hos-entry form .input dl.row dd input, main#hos-entry form .input dl.row dd select, main#TopContact form .input dl.row dd input, main#TopContact form .input dl.row dd select {
  border: 0.5px solid #cccccc;
  -webkit-box-shadow: inset 0 3px 6px #dadada;
          box-shadow: inset 0 3px 6px #dadada;
  border-radius: 5px;
  margin-right: 10px;
  height: 30px;
}

main#hos-entry form .input dl.row dd input[type="checkbox"], main#TopContact form .input dl.row dd input[type="checkbox"] {
  -webkit-box-shadow: none;
          box-shadow: none;
  height: auto;
}

main#hos-entry form .input dl.row dd input[type="checkbox"] + label, main#TopContact form .input dl.row dd input[type="checkbox"] + label {
  -webkit-align-self: flex-end;
      -ms-flex-item-align: end;
          align-self: flex-end;
  margin-left: 0;
}

main#hos-entry form .input dl.row dd, main#TopContact form .input dl.row dd {
  margin-top: 3px;
}

main#hos-entry form .input dl.row dd > dl, main#TopContact form .input dl.row dd > dl {
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

main#hos-entry form .input dl.row dd > dl > dt, main#TopContact form .input dl.row dd > dl > dt {
  width: 100%;
  font-size: 1.4rem;
}

main#hos-entry form .input dl.row dd > dl > dd, main#TopContact form .input dl.row dd > dl > dd {
  margin-bottom: 25px;
}

main#hos-entry form .input dl.row.hp dt::after, main#TopContact form .input dl.row.hp dt::after {
  display: none;
}

main#hos-entry form .input dl.row:last-of-type dt a, main#TopContact form .input dl.row:last-of-type dt a {
  font-weight: bold;
}

main#hos-entry form button.c_52C856, main#TopContact form button.c_52C856 {
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  border: none;
  padding: 10px;
  border-radius: 5px;
  margin-right: auto;
  margin-left: auto;
  margin-top: 50px;
  display: table;
  background-color: #52C856;
  -webkit-box-shadow: inset 0 -3px 6px #378a3a;
          box-shadow: inset 0 -3px 6px #378a3a;
}

main#hos-entry form button.c_52C856 a, main#TopContact form button.c_52C856 a {
  text-decoration: none;
  color: #fff;
}

/*===========================================================
登録希望完了画面
===========================================================*/
main#hos-entry_comp h2 {
  margin-bottom: 50px;
}

main#hos-entry_comp .wrap {
  width: 80%;
  margin-bottom: 100px;
}

main#hos-entry_comp .wrap p {
  margin-bottom: 50px;
}

/*===========================================================
プライバシーポリシー、利用規約ページ
===========================================================*/
main#terms {
  font-size: 1.4rem;
  height: 500px;
  width: 1000px;
  background-color: #f3f3f3;
  overflow-y: scroll;
  margin-top: 5rem;
  padding: 2rem 3rem;
}

main#terms h2 {
  margin-top: 2rem;
}

main#terms h3 {
  margin-top: 30px;
  margin-bottom: 30px;
  padding: 10px;
  background-color: #CECECE;
  font-size: 1.5em;
}

main#terms dl {
  margin-bottom: 20px;
}

main#terms dl dt {
  border-bottom: double;
  display: inline;
}

main#terms dl dd {
  margin-top: 5px;
}

main#terms dl dd ol > li {
  list-style-type: none;
  counter-increment: cnt;
}

main#terms dl dd ol > li::before {
  content: "(" counter(cnt) ") ";
  margin-right: 10px;
  display: inline-block;
  width: 3rem;
  margin-left: -4rem;
  text-align: right;
}

main#terms .block {
  margin-bottom: 30px;
}

/*===========================================================
パスワード忘れ
===========================================================*/
dl.puzzle_wrap {
  background: aliceblue;
  padding: 20px;
  width: 80%;
  margin: auto;
}

dl.puzzle_wrap dt {
  font-size: 1.4rem;
}

dl.puzzle_wrap dt span {
  font-size: 2rem;
  display: inline-block;
}

.puzzle {
  width: 90%;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 30px;
  margin-left: none;
  background: #fff;
  border: 10px solid #fff;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 32% 32% 32%;
      grid-template-columns: 32% 32% 32%;
}

.puzzle div:nth-of-type(n+4):nth-of-type(-n+6) {
  margin-top: 6%;
  margin-bottom: 6%;
}

.puzzle .active {
  border: 10px solid #45e700;
}
/*# sourceMappingURL=login.css.map */