@charset "UTF-8";
/*==========================================================================
# reset - ブラウザの差異や不要なスタイルを無くすためのスタイル
========================================================================== */
* {
  box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
  border: 0;
  font-family: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

li,
dd {
  list-style-type: none;
}

header,
footer,
nav,
section,
article,
aside,
figure,
figcaption {
  display: block;
}

img {
  border: none;
  vertical-align: bottom;
}

a {
  cursor: pointer;
  text-decoration: none;
}

/* フォームリセット */
input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

textarea {
  resize: vertical;
}

input[type=checkbox],
input[type=radio] {
  opacity: 0;
  position: absolute;
}

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

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

@media (max-width: 767px) {
  .is-pc {
    display: none;
  }
}

.is-sp {
  display: none;
}
@media (max-width: 767px) {
  .is-sp {
    display: block;
  }
}

.inner {
  width: 100%;
  max-width: 96rem;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .inner {
    max-width: 32.8rem;
  }
}

html {
  font-size: 62.5%;
}

body.is-active {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  overflow: scroll;
}

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

.drawer-icon {
  position: fixed;
  top: 4rem;
  right: 4rem;
  z-index: 300;
}
.drawer-icon:hover {
  cursor: pointer;
}
@media (max-width: 767px) {
  .drawer-icon {
    top: 2.4rem;
    right: 2.4rem;
  }
}

.drawer-icon__bars {
  display: block;
  position: relative;
  width: 4.4rem;
  height: 2.7rem;
}

.drawer-icon__bar1,
.drawer-icon__bar2,
.drawer-icon__bar3 {
  position: absolute;
  width: 4.4rem;
  height: 0.3rem;
  background: #1d1d1d;
}

.drawer-icon__bar1 {
  top: 0;
}

.drawer-icon__bar2 {
  top: 1.2rem;
}

.drawer-icon__bar3 {
  top: 2.4rem;
}

.drawer-content {
  display: none;
  position: fixed;
  top: 12rem;
  right: 50%;
  transform: translateX(50%);
  z-index: 320;
  width: 100%;
  text-align: center;
}
.drawer-content.is-active {
  display: block;
}

.drawer-nav {
  margin-bottom: 4.6rem;
}

.drawer-nav__item:not(:last-child) {
  margin-bottom: 3.8rem;
}

.drawer-nav__item a {
  display: inline-block;
  font-size: 2.6rem;
  line-height: 1.5384615385;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
}
.drawer-nav__item a:hover {
  text-decoration: underline;
}
@media (max-width: 767px) {
  .drawer-nav__item a {
    display: block;
  }
}

.drawer-close {
  display: inline-block;
}
.drawer-close:hover {
  cursor: pointer;
}

.drawer-background {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 310;
  width: 100%;
  height: 100vh;
  background: #1d1d1d;
  opacity: 0.7;
  transition: opacity 0.5s;
}
.drawer-background.is-active {
  display: block;
}

.button {
  max-width: 32rem;
  margin: 0 auto;
  text-align: center;
}
.button a {
  position: relative;
  display: inline-block;
  width: 100%;
  padding: 1.1rem 0;
  text-align: center;
  text-decoration: none;
  border-radius: 100px;
  border: 1px solid #cccccc;
  background: transparent;
  color: #1d1d1d;
  line-height: 2.5;
  transition: all 0.3s;
  z-index: 10;
}
.button a::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: 100px;
  background: #fff;
  z-index: -10;
  transition: all 0.3s;
}
.button a::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: 100px;
  background: linear-gradient(90deg, #eafaff 0%, #f1fde5 50%, #f5eafd 100%);
  z-index: -20;
  transition: all 0.3s;
}
.button a:hover::before {
  opacity: 0;
}

