@charset "UTF-8";
/* break point */
/* base setting */
html {
  font-size: 0.78125vw;
}
@media only screen and (max-width: 768px) {
  html {
    font-size: 62.5%;
  }
}
@media only screen and (min-width: 1280px) {
  html {
    font-size: 62.5%;
  }
}
@media only screen and (max-width: 375px) {
  html {
    font-size: 2.6666666667vw;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
}

* {
  box-sizing: border-box;
  line-height: inherit;
}

picture {
  display: block;
}

img {
  height: auto;
  max-width: 100%;
  vertical-align: middle;
  width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
  transition: opacity 0.4s ease;
}

h1,
h2,
h3,
h4,
h5 {
  font-weight: inherit;
}

ul {
  list-style: none;
}

input,
button,
select,
textarea {
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
}

input[type=checkbox],
input[type=radio] {
  display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}

input::-webkit-input-placeholder {
  color: #777;
}

input:-ms-input-placeholder {
  color: #777;
}

input::-ms-input-placeholder {
  color: #777;
}

input::placeholder {
  color: #777;
}

/* IE */
input:-ms-input-placeholder {
  color: #777;
}

/* Edge */
input::-ms-input-placeholder {
  color: #777;
}

@media only screen and (min-width: 769px) {
  .only-sp {
    display: none !important;
  }
}

@media only screen and (max-width: 768px) {
  .only-pc {
    display: none !important;
  }
}

.nowrap {
  white-space: nowrap;
}

html {
  font-size: 0.78125vw;
}
@media only screen and (max-width: 768px) {
  html {
    font-size: 62.5%;
  }
}
@media only screen and (min-width: 1280px) {
  html {
    font-size: 62.5%;
  }
}
@media only screen and (max-width: 375px) {
  html {
    font-size: 2.6666666667vw;
  }
}

img {
  height: 100%;
  width: 100%;
}

input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #c6c6c6;
}

input:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #c6c6c6;
}

input::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: #c6c6c6;
}

input::placeholder,
textarea::placeholder {
  color: #c6c6c6;
}

.form__ttl.-lp {
  color: #1a4217;
  font-weight: 900;
}

.br--sp {
  display: none;
}
@media only screen and (max-width: 768px) {
  .br--sp {
    display: block;
  }
}

.br--pc {
  display: block;
}
@media only screen and (max-width: 768px) {
  .br--pc {
    display: none;
  }
}

.main__wrapper {
  padding-top: 10rem;
}
@media only screen and (max-width: 768px) {
  .main__wrapper {
    padding-top: 7rem;
  }
}

