@charset "UTF-8";
.container-txt {
  max-width: 90rem;
  margin: 0 auto 1rem;
  padding: 0; }
  @media only screen and (max-width: 1024px) {
    .container-txt {
      padding: 3rem 3vw 0; } }
  .container-txt p {
    text-align: left; }
    .container-txt p strong {
      font-size: 2.4rem; }
      @media only screen and (max-width: 767px) {
        .container-txt p strong {
          font-size: 1.8rem; } }
    .container-txt p.no_entry {
      text-align: center;
      padding: 3rem 0 15rem; }
      @media only screen and (max-width: 767px) {
        .container-txt p.no_entry {
          padding: 0 0 5rem; } }
  .container-txt-btns {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-bottom: 4rem; }
    @media only screen and (max-width: 767px) {
      .container-txt-btns {
        padding-bottom: 2.5rem; } }
    .container-txt-btns li {
      margin: 0 1.5rem; }
      @media only screen and (max-width: 767px) {
        .container-txt-btns li {
          margin: 0 .5rem; } }
      @media only screen and (max-width: 767px) {
        .container-txt-btns li a {
          width: 12rem; } }
.container-form {
  max-width: 90rem;
  margin: 0 auto 5rem; }
  @media only screen and (max-width: 1024px) {
    .container-form {
      padding: 0 3vw 4rem 3vw; } }
  @media only screen and (max-width: 767px) {
    .container-form {
      padding: 0 3vw 2rem 3vw;
      margin-bottom: 0; } }
  .container-form .wpcf7 form.invalid .wpcf7-response-output {
    border-color: #003e70; }
  .container-form .wpcf7 form.sent .wpcf7-response-output {
    border-color: #026eb7; }
  .container-form .wpcf7 form .wpcf7-response-output {
    max-width: 60rem;
    margin: 0 auto;
    padding: 2.5rem;
    text-align: center; }
  .container-form .div-privacy {
    max-width: 128rem;
    margin: 0 auto;
    flex-direction: column;
    padding: 3rem 0; }
    @media only screen and (max-width: 767px) {
      .container-form .div-privacy {
        padding: 1.5rem 0; } }
    .container-form .div-privacy p {
      text-align: center;
      font-size: 1.6rem;
      padding-bottom: 2.5rem; }
      @media only screen and (max-width: 767px) {
        .container-form .div-privacy p {
          padding-bottom: 1rem; } }
      .container-form .div-privacy p a {
        text-decoration: underline;
        color: #026eb7; }
        .container-form .div-privacy p a:hover {
          text-decoration: none; }
    .container-form .div-privacy-check {
      display: flex;
      justify-content: center;
      align-items: center; }
      .container-form .div-privacy-check label {
        min-width: none;
        max-width: auto;
        width: 100%;
        display: flex;
        flex-direction: row-reverse;
        padding: 0;
        border: none; }
        @media only screen and (max-width: 767px) {
          .container-form .div-privacy-check label {
            font-size: 1.6rem; } }
      .container-form .div-privacy-check .wpcf7-list-item label:has(input[type="checkbox"])::after {
        width: 2.6rem;
        border-radius: .5rem;
        margin-right: 1rem;
        background: #eee;
        opacity: 1; }
      .container-form .div-privacy-check .wpcf7-list-item label:has(input[type="checkbox"]:checked) {
        overflow: hidden; }
        .container-form .div-privacy-check .wpcf7-list-item label:has(input[type="checkbox"]:checked)::after {
          background: #026eb7; }
  .container-form .dl-privacy {
    max-width: 128rem;
    margin: 0 auto;
    flex-direction: column;
    padding: 3rem 0; }
    @media only screen and (max-width: 767px) {
      .container-form .dl-privacy {
        padding: 1.5rem 0; } }
    .container-form .dl-privacy dt {
      width: 100%;
      text-align: center;
      padding-bottom: 2.5rem;
      justify-content: center; }
      @media only screen and (max-width: 767px) {
        .container-form .dl-privacy dt {
          padding-bottom: 1rem; } }
    .container-form .dl-privacy-box {
      padding: 3.5rem;
      border: 1px solid #eee;
      height: 20rem;
      overflow: auto;
      font-size: 1.3rem;
      flex-direction: column; }
      @media only screen and (max-width: 767px) {
        .container-form .dl-privacy-box {
          padding: 1.5rem;
          font-size: 1.1rem; } }
      .container-form .dl-privacy-box p {
        padding-bottom: 1em; }
      .container-form .dl-privacy-box h6 {
        font-size: 1.4rem;
        font-weight: 700;
        padding: .5em 1em;
        background: #eee;
        margin-top: 1em;
        margin-bottom: .5em; }
        @media only screen and (max-width: 767px) {
          .container-form .dl-privacy-box h6 {
            font-size: 1.2rem; } }
    .container-form .dl-privacy dd {
      font-size: 1.3rem; }
      @media only screen and (max-width: 767px) {
        .container-form .dl-privacy dd {
          font-size: 1.1rem; } }
      .container-form .dl-privacy dd ul li {
        display: flex;
        justify-content: flex-start;
        margin-bottom: .5em; }
        .container-form .dl-privacy dd ul li:before {
          content: "●";
          font-size: 1.1rem;
          color: #026eb7;
          position: relative;
          top: .1rem;
          margin-right: .5rem; }
      .container-form .dl-privacy dd .wpcf7-form-control {
        align-items: center; }
        .container-form .dl-privacy dd .wpcf7-form-control .wpcf7-list-item {
          width: 30rem;
          max-width: 100%; }
  .container-form .wpcf7-not-valid-tip {
    color: #ec6941;
    margin: .5rem 0 0 0;
    font-weight: 700; }
  .container-form .wpcf7-form-control {
    display: flex; }
    @media only screen and (max-width: 767px) {
      .container-form .wpcf7-form-control {
        flex-wrap: wrap; } }
    .container-form .wpcf7-form-control .wpcf7-list-item {
      margin-right: 1rem; }
      @media only screen and (max-width: 767px) {
        .container-form .wpcf7-form-control .wpcf7-list-item {
          margin-right: .5rem;
          margin-bottom: .5rem; } }
      .container-form .wpcf7-form-control .wpcf7-list-item.last {
        margin-right: 0; }
  .container-form textarea,
  .container-form input[type='text'],
  .container-form input[type='date'],
  .container-form input[type='tel'],
  .container-form input[type='email'],
  .container-form input[type='url'] {
    width: 100%;
    padding: 1.2rem 1.2rem;
    font-size: 1.6rem;
    border: none;
    border: 1px solid #dcdcdc;
    border-radius: .5rem; }
  .container-form textarea {
    height: 20rem; }
    .container-form textarea.small {
      height: 9rem; }
  .container-form-btn {
    padding: 5rem 0 2rem;
    display: flex;
    justify-content: center; }
    @media only screen and (max-width: 767px) {
      .container-form-btn {
        padding: 2rem 0 1rem; } }
    .container-form-btn .wpcf7-spinner {
      display: none; }
    .container-form-btn input {
      width: 32rem;
      height: 6rem;
      border: none;
      outline: none;
      background: #026eb7;
      font-size: 1.6rem;
      border-radius: 5rem;
      display: flex;
      justify-content: center;
      align-items: center;
      margin: 0 1.5rem;
      color: #fff; }
      .container-form-btn input:hover {
        background: #003e70; }
      .container-form-btn input.active {
        pointer-events: none;
        opacity: 0.5; }
      .container-form-btn input.wpcf7-previous {
        background: #888; }
      @media only screen and (max-width: 767px) {
        .container-form-btn input {
          font-size: 1.3rem;
          height: 4.8rem;
          width: 24rem; } }
  .container-form dl {
    border-top: 1px solid #dcdcdc; }
    .container-form dl > div {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 1.5rem 0;
      border-bottom: 1px solid #dcdcdc;
      min-height: 8rem; }
      @media only screen and (max-width: 767px) {
        .container-form dl > div {
          min-height: 0; } }
      .container-form dl > div.req > dt:before {
        content: "必須";
        font-size: 1.3rem;
        border-radius: .2rem;
        background: #ec6941;
        color: #fff;
        width: 4rem;
        height: 2.2rem;
        display: flex;
        justify-content: center;
        align-items: center;
        margin-right: .8rem; }
        @media only screen and (max-width: 767px) {
          .container-form dl > div.req > dt:before {
            font-size: .9rem;
            width: 4rem;
            height: 1.7rem; } }
@media only screen and (max-width: 1024px) and (max-width: 767px) {
  .container-form dl > div {
    flex-direction: column;
    padding: 1.5rem 0; } }

      .container-form dl > div > dt {
        width: 24rem;
        flex-shrink: 0;
        font-size: 1.6rem;
        display: flex;
        align-items: center;
        justify-content: flex-start; }
        @media only screen and (max-width: 1024px) {
          .container-form dl > div > dt {
            width: 22rem; } }
  @media only screen and (max-width: 1024px) and (max-width: 767px) {
    .container-form dl > div > dt {
      width: 100%;
      font-size: 1.4rem;
      padding-bottom: 1rem;
      padding-top: 0; } }

      .container-form dl > div > dd {
        width: 100%;
        margin: auto 0;
        font-size: 1.6rem; }
        .container-form dl > div > dd p {
          font-size: 1.2rem;
          padding-top: .5rem; }
          @media only screen and (max-width: 767px) {
            .container-form dl > div > dd p {
              font-size: 1rem; } }
        @media only screen and (max-width: 767px) {
          .container-form dl > div > dd {
            font-size: 1.4rem; } }
        .container-form dl > div > dd ol {
          display: flex; }
          .container-form dl > div > dd ol li {
            width: 100%;
            padding-right: 1rem; }
            .container-form dl > div > dd ol li:nth-last-of-type(1) {
              padding-right: 0; }
        .container-form dl > div > dd dl {
          display: flex;
          justify-content: space-between;
          align-items: center;
          padding: 1.5rem 0; }
          @media only screen and (max-width: 767px) {
            .container-form dl > div > dd dl {
              padding: 1rem 0;
              flex-direction: column; } }
          .container-form dl > div > dd dl:nth-of-type(1) {
            border: none;
            padding-top: 0; }
          .container-form dl > div > dd dl:nth-last-of-type(1) {
            padding-bottom: 0; }
          .container-form dl > div > dd dl dt {
            width: 14rem;
            flex-shrink: 0;
            margin-right: 1rem; }
            @media only screen and (max-width: 767px) {
              .container-form dl > div > dd dl dt {
                width: 100%;
                font-size: 1.2rem;
                color: #666;
                margin: 0 0 .5rem; } }
          .container-form dl > div > dd dl dd {
            width: 100%; }

.wpcf7-list-item label {
  max-width: 25rem;
  min-width: 18rem;
  cursor: pointer;
  font-size: 1.6rem;
  position: relative;
  display: flex;
  align-items: center;
  padding: 1.2rem 1.2rem;
  border-radius: .6rem;
  background: #fff;
  border: 1px solid #dcdcdc;
  justify-content: center;
  /*		&::before,
  		&::after {
  			content: "";
  			display: block;
  			position: absolute;
  			transform: translateY(-50%);
  			top: 50%;
  			left: 1.5rem;
  			height: 2rem;
  			width: 2rem;
  			box-sizing: border-box;
  			border-radius: 50%;
  			@media only screen and (max-width:767px){
  				left: 1rem;
  				width: 1.6rem;
  				height: 1.6rem;
  			}
  		}
  		&:has(input[type="radio"]) {
  			&::before {
  				background-color: #fff;
  				border: .3rem solid #eee;
  			}
  		} */ }
  @media only screen and (max-width: 1024px) {
    .wpcf7-list-item label {
      width: 20rem; } }
  @media only screen and (max-width: 767px) {
    .wpcf7-list-item label {
      font-size: 1.2rem;
      height: 4rem;
      padding: .5rem;
      width: 14rem; } }
  .wpcf7-list-item label:hover {
    border-color: #026eb7; }
  .wpcf7-list-item label:has(input[type="checkbox"])::before {
    background-color: #fff;
    background: #ECECEC; }
  .wpcf7-list-item label:has(input[type="checkbox"])::after {
    content: "\e5ca";
    font-family: "material symbols Outlined", cursive;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    letter-spacing: 0;
    opacity: 0; }
  .wpcf7-list-item label:has(input[type="radio"]:checked) {
    background: #026eb7;
    font-weight: 700;
    color: #fff;
    /*			&::before {
    				border-color: $b;
    				border-width: .6rem;
    				@media only screen and (max-width:767px){
    					border-width: .5rem;
    				}
    			} */ }
  .wpcf7-list-item label:has(input[type="checkbox"]:checked) {
    font-weight: 700;
    border-color: #026eb7; }
    .wpcf7-list-item label:has(input[type="checkbox"]:checked)::after {
      opacity: 1;
      background: #026eb7; }
.wpcf7-list-item input[type="radio"], .wpcf7-list-item input[type="checkbox"] {
  position: absolute;
  white-space: nowrap;
  border: 0;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  overflow: hidden;
  height: 1px;
  width: 1px;
  margin: -1px;
  padding: 0; }

.form-select {
  line-height: 4.8rem;
  height: 5rem;
  overflow: hidden;
  background: #fff;
  border: .1rem solid #dcdcdc;
  border-radius: .5rem;
  position: relative;
  width: 30rem; }
  @media only screen and (max-width: 767px) {
    .form-select {
      width: 100%; } }
  .form-select:after {
    width: 2em;
    font-size: 2rem;
    line-height: 1;
    font-family: "material symbols Outlined", cursive;
    text-align: center;
    content: "expand_more";
    color: #666;
    top: 50%;
    margin-top: -.5em;
    right: 0;
    position: absolute; }
  .form-select select {
    width: 130%;
    line-height: 5rem;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    text-indent: 0.01px;
    text-overflow: '';
    border-radius: 0;
    border: 0;
    margin: 0;
    padding: 0 3rem 0 1.5rem;
    background: transparent;
    vertical-align: middle;
    font-size: inherit;
    color: inherit;
    box-sizing: content-box; }
    .form-select select::-ms-expand {
      display: none; }
    .form-select select:focus {
      border: none;
      outline: none;
      box-shadow: none; }