.form-button {
  max-width: 32rem;
  margin: 0 auto;
  text-align: center;
}
.form-button button {
  position: relative;
  display: inline-block;
  width: 100%;
  padding: 1.1rem 0;
  text-align: center;
  border-radius: 100px;
  border: 1px solid #cccccc;
  background: transparent;
  color: #1d1d1d;
  line-height: 2.5;
  transition: all 0.3s;
  z-index: 10;
}
.form-button button::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: 100px;
  background: #fff;
  z-index: -10;
  transition: all 0.3s;
}
.form-button button::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: 100px;
  background: linear-gradient(90deg, #eafaff 0%, #f1fde5 50%, #f5eafd 100%);
  z-index: -20;
  transition: all 0.3s;
}
.form-button button:hover::before {
  opacity: 0;
}

.wrap {
  position: relative;
  overflow: hidden;
  z-index: 100;
  font-size: 1.6rem;
  line-height: 1.6;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: 500;
  color: #1d1d1d;
  background: linear-gradient(198deg, #fef2f8 0%, #f8fff9 32%, #f7fbfc 58%, #f2f9fe 72%, #fbf2ff 100%);
}

.contact-wrap {
  font-size: 1.6rem;
  line-height: 1.6;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: 500;
  background: linear-gradient(232deg, #f8fff9 0%, #f2f9fe 72%, #fbf2ff 100%);
}

.header {
  width: 100%;
  height: 6.7rem;
}
@media (max-width: 767px) {
  .header {
    height: 5.1rem;
  }
}

.header__inner {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  height: inherit;
}
@media (max-width: 767px) {
  .header__inner {
    justify-content: flex-start;
  }
}

.header__logo {
  width: 21.4rem;
}
@media (max-width: 767px) {
  .header__logo {
    margin-top: 1.9rem;
  }
}

.section {
  padding-bottom: 12.8rem;
}
@media (max-width: 767px) {
  .section {
    padding-bottom: 8rem;
  }
}

.section-head {
  text-align: center;
}

.section-head__subtitle {
  margin-bottom: 1.3rem;
  font-size: 1.8rem;
  line-height: 1.2222222222;
  font-family: "Lato", sans-serif;
  color: #9B9B9B;
  font-weight: bold;
}
@media (max-width: 767px) {
  .section-head__subtitle {
    margin-bottom: 0.5rem;
  }
}

.section-head__title {
  font-size: 2.6rem;
  line-height: 1.6923076923;
  font-weight: bold;
}

@-webkit-keyframes circle-animation1 {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-40px);
  }
  100% {
    transform: translateY(0);
  }
}