.kv {
  aspect-ratio: 1.835234474;
  background: url(../img/golf_ad_lp/01_kv/bgimage2.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .kv {
    aspect-ratio: 1;
    background: url(../img/golf_ad_lp/01_kv/bgimage2.jpg);
    background-position: top -30% right;
    background-repeat: no-repeat;
    background-size: auto 100%;
  }
}
.kv__body {
  background-color: rgba(255, 255, 255, 0.7);
  height: 100%;
  position: absolute;
  width: 47.152777%;
}
@media only screen and (max-width: 768px) {
  .kv__body {
    display: none;
  }
}
.kv__inner {
  left: 50%;
  position: absolute;
  top: 50%;
  width: 100%;
  -webkit-transform: translate(-50%, -50%);
  text-align: center;
  transform: translate(-50%, -50%);
}
.kv__logo {
  margin-bottom: 2rem;
  max-width: 36.6rem;
  width: 100%;
  -webkit-transform: translateX(-1.7rem);
  transform: translateX(-1.7rem);
}
.kv__title {
  font-size: 2.3rem;
  font-weight: 700;
  letter-spacing: 0.018em;
  line-height: 1.7391304348;
  margin-bottom: 2rem;
  margin-right: 2rem;
}
@media screen and (max-width: 769px) {
  .kv__title {
    font-size: 1.5rem;
    line-height: 1.3043478261;
    margin-bottom: 1rem;
  }
}
.kv-under {
  display: none;
  padding: 1rem;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .kv-under {
    display: block;
  }
}
.kv-under__logo {
  width: 50%;
}
.kv-under__title {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 2rem;
  margin-top: 1rem;
}

.main__flexbox {
  display: flex;
}
@media screen and (max-width: 769px) {
  .main__flexbox {
    display: block;
  }
}

main {
  flex: 0 0 74.3055555556%;
  width: 100%;
}

aside {
  flex: 0 0 25.6944444444%;
}

.sticky-form {
  position: sticky;
  top: 7rem;
}
.sticky-form.form {
  background-color: #f7f7f7;
  box-shadow: -0.4rem 0.4rem 1rem rgba(0, 0, 0, 0.1);
  height: calc(100vh - 7rem);
  padding: 1vh 1.6rem 1.6rem 1.6rem;
}

.section.about {
  padding: 2.4rem 4rem 2.7rem 4rem;
}
@media only screen and (max-width: 768px) {
  .section.about {
    padding: 3.8rem 2rem 2.7rem 2rem;
  }
}
.section.flow {
  padding: 6.5rem 4rem 6.7rem 4rem;
}
@media only screen and (max-width: 768px) {
  .section.flow {
    padding: 3.8rem 2rem 2.7rem 2rem;
  }
}
.section.company {
  padding: 5rem 4rem 6rem 4rem;
}
@media only screen and (max-width: 768px) {
  .section.company {
    padding: 3.8rem 2rem 2.7rem 2rem;
  }
}

.section__ttl {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 2.0714285714;
  text-align: center;
}

.about__ttl {
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 768px) {
  .about__ttl {
    font-size: 2.5rem;
    line-height: 1.6875;
  }
}
.about__desc {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.7777777778;
  margin-bottom: 2.7rem;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .about__desc {
    font-size: 1.6rem;
    line-height: 1.6875;
  }
}
.about__catch {
  color: #1a4217;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.2272727273;
  margin-bottom: 2rem;
  text-align: center;
  text-decoration: underline;
}
.about__balloon {
  align-items: center;
  background-color: #e2f2e1;
  border-radius: 0.6rem;
  display: flex;
  font-size: 2rem;
  font-weight: 700;
  justify-content: center;
  margin: 0 auto;
  margin-bottom: 3.2rem;
  max-width: 68.1rem;
  padding-block: 2.5rem;
  position: relative;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .about__balloon {
    font-size: 1.5rem;
  }
}
.about__balloon-desc {
  line-height: 1;
  margin-bottom: 2.2rem;
  padding-left: 6rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .about__balloon-desc {
    padding-left: 3rem;
  }
}
.about__balloon-desc:last-of-type {
  margin: 0;
}
.about__balloon-desc::before {
  display: block;
  left: 6%;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  background: url(../img/golf_ad_lp/01_2about/icon_check.svg);
  background-repeat: no-repeat;
  background-size: cover;
  content: "";
  height: 2.2rem;
  transform: translateY(-50%);
  width: 2.2rem;
}
@media only screen and (max-width: 768px) {
  .about__balloon-desc::before {
    left: 0.5rem;
  }
}
.about__balloon::after {
  content: "";
  display: block;
  left: 50%;
  position: absolute;
  top: 87%;
  -webkit-transform: translateX(-50%);
  background-color: inherit;
  height: 3.5rem;
  transform: translateX(-50%);
  width: 5rem;
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  z-index: -1;
}
.about__copy {
  background-color: #145d1e;
  border-radius: 0.6rem;
  color: white;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.3333333333;
  margin: 0 auto;
  margin-bottom: 1.2rem;
  max-width: 76.8rem;
  padding: 1.6rem 0.5rem 1.8rem;
  text-align: center;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .about__copy {
    font-size: 2rem;
  }
}
.about__copy .yellow {
  color: #ffed12;
  font-size: 2.7rem;
  text-decoration: underline;
}

.rank-badge {
  align-items: center;
  aspect-ratio: 1;
  background: linear-gradient(#298d36, #11551a);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 20rem;
}
@media only screen and (max-width: 768px) {
  .rank-badge {
    width: 30%;
  }
}
.rank-badge__container {
  align-items: center;
  display: flex;
  gap: 4rem;
  justify-content: center;
  margin: 0 auto 2rem auto;
  max-width: 68rem;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .rank-badge__container {
    gap: 1rem;
  }
}
.rank-badge__ttl {
  color: white;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 500px) {
  .rank-badge__ttl {
    font-size: 1.3rem;
  }
}
.rank-badge__val {
  color: #ffed12;
  font-size: 6rem;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 450px) {
  .rank-badge__val {
    font-size: 4rem;
  }
}
.rank-badge__yen {
  font-size: 3.5rem;
}
@media screen and (max-width: 450px) {
  .rank-badge__yen {
    font-size: 2rem;
  }
}

.note {
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.3846153846;
  margin: 0 auto;
  max-width: 55.3rem;
}

.features {
  background-color: #fffbf6;
  padding-inline: 4rem;
  padding-top: 5.2rem;
}
@media only screen and (max-width: 768px) {
  .features {
    padding-inline: 1.2rem;
  }
}
.features__ttl {
  margin-bottom: 4rem;
}
.features__unit {
  background-color: white;
}

.point {
  background-color: #fff;
  border-radius: 2rem;
  height: 100%;
  padding: 3.5rem 0 6.7rem 0;
  text-align: center;
  width: 100%;
}
.point:nth-of-type(2) {
  position: relative;
}
.point:first-of-type {
  padding-inline: 4rem;
  padding-top: 3.1rem;
}
@media only screen and (max-width: 768px) {
  .point:first-of-type {
    padding-inline: 0.5rem;
  }
}
.point:nth-of-type(3) {
  padding-inline: 4rem;
  padding-top: 7rem;
}
@media only screen and (max-width: 768px) {
  .point:nth-of-type(3) {
    padding-inline: 1rem;
  }
}

.point__wrapper {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 5rem;
  padding-bottom: 4.1rem;
  width: 100%;
}

.point__num {
  border-bottom: 0.4rem solid #1a4217;
  display: inline-block;
  font-family: "Barlow", sans-serif;
  font-size: 2.2rem;
  font-style: normal;
  font-weight: 700;
  font-weight: 700;
  margin-bottom: 2.3rem;
  padding-bottom: 1rem;
}

.point__num1 {
  margin-bottom: 1.9rem;
}

.point__num2 {
  margin-bottom: 2rem;
}

.point__ttl {
  color: #1a4217;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.2272727273;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 768px) {
  .point__ttl {
    line-height: 1.5909090909;
  }
}

.container {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 1.3rem;
  justify-content: center;
  margin: 0 auto;
  max-width: 74.3rem;
}

.pair {
  display: flex;
  gap: 6.9rem;
  margin: 0 auto;
  width: 100%;
}

.pair.--3 .item,
.pair.--3 .effect,
.pair.--6 .item,
.pair.--6 .effect {
  padding-bottom: 1rem;
}

.pair.--7 .item,
.pair.--7 .effect {
  padding-top: 0.5rem;
}

.pair.--8 .item,
.pair.--8 .effect {
  padding-top: 0.8rem;
}

.item,
.effect {
  flex: 1;
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 1.6470588235;
  padding: 1.5rem;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .item,
  .effect {
    font-size: 1.3rem;
    padding-inline: 0.8rem;
  }
}

.item {
  align-items: center;
  background: #e2f2e1;
  display: flex;
  justify-content: center;
  padding-bottom: 0.6rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item {
    flex: 0 0 43%;
  }
}
.item::before {
  display: block;
  height: 100%;
  position: absolute;
  right: -5.95rem;
  top: 0;
  width: 6rem;
  -webkit-clip-path: polygon(0 0, 100% 50%, 0 100%);
  background-color: inherit;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  content: "";
}
@media only screen and (max-width: 768px) {
  .item::before {
    right: -1.95rem;
    width: 2rem;
  }
}
.item.--ttl {
  background-color: #fff;
  border: 0.7rem solid #c7e8c4;
  color: #79be72;
  font-size: 1.9rem;
  padding-bottom: 0.5rem;
  padding-top: 1.2rem;
}
.item.--ttl::before {
  display: none;
}

.effect {
  align-items: center;
  background: #378331;
  color: white;
  display: flex;
  justify-content: center;
  padding-bottom: 0.6rem;
}
.effect.--ttl {
  background-color: #fff;
  border: 0.7rem solid currentColor;
  color: #378331;
  font-size: 1.9rem;
  padding-bottom: 0.5rem;
  padding-top: 1.2rem;
}

@media (max-width: 768px) {
  .pair {
    gap: 2rem;
  }
}
.slide-display__wrapper {
  aspect-ratio: 2.3404255319;
  margin-top: 3.7rem;
  position: relative;
  width: 100%;
  z-index: 2;
}

.slider-display {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.slider-display div {
  height: 100%;
  width: 100%;
}

.slider-display__item {
  margin-right: 2rem;
}

.point__inner {
  height: 100%;
  margin: 0 auto;
  max-width: 886px;
  width: 100%;
}

.picture__inner {
  align-items: center;
  display: flex;
  gap: 4.5rem;
  height: 100%;
  justify-content: center;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .picture__inner {
    align-items: center;
    justify-content: flex-start;
  }
}

.picture__wrapper {
  position: relative;
}
.picture__wrapper::after {
  content: "";
  display: block;
  height: 4.8rem;
  position: absolute;
  right: -3.7rem;
  top: 50%;
  width: 2.4rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-clip-path: polygon(0 0, 100% 50%, 0 100%);
  background: #378331;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.picture__caption {
  font-size: 1.8rem;
  line-height: 1.7777777778;
}

.point__text {
  background-color: #f4f4f4;
  border-radius: 1rem;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.6875;
  margin-top: 2rem;
  max-width: 94.2rem;
  padding: 1.4rem 2rem;
  position: relative;
  text-align: center;
  width: 100%;
}
.point__text::after {
  content: "";
  display: block;
  left: 50%;
  position: absolute;
  top: -30%;
  -webkit-transform: translateX(-50%);
  background-color: inherit;
  height: 3.5rem;
  transform: translateX(-50%);
  width: 5rem;
  -webkit-clip-path: polygon(50% 0, 0 100%, 100% 100%);
  clip-path: polygon(50% 0, 0 100%, 100% 100%);
}
@media only screen and (max-width: 768px) {
  .point__text::after {
    height: 2rem;
    top: -14%;
    width: 2rem;
  }
}

.response {
  padding: 0 4rem;
  padding-bottom: 5.5rem;
  padding-top: 2.4rem;
}
@media only screen and (max-width: 768px) {
  .response {
    padding: 0 1.5rem;
  }
}

.response__ttl {
  margin-bottom: 1rem;
}

.response__ttl2 {
  margin-bottom: 3.5rem;
  margin-top: 4rem;
}

.response-unit {
  background-color: #f7f7f7;
  border-radius: 2rem;
  max-width: 99rem;
  padding-block: 4.1rem;
  padding-inline: 2.4rem;
  text-align: center;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .response-unit {
    padding: 4rem 1.5rem;
  }
}
.response-unit__container {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 3.3rem;
}
.response-unit.--unit1 {
  padding-bottom: 2.4rem;
}
.response-unit.--unit2 {
  padding-bottom: 5.3rem;
}

.response__text {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.7777777778;
  margin-bottom: 2.6rem;
  position: relative;
}
.response__text::after {
  content: "";
  display: block;
  height: 1.8rem;
  left: 50%;
  position: absolute;
  width: 3.5rem;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
  background: #378331;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.response__text--balloon0 {
  background-color: #f4f4f4;
  border-radius: 1rem;
  color: #1a4217;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.2272727273;
  margin: 0 auto;
  margin-bottom: 3.7rem;
  max-width: 94.2rem;
  padding: 1.8rem 1rem;
  padding-left: 2.3rem;
  position: relative;
  text-align: center;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .response__text--balloon0 {
    font-size: 1.85rem;
  }
}
.response__text--balloon0::after {
  content: "";
  display: block;
  left: 50%;
  position: absolute;
  top: 87%;
  -webkit-transform: translateX(-50%);
  background-color: inherit;
  height: 3.5rem;
  transform: translateX(-50%);
  width: 5rem;
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  z-index: -1;
}

.response__text--balloon {
  aspect-ratio: 11.6666666667;
  background-color: #ffffff;
  border-radius: 1rem;
  color: #000000;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin: 0 auto 1.5rem auto;
  max-width: 70rem;
  padding: 0.5rem 0.5rem;
  position: relative;
  text-align: center;
  width: 100%;
  -webkit-filter: drop-shadow(0 0 0.1rem black) drop-shadow(0 0 0.08rem black);
  filter: drop-shadow(0 0 0.1rem black) drop-shadow(0 0 0.08rem black);
}
.response__text--balloon::after {
  border-color: #ffffff transparent transparent;
  border-style: solid;
  border-width: 1.75rem 0.88rem 0 0.88rem;
  bottom: 0.1rem;
  content: "";
  left: 50%;
  position: absolute;
  translate: -50% 100%;
}

.red {
  color: #ba0000;
}

.green {
  color: #1a4217;
}

.yellow {
  color: #ffed12;
}

.fz27 {
  font-size: 2.7rem;
}

.fz22 {
  font-size: 2.2rem;
}

.fz23 {
  font-size: 2.3rem;
}

.fz19 {
  font-size: 1.9rem;
}

.fz18 {
  font-size: 1.8rem;
}

.fz30 {
  font-size: 3rem;
}
@media only screen and (max-width: 768px) {
  .fz30 {
    font-size: 2.7rem;
  }
}

.fz25 {
  font-size: 2.5rem;
}
@media only screen and (max-width: 768px) {
  .fz25 {
    font-size: 2.1rem;
  }
}

.fw700 {
  font-weight: 700;
}

.response-unit {
  width: 100%;
}
.response-unit__part {
  align-items: center;
  display: flex;
  gap: 6.9rem;
  justify-content: center;
  margin: 0 auto 4rem;
  max-width: 74.3rem;
}
@media only screen and (max-width: 768px) {
  .response-unit__part {
    gap: 2rem;
  }
}
.response-unit__pair {
  margin: 0 auto;
  width: 100%;
}
.response-unit__ttl, .response-unit__desc {
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 1.4;
  max-width: 33.7rem;
  padding: 0.4rem 0 0;
  width: 100%;
}
.response-unit__ttl {
  border: 0.7rem solid #c7e8c4;
  color: #79be72;
  margin-bottom: 0.5rem;
}
.response-unit__ttl.--right {
  border-color: currentColor;
  color: #378331;
}
.response-unit__desc {
  align-items: center;
  background: #e2f2e1;
  color: #777;
  display: flex;
  font-size: 2rem;
  justify-content: center;
  min-height: 13rem;
  position: relative;
}
.response-unit__desc::before {
  display: block;
  height: 50%;
  position: absolute;
  right: -3.45rem;
  top: 25%;
  width: 6rem;
  -webkit-clip-path: polygon(0 0, 100% 50%, 0 100%);
  background-color: inherit;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  content: "";
}
@media only screen and (max-width: 768px) {
  .response-unit__desc::before {
    right: -1.7rem;
    width: 3rem;
  }
}
.response-unit__desc.--right {
  background-color: #378331;
  color: white;
}
.response-unit__desc.--right::before {
  display: none;
}

.shadow {
  -webkit-filter: drop-shadow(0 0.3rem 0.6rem rgba(0, 0, 0, 0.16));
  filter: drop-shadow(0 0.3rem 0.6rem rgba(0, 0, 0, 0.16));
}

.response__text--balloon2 {
  background-color: #ffffff;
  border-radius: 1rem;
  color: #1a4217;
  font-size: 2rem;
  font-weight: 500;
  height: 100%;
  line-height: 1.5;
  margin: 0 auto 3.5rem auto;
  max-width: 94.2rem;
  padding: 1.7rem 1.5rem 1.8rem;
  position: relative;
  text-align: center;
  width: 100%;
}
.response__text--balloon2 .fz22 {
  font-size: 1.1em;
}
.response__text--balloon2.--2 {
  margin-bottom: 0;
}
@media only screen and (max-width: 768px) {
  .response__text--balloon2 {
    font-size: 1.5rem;
  }
}
.response__text--balloon2::before {
  content: "お客様の声";
  left: 50%;
  position: absolute;
  top: -0.6rem;
  -webkit-transform: translateX(-50%);
  background-color: #1a4217;
  border-radius: 2rem;
  color: white;
  font-size: 0.8em;
  max-width: 14.2rem;
  transform: translateX(-50%);
  width: 100%;
}
.response__text--balloon2::after {
  bottom: -2.8rem;
  display: block;
  height: 5rem;
  position: absolute;
  right: 3rem;
  width: 5rem;
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%);
  background-color: inherit;
  clip-path: polygon(0 0, 100% 0, 100% 100%);
  content: "";
  z-index: -1;
}

.others {
  align-items: center;
  background-color: #e2f2e1;
  border-radius: 1rem;
  display: flex;
  gap: 2.8rem;
  justify-content: center;
  margin: 0 auto;
  margin-bottom: 2.4rem;
  max-width: 99rem;
  padding: 2.6rem;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .others {
    flex-direction: column-reverse;
  }
}
.others__text {
  flex: 0 0 68.9%;
  width: 100%;
}
.others__text2 {
  padding-bottom: 2.5rem;
}
.others__ttl {
  color: #1a4217;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.35;
  margin-bottom: 1.6rem;
}
.others__desc {
  color: black;
  font-size: 1.6rem;
  line-height: 1.875;
}
.others__img-wrapper {
  aspect-ratio: 1.6100628931;
  background-color: #fff;
  overflow: hidden;
  position: relative;
  width: 25.6rem;
}
.others__img {
  position: absolute;
  top: 0;
}
.others__img.--1 {
  right: -2.4rem;
  width: 91%;
}
.others__img.--2 {
  -webkit-transform: scale(0.8);
  transform: scale(0.8);
}

.cta {
  background: url(../img/golf_ad_lp/06_bg/bg.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  overflow: hidden;
  padding: 9rem 0;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 769px) {
  .cta {
    padding: 4rem 2rem;
  }
}

.cta::before {
  background: url(../img/golf_ad_lp/06_bg/bg.jpg) no-repeat center/cover;
  content: "";
  display: block;
  inset: 0;
  position: absolute;
  -webkit-filter: blur(0.9rem);
  filter: blur(0.9rem);
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}

.flow__ttl {
  margin-bottom: 3rem;
}
.flow__body {
  background-color: #fffbf6;
  border-radius: 1rem;
  padding: 4.8rem 4rem 2.7rem 9rem;
}
@media only screen and (max-width: 768px) {
  .flow__body {
    padding: 3rem 4rem 2.7rem 3rem;
  }
}
.flow__list {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 6.2rem;
  justify-content: center;
  margin: 0 auto;
  max-width: 55.1rem;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .flow__list {
    gap: 4rem;
  }
}
.flow__item {
  align-items: center;
  display: flex;
  gap: 4rem;
  justify-content: center;
  margin: 0 auto;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .flow__item {
    gap: 0.5rem;
  }
}
.flow__item:last-of-type .flow__no-wrapper::after {
  display: none;
}
.flow__no-wrapper {
  aspect-ratio: 121/100;
  flex: 0 0 auto;
  margin-left: 1.3rem;
  position: relative;
  width: 12.1rem;
}
@media only screen and (max-width: 768px) {
  .flow__no-wrapper {
    width: 7.5rem;
  }
}
.flow__no-wrapper::after {
  background: url(../img/golf_ad_lp/07_flow/arrow.svg) no-repeat center/cover;
  bottom: -4.5rem;
  content: "";
  display: block;
  height: 3rem;
  left: 31%;
  position: absolute;
  width: 2.4rem;
  z-index: 5;
}
@media only screen and (max-width: 768px) {
  .flow__no-wrapper::after {
    bottom: -3.5rem;
    left: 25%;
  }
}
.flow__image {
  aspect-ratio: 121/100;
  flex: 0 0 auto;
  width: 10.15rem;
}
@media only screen and (max-width: 768px) {
  .flow__image {
    width: 8rem;
  }
}
.flow__text {
  color: #1a4217;
  flex: 0 0 45.3720508167%;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.5555555556;
  text-align: left;
  white-space: nowrap;
}
@media only screen and (max-width: 768px) {
  .flow__text {
    font-size: 1.8rem;
  }
}

.flow__item:nth-child(2) .flow__image, .flow__item:nth-child(1) .flow__image {
  -webkit-transform: scale(1.2) translateX(1rem);
  transform: scale(1.2) translateX(1rem);
}
.flow__item:nth-child(3) .flow__image {
  -webkit-transform: scale(1.5) translateX(1rem);
  transform: scale(1.5) translateX(1rem);
}
.flow__item:nth-child(4) .flow__image {
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
}
@media only screen and (max-width: 768px) {
  .flow__item:nth-child(2) .flow__image, .flow__item:nth-child(1) .flow__image {
    -webkit-transform: none;
    transform: none;
  }
  .flow__item:nth-child(3) .flow__image {
    -webkit-transform: none;
    transform: none;
  }
  .flow__item:nth-child(4) .flow__image {
    -webkit-transform: none;
    transform: none;
  }
}

.contact {
  padding: 5rem 2rem 6.9rem;
}

.contact__ttl {
  margin-bottom: 3rem;
}

.fixed-btn {
  background-color: #fff;
  bottom: 0;
  box-shadow: 0 0.6rem 1rem rgba(0, 0, 0, 0.1);
  display: none;
  padding: 2rem;
  position: fixed;
  width: 100%;
  z-index: 1000;
}

.response__img-wrapper {
  margin: 0 auto;
  overflow-x: auto;
  width: 82%;
  -webkit-transform: translateX(3.4rem);
  transform: translateX(3.4rem);
}
@media only screen and (max-width: 768px) {
  .response__img-wrapper {
    -webkit-transform: none;
    margin: 0;
    transform: none;
    width: 100%;
  }
  .response__img-wrapper img {
    flex-shrink: 0;
    max-width: none !important;
    width: 800px !important;
  }
}

.picture__container {
  overflow-x: auto;
}
@media only screen and (max-width: 768px) {
  .picture__container figure {
    flex-shrink: 0;
    max-width: none !important;
    width: 90% !important;
  }
}

[data-simplebar] {
  padding-bottom: 16px;
  position: relative;
}

.simplebar-track.simplebar-horizontal {
  background-color: #eee;
  border-radius: 0.5rem;
  height: 1rem;
}

.simplebar-scrollbar:before {
  background-color: #888;
  border-radius: 6px;
}

.sticky-form {
  overflow-y: auto;
}

.cta-btn {
  display: block;
  position: relative;
  -webkit-appearance: none;
  appearance: none;
  background: linear-gradient(to right, #2c943a, #11551a);
  border: none;
  border-radius: 4rem;
  color: white;
  font-size: 2.1rem;
  font-weight: 700;
  line-height: 1.4545454545;
  margin: 0 auto;
  max-width: 45.3rem;
  padding: 1.9rem 1rem 2.1rem;
  text-align: center;
  white-space: nowrap;
  width: 100%;
  -webkit-transform: translateY(-0.3rem);
  box-shadow: 0px 0.3rem #14481b;
  transform: translateY(-0.3rem);
  transition: box-shadow 200ms ease, -webkit-transform 200ms ease;
  transition: box-shadow 200ms ease, transform 200ms ease;
  transition: box-shadow 200ms ease, transform 200ms ease, -webkit-transform 200ms ease;
}
.cta-btn:hover {
  box-shadow: 0px 0px #14481b;
  -webkit-transform: translateY(0.2rem);
  transform: translateY(0.2rem);
}
.cta-btn.header__nav-btn {
  font-size: 1.6rem;
  max-width: 26rem;
  padding: 1.4rem 5rem 1.5rem;
  width: 100%;
}
@media screen and (max-width: 1000px) {
  .cta-btn.header__nav-btn {
    padding: 1.4rem 2rem 1.5rem;
  }
}
.cta-btn.--yellow {
  background: #ffed12;
  box-shadow: 0px 0.3rem #b2a70f;
  color: #000;
  font-size: 2.2rem;
  font-weight: 900;
  max-width: 55rem;
  padding-inline: 2rem;
  padding-right: 5rem;
  position: relative;
  z-index: 50;
}
.cta-btn.--yellow::after {
  position: absolute;
  right: 4rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
  background: url(../img/golf_ad_lp/06_bg/arrow.svg);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 4rem;
  transform: translateY(-50%);
  width: 2rem;
  z-index: 1000;
}
@media only screen and (max-width: 768px) {
  .cta-btn.--yellow::after {
    right: 2rem;
  }
}
.cta-btn.--yellow:hover {
  box-shadow: 0px 0px #b2a70f;
  -webkit-transform: translateY(0.2rem);
  transform: translateY(0.2rem);
}

.slider_ttl {
  color: #717171;
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 2.0714285714;
  margin-bottom: 1.8rem;
  margin-top: 3.5rem;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .slider_ttl {
    font-size: 2rem;
    margin-bottom: 2rem;
    margin-top: 8rem;
  }
}

.slider-photo__container {
  background-color: #fffbf6;
  margin-top: 1.2rem;
}
.slider-photo__item {
  padding: 2.8rem 1.5rem 1.5rem 1.5rem;
  text-align: center;
  width: 34rem;
}
.slider-photo__img-wrapper {
  height: 20rem;
  overflow: hidden;
  width: 31rem;
}
.slider-photo__img {
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.slider-photo__text {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5555555556;
  margin-top: 2rem;
}

.slider__logo .slick-track {
  align-items: center;
  display: flex;
  gap: 40px;
}

.image-wrapper {
  height: 6.8rem;
  overflow: hidden;
  position: relative;
  width: 44rem;
}
.image-wrapper img {
  left: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  height: auto;
  transform: translate(-50%, -50%);
  width: 100%;
}
.image-wrapper.--0 img {
  left: 50%;
  top: 50%;
}
.image-wrapper.--1 {
  height: 4.3rem;
  width: 32rem;
}
.image-wrapper.--1 img {
  left: 0%;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.image-wrapper.--2 {
  height: 7.3rem;
  width: 39.9rem;
}
.image-wrapper.--2 img {
  left: 50%;
  top: 57%;
}
.image-wrapper.--3 {
  height: 5.6rem;
  width: 16rem;
}
.image-wrapper.--3 img {
  left: 48%;
  top: 50%;
}
.image-wrapper.--4 {
  height: 7.94rem;
  width: 27.165rem;
}
.image-wrapper.--4 img {
  left: 0;
  top: 0;
  -webkit-transform: none;
  transform: none;
}
.image-wrapper.--5 {
  height: 8rem;
  width: 16rem;
}
.image-wrapper.--5 img {
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.image-wrapper.--6 {
  height: 5rem;
  width: 35.697rem;
}
.image-wrapper.--6 img {
  left: 50%;
  top: 50%;
}
.image-wrapper.--7 {
  height: 5.8rem;
  width: 25rem;
}
.image-wrapper.--7 img {
  left: 0;
  top: 0;
  -webkit-transform: none;
  transform: none;
}
.image-wrapper.--8 {
  height: 6.5rem;
  width: 9.7rem;
}
.image-wrapper.--8 img {
  left: 0;
  top: 0;
  -webkit-transform: none;
  transform: none;
}
.image-wrapper.--9 {
  height: 5.7rem;
  width: 23.5rem;
}
.image-wrapper.--9 img {
  left: 50%;
  top: 50%;
}
.image-wrapper.--10 {
  height: 9.5rem;
  width: 8.7rem;
}
.image-wrapper.--10 img {
  left: 50%;
  top: 50%;
}

.dots-wrapper {
  display: flex;
  justify-content: center;
  margin-top: 4rem;
}
.dots-wrapper li {
  background: #dedede;
  border-radius: 50%;
  cursor: pointer;
  height: 1.4rem;
  margin: 0 0.7rem;
  width: 1.4rem;
}
.dots-wrapper li.slick-active, .dots-wrapper li:hover {
  background: #bcbbbb;
}
.dots-wrapper li button {
  display: none;
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent;
  border: none;
  outline: none;
  padding: 0;
}

.logo_container {
  display: none;
}

@media only screen and (max-width: 768px) {
  .slider__logo {
    display: none;
  }
  .logo_container {
    display: flex;
    justify-content: flex-start;
    margin: 0 auto;
    width: 90%;
  }
  .logo_container ul {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1rem;
    justify-content: space-between;
  }
  .logo_container ul li {
    display: flex;
    justify-content: center;
    width: 48%;
  }
  .logo_container ul img {
    height: auto;
    width: 100%;
  }
  .logo_container ul .toyo {
    width: 90%;
  }
  .logo_container ul .hirakawa {
    width: 40%;
  }
  .logo_container ul .rose {
    width: 70%;
  }
  .logo_container ul .olympic {
    width: 30%;
  }
  .logo_container ul .tsukuba {
    margin-block: 0.6rem;
    width: 60%;
  }
}
.slider2 {
  margin-bottom: 2.4rem;
  margin-top: 0.4rem;
}

.slider-display__img {
  aspect-ratio: 752.38/423;
  width: auto;
}

.header {
  align-items: center;
  background-color: #fff;
  box-shadow: 0 0.6rem 1rem rgba(0, 0, 0, 0.1);
  display: flex;
  height: 10rem;
  justify-content: center;
  padding-inline: 7.34rem;
  position: fixed;
  transition: height 200ms ease;
  width: 100%;
  z-index: 1000;
}
@media screen and (max-width: 1000px) {
  .header {
    padding-inline: 2rem;
  }
}
.header.--short {
  height: 7rem;
}
.header__logo img {
  height: 4.1rem;
  width: auto;
}
@media only screen and (max-width: 768px) {
  .header {
    height: 7rem;
  }
}
.header__inner {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 140rem;
  padding: 2.4rem 0 2rem 2.7rem;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .header__inner {
    padding-left: 0;
  }
}
.header__nav {
  display: none;
}
@media screen and (min-width: 769px) {
  .header__nav {
    display: block;
  }
}
.header__nav-list {
  align-items: center;
  display: flex;
  gap: 4.4rem;
  justify-content: space-between;
}
.header__nav-link {
  font-size: 1.6rem;
}
.header__nav-item:last-of-type {
  margin-left: 3.8rem;
}

@media only screen and (max-width: 768px) {
  .form {
    display: none;
  }
}
.form__ttl {
  color: #28ae13;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 2.4rem;
  text-align: center;
}
.form__ttl.-brushup {
  color: #1a4217;
  margin-bottom: 2rem;
}
.form__ttl.-download {
  color: #1a4217;
  margin-bottom: 1.2rem;
}
.form__txt {
  font-size: 1.4rem;
  line-height: 1.5;
  margin-bottom: 2rem;
}
.form__list {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  margin-bottom: 2.4rem;
}
.form__item-ttl {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.4166666667;
  margin-bottom: 0.8rem;
}
.form__item-field input[type=text],
.form__item-field textarea {
  background: #ffffff;
  border-radius: 0.4rem;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.4285714286;
  padding: 1rem 1.6rem;
  width: 100%;
}
.form__item-field textarea {
  height: 18rem;
  resize: none;
}
.form__check {
  margin-bottom: 2rem;
  text-align: center;
}
.form__check input[type=checkbox]:checked + span::after {
  opacity: 1;
}
.form__check input[type=checkbox] + span {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.4166666667;
  padding-left: 2.5rem;
  position: relative;
}
.form__check input[type=checkbox] + span::before, .form__check input[type=checkbox] + span::after {
  aspect-ratio: 1/1;
  border-radius: 2px;
  content: "";
  left: 0;
  position: absolute;
  top: 50%;
  width: 1.7rem;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
}
.form__check input[type=checkbox] + span::before {
  background: #fff;
  border: 1px solid #d9d9d9;
}
.form__check input[type=checkbox] + span::after {
  background: url(../img/golf/check.svg) no-repeat left 1px center/1.7rem auto;
  opacity: 0;
}
.form__btn-box {
  text-align: center;
}
.form__btn-box button {
  align-items: center;
  color: #fff;
  display: flex;
  font-size: 1.6rem;
  font-weight: 700;
  height: 5rem;
  justify-content: center;
  line-height: 1.5;
  position: relative;
  transition: 0.3s ease-out;
  transition-property: opacity;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  width: 100%;
  z-index: 1;
}
@media (hover: hover) {
  .form__btn-box button:hover {
    opacity: 0.7;
  }
  .form__btn-box button:hover .txt {
    -webkit-transform: translate(0, 1px);
    transform: translate(0, 1px);
  }
  .form__btn-box button:hover::before {
    -webkit-transform: translate(0, 1px);
    transform: translate(0, 1px);
  }
}
@media (hover: none) {
  .form__btn-box button:active {
    opacity: 0.7;
  }
  .form__btn-box button:active .txt {
    -webkit-transform: translate(0, 1px);
    transform: translate(0, 1px);
  }
  .form__btn-box button:active::before {
    -webkit-transform: translate(0, 1px);
    transform: translate(0, 1px);
  }
}
.form__btn-box button .arrow {
  background: url(../img/golf/btn-arrow-pc.png) no-repeat center/100% auto;
  content: "";
  height: 1.4rem;
  position: absolute;
  right: 1.9rem;
  top: 50%;
  width: 1.2rem;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
}
.form__btn-box button::before, .form__btn-box button::after {
  border-radius: 3rem;
  content: "";
  left: 0;
  position: absolute;
  right: 0;
}
.form__btn-box button::before {
  background: #ff5f5f;
  bottom: 0;
  top: 0;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  z-index: -1;
}
.form__btn-box button::after {
  background: #ba0000;
  bottom: -2px;
  top: 2px;
  z-index: -2;
}
.form .contact__ttl {
  margin-bottom: 1.1rem;
}

.company {
  background: #f7f7f7;
  padding-bottom: 6rem;
  padding-top: 6rem;
}
.company__ttl {
  margin-bottom: 3rem;
}
.company__list {
  background: #fff;
  border-radius: 1rem;
  display: block;
  margin: 0 auto;
  max-width: 99rem;
  padding: 4rem;
  padding-bottom: 9rem;
}
@media only screen and (max-width: 768px) {
  .company__list {
    padding: 2rem 2.4rem 2.4rem;
  }
}
.company__item {
  align-items: flex-start;
  display: flex;
  gap: 2.4rem;
}
@media only screen and (max-width: 768px) {
  .company__item {
    flex-direction: column;
    gap: 1.6rem;
  }
}
.company__item:nth-child(n+2) {
  border-top: 1px solid #d9d9d9;
  margin-top: 1.9rem;
  padding-top: 2rem;
}
@media only screen and (max-width: 768px) {
  .company__item:nth-child(n+2) {
    border-top: none;
    margin-top: 2.4rem;
    padding-top: 0;
  }
}
.company__item:last-child .company__item-txt {
  margin-top: 0.8rem;
}
@media only screen and (max-width: 768px) {
  .company__item:last-child .company__item-txt {
    margin-top: 0;
  }
}
.company__item-ttl {
  align-items: center;
  background: #1a4217;
  border-radius: 0.6rem;
  color: #fff;
  display: flex;
  flex: 0 0 auto;
  font-size: 1.8rem;
  font-weight: 700;
  height: 4.4rem;
  justify-content: center;
  width: 16.6rem;
}
@media only screen and (max-width: 768px) {
  .company__item-ttl {
    font-size: 1.6rem;
    width: 100%;
  }
}
.company__item-txt {
  align-items: center;
  display: flex;
  font-size: 1.8rem;
  line-height: 1.7777777778;
  min-height: 4.4rem;
}
@media only screen and (max-width: 768px) {
  .company__item-txt {
    font-size: 1.6rem;
    justify-content: center;
    line-height: 1.625;
    min-height: auto;
    text-align: center;
    width: 100%;
  }
}

.footer {
  background-color: #1a4217;
  color: white;
  padding: 11rem 2rem 12rem;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .footer {
    padding: 3rem 2rem 16rem;
  }
}
.footer__inner {
  align-items: center;
  display: flex;
  gap: 5.2rem;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 120rem;
}
@media only screen and (max-width: 768px) {
  .footer__inner {
    flex-direction: column;
    gap: 4rem;
  }
}
.footer__logo {
  flex: 0 0 26.3rem;
  width: 26.3rem;
}
@media only screen and (max-width: 768px) {
  .footer__logo {
    flex: 0 0 auto;
  }
}
.footer__logo img {
  max-width: 26.3rem;
  width: 100%;
}
.footer__nav {
  display: flex;
  flex-direction: column;
  gap: 3rem;
}
@media only screen and (max-width: 768px) {
  .footer__nav {
    flex-direction: column;
  }
}
.footer__nav-list {
  display: flex;
}
@media only screen and (max-width: 768px) {
  .footer__nav-list {
    flex-direction: column;
    gap: 1.8rem;
  }
}
.footer__nav-item {
  border-right: 1px solid #fff;
}
@media only screen and (max-width: 768px) {
  .footer__nav-item {
    border: none;
  }
}
.footer__nav-item:last-child {
  border-right: none;
}
.footer__nav-item:last-child a {
  margin-right: 0;
  padding-right: 0;
}
.footer__nav-link {
  color: inherit;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  padding-inline: 5rem;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
}
@media only screen and (max-width: 768px) {
  .footer__nav-link {
    padding-inline: 0;
  }
}
.footer__nav-link:hover {
  text-decoration: underline;
}

.contact {
  background: #fff;
  position: relative;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  .contact {
    padding-bottom: 3.5rem;
  }
}
.contact .mw_wp_form .horizontal-item + .horizontal-item {
  margin: 0;
}
.contact .mw_wp_form .error {
  display: block;
  flex: 0 0 auto;
  font-size: 1.4rem;
  line-height: 1.4285714286;
  padding-top: 1rem;
  width: 100%;
}
.contact .mw_wp_form .l-contact__radio .error {
  padding-top: 0;
}
.contact__body {
  margin: 0 auto;
  max-width: 100rem;
}
.contact__list {
  border-top: 1px solid #d9d9d9;
  margin-bottom: 4rem;
}
@media only screen and (max-width: 768px) {
  .contact__list {
    margin-bottom: 2.8rem;
    margin-top: -1px;
  }
}
.contact__item {
  border-bottom: 1px solid #d9d9d9;
  display: flex;
  padding: 1.9rem 0 2rem;
}
@media only screen and (max-width: 768px) {
  .contact__item {
    flex-direction: column;
    gap: 1.6rem;
  }
}
.contact__item.-radio {
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .contact__item.-radio {
    align-items: flex-start;
  }
}
.contact__item-ttl {
  flex: 0 0 auto;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.4444444444;
  padding-top: 1.2rem;
  width: 32rem;
}
@media only screen and (max-width: 768px) {
  .contact__item-ttl {
    font-size: 1.6rem;
    line-height: 1.5;
    padding-top: 0;
    width: 100%;
  }
}
.contact__item-ttl.-radio {
  padding-top: 0;
}
.contact__item-field {
  flex: 1 1 auto;
}
.contact__item-field input[type=text],
.contact__item-field input[type=tel],
.contact__item-field input[type=email],
.contact__item-field textarea {
  background: #f8f8f8;
  border: 1px solid #d9d9d9;
  border-radius: 0.25rem;
  font-size: 1.6rem;
  line-height: 1.5;
  padding: 1.2rem 1.9rem;
  width: 100%;
}
.contact__item-field textarea {
  height: 14rem;
  resize: none;
}
@media only screen and (max-width: 768px) {
  .contact__item-field textarea {
    height: 22rem;
  }
}
.contact__item-field input[type=radio] {
  display: none;
}
.contact__item-field input[type=radio]:checked + span::after {
  opacity: 1;
}
.contact__item-field input[type=radio] + span {
  cursor: pointer;
  font-size: 1.6rem;
  line-height: 1.5;
  padding-left: 3.4rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .contact__item-field input[type=radio] + span {
    font-size: 1.4rem;
    line-height: 1.4285714286;
  }
}
.contact__item-field input[type=radio] + span::before, .contact__item-field input[type=radio] + span::after {
  box-sizing: border-box;
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.contact__item-field input[type=radio] + span::before {
  border: 1px solid #707070;
  border-radius: 50%;
  height: 2.2rem;
  left: 0;
  width: 2.2rem;
}
.contact__item-field input[type=radio] + span::after {
  background: #000000;
  border-radius: 50%;
  height: 1.2rem;
  left: 0.5rem;
  opacity: 0;
  width: 1.2rem;
}
.contact__radio {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 3.2rem;
}
@media only screen and (max-width: 768px) {
  .contact__radio {
    align-items: flex-start;
    flex-direction: column;
    gap: 1.7rem;
  }
}
.contact__btn-box {
  text-align: center;
}
.contact__privacy {
  margin-bottom: 3.2rem;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .contact__privacy {
    margin-bottom: 2.1rem;
  }
}
.contact__privacy input[type=checkbox]:checked + span::after {
  opacity: 1;
}
.contact__privacy input[type=checkbox] + span {
  font-size: 1.6rem;
  line-height: 1.5;
  padding-left: 4rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .contact__privacy input[type=checkbox] + span {
    font-size: 1.4rem;
    line-height: 1.5714285714;
  }
}
.contact__privacy input[type=checkbox] + span::before, .contact__privacy input[type=checkbox] + span::after {
  box-sizing: border-box;
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.contact__privacy input[type=checkbox] + span::before {
  background: #fff;
  border: 1px solid #d9d9d9;
  border-radius: 2px;
  height: 2.4rem;
  left: 0;
  width: 2.4rem;
}
.contact__privacy input[type=checkbox] + span::after {
  background: url(../img/top/privacy-check.svg) no-repeat center/2.4rem auto;
  height: 2.4rem;
  left: 1px;
  opacity: 0;
  pointer-events: none;
  width: 2.4rem;
}
.contact__submit {
  align-items: center;
  border-radius: 4rem;
  color: #fff;
  display: inline-flex;
  font-size: 2.2rem;
  font-weight: 900;
  height: 7rem;
  justify-content: center;
  max-width: 44rem;
  position: relative;
  width: 100%;
}
@media (hover: hover) {
  .contact__submit:hover::before {
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
  }
  .contact__submit:hover .txt {
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
  }
}
@media (hover: none) {
  .contact__submit:active::before {
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
  }
  .contact__submit:active .txt {
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
  }
}
.contact__submit::before {
  background: #ff5f5f;
  border-radius: 4rem;
  bottom: 0;
  content: "";
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  transition: 0.3s ease-out;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  z-index: 1;
}
.contact__submit::after {
  background: #ba0000;
  border-radius: 4rem;
  bottom: -3px;
  content: "";
  left: 0;
  position: absolute;
  right: 0;
  top: 3px;
  z-index: 0;
}
.contact__submit .txt {
  display: inline-block;
  line-height: 1.4545454545;
  padding-right: 2.4rem;
  position: relative;
  transition: 0.3s ease-out;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  z-index: 2;
}
@media only screen and (max-width: 768px) {
  .contact__submit .txt {
    font-size: 1.8rem;
    padding-right: 0;
  }
}
.contact__submit .txt::before {
  background: url(../img/top/btn-arrow.svg) no-repeat bottom center/1rem auto;
  content: "";
  height: 1.7rem;
  position: absolute;
  right: 1px;
  top: 50%;
  width: 1rem;
  -webkit-transform: translateY(-50%);
  pointer-events: none;
  transform: translateY(-50%);
}
@media only screen and (max-width: 768px) {
  .contact__submit .txt::before {
    right: -1.6rem;
    -webkit-transform: translate(100%, -50%);
    transform: translate(100%, -50%);
  }
}
.contact__complete {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.7777777778;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .contact__complete {
    font-size: 1.6rem;
    line-height: 1.875;
    text-align: left;
  }
}
.contact__bottom-ttl {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 2.4rem;
  text-align: center;
}
.contact__bottom-txt {
  font-size: 1.4rem;
  line-height: 1.5;
  margin-top: 1.6rem;
  text-align: center;
}
.contact__bottom-txt a {
  transition: 0.3s ease-out;
  transition-property: opacity;
}
@media (hover: hover) {
  .contact__bottom-txt a:hover {
    opacity: 0.7;
  }
}
@media (hover: none) {
  .contact__bottom-txt a:active {
    opacity: 0.7;
  }
}

.form .contact {
  background: #fff;
  position: relative;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  .form .contact {
    padding-bottom: 3.5rem;
  }
}
.form .contact .mw_wp_form .horizontal-item + .horizontal-item {
  margin: 0;
}
.form .contact .mw_wp_form .error {
  display: block;
  flex: 0 0 auto;
  font-size: 1.4rem;
  line-height: 1.4285714286;
  padding-top: 1rem;
  width: 100%;
}
.form .contact .mw_wp_form .l-contact__radio .error {
  padding-top: 0;
}
.form .contact__ttl {
  color: #1a4217;
  font-size: 1.6rem;
  margin-bottom: 0;
}
.form .contact__body {
  margin: 0 auto;
  max-width: 100rem;
}
.form .contact__list {
  border: none;
  margin-bottom: 1.3rem;
}
@media only screen and (max-width: 768px) {
  .form .contact__list {
    margin-bottom: 2.8rem;
    margin-top: -1px;
  }
}
.form .contact__item {
  border: none;
  display: flex;
  flex-direction: column;
  padding: 0.3vh 0 0.3vh;
}
@media only screen and (max-width: 768px) {
  .form .contact__item {
    flex-direction: column;
    gap: 1.6rem;
  }
}
.form .contact__item.-radio {
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .form .contact__item.-radio {
    align-items: flex-start;
  }
}
.form .contact__item-ttl {
  flex: 0 0 auto;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.4444444444;
  padding-bottom: 0.3vh;
  padding-top: 0;
  width: auto;
}
@media only screen and (max-width: 768px) {
  .form .contact__item-ttl {
    font-size: 1.6rem;
    line-height: 1.5;
    padding-top: 0;
    width: 100%;
  }
}
.form .contact__item-ttl.-radio {
  padding-top: 0;
}
.form .contact__item-field {
  flex: 1 1 auto;
}
.form .contact__item-field input[type=text],
.form .contact__item-field input[type=tel],
.form .contact__item-field input[type=email],
.form .contact__item-field textarea {
  background: #fff;
  border: none;
  border-radius: 0.4rem;
  font-size: 1.6rem;
  line-height: 1.5;
  padding: 0.8rem 1.9rem;
  width: 100%;
}
.form .contact__item-field textarea {
  height: 16rem;
  resize: none;
}
@media only screen and (max-width: 768px) {
  .form .contact__item-field textarea {
    height: 22rem;
  }
}
.form .contact__item-field input[type=radio] {
  display: none;
}
.form .contact__item-field input[type=radio]:checked + span::after {
  opacity: 1;
}
.form .contact__item-field input[type=radio] + span {
  cursor: pointer;
  font-size: 1.6rem;
  line-height: 1.5;
  padding-left: 3.4rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .form .contact__item-field input[type=radio] + span {
    font-size: 1.4rem;
    line-height: 1.4285714286;
  }
}
.form .contact__item-field input[type=radio] + span::before, .form .contact__item-field input[type=radio] + span::after {
  box-sizing: border-box;
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.form .contact__item-field input[type=radio] + span::before {
  border: 1px solid #707070;
  border-radius: 50%;
  height: 2.2rem;
  left: 0;
  width: 2.2rem;
}
.form .contact__item-field input[type=radio] + span::after {
  background: #000000;
  border-radius: 50%;
  height: 1.2rem;
  left: 0.5rem;
  opacity: 0;
  width: 1.2rem;
}
.form .contact__radio {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 3.2rem;
}
@media only screen and (max-width: 768px) {
  .form .contact__radio {
    align-items: flex-start;
    flex-direction: column;
    gap: 1.7rem;
  }
}
.form .contact__btn-box {
  text-align: center;
}
.form .contact__privacy {
  margin-bottom: 1rem;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .form .contact__privacy {
    margin-bottom: 2.1rem;
  }
}
.form .contact__privacy input[type=checkbox]:checked + span::after {
  opacity: 1;
}
.form .contact__privacy input[type=checkbox] + span {
  font-size: 1.2rem;
  line-height: 1.5;
  padding-left: 2.5rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .form .contact__privacy input[type=checkbox] + span {
    font-size: 1.4rem;
    line-height: 1.5714285714;
  }
}
.form .contact__privacy input[type=checkbox] + span::before, .form .contact__privacy input[type=checkbox] + span::after {
  box-sizing: border-box;
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.form .contact__privacy input[type=checkbox] + span::before {
  background: #fff;
  border: 1px solid #d9d9d9;
  border-radius: 2px;
  height: 1.7rem;
  left: 0;
  width: 1.7rem;
}
.form .contact__privacy input[type=checkbox] + span::after {
  background: url(../img/top/privacy-check.svg) no-repeat center/1.7rem auto;
  height: 1.7rem;
  left: 1px;
  opacity: 0;
  pointer-events: none;
  width: 1.7rem;
}
.form .contact__submit {
  align-items: center;
  border-radius: 2.5rem;
  color: #fff;
  display: inline-flex;
  font-size: 1.6rem;
  font-weight: 900;
  height: 5rem;
  justify-content: center;
  max-width: 44rem;
  position: relative;
  width: 100%;
}
@media (hover: hover) {
  .form .contact__submit:hover::before {
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
  }
  .form .contact__submit:hover .txt {
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
  }
}
@media (hover: none) {
  .form .contact__submit:active::before {
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
  }
  .form .contact__submit:active .txt {
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
  }
}
.form .contact__submit::before {
  background: #ff5f5f;
  border-radius: 4rem;
  bottom: 0;
  content: "";
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  transition: 0.3s ease-out;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  z-index: 1;
}
.form .contact__submit::after {
  background: #ba0000;
  border-radius: 4rem;
  bottom: -3px;
  content: "";
  left: 0;
  position: absolute;
  right: 0;
  top: 3px;
  z-index: 0;
}
.form .contact__submit .txt {
  display: inline-block;
  line-height: 1.4545454545;
  padding-right: 0;
  position: relative;
  transition: 0.3s ease-out;
  transition-property: -webkit-transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  z-index: 2;
}
@media only screen and (max-width: 768px) {
  .form .contact__submit .txt {
    font-size: 1.8rem;
    padding-right: 0;
  }
}
.form .contact__submit .txt::before {
  background: url(../img/top/btn-arrow.svg) no-repeat bottom center/1rem auto;
  content: "";
  height: 1.7rem;
  position: absolute;
  right: -10.1rem;
  top: 50%;
  width: 1rem;
  -webkit-transform: translateY(-50%);
  pointer-events: none;
  transform: translateY(-50%);
}
@media only screen and (max-width: 768px) {
  .form .contact__submit .txt::before {
    right: -1.6rem;
    -webkit-transform: translate(100%, -50%);
    transform: translate(100%, -50%);
  }
}
.form .contact__complete {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.7777777778;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .form .contact__complete {
    font-size: 1.6rem;
    line-height: 1.875;
    text-align: left;
  }
}
.form .contact__bottom-ttl {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 2.4rem;
  text-align: center;
}
.form .contact__bottom-txt {
  font-size: 1.4rem;
  line-height: 1.5;
  margin-top: 1.6rem;
  text-align: center;
}
.form .contact__bottom-txt a {
  transition: 0.3s ease-out;
  transition-property: opacity;
}
@media (hover: hover) {
  .form .contact__bottom-txt a:hover {
    opacity: 0.7;
  }
}
@media (hover: none) {
  .form .contact__bottom-txt a:active {
    opacity: 0.7;
  }
}

.hamburger {
  background-color: #1a4217;
  border: none;
  border-radius: 0.4rem;
  cursor: pointer;
  display: none;
  height: 4rem;
  position: relative;
  width: 4rem;
  z-index: 1100;
}
@media only screen and (max-width: 768px) {
  .hamburger {
    display: block;
  }
}

.hamburger__line {
  display: block;
  left: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translateX(-50%);
  background-color: #fff;
  height: 0.1rem;
  margin: 0 auto;
  transform: translate(-50%, -50%);
  transition: background-color 300ms ease;
  width: 2rem;
}

.hamburger__line::before,
.hamburger__line::after {
  background-color: #fff;
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  transition: -webkit-transform 300ms ease;
  transition: transform 300ms ease;
  transition: transform 300ms ease, -webkit-transform 300ms ease;
  width: 100%;
}

.hamburger__line::before {
  top: 0.8rem;
}

.hamburger__line::after {
  top: -0.8rem;
}

.hamburger.open .hamburger__line::before {
  -webkit-transform: translateY(-0.8rem) rotate(-45deg);
  transform: translateY(-0.8rem) rotate(-45deg);
}

.hamburger.open .hamburger__line {
  background-color: transparent;
}

.hamburger.open .hamburger__line::after {
  -webkit-transform: translateY(0.8rem) rotate(45deg);
  transform: translateY(0.8rem) rotate(45deg);
}

.hamburger-nav {
  background-color: #fff;
  box-shadow: 0 0.6rem 1rem rgba(0, 0, 0, 0.1);
  display: none;
  position: fixed;
  top: 7rem;
  width: 100%;
  z-index: 100;
}
.hamburger-nav__item {
  border-bottom: 1px solid #f7f7f7;
}
.hamburger-nav__link {
  color: #000;
  display: block;
  font-size: 1.6rem;
  height: 100%;
  padding: 2rem;
  width: 100%;
}