@charset "UTF-8";
/*
File: style.css
Description: 登録サイト
*/
/*-----------------------------------------------------------
■ General
-----------------------------------------------------------*/
/*--------------------------------------
	import & vars
--------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap");
/*--------------------------------------
	html
--------------------------------------*/
body {
  position: relative;
  -webkit-text-size-adjust: 100%;
  font-family: 'Noto Sans JP', 'メイリオ', 'Meiryo', 'ＭＳ ゴシック', sans-serif;
  font-size: 16px;
  letter-spacing: 0px;
  color: #20282E;
  background: #EDF4F8; }

main {
  min-height: calc(100vh - 16px);
  padding: 8px 0; }

a {
  text-decoration: none;
  vertical-align: middle;
  color: inherit; }

a.link {
  font-weight: bold;
  text-decoration: underline;
  color: #0092C4; }

a[href^="tel:"] {
  pointer-events: none;
  cursor: text; }

a:focus, button:focus, *:focus {
  outline: none; }

a:hover {
  color: inherit;
  text-decoration: none; }

a:hover img {
  opacity: 0.8; }

:any-link {
  color: inherit; }

img {
  width: auto;
  max-width: 100%;
  margin: 0;
  padding: 0;
  vertical-align: bottom; }

table {
  width: 100%; }

strong {
  font-weight: bold; }

.pc {
  display: block !important; }

.sp {
  display: none !important; }

@media screen and (max-width: 767px) {
  a[href^="tel:"] {
    pointer-events: auto;
    cursor: pointer; }

  .pc {
    display: none !important; }

  .sp {
    display: block !important; } }
/*--------------------------------------
	button
--------------------------------------*/
.primary-button {
  width: 100%;
  line-height: initial;
  text-align: center;
  cursor: pointer;
  -moz-transition-duration: 0.3s;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s; }
  .primary-button a, .primary-button button, .primary-button input {
    display: block;
    width: 100%;
    margin: auto;
    border: 0px;
    text-align: center;
    background: none;
    cursor: pointer; }
  .primary-button:hover {
    opacity: 0.8; }

.primary-button {
  border-radius: 35px;
  background: #007FDD; }
  .primary-button a, .primary-button button, .primary-button input {
    padding: 17.5px 0;
    font-size: 24px;
    font-weight: bold;
    color: #fff; }
    .primary-button a:focus, .primary-button button:focus, .primary-button input:focus {
      border-radius: 35px;
      box-shadow: 0 0 0 0.25rem rgba(94, 186, 255, 0.8); }

@media screen and (max-width: 767px) {
  .primary-button a, .primary-button button, .primary-button input {
    padding: 10.5px 0;
    font-size: 20px; } }
/*--------------------------------------
	input textarea select checkbox radio
--------------------------------------*/
button,
select,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer; }

input.input[type=text],
input.input[type=search],
input.input[type=password],
input.input[type=number],
input.input[type=email] {
  width: calc(100% - 20px);
  height: 48px;
  padding: 0 10px 0 10px;
  border: 1px solid #B5B9BC;
  border-radius: 3px;
  background: #ffffff;
  -webkit-transition: all 0.2s;
  transition: all 0.2s; }
  input.input[type=text]:focus,
  input.input[type=search]:focus,
  input.input[type=password]:focus,
  input.input[type=number]:focus,
  input.input[type=email]:focus {
    border: 1px solid #007FDD;
    box-shadow: 0 0 1px 1px #007FDD; }

.textarea {
  width: calc(100% - 10px);
  min-height: 30px;
  padding: 5px;
  border: 1px solid #B5B9BC;
  resize: vertical; }

.select {
  width: 100%;
  height: 50px;
  padding: 5px 25px 5px 10px;
  border: 1px solid #B5B9BC;
  border-radius: 3px;
  line-height: initial;
  background: url(../images/icons/ico_arrow.svg) no-repeat right #ffffff;
  background-position-x: calc(100% - 10px);
  background-size: 13px 10px;
  -webkit-appearance: none; }

/* checkbox */
input[type=checkbox] {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0; }

input[type=checkbox] + label {
  box-sizing: border-box;
  cursor: pointer;
  display: inline-block;
  padding: 0px 0px 0px 30px;
  position: relative;
  width: auto; }

input[type=checkbox] + label::before {
  content: "";
  position: absolute;
  left: 2px;
  top: calc(50% - 9px);
  display: block;
  height: 20px;
  width: 20px;
  background: url(../images/icons/ico_check_off.svg) no-repeat;
  background-position: center;
  background-size: cover; }

input[type=checkbox]:focus + label::before {
  border-radius: 4px;
  box-shadow: 0 0 2px 2px #007FDD; }

input[type=checkbox]:checked + label::before {
  border-radius: initial;
  box-shadow: 0 0 0px 0px #007FDD;
  background: url(../images/icons/ico_check_on.svg) no-repeat;
  background-position: center;
  background-size: cover; }

/* radio */
input[type=radio] {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0; }

input[type=radio] + label {
  position: relative;
  width: auto;
  display: inline-block;
  padding: 0px 0px 0 30px;
  box-sizing: border-box;
  cursor: pointer; }

input[type=radio] + label::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 5px;
  display: block;
  width: 18px;
  height: 18px;
  border: 1px solid #BCD3D8;
  margin-top: -9px;
  border-radius: 50%;
  background: #fff; }

input[type=radio] + label::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 8px;
  display: block;
  width: 14px;
  height: 14px;
  margin-top: -6px;
  border-radius: 50%;
  opacity: 0;
  background: #007FDD; }

input[type=radio]:focus + label::before {
  box-shadow: 0 0 2px 2px #007FDD; }

input[type=radio]:checked + label::after {
  opacity: 1; }

input[type=radio]:checked + label::before {
  box-shadow: 0 0 0px 0px #007FDD; }

/*-----------------------------------------------------------
■ Main page
-----------------------------------------------------------*/
/*--------------------------------------
	general
--------------------------------------*/
.main_container {
  max-width: 800px;
  padding: 0 30px;
  margin: auto; }

@media screen and (max-width: 767px) {
  .main_container {
    padding: 0 20px; } }
/*--------------------------------------
	corners
--------------------------------------*/
main.cornered {
  position: relative;
  padding: 81px 0;
  min-height: calc(100vh - 162px); }

main.cornered::before,
main.cornered::after {
  content: "";
  position: absolute;
  left: 0;
  width: calc(100% - 146px);
  height: 0;
  border-right: 73px solid transparent;
  border-left: 73px solid transparent;
  background: #B9E1FF; }

main.cornered::before {
  top: 0px;
  border-bottom: 73px solid #edf4f8; }

main.cornered::after {
  bottom: 0px;
  border-top: 73px solid #edf4f8; }

@media screen and (max-width: 767px) {
  main.cornered {
    padding: 32px 0 49px 0;
    min-height: calc(100vh - 81px); }

  main.cornered::before,
  main.cornered::after {
    content: "";
    position: absolute;
    left: 0;
    width: calc(100% - 64px);
    height: 0;
    border-right: 32px solid transparent;
    border-left: 32px solid transparent;
    background: #B9E1FF; }

  main.cornered::before {
    top: 0px;
    border-bottom: 32px solid #edf4f8; }

  main.cornered::after {
    bottom: 0px;
    border-top: 32px solid #edf4f8; } }
/*--------------------------------------
	title
--------------------------------------*/
.title_section {
  margin-bottom: 40px; }
  .title_section h1 {
    text-align: center;
    font-size: 30px;
    font-weight: bold; }
    .title_section h1 span {
      font-size: 20px; }

@media screen and (max-width: 767px) {
  .title_section {
    margin-bottom: 33px; }
    .title_section h1 {
      font-size: 24px; }
      .title_section h1 span {
        font-size: inherit; } }
@media screen and (max-width: 374px) {
  .title_section h1 {
    font-size: 6vw; } }
/*--------------------------------------
	text
--------------------------------------*/
.text_section {
  margin-bottom: 60px;
  font-weight: 300; }
  .text_section p + p {
    margin-top: 30px; }
  .text_section.center {
    text-align: center; }

@media screen and (max-width: 767px) {
  .text_section {
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 40px; }
    .text_section.center {
      text-align: left; } }
@media screen and (max-width: 374px) {
  .text_section {
    font-size: 14px; } }
/*--------------------------------------
	foot note
--------------------------------------*/
.foot_note {
  padding: 40px 0 17px 0;
  text-align: center; }

@media screen and (max-width: 767px) {
  .foot_note {
    padding: 25px 0 17px 0;
    text-align: left; } }
/*-----------------------------------------------------------
■ Form
-----------------------------------------------------------*/
/*--------------------------------------
	general
--------------------------------------*/
.form_field_list {
  margin-bottom: 60px; }
  .form_field_list .form_field + .form_field {
    margin-top: 20px; }
  .form_field_list .form_field.distant {
    margin-top: 30px; }
  .form_field_list .form_field.close {
    margin-top: 10px; }
  .form_field_list .form_field_inner {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    -webkit-align-items: center;
    align-items: center; }
    .form_field_list .form_field_inner > label {
      max-width: 240px;
      width: 100%;
      padding: 0px 5px 0 0;
      font-size: 16px;
      font-weight: bold; }
  .form_field_list .form_checkbox {
    align-self: flex-start; }
  .form_field_list .form_radios .form_radio + .form_radio {
    margin-top: 5px; }

.form_button {
  max-width: 550px;
  margin: auto; }

@media screen and (max-width: 767px) {
  .form_field_list {
    margin-bottom: 33px; }
    .form_field_list .form_field + .form_field {
      margin-top: 30px; }
    .form_field_list .form_field_inner {
      display: block; }
      .form_field_list .form_field_inner > label {
        display: block;
        max-width: initial;
        padding: 0px;
        margin-bottom: 7px; }

  .form_button {
    max-width: 450px; } }
/*--------------------------------------
	warnings
--------------------------------------*/
.form_warnings {
  margin-bottom: 40px; }

.form_warnings_frame {
  padding: 30px;
  margin-bottom: 15px;
  border-radius: 5px;
  background: #fff; }
  .form_warnings_frame .form_warnings_title {
    margin-bottom: 20px; }
    .form_warnings_frame .form_warnings_title h2, .form_warnings_frame .form_warnings_title h3 {
      text-align: center;
      font-size: 16px;
      font-weight: bold; }
  .form_warnings_frame .form_warnings_text p em {
    color: #DE0101; }
  .form_warnings_frame .form_warnings_text p + p {
    margin-top: 25px; }

.form_warnings_note {
  padding-bottom: 33px; }
  .form_warnings_note p {
    font-size: 13px; }

.form_warnings_agreement {
  text-align: center; }
  .form_warnings_agreement .form_warnings_radios {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-align-items: center;
    align-items: center;
    margin-top: 23px;
    text-align: left; }
    .form_warnings_agreement .form_warnings_radios .form_warnings_radio + .form_warnings_radio {
      margin-left: 33px; }

@media screen and (max-width: 767px) {
  .form_warnings {
    margin-bottom: 27px; }

  .form_warnings_frame {
    padding: 15px; }

  .form_warnings_note {
    padding-bottom: 25px; }

  .form_warnings_agreement {
    text-align: left; }
    .form_warnings_agreement .form_warnings_radios {
      margin-top: 25px; } }
@media screen and (max-width: 374px) {
  .form_warnings_frame .form_warnings_text {
    font-size: 14px; } }

/*# sourceMappingURL=style.css.map */