@keyframes circle-animation1 {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-40px);
  }
  100% {
    transform: translateY(0);
  }
}
@-webkit-keyframes circle-animation2 {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(40px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes circle-animation2 {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(40px);
  }
  100% {
    transform: translateY(0);
  }
}
@-webkit-keyframes circle-animation3 {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes circle-animation3 {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
  100% {
    transform: translateY(0);
  }
}
@-webkit-keyframes circle-animation4 {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(20px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes circle-animation4 {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(20px);
  }
  100% {
    transform: translateY(0);
  }
}
.circle-animation1 {
  -webkit-animation: circle-animation1 4s infinite;
          animation: circle-animation1 4s infinite;
}

.circle-animation2 {
  -webkit-animation: circle-animation2 4s infinite;
          animation: circle-animation2 4s infinite;
}

.circle-animation3 {
  -webkit-animation: circle-animation3 2s infinite;
          animation: circle-animation3 2s infinite;
}

.circle-animation4 {
  -webkit-animation: circle-animation4 2s infinite;
          animation: circle-animation4 2s infinite;
}

.circle-sm {
  width: 5.1rem;
  height: 4.7rem;
  background: #fff;
  border-radius: 50%;
}

.circle-md {
  width: 8.2rem;
  height: 7.5rem;
  background: #fff;
  border-radius: 50%;
}

.circle-lg {
  width: 13.4rem;
  height: 12.1rem;
  background: #fff;
  border-radius: 50%;
}

.circle-xl {
  width: 28.6rem;
  height: 25.9rem;
  background: #fff;
  border-radius: 50%;
}

.circle1 {
  position: absolute;
  top: 5.8%;
  right: 20%;
  box-shadow: 0 0 44px rgba(198, 232, 193, 0.4);
  z-index: -100;
}
@media (max-width: 767px) {
  .circle1 {
    top: 21.5%;
    right: -4%;
  }
}

.circle2 {
  position: absolute;
  bottom: 15%;
  left: 17.4%;
  box-shadow: 0 0 44px rgba(157, 234, 231, 0.4);
  z-index: -100;
}
@media (max-width: 767px) {
  .circle2 {
    display: none;
  }
}

.circle2-sp {
  display: none;
}
@media (max-width: 767px) {
  .circle2-sp {
    display: block;
    position: absolute;
    top: -8%;
    left: 11.2%;
    box-shadow: 0 0 44px rgba(157, 234, 231, 0.4);
    z-index: -100;
  }
}

.circle3 {
  position: absolute;
  top: 40%;
  right: 24.3%;
  box-shadow: 0 0 44px rgba(157, 234, 231, 0.4);
  z-index: -100;
}
@media (max-width: 767px) {
  .circle3 {
    display: none;
  }
}

.circle4 {
  position: absolute;
  top: -5%;
  left: 9.8%;
  box-shadow: 0 0 44px rgba(198, 232, 193, 0.4);
  z-index: -100;
}
@media (max-width: 767px) {
  .circle4 {
    top: 45.5%;
    left: -7.8%;
  }
}

.circle5 {
  position: absolute;
  top: 8%;
  right: 1.7%;
  box-shadow: 0 0 44px rgba(157, 234, 231, 0.4);
  z-index: -100;
}
@media (max-width: 767px) {
  .circle5 {
    top: 80%;
    right: -43.8%;
  }
}

.circle6 {
  position: absolute;
  bottom: 20%;
  right: 14.7%;
  box-shadow: 0 0 44px rgba(157, 234, 231, 0.4);
  z-index: -100;
}
@media (max-width: 767px) {
  .circle6 {
    display: none;
  }
}

.circle6-sp {
  display: none;
}
@media (max-width: 767px) {
  .circle6-sp {
    display: block;
    position: absolute;
    bottom: -4%;
    right: -2.7%;
    box-shadow: 0 0 44px rgba(157, 234, 231, 0.4);
    z-index: -100;
  }
}

.circle7 {
  position: absolute;
  top: 21.5%;
  left: 4.9%;
  box-shadow: 0 0 44px rgba(198, 232, 193, 0.4);
  z-index: -100;
}
@media (max-width: 767px) {
  .circle7 {
    width: 8.2rem;
    height: 7.5rem;
    top: 12.5%;
    left: 76%;
  }
}

.circle8 {
  position: absolute;
  bottom: 27%;
  right: 21.6%;
  box-shadow: 0 0 44px rgba(157, 234, 231, 0.4);
  z-index: -100;
}
@media (max-width: 767px) {
  .circle8 {
    bottom: 42.8%;
    right: auto;
    left: 0;
  }
}

.circle9 {
  position: absolute;
  bottom: 7.3%;
  right: 10.3%;
  box-shadow: 0 0 44px rgba(198, 232, 193, 0.4);
  z-index: -100;
}
@media (max-width: 767px) {
  .circle9 {
    bottom: 14%;
    right: 2%;
  }
}

.circle10 {
  position: absolute;
  bottom: -20.9%;
  left: 10.7%;
  box-shadow: 0 0 44px rgba(157, 234, 231, 0.4);
  z-index: -100;
}
@media (max-width: 767px) {
  .circle10 {
    bottom: -14.6%;
    left: -21.6%;
  }
}

.footer {
  height: 4.8rem;
}

.footer__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  height: inherit;
}

.footer__copyright {
  font-size: 1.4rem;
  line-height: 1.2142857143;
  color: #9B9B9B;
  font-family: "Lato", sans-serif;
  font-weight: bold;
}

.main__inner {
  margin: 0 auto;
  width: 100%;
  max-width: 56rem;
}

.main__wrapper {
  position: relative;
  margin: 4.2rem auto 5rem;
  height: 50.8rem;
}
@media (max-width: 767px) {
  .main__wrapper {
    margin: 4rem 0;
    padding-top: 90.7%;
    height: 0;
  }
}

.main__logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 200;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  opacity: 0.6;
}

.main__block {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  border-radius: 50%;
}

.mainview {
  width: 100%;
  height: 100%;
  border-radius: 50%;
}

@-webkit-keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15);
  }
}

@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15);
  }
}
.swiper-slide-active .mainview-slide,
.swiper-slide-duplicate-active .mainview-slide,
.swiper-slide-prev .mainview-slide {
  -webkit-animation: zoomUp 10s linear 0s 1 normal both;
          animation: zoomUp 10s linear 0s 1 normal both;
}

.main-head {
  margin-bottom: 7.5rem;
  text-align: center;
}
@media (max-width: 767px) {
  .main-head {
    margin-bottom: 3.2rem;
  }
}

.main-head__subtitle {
  margin-bottom: 0.9rem;
  font-size: 3.2rem;
  line-height: 1.21875;
  font-family: "Lato", sans-serif;
  font-weight: bold;
}

.main-head__title {
  font-size: 1.6rem;
  line-height: 1.8;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  color: #1d1d1d;
  font-weight: 500;
}

.news {
  padding-top: 10.1rem;
}
@media (max-width: 767px) {
  .news {
    padding-top: 3.8rem;
  }
}

.news__wrapper {
  position: relative;
  margin: 6rem calc(50% - 50vw) 0;
  width: 100vw;
}
@media (max-width: 767px) {
  .news__wrapper {
    width: 100%;
    margin: 3rem auto 0;
  }
}

.cards {
  padding-bottom: 9.4rem;
}
@media (max-width: 767px) {
  .cards {
    padding-bottom: 4rem;
  }
}

.cards__wrapper .swiper-slide {
  width: 24.1% !important;
}
@media (max-width: 767px) {
  .cards__wrapper .swiper-slide {
    width: 100% !important;
  }
}

.card__date {
  margin-bottom: 0.4rem;
  font-size: 1.4rem;
  line-height: 1.2142857143;
  font-family: "Lato", sans-serif;
  font-weight: bold;
  color: #9B9B9B;
  text-align: right;
}

.card__link {
  width: 100%;
  display: inline-block;
}
.card__link:hover {
  opacity: 0.7;
  transition: all 0.3s ease 0s;
}

.card__image {
  position: relative;
  padding-top: 100%;
  margin-bottom: 1.5rem;
  box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.24);
  border-radius: 8px;
}
.card__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 50%;
     object-position: 50% 50%;
  border-radius: 8px;
}

.card__label {
  margin-bottom: 1.5rem;
  line-height: 1.1875;
  font-family: "Lato", sans-serif;
  font-weight: bold;
}

.card__label--apricoot {
  color: #a2b2a8;
}
.card__label--apricoot span {
  color: #de936d;
}

.card__label--cocoaball {
  color: #8d6740;
}

.card__title {
  line-height: 1.9;
  font-family: "Lato", sans-serif;
}
.card__title a {
  color: #1456D3;
  text-decoration: underline;
  transition: all 0.3s ease 0s;
}
.card__title a:hover {
  cursor: pointer;
  text-decoration: none;
}

.arrow-button {
  display: flex;
  position: absolute;
  bottom: 0.5rem;
  right: 20.5rem;
  width: 11.4rem;
  height: 5.3rem;
}
@media (max-width: 767px) {
  .arrow-button {
    position: static;
    margin: 0 auto;
  }
}

.swiper-button-prev,
.swiper-button-next {
  width: 5.3rem;
  height: 5.3rem;
}

.swiper-button-prev {
  position: absolute;
  left: 0;
  margin-top: 0;
}
@media (max-width: 767px) {
  .swiper-button-prev {
    position: static;
  }
}
.swiper-button-prev::after {
  content: "";
  width: 100%;
  height: 100%;
  background: url(../img/previous-icon.png) no-repeat center center/contain;
}

.swiper-button-next {
  position: absolute;
  right: 0;
  margin-top: 0;
}
@media (max-width: 767px) {
  .swiper-button-next {
    position: static;
    margin-left: 0.8rem;
  }
}
.swiper-button-next::after {
  content: "";
  width: 100%;
  height: 100%;
  background: url(../img/next-icon.png) no-repeat center center/contain;
}

.about {
  position: relative;
  padding-bottom: 0;
}

.about-list {
  margin: 4rem 0 0;
  text-align: center;
}

.about-list__item span {
  font-weight: bold;
}

.about-list__item:not(:last-child) {
  margin-bottom: 2.5rem;
}

.about-list__item--works {
  margin-bottom: 4rem;
  line-height: 2;
  font-weight: bold;
}
@media (max-width: 767px) {
  .about-list__item--works {
    letter-spacing: -0.8px;
  }
}
.about-list__item--works a {
  color: #1456D3;
  text-decoration: underline;
  transition: all 0.3s ease 0s;
}
.about-list__item--works a:hover {
  cursor: pointer;
  text-decoration: none;
}

.about-list__item--contact a {
  color: #1456D3;
  text-decoration: underline;
  transition: all 0.3s ease 0s;
}
.about-list__item--contact a:hover {
  cursor: pointer;
  text-decoration: none;
}

.about__wrapper {
  width: min(100%, 86.9rem);
  margin: 0 auto;
  padding: 4.6rem 0 8rem;
}
@media (max-width: 767px) {
  .about__wrapper {
    padding: 4rem 0 8rem;
  }
}

.about-company {
  position: relative;
  width: 100%;
  height: 100%;
}
.about-company::before {
  content: "";
  display: block;
  padding-top: 66.7%;
}
@media (max-width: 767px) {
  .about-company::before {
    padding-top: 70rem;
  }
}

.about-company__circle {
  width: 44.8rem;
  height: 40.6rem;
  border-radius: 50%;
  background: #fff;
}
@media (max-width: 767px) {
  .about-company__circle {
    width: 37.5rem;
    height: 36.3rem;
  }
}

.about-company__circle--japanese {
  position: absolute;
  bottom: 13.2rem;
  left: 0;
  box-shadow: 0 0 44px rgba(157, 234, 231, 0.4);
  z-index: 200;
}
@media (max-width: 767px) {
  .about-company__circle--japanese {
    top: 0;
    left: -6.4%;
    bottom: auto;
    z-index: 0;
  }
}
@media (min-width: 376px) and (max-width: 766px) {
  .about-company__circle--japanese {
    left: 50%;
    transform: translateX(-50%);
    top: 0;
  }
}

.about-company__circle--english {
  position: absolute;
  bottom: 0;
  right: 0;
  font-family: "Lato", sans-serif;
  box-shadow: 0 0 44px rgba(198, 232, 193, 0.4);
}
@media (max-width: 767px) {
  .about-company__circle--english {
    bottom: 0;
    right: -6.4%;
    z-index: 200;
  }
}
@media (min-width: 376px) and (max-width: 766px) {
  .about-company__circle--english {
    bottom: 0;
    right: 50%;
    transform: translateX(50%);
  }
}

.about-company__content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}

.about-company__name--japanese {
  margin-bottom: 1.9rem;
  line-height: 1.8;
  text-align: center;
}

.about-company__name--english {
  margin-bottom: 3rem;
  line-height: 1.8;
  font-family: "Lato", sans-serif;
  text-align: center;
}
@media (max-width: 767px) {
  .about-company__name--english {
    margin-bottom: 1rem;
  }
}

.about-company__info {
  margin: 0 auto;
}
.about-company__info td {
  line-height: 1.9;
}

.about-company__info--japanese {
  margin: 0 auto;
}
@media (max-width: 767px) {
  .about-company__info--japanese {
    margin: 0 7.3rem 0 auto;
  }
}

.about-company__info--english {
  margin: 0 2rem 0 7rem;
}
@media (max-width: 767px) {
  .about-company__info--english {
    margin: 0 3rem 0 4rem;
  }
}
@media (min-width: 376px) and (max-width: 766px) {
  .about-company__info--english {
    margin: 0 2rem 0 7rem;
  }
}

.about-company__info--japanese td:last-of-type {
  display: block;
  margin-left: 1.6rem;
}

.about-company__info--english td:last-of-type {
  display: block;
  margin-left: 1.3rem;
}

.label {
  position: relative;
}

.label__wrapper {
  text-align: center;
}

.label-description {
  margin: 3.5rem 0 5rem;
}

.label-description__title {
  font-size: 2rem;
  line-height: 2;
  font-weight: bold;
}
@media (max-width: 767px) {
  .label-description__title {
    margin-bottom: 1.2rem;
    line-height: 1.6;
  }
}

.label-description__text {
  line-height: 2.5;
  font-weight: 500;
}
@media (max-width: 767px) {
  .label-description__text {
    line-height: 1.6;
  }
}
.label-description__text a {
  color: #1456D3;
  text-decoration: underline;
  transition: all 0.3s ease 0s;
}
.label-description__text a:hover {
  cursor: pointer;
  text-decoration: none;
}

.label__items {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin-bottom: 4.8rem;
}

.label-item--apricot {
  width: 17.9rem;
}

.label-item--cocoaball {
  width: 11.6rem;
  margin-left: 8rem;
}
@media (max-width: 767px) {
  .label-item--cocoaball {
    margin-left: 3.7rem;
  }
}

.label-item__image--apricot {
  margin-bottom: 1rem;
}

.label-item__image--cocoaball {
  margin-bottom: 2rem;
}

.label-item__link {
  display: inline-block;
  margin-bottom: 2rem;
  font-size: 1.4rem;
  line-height: 1.7142857143;
  color: #1456D3;
  text-decoration: underline;
  transition: all 0.3s ease 0s;
}
.label-item__link:hover {
  cursor: pointer;
  text-decoration: none;
}

.label-icon {
  display: flex;
  justify-content: center;
}
.label-icon a {
  transition: all 0.3s ease 0s;
}
.label-icon a:hover {
  opacity: 0.7;
}

.label-icon__sns {
  margin-left: 2.2rem;
}

.copyright {
  position: relative;
}

.copyright__wrapper {
  margin-top: 4rem;
  text-align: center;
}

.copyright__message--japanese {
  margin-bottom: 3.2rem;
}
.copyright__message--japanese dt {
  margin-bottom: 2.5rem;
  font-weight: bold;
}

.copyright__message--english {
  font-family: "Lato", sans-serif;
  line-height: 1.8;
}
.copyright__message--english dt {
  margin-bottom: 2.5rem;
  font-weight: bold;
}

.contact {
  position: relative;
  overflow: hidden;
}

.contact__wrapper {
  max-width: 67.2rem;
  margin: 5.7rem auto 0;
}

.form-group {
  margin-bottom: 4.8rem;
}
@media (max-width: 767px) {
  .form-group {
    margin-bottom: 4rem;
  }
}

.form-group__attention {
  margin-bottom: 4.3rem;
  text-align: center;
}
@media (max-width: 767px) {
  .form-group__attention {
    letter-spacing: -0.8px;
    margin-bottom: 4.8rem;
  }
}

.form-group__input {
  display: grid;
  grid-template-columns: 1fr 1fr;
  -moz-column-gap: 3.2rem;
       column-gap: 3.2rem;
  row-gap: 3.2rem;
  margin-bottom: 3.2rem;
}
@media (max-width: 767px) {
  .form-group__input {
    grid-template-columns: 1fr;
    -moz-column-gap: 0;
         column-gap: 0;
    row-gap: 2.4rem;
  }
}

.form-group__textarea {
  height: 20rem;
}
@media (max-width: 767px) {
  .form-group__textarea {
    height: 36rem;
  }
}

input[type=text],
textarea {
  padding: 2.1rem 2.4rem;
  background: #fff;
}

::-moz-placeholder {
  line-height: 1.6875;
  color: #777777;
}

::placeholder {
  line-height: 1.6875;
  color: #777777;
}

input[type=text] {
  width: 32rem;
  height: 6.4rem;
}
@media (max-width: 767px) {
  input[type=text] {
    width: 100%;
  }
}

textarea {
  width: 100%;
  height: 100%;
  resize: none;
}

.confirm {
  margin-top: 11.5rem;
  padding-bottom: 12rem;
}
@media (max-width: 767px) {
  .confirm {
    margin-top: 9.7rem;
  }
}

.confirm__inner {
  position: relative;
  max-width: 67.2rem;
  margin: 5.7rem auto 0;
}

.confirm-group {
  margin-bottom: 4.8rem;
}
@media (max-width: 767px) {
  .confirm-group {
    margin-bottom: 8rem;
  }
}

.confirm-group__attention {
  margin-bottom: 4.3rem;
  text-align: center;
}
@media (max-width: 767px) {
  .confirm-group__attention {
    text-align: center;
    margin-bottom: 4.8rem;
  }
}

.confirm-group__input {
  display: grid;
  grid-template-columns: 1fr 1fr;
  -moz-column-gap: 3.2rem;
       column-gap: 3.2rem;
  row-gap: 3.2rem;
  margin-bottom: 3.2rem;
}
@media (max-width: 767px) {
  .confirm-group__input {
    grid-template-columns: 1fr;
    -moz-column-gap: 0;
         column-gap: 0;
    row-gap: 2.4rem;
  }
}
.confirm-group__input dd {
  padding: 2.1rem 2.4rem;
  width: 32rem;
  height: 6.4rem;
  line-height: 1.6875;
  color: #777777;
  background: #fff;
}
@media (max-width: 767px) {
  .confirm-group__input dd {
    width: 100%;
  }
}

.confirm-group__textarea {
  padding: 2.1rem 2.4rem;
  width: 100%;
  height: 20rem;
  line-height: 1.6875;
  color: #777777;
  background: #fff;
}
@media (max-width: 767px) {
  .confirm-group__textarea {
    height: 36rem;
  }
}

.confirm__back {
  position: absolute;
  bottom: 1.9rem;
  left: 0;
  color: #1456D3;
  text-decoration: underline;
}
.confirm__back:hover {
  text-decoration: none;
}
@media (max-width: 767px) {
  .confirm__back {
    bottom: 10.4rem;
  }
}

.thanks {
  margin-top: 11.5rem;
  padding-bottom: 15rem;
}
@media (max-width: 767px) {
  .thanks {
    margin-top: 9.7rem;
    padding-bottom: 8rem;
  }
}

.thanks__inner {
  text-align: center;
  margin: 5.7rem auto 0;
}

.end-message {
  margin-bottom: 7.5rem;
}
@media (max-width: 767px) {
  .end-message {
    margin-bottom: 5.1rem;
  }
}

.end-text:first-of-type {
  margin-bottom: 2rem;
}
@media (max-width: 767px) {
  .end-text:first-of-type {
    letter-spacing: -0.8px;
  }
}

.thanks__logo {
  width: 28rem;
  margin: 0 auto 3.8rem;
}

.thanks__back {
  color: #1456D3;
  text-decoration: underline;
}
.thanks__back:hover {
  text-decoration: none;
}