@charset "UTF-8";
/*! destyle.css v2.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

/* Document */
/* ============================================ */
/**
* 1. Correct the line height in all browsers.
* 2. Prevent adjustments of font size after orientation changes in iOS.
* 3. Remove gray overlay on links for iOS.
*/
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections */
/* ============================================ */
/**
* Remove the margin in all browsers.
*/
body {
  margin: 0;
}

/**
* Render the `main` element consistently in IE.
*/
main {
  display: block;
}

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0;
}

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
  margin: 0;
  padding: 0;
}
ul li,
ol li {
  list-style: none;
}

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

/* Grouping content */
/* ============================================ */
/**
* 1. Add the correct box sizing in Firefox.
* 2. Show the overflow in Edge and IE.
*/
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

/**
* 1. Correct the inheritance and scaling of font size in all browsers.
* 2. Correct the odd `em` font sizing in all browsers.
*/
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

address {
  font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */
/**
* Remove the gray background on active links in IE 10.
*/
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

/**
* 1. Remove the bottom border in Chrome 57-
* 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
*/
abbr[title] {
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
* Add the correct font weight in Chrome, Edge, and Safari.
*/
b,
strong {
  font-weight: bolder;
}

/**
* 1. Correct the inheritance and scaling of font size in all browsers.
* 2. Correct the odd `em` font sizing in all browsers.
*/
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

/**
* Add the correct font size in all browsers.
*/
small {
  font-size: 80%;
}

/**
* Prevent `sub` and `sup` elements from affecting the line height in
* all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content */
/* ============================================ */
/**
* Prevent vertical alignment issues.
*/
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */
/**
* Reset form fields to make them styleable
*/
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
}

/**
* Reset radio and checkbox appearance to preserve their look in iOS.
*/
[type=checkbox] {
  -webkit-appearance: checkbox;
  appearance: checkbox;
}

[type=radio] {
  -webkit-appearance: radio;
  appearance: radio;
}

/**
* Show the overflow in IE.
* 1. Show the overflow in Edge.
*/
button,
input {
  /* 1 */
  overflow: visible;
}

/**
* Remove the inheritance of text transform in Edge, Firefox, and IE.
* 1. Remove the inheritance of text transform in Firefox.
*/
button,
select {
  /* 1 */
  text-transform: none;
}

/**
* Correct the inability to style clickable types in iOS and Safari.
*/
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

button[disabled],
[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled] {
  cursor: default;
}

/**
* Remove the inner border and padding in Firefox.
*/
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
* Restore the focus styles unset by the previous rule.
*/
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
* Remove arrow in IE10 & IE11
*/
select::-ms-expand {
  display: none;
}

/**
* Remove padding
*/
option {
  padding: 0;
}

/**
* Reset to invisible
*/
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

/**
* 1. Correct the text wrapping in Edge and IE.
* 2. Correct the color inheritance from `fieldset` elements in IE.
* 3. Remove the padding so developers are not caught out when they zero out
*    `fieldset` elements in all browsers.
*/
legend {
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
* Add the correct vertical alignment in Chrome, Firefox, and Opera.
*/
progress {
  vertical-align: baseline;
}

/**
* Remove the default vertical scrollbar in IE 10+.
*/
textarea {
  overflow: auto;
}

/**
* Correct the cursor style of increment and decrement buttons in Chrome.
*/
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
* 1. Correct the outline style in Safari.
*/
[type=search] {
  outline-offset: -2px; /* 1 */
}

/**
* Remove the inner padding in Chrome and Safari on macOS.
*/
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
* 1. Correct the inability to style clickable types in iOS and Safari.
* 2. Change font properties to `inherit` in Safari.
*/
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
* Clickable labels
*/
label[for] {
  cursor: pointer;
}

/* Interactive */
/* ============================================ */
/*
* Add the correct display in Edge, IE 10+, and Firefox.
*/
details {
  display: block;
}

/*
* Add the correct display in all browsers.
*/
summary {
  display: list-item;
}

/*
* Remove outline for editable content.
*/
[contenteditable] {
  outline: none;
}

/* Table */
/* ============================================ */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

/* Misc */
/* ============================================ */
/**
* Add the correct display in IE 10+.
*/
template {
  display: none;
}

/**
* Add the correct display in IE 10.
*/
[hidden] {
  display: none;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(0 0 99.9% 99.9%);
  border: 0;
}

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

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

.js-sa {
  opacity: 0;
  transition: opacity 0.6s cubic-bezier(0.43, 0.05, 0.17, 1), transform 0.6s cubic-bezier(0.43, 0.05, 0.17, 1);
}
.js-sa.-up {
  transform: translateY(30px);
}
.js-sa.-right {
  transform: translateX(30px);
}
.js-sa.-left {
  transform: translateX(-30px);
}
.js-sa.is-show {
  opacity: 1;
  transform: none;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes loadingBg {
  0% {
    transform: none;
  }
  100% {
    transform: translateY(-50%);
  }
}
@keyframes loading {
  0% {
    opacity: 1;
  }
  99% {
    opacity: 0;
    transform: none;
  }
  100% {
    transform: translateY(100vh);
  }
}
body {
  font-size: 18px;
  line-height: 2.1111111111;
  color: #745E5E;
  font-family: YuGothic, "Yu Gothic", Hiragino Sans, Hiragino Kaku Gothic ProN, Meiryo, Osaka, sans-serif;
  -webkit-text-size-adjust: 100%;
}

a {
  text-decoration: none;
  transition: opacity 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  a:hover {
    opacity: 0.7;
  }
}
a[href^="tel:"] {
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  a[href^="tel:"] {
    pointer-events: all;
  }
}

em {
  font-style: normal;
}

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

svg {
  height: auto;
}

summary {
  cursor: pointer;
}
summary::-webkit-details-marker {
  display: none;
}

select {
  cursor: pointer;
}

i {
  font-style: normal;
}

[aria-disabled=true] {
  pointer-events: none;
}

[data-whatinput=mouse] *:focus,
[data-whatinput=touch] *:focus {
  outline: none;
}

input[type=text],
input[type=tel],
input[type=number],
input[type=email],
input[type=url],
input[type=date],
input[type=password],
textarea,
select {
  width: 100%;
  border: solid 1px #d3d3d3;
  border-radius: 38px;
  background: #F2F2F2;
  transition: background 0.4s;
}
input[type=text] ::placeholder,
input[type=tel] ::placeholder,
input[type=number] ::placeholder,
input[type=email] ::placeholder,
input[type=url] ::placeholder,
input[type=date] ::placeholder,
input[type=password] ::placeholder,
textarea ::placeholder,
select ::placeholder {
  color: #717171;
}
input[type=text]:focus,
input[type=tel]:focus,
input[type=number]:focus,
input[type=email]:focus,
input[type=url]:focus,
input[type=date]:focus,
input[type=password]:focus,
textarea:focus,
select:focus {
  background: #fff;
}

input {
  height: 66px;
  padding: 0 16px;
}

input[type=submit],
input[type=send] {
  display: block;
  width: 284px;
  height: 55px;
  margin: 0 auto;
  font-size: 16px;
  line-height: 3.4375;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.1em;
  text-indent: 0.1em;
  border-radius: 30px;
  background: #FFD1CE;
  transition: opacity 0.4s;
}
@media screen and (max-width: 768px) {
  input[type=submit],
  input[type=send] {
    width: 72.8205128205vw;
  }
}
input[type=submit]:hover,
input[type=send]:hover {
  opacity: 0.7;
}

textarea {
  height: 213px;
  padding: 16px;
}
@media screen and (max-width: 768px) {
  textarea {
    height: 194px;
  }
}

.l-main {
  display: block;
  padding-top: 139px;
  overflow: clip;
}
@media screen and (max-width: 768px) {
  .l-main {
    padding-top: 92px;
  }
}

.l-wrapper {
  max-width: 1346px;
  margin: 0 auto;
  padding: 0 min(2.2619047619vw, 38px);
}
@media screen and (max-width: 768px) {
  .l-wrapper {
    padding: 0 6.6666666667vw;
  }
}
.l-wrapper.-wide {
  max-width: 1680px;
}
.l-wrapper.-narrow {
  max-width: 1202px;
}
.l-wrapper.-min {
  max-width: 1100px;
  box-sizing: content-box;
}

.l-scroll {
  display: contents;
}
@media screen and (max-width: 768px) {
  .l-scroll {
    display: block;
    padding-bottom: 10px;
    overflow-x: auto;
  }
}
@media screen and (max-width: 768px) {
  .l-scroll::-webkit-scrollbar {
    width: 5px;
    background: #EFEFEF;
  }
}
@media screen and (max-width: 768px) {
  .l-scroll::-webkit-scrollbar:horizontal {
    height: 7px;
    background: #EFEFEF;
  }
}
@media screen and (max-width: 768px) {
  .l-scroll::-webkit-scrollbar-thumb {
    --bg-opacity: 1;
    background: #FF45A1;
    border-radius: 36px;
  }
}
@media screen and (max-width: 768px) {
  .l-scroll::-webkit-scrollbar-thumb:horizontal {
    background: #FF45A1;
    border-radius: 36px;
  }
}

.loading {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  overflow: hidden;
  background: #FFE2E7;
  z-index: 10000;
  animation: loading 1s forwards;
  animation-delay: 3s;
}
.loading::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 400%;
  top: 0;
  left: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 25%, #fff 50%, #fff 100%);
  z-index: 1;
  animation: loadingBg 1s linear forwards;
  animation-delay: 1.5s;
}
.loading__head {
  position: absolute;
  width: 622px;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  animation: fadeOut 1s forwards;
  animation-delay: 0.5s;
}
@media screen and (max-width: 768px) {
  .loading__head {
    width: 71.7948717949vw;
    max-width: 300px;
  }
}
.loading__head img {
  width: 100%;
}
.loading__image {
  position: absolute;
  width: 265px;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  opacity: 0;
  animation: fadeIn 1s forwards;
  animation-delay: 2s;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .loading__image {
    width: 200px;
  }
}
.loading__image img {
  width: 100%;
}

.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  backface-visibility: hidden;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  -ms-flex-align: center;
  align-items: center;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized, .splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  backface-visibility: hidden;
  box-sizing: border-box;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

.splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.splide__track--fade > .splide__list {
  display: block;
}

.splide__track--fade > .splide__list > .splide__slide {
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  position: relative;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__arrow {
  -ms-flex-align: center;
  align-items: center;
  background: #ccc;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  display: -ms-flexbox;
  display: flex;
  height: 2em;
  -ms-flex-pack: center;
  justify-content: center;
  opacity: 0.7;
  padding: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2em;
  z-index: 1;
}

.splide__arrow svg {
  fill: #000;
  height: 1.2em;
  width: 1.2em;
}

.splide__arrow:hover:not(:disabled) {
  opacity: 0.9;
}

.splide__arrow:disabled {
  opacity: 0.3;
}

.splide__arrow:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__arrow--prev {
  left: 1em;
}

.splide__arrow--prev svg {
  transform: scaleX(-1);
}

.splide__arrow--next {
  right: 1em;
}

.splide.is-focus-in .splide__arrow:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__pagination {
  bottom: 0.5em;
  left: 0;
  padding: 0 1em;
  position: absolute;
  right: 0;
  z-index: 1;
}

.splide__pagination__page {
  background: #ccc;
  border: 0;
  border-radius: 50%;
  display: inline-block;
  height: 8px;
  margin: 3px;
  opacity: 0.7;
  padding: 0;
  position: relative;
  transition: transform 0.2s linear;
  width: 8px;
}

.splide__pagination__page.is-active {
  background: #fff;
  transform: scale(1.4);
  z-index: 1;
}

.splide__pagination__page:hover {
  cursor: pointer;
  opacity: 0.9;
}

.splide__pagination__page:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__pagination__page:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__progress__bar {
  background: #ccc;
  height: 3px;
}

.splide__slide {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.splide__slide:focus {
  outline: 0;
}

@supports (outline-offset: -3px) {
  .splide__slide:focus-visible {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide__slide:focus-visible {
    border: 3px solid #0bf;
  }
}
@supports (outline-offset: -3px) {
  .splide.is-focus-in .splide__slide:focus {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide.is-focus-in .splide__slide:focus {
    border: 3px solid #0bf;
  }
  .splide.is-focus-in .splide__track > .splide__list > .splide__slide:focus {
    border-color: #0bf;
  }
}
.splide__toggle {
  cursor: pointer;
}

.splide__toggle:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__toggle:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__track--nav > .splide__list > .splide__slide {
  border: 3px solid transparent;
  cursor: pointer;
}

.splide__track--nav > .splide__list > .splide__slide.is-active {
  border: 3px solid #000;
}

.splide__arrows--rtl .splide__arrow--prev {
  left: auto;
  right: 1em;
}

.splide__arrows--rtl .splide__arrow--prev svg {
  transform: scaleX(1);
}

.splide__arrows--rtl .splide__arrow--next {
  left: 1em;
  right: auto;
}

.splide__arrows--rtl .splide__arrow--next svg {
  transform: scaleX(-1);
}

.splide__arrows--ttb .splide__arrow {
  left: 50%;
  transform: translate(-50%);
}

.splide__arrows--ttb .splide__arrow--prev {
  top: 1em;
}

.splide__arrows--ttb .splide__arrow--prev svg {
  transform: rotate(-90deg);
}

.splide__arrows--ttb .splide__arrow--next {
  bottom: 1em;
  top: auto;
}

.splide__arrows--ttb .splide__arrow--next svg {
  transform: rotate(90deg);
}

.splide__pagination--ttb {
  bottom: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  left: auto;
  padding: 1em 0;
  right: 0.5em;
  top: 0;
}

.splide__pagination {
  gap: 28px;
}
@media screen and (max-width: 768px) {
  .splide__pagination {
    gap: 20px;
  }
}
.splide__pagination__page {
  width: 19px;
  height: 16px;
  margin: 0;
  opacity: 1;
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2219%22%20height%3D%2215.183%22%20viewBox%3D%220%200%2019%2015.183%22%3E%20%3Cdefs%3E%20%3CclipPath%20id%3D%22splidePagenation01%22%3E%20%3Crect%20width%3D%2219%22%20height%3D%2215.183%22%20transform%3D%22translate(0%200)%22%20fill%3D%22%23c1a9b5%22%2F%3E%20%3C%2FclipPath%3E%20%3C%2Fdefs%3E%20%3Cg%20clip-path%3D%22url(%23splidePagenation01)%22%3E%20%3Cpath%20d%3D%22M11.046%2C1.365h0a2.187%2C2.187%2C0%2C0%2C1-3.094%2C0A4.659%2C4.659%2C0%2C0%2C0%2C1.364%2C7.953l6.589%2C6.589a2.188%2C2.188%2C0%2C0%2C0%2C3.094%2C0l6.589-6.589a4.659%2C4.659%2C0%2C0%2C0-6.589-6.589%22%20transform%3D%22translate(0%200)%22%20fill%3D%22%23c1a9b5%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center/contain;
}
.splide__pagination__page.is-active {
  transform: none;
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2219%22%20height%3D%2215.183%22%20viewBox%3D%220%200%2019%2015.183%22%3E%20%3Cdefs%3E%20%3CclipPath%20id%3D%22splidePagenation01%22%3E%20%3Crect%20width%3D%2219%22%20height%3D%2215.183%22%20transform%3D%22translate(0%200)%22%20fill%3D%22%23c1a9b5%22%2F%3E%20%3C%2FclipPath%3E%20%3C%2Fdefs%3E%20%3Cg%20clip-path%3D%22url(%23splidePagenation01)%22%3E%20%3Cpath%20d%3D%22M11.046%2C1.365h0a2.187%2C2.187%2C0%2C0%2C1-3.094%2C0A4.659%2C4.659%2C0%2C0%2C0%2C1.364%2C7.953l6.589%2C6.589a2.188%2C2.188%2C0%2C0%2C0%2C3.094%2C0l6.589-6.589a4.659%2C4.659%2C0%2C0%2C0-6.589-6.589%22%20transform%3D%22translate(0%200)%22%20fill%3D%22%23FF45A1%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center/contain;
}
.splide__arrows {
  position: relative;
  display: flex;
  justify-content: center;
  gap: 30px;
  height: 43px;
}
@media screen and (max-width: 768px) {
  .splide__arrows {
    gap: 22px;
  }
}
.splide__arrow {
  position: inherit;
  display: flex;
  width: auto;
  height: auto;
  top: auto;
  left: auto;
  right: auto;
  background: none;
  transform: none;
  opacity: 1;
}
.splide__arrow i {
  aspect-ratio: 1;
  display: flex;
  width: 43px;
  rotate: 180deg;
}
.splide__arrow i svg {
  width: 100%;
  height: 100%;
  scale: 1;
}

.header {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  background: #fff;
  z-index: 1000;
}
.header::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 7px;
  top: 0;
  left: 0;
  background: #FF44A1;
  z-index: 1000;
}
.header__wrap {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  height: 139px;
  padding: 0 min(2.2619047619vw, 38px);
}
@media screen and (max-width: 768px) {
  .header__wrap {
    height: auto;
    padding: 20px 3.0769230769vw;
  }
}
.header__head {
  width: 122px;
  margin: auto 0 auto min(2.0833333333vw, 35px);
}
@media screen and (max-width: 768px) {
  .header__head {
    position: relative;
    width: 154px;
    margin-left: 0;
    z-index: 1000;
  }
}
.header__head a {
  display: block;
}
.header__head a img {
  width: 100%;
}
.header__btn {
  display: none;
}
@media screen and (max-width: 768px) {
  .header__btn {
    aspect-ratio: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 36px;
    margin-top: 6px;
    z-index: 1000;
  }
}
.header__btn i {
  width: 100%;
}
.header__btn i svg {
  width: 100%;
}
.header__btn i svg:last-child {
  display: none;
}
.header__btn[aria-expanded=true] i svg {
  display: none;
}
.header__btn[aria-expanded=true] i svg:last-child {
  display: block;
}
@media screen and (max-width: 768px) {
  .header__item {
    display: flex;
    gap: 20px;
  }
}
.header__state {
  position: fixed;
  top: 32px;
  right: min(2.5vw, 42px);
  z-index: 1000;
}
@media screen and (max-width: 768px) {
  .header__state {
    position: relative;
    top: auto;
    right: auto;
  }
}
.header__current {
  position: relative;
  display: flex;
  align-items: center;
  gap: 4px;
  width: min(8.8426527958vw, 110px);
  height: 41px;
  padding: min(0.7142857143vw, 8px);
  font-size: clamp(8px, 0.9523809524vw, 16px);
  line-height: 1.5;
  font-weight: bold;
  text-transform: uppercase;
  border: 1px solid #745E5E;
  border-radius: 22px;
  transition: color 0.3s, background-color 0.3s;
}
@media screen and (max-width: 768px) {
  .header__current {
    width: clamp(98px, 25.1282051282vw, 110px);
    padding: clamp(6px, 1.5384615385vw, 8px);
    font-size: min(3.5897435897vw, 16px);
  }
}
.header__current img {
  width: clamp(12px, 1.4285714286vw, 24px);
}
@media screen and (max-width: 768px) {
  .header__current img {
    width: clamp(14px, 0.8333333333vw, 20px);
  }
}
.header__current i {
  position: absolute;
  display: flex;
  aspect-ratio: 1;
  width: clamp(10px, 0.7142857143vw, 12px);
  top: 50%;
  right: clamp(6px, 0.7142857143vw, 8px);
  translate: 0 -50%;
}
.header__current i svg {
  width: 100%;
}
.header__current:hover {
  opacity: 1;
  color: #FF44A1;
  border-color: #FF44A1;
  fill: #FF44A1;
}
[open] > .header__current i {
  rotate: 180deg;
}
.header__flag img {
  display: none;
}
.header__flag img[data-lang=ja] {
  display: block;
}
.header__lang {
  position: absolute;
  display: none;
  width: clamp(90px, 11.7035110533vw, 110px);
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  padding: 10px;
  background: #fff;
}
@media screen and (max-width: 768px) {
  .header__lang {
    width: 100px;
  }
}
.header__lang a {
  display: none;
  width: fit-content;
  white-space: nowrap;
}
.header__lang a span {
  display: inline-block;
  width: fit-content;
  margin-right: 0 !important;
  font-size: clamp(10px, 0.9523809524vw, 16px) !important;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .header__lang a span {
    font-size: 12px !important;
  }
}
.header__lang a[title="Chinese (Simplified)"], .header__lang a[title="Chinese (Traditional)"], .header__lang a[title=Korean], .header__lang a[title=English], .header__lang a[title=Japanese] {
  display: block;
}
[open] > .header__lang {
  display: block;
}

.nav {
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .nav {
    position: fixed;
    width: 100%;
    height: 100vh;
    top: 0;
    left: 0;
    overflow: hidden;
    background: #fff;
    z-index: 100;
    transition: opacity 0.3s, visibility 0.3s;
    opacity: 0;
    visibility: hidden;
  }
}
@media screen and (max-width: 768px) {
  .nav::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 108px;
    top: 0;
    left: 0;
    background: #fff;
  }
}
.nav[aria-hidden=false] {
  opacity: 1;
  visibility: visible;
}
.nav__wrap {
  max-width: 1680px;
  height: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .nav__wrap {
    height: 100%;
    overflow-y: auto;
  }
}
.nav__inner {
  display: flex;
  align-items: center;
  gap: min(3.0952380952vw, 52px);
  height: 100%;
}
@media screen and (max-width: 768px) {
  .nav__inner {
    flex-direction: column;
    gap: 32px;
    padding: 0 9.4871794872vw;
  }
}
.nav__item {
  display: flex;
  gap: min(3.1547619048vw, 53px);
  height: 100%;
}
@media screen and (max-width: 768px) {
  .nav__item {
    display: grid;
    gap: 0;
    width: 100%;
    height: auto;
    margin-top: 108px;
    padding-bottom: 0;
    border-top: 1px solid #C1C6D0;
  }
}
.nav__details {
  position: relative;
}
@media screen and (max-width: 768px) {
  .nav__details {
    border-bottom: 1px solid #C1C6D0;
  }
}
.nav__summary {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
  height: 100%;
  font-weight: bold;
  transition: color 0.3s;
}
@media screen and (max-width: 768px) {
  .nav__summary {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    height: 114px;
    padding: 0 3.0769230769vw 0 5.1282051282vw;
  }
}
.nav__summary::before {
  content: attr(data-attr);
  font-size: clamp(8px, 1.0403120936vw, 13px);
  line-height: 1.4615384615;
  color: #FF44A1;
}
@media screen and (max-width: 768px) {
  .nav__summary::before {
    content: none;
  }
}
.nav__summary::after {
  content: "";
  position: absolute;
  width: 100%;
  height: min(0.4166666667vw, 7px);
  bottom: 0;
  left: 0;
  border-radius: 3px;
  background: #FF44A1;
  z-index: 1;
  transition: scale 0.3s;
  transform-origin: left;
  scale: 0 1;
}
@media screen and (max-width: 768px) {
  .nav__summary::after {
    content: none;
  }
}
.nav__summary span {
  display: flex;
  align-items: center;
  min-height: clamp(30px, 3.9011703511vw, 52px);
  font-size: clamp(10px, 1.300390117vw, 18px);
  line-height: 1.4444444444;
}
@media screen and (max-width: 768px) {
  .nav__summary span {
    min-height: 68px;
    font-size: 23px;
    line-height: 1.4782608696;
  }
}
.nav__summary i {
  display: none;
}
@media screen and (max-width: 768px) {
  .nav__summary i {
    position: relative;
    aspect-ratio: 1;
    flex-shrink: 0;
    display: block;
    width: 23px;
    border-radius: 50%;
    background: #FF44A1;
  }
}
.nav__summary i::before, .nav__summary i::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 3px;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  background: #fff;
  border-radius: 3px;
  transition: rotate 0.3s;
}
.nav__summary i::before {
  rotate: 90deg;
}
@media (hover: hover) and (pointer: fine) {
  .nav__summary::after:hover {
    scale: 1;
  }
}
[open] > .nav__summary {
  color: #FF44A1;
}
@media screen and (max-width: 768px) {
  [open] > .nav__summary {
    color: inherit;
  }
}
[open] > .nav__summary::after {
  scale: 1;
}
[open] > .nav__summary i::before {
  rotate: 180deg;
}
.nav__content {
  position: fixed;
  display: grid;
  justify-items: center;
  top: 139px;
  left: 0;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .nav__content {
    position: relative;
    justify-items: start;
    top: auto;
    left: auto;
    border-top: 1px solid #C1C6D0;
  }
}
.nav__content::before {
  content: "";
  position: absolute;
  width: 100%;
  height: calc(100% - 34px);
  top: 0;
  left: 0;
  background: #FCFCFC;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .nav__content::before {
    content: none;
  }
}
.nav__content * {
  transition: opacity 0.6s;
  opacity: 0;
}
[open] > .nav__content * {
  transition-delay: 0.15s;
  opacity: 1;
}
.nav__links {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  gap: 12px min(2.5595238095vw, 43px);
  height: 172px;
  padding: 48px 0 55px;
  box-sizing: content-box;
}
@media screen and (max-width: 768px) {
  .nav__links {
    width: 100%;
    height: auto;
    gap: 22px;
    padding: 24px 0 36px;
  }
}
.nav__link {
  display: flex;
  align-items: flex-start;
  gap: min(1.9047619048vw, 32px);
  font-size: clamp(16px, 2.0806241873vw, 18px);
  line-height: 1.8888888889;
}
@media screen and (max-width: 768px) {
  .nav__link {
    flex-direction: column;
    gap: 21px;
    font-size: 23px;
    line-height: 1.8695652174;
  }
}
.nav__link:first-child {
  height: 100%;
}
@media screen and (max-width: 1040px) {
  .nav__link:first-child {
    height: auto;
  }
}
.nav__parent {
  display: flex;
  align-items: center;
  gap: min(0.6547619048vw, 11px);
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .nav__parent {
    gap: 15px;
    padding-left: 19px;
  }
}
.nav__parent::before {
  content: "";
  aspect-ratio: 1;
  flex-shrink: 0;
  width: 9px;
  border-radius: 50%;
  background: #FF44A1;
}
@media screen and (max-width: 768px) {
  .nav__parent::before {
    width: 12px;
  }
}
.nav__children {
  display: grid;
  grid-auto-flow: column;
  grid-template-rows: repeat(auto-fill, 34px);
  gap: 12px min(1.8452380952vw, 31px);
  max-height: 126px;
  padding-left: min(2.0833333333vw, 35px);
  border-left: 1px solid #B9B9B9;
}
@media screen and (max-width: 768px) {
  .nav__children {
    display: flex;
    flex-direction: column;
    gap: 19px;
    max-height: 100%;
    border-left: none;
    padding-left: 46px;
  }
}
.nav__children:has(> :only-child) {
  max-height: 100%;
}
.nav__child a {
  display: flex;
  align-items: center;
  gap: min(0.5357142857vw, 9px);
}
@media screen and (max-width: 768px) {
  .nav__child a {
    gap: 12px;
  }
}
.nav__child a::before {
  content: "";
  aspect-ratio: 1;
  flex-shrink: 0;
  width: 7px;
  border-radius: 50%;
  background: #FF44A1;
}
@media screen and (max-width: 768px) {
  .nav__child a::before {
    width: 10px;
  }
}
.nav__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 100%;
  font-size: 14px;
  line-height: 2.4285714286;
  font-weight: 600;
  background: rgba(239, 239, 239, 0.9);
}
@media screen and (max-width: 768px) {
  .nav__btn {
    display: none;
  }
}
.nav__btn i {
  width: 12px;
}
.nav__btn i svg {
  width: 100%;
}
.nav__foot {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 13px;
}
@media screen and (max-width: 768px) {
  .nav__foot {
    gap: 25px;
    padding-bottom: 31px;
  }
}
.nav__other {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: clamp(10px, 1.300390117vw, 18px);
  line-height: 1.2222222222;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .nav__other {
    font-size: 18px;
  }
}
.nav__other i {
  width: min(1.5604681404vw, 18px);
}
@media screen and (max-width: 768px) {
  .nav__other i {
    width: 18px;
  }
}
.nav__other i img {
  width: 100%;
}

.heading-1 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 19px;
  font-size: 34px;
  line-height: 1.6470588235;
  font-weight: bold;
  text-align: center;
  font-family: "Zen Maru Gothic", YuGothic, "Yu Gothic", Hiragino Sans, Hiragino Kaku Gothic ProN, Meiryo, Osaka, sans-serif;
}
@media screen and (max-width: 768px) {
  .heading-1 {
    order: var(--_order, 0);
    gap: 25px;
    word-break: auto-phrase;
    font-size: 30px;
    line-height: 1.5333333333;
  }
}
.heading-1::after {
  content: "";
  width: 66px;
  height: 10px;
  border-radius: 5px;
  background: #FF44A1;
}
.heading-1.-left {
  align-items: flex-start;
  text-align: left;
}
.heading-1.-post {
  line-height: 1.4411764706;
}
@media screen and (max-width: 768px) {
  .heading-1.-post {
    font-size: 28px;
    line-height: 1.4285714286;
  }
}
.heading-1.-contact {
  line-height: 1.4411764706;
}
@media screen and (max-width: 768px) {
  .heading-1.-contact {
    font-size: 34px;
    line-height: 1.4411764706;
  }
}

.heading-2 {
  font-size: 28px;
  line-height: 1.8571428571;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .heading-2 {
    font-size: min(6.1538461538vw, 24px);
    line-height: 1.5;
  }
}

.heading-3 {
  position: relative;
  padding-left: 20px;
  font-size: 22px;
  line-height: 1.4545454545;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .heading-3 {
    order: var(--_order);
    font-size: 20px;
    line-height: 1.45;
  }
}
.heading-3::before {
  content: "";
  position: absolute;
  width: 4px;
  height: calc(100% - 5px);
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  border-radius: 4px;
  background: #FF44A1;
}

.btn-1 {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: var(--_width-PC, 259px);
  height: 65px;
  margin: var(--_margin-PC, 0 auto);
  font-size: 16px;
  line-height: 2.125;
  font-weight: bold;
  color: #FF44A1;
  border: 3px solid #fff;
  border-radius: 33px;
  box-shadow: 2px 2px 6px rgba(149, 120, 120, 0.6);
  background: #fff;
  transition: border-color 0.3s;
}
@media screen and (max-width: 768px) {
  .btn-1 {
    margin: var(--_margin-SP, 0 auto);
  }
}
.btn-1:hover {
  opacity: 1;
  border-color: #FF44A1;
}
.btn-1:hover i {
  background: none;
}
.btn-1:hover i::before {
  opacity: 1;
}
.btn-1.-left {
  margin-left: 0;
}
@media screen and (max-width: 768px) {
  .btn-1.-left {
    margin-left: auto;
  }
}

.btn-icon-1 {
  position: absolute;
  aspect-ratio: 1;
  width: 12px;
  top: 50%;
  right: 25px;
  transform: translateY(-50%);
  border-radius: 50%;
  background: #FF44A1;
}
.btn-icon-1::before {
  content: "";
  position: absolute;
  width: 17px;
  height: 17px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2219%22%20height%3D%2215.183%22%20viewBox%3D%220%200%2019%2015.183%22%3E%20%3Cdefs%3E%20%3CclipPath%20id%3D%22splidePagenation01%22%3E%20%3Crect%20width%3D%2219%22%20height%3D%2215.183%22%20transform%3D%22translate(0%200)%22%20fill%3D%22%23c1a9b5%22%2F%3E%20%3C%2FclipPath%3E%20%3C%2Fdefs%3E%20%3Cg%20clip-path%3D%22url(%23splidePagenation01)%22%3E%20%3Cpath%20d%3D%22M11.046%2C1.365h0a2.187%2C2.187%2C0%2C0%2C1-3.094%2C0A4.659%2C4.659%2C0%2C0%2C0%2C1.364%2C7.953l6.589%2C6.589a2.188%2C2.188%2C0%2C0%2C0%2C3.094%2C0l6.589-6.589a4.659%2C4.659%2C0%2C0%2C0-6.589-6.589%22%20transform%3D%22translate(0%200)%22%20fill%3D%22%23FF45A1%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center/contain;
}

.btn-pagetop {
  position: absolute;
  aspect-ratio: 1;
  display: flex;
  width: 60px;
  border-radius: 50%;
  top: -30px;
  right: 0;
}
.btn-pagetop i {
  width: 100%;
}
.btn-pagetop i svg {
  width: 100%;
}

.breadcrumb {
  max-width: 1512px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .breadcrumb {
    margin: 0 -3.0769230769vw;
  }
}
.breadcrumb__item {
  display: inline;
  font-size: 16px;
  line-height: 2.125;
  text-transform: uppercase;
}
@media screen and (max-width: 768px) {
  .breadcrumb__item {
    gap: 12px;
  }
}
.breadcrumb__item + .breadcrumb__item {
  margin-left: 18px;
}
@media screen and (max-width: 768px) {
  .breadcrumb__item + .breadcrumb__item {
    margin-left: 7px;
  }
}
.breadcrumb__item + .breadcrumb__item::before {
  content: "";
  aspect-ratio: 1;
  display: inline-block;
  width: 10px;
  margin-right: 18px;
  rotate: -45deg;
  border-bottom: 2px solid #745E5E;
  border-right: 2px solid #745E5E;
}
@media screen and (max-width: 768px) {
  .breadcrumb__item + .breadcrumb__item::before {
    margin-right: 12px;
  }
}
.breadcrumb__item a {
  display: inline-block;
}
.breadcrumb__item a * {
  transition: 0.6s;
}
.breadcrumb__item [aria-current] {
  font-weight: bold;
  text-decoration: underline;
}

.top-mv {
  position: relative;
  margin-bottom: 71px;
  padding: 0 min(2.2619047619vw, 38px);
}
@media screen and (max-width: 768px) {
  .top-mv {
    margin-bottom: 36px;
    padding: 0 3.0769230769vw;
  }
}
.top-mv__item {
  position: absolute;
  width: 100%;
  max-width: 1522px;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  padding: 0 min(2.6388888889vw, 38px);
  margin: 0 min(2.6388888889vw, 38px);
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .top-mv__item {
    display: flex;
    justify-content: center;
    top: 55px;
    left: 47%;
    translate: -50% 0;
    margin: 0 3.0769230769vw;
    padding: 0;
  }
}
.top-mv__head {
  width: min(43.2638888889vw, 623px);
}
@media screen and (max-width: 768px) {
  .top-mv__head {
    width: min(69.2307692308vw, 270px);
  }
}
.top-mv__head img {
  width: 100%;
}
.top-mv__wrap .splide__pagination {
  bottom: 20px;
}
@media screen and (max-width: 768px) {
  .top-mv__wrap .splide__pagination {
    bottom: 14px;
  }
}
.top-mv__image {
  transform: none !important;
  overflow: hidden;
  border-radius: 56px;
}
@media screen and (max-width: 768px) {
  .top-mv__image {
    height: min(154.1025641026vw, 601px);
    border-radius: 25px;
  }
}
.top-mv__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center right;
}
@media screen and (max-width: 768px) {
  .top-mv__image img {
    object-position: center;
  }
}

.top-video {
  margin-bottom: 165px;
}
@media screen and (max-width: 768px) {
  .top-video {
    margin-bottom: 55px;
  }
}
.top-video__wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  max-width: 1126px;
  margin: 0 auto;
  padding: 45px 30px 53px;
  border-radius: 50px;
  background: linear-gradient(to bottom, #FFF8F8, #FFCED9);
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .top-video__wrap {
    gap: 22px;
    margin: 0 -2.5641025641vw;
    padding: 38px max(4.8717948718vw, 19px) 42px;
    border-radius: 45px;
  }
}
.top-video__wrap figcaption {
  word-break: auto-phrase;
  font-size: 24px;
  line-height: 1.6666666667;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .top-video__wrap figcaption {
    font-size: 16px;
    line-height: 1.5;
  }
}
.top-video__wrap span {
  aspect-ratio: 16/9;
  width: 100%;
  max-width: 790px;
  overflow: hidden;
  border-radius: 20px;
}
.top-video__wrap span iframe {
  width: 100%;
  height: 100%;
}
.top-video__wrap i {
  position: absolute;
  width: 97.158%;
  max-width: 1094px;
  top: 60.5%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .top-video__wrap i {
    display: none;
  }
}
.top-video__wrap i svg {
  width: 100%;
}

.top-introduction {
  margin-bottom: 160px;
}
@media screen and (max-width: 768px) {
  .top-introduction {
    margin-bottom: 65px;
  }
}
.top-introduction__wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 717px;
}
.top-introduction__content {
  margin-top: 56px;
}
@media screen and (max-width: 768px) {
  .top-introduction__content {
    display: grid;
    margin-top: 10px;
  }
}
.top-introduction__txt {
  line-height: 2.75;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .top-introduction__txt {
    font-size: 17px;
    line-height: 2.2222222222;
  }
}
.top-introduction__bg {
  display: none;
}
@media screen and (max-width: 768px) {
  .top-introduction__bg {
    display: block;
  }
}
.top-introduction__bg img {
  width: 100%;
}
.top-introduction__bg.-type-1 {
  position: absolute;
  display: block;
  width: 1260px;
  top: 53px;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .top-introduction__bg.-type-1 {
    display: none;
  }
}
.top-introduction__bg.-type-2 {
  order: -1;
  width: 109.2307692308vw;
  margin-bottom: -6.1538461538vw;
}
.top-introduction__bg.-type-3 {
  width: 107.1794871795vw;
  margin-top: -10.2564102564vw;
}

.top-promise {
  margin-bottom: 153px;
}
@media screen and (max-width: 768px) {
  .top-promise {
    margin-bottom: 60px;
  }
}
.top-promise__wrap {
  display: flex;
  justify-content: space-between;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .top-promise__wrap {
    flex-direction: column;
  }
}
.top-promise__item {
  position: relative;
  display: grid;
  width: 576px;
  z-index: 2;
}
@media screen and (max-width: 768px) {
  .top-promise__item {
    display: contents;
  }
}
.top-promise__lead {
  max-width: 510px;
  margin: 38px 0 8px;
  mix-blend-mode: multiply;
}
@media screen and (max-width: 768px) {
  .top-promise__lead {
    position: relative;
    order: 2;
    margin-top: 0;
    z-index: 2;
  }
}
.top-promise__lead img {
  width: 100%;
}
.top-promise__txt {
  margin-bottom: 20px;
  line-height: 2.75;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .top-promise__txt {
    position: relative;
    order: 2;
    line-height: 2;
    z-index: 1;
  }
}
.top-promise__name {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 23px;
  font-size: 18px;
  line-height: 1.6666666667;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .top-promise__name {
    order: 2;
    flex-direction: column;
    align-items: flex-end;
    gap: 16px;
  }
}
.top-promise__name em {
  width: 139px;
}
.top-promise__name em img {
  width: 100%;
}
.top-promise__image {
  position: relative;
  order: -1;
  width: 543px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .top-promise__image {
    order: 1;
    width: 100%;
    margin: 35px auto 27px;
  }
}
.top-promise__image::before, .top-promise__image::after {
  content: "";
  position: absolute;
  background: #FFE4E3;
  opacity: 0.45;
  z-index: -1;
}
.top-promise__image::before {
  width: 219px;
  height: 232px;
  top: calc(100% - 165px);
  left: -90px;
  border-radius: 46px;
}
@media screen and (max-width: 768px) {
  .top-promise__image::before {
    width: 41.7948717949vw;
    height: 44.358974359vw;
    top: 65.641025641vw;
    left: -19.4871794872vw;
  }
}
.top-promise__image::after {
  width: 149px;
  height: 158px;
  top: -45px;
  right: -70px;
  border-radius: 36px;
}
@media screen and (max-width: 768px) {
  .top-promise__image::after {
    width: 28.7179487179vw;
    height: 30vw;
    top: -11.7948717949vw;
    right: -11.5384615385vw;
  }
}
.top-promise__image img {
  width: 100%;
  overflow: hidden;
  border-radius: 56px;
}

.top-business {
  margin-bottom: 132px;
}
@media screen and (max-width: 768px) {
  .top-business {
    margin-bottom: 37px;
  }
}
.top-business__wrap {
  max-width: 2136px;
  margin: 44px auto 0;
  padding: 34px 0;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .top-business__wrap {
    margin-top: 8px;
  }
}
.top-business__arrows {
  margin-top: 60px;
}
@media screen and (max-width: 768px) {
  .top-business__arrows {
    margin-top: 45px;
  }
}
.top-business__arrows .splide__pagination {
  position: inherit;
  bottom: auto;
  left: auto;
  right: auto;
  padding: 0;
}
.top-business__content {
  overflow: visible;
}
.top-business__item {
  display: flex;
  flex-direction: column;
  width: 384px;
}
.top-business__heading {
  margin-bottom: 16px;
  font-size: 26px;
  line-height: 1.4583333333;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .top-business__heading {
    font-size: 24px;
  }
}
.top-business__image {
  position: relative;
  order: -1;
  margin-bottom: 19px;
}
@media screen and (max-width: 768px) {
  .top-business__image {
    margin-bottom: 16px;
  }
}
.top-business__image span {
  display: block;
  overflow: hidden;
  border-radius: 38px;
}
.top-business__image span img {
  width: 100%;
}
.top-business__image i {
  position: absolute;
  width: 85px;
  top: -34px;
  left: 0;
}
@media screen and (max-width: 768px) {
  .top-business__image i {
    width: 72px;
  }
}
.top-business__image i img {
  width: 100%;
}
.top-business__txt {
  margin-bottom: 23px;
  font-size: 20px;
  line-height: 1.8888888889;
}
@media screen and (max-width: 768px) {
  .top-business__txt {
    margin-bottom: 19px;
    font-size: 18px;
  }
}

.top-product {
  margin-bottom: 170px;
}
@media screen and (max-width: 768px) {
  .top-product {
    margin-bottom: 76px;
  }
}
.top-product__wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 41px;
  padding: 105px 70px 53px;
  overflow: hidden;
  border-radius: 46px;
  background: linear-gradient(180deg, #FFF8F2, #FFF0F5);
}
@media screen and (max-width: 768px) {
  .top-product__wrap {
    margin: 34px -2.5641025641vw 0;
    padding: 78px 30px 55px;
  }
}
.top-product__image {
  position: relative;
  min-width: 1464px;
}
@media screen and (max-width: 768px) {
  .top-product__image {
    min-width: 0;
    width: 100%;
    max-width: 350px;
    margin-bottom: max(-9.7435897436vw, -38px);
  }
}
.top-product__image img {
  width: 100%;
}

.top-sdgs {
  margin-bottom: 88px;
}
@media screen and (max-width: 768px) {
  .top-sdgs {
    margin-bottom: 65px;
  }
}
.top-sdgs__wrap {
  max-width: 1110px;
  margin: 42px auto 0;
}
@media screen and (max-width: 768px) {
  .top-sdgs__wrap {
    margin-top: 35px;
  }
}
.top-sdgs__intro {
  margin-bottom: 62px;
}
@media screen and (max-width: 768px) {
  .top-sdgs__intro {
    margin-right: -6.6666666667vw;
    padding: 0 6.6666666667vw 20px 0;
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: #FF44A1 #EFEFEF;
  }
}
@media screen and (max-width: 768px) {
  .top-sdgs__intro::-webkit-scrollbar {
    height: 7px;
  }
}
.top-sdgs__intro::-webkit-scrollbar-thumb {
  background: #FF44A1;
  border-radius: 7px;
}
.top-sdgs__tabs {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-radius: 44px;
  background: #EFEFEF;
}
@media screen and (max-width: 768px) {
  .top-sdgs__tabs {
    display: flex;
    min-width: 695px;
  }
}
.top-sdgs__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 62px;
  font-size: 20px;
  line-height: 1.45;
  font-weight: 500;
  color: #979797;
  border-radius: 44px;
  transition: background 0.3s, color 0.3s;
}
@media screen and (max-width: 768px) {
  .top-sdgs__btn {
    width: 139px;
    font-size: 18px;
    line-height: 1.4444444444;
  }
}
.top-sdgs__btn span {
  min-width: 3em;
  text-align-last: justify;
}
.top-sdgs__btn[aria-selected=true] {
  color: #fff;
  background: #FF44A1;
}
.top-sdgs__item {
  display: none;
}
.top-sdgs__item[aria-hidden=false] {
  display: block;
}
.top-sdgs__rows {
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .top-sdgs__rows {
    margin-bottom: 22px;
  }
}
.top-sdgs__row {
  display: flex;
  justify-content: space-between;
  gap: 30px;
}
@media screen and (max-width: 768px) {
  .top-sdgs__row {
    flex-wrap: wrap;
    gap: 26px;
  }
}
.top-sdgs__row + .top-sdgs__row {
  margin-top: 48px;
}
@media screen and (max-width: 768px) {
  .top-sdgs__row + .top-sdgs__row {
    margin-top: 26px;
  }
}
.top-sdgs__detail {
  flex-grow: 1;
  max-width: 676px;
  margin: auto 0;
}
@media screen and (max-width: 768px) {
  .top-sdgs__detail {
    max-width: 100%;
  }
}
.top-sdgs__heading {
  margin-bottom: 20px;
  font-size: 24px;
  line-height: 1.4545454545;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .top-sdgs__heading {
    font-size: 20px;
    line-height: 1.45;
  }
}
.top-sdgs__txt {
  font-size: 18px;
  line-height: 2.125;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .top-sdgs__txt {
    font-size: 16px;
  }
}
.top-sdgs__image {
  order: -1;
  flex-shrink: 0;
  width: 384px;
}
@media screen and (max-width: 768px) {
  .top-sdgs__image {
    width: 100%;
  }
}
.top-sdgs__image img {
  width: 100%;
  overflow: hidden;
  border-radius: 38px;
}

.top-news {
  padding: 81px 0 76px;
  background: rgba(253, 246, 237, 0.6);
}
@media screen and (max-width: 768px) {
  .top-news {
    padding: 43px 0 71px;
  }
}
.top-news__items {
  margin: 41px 0 33px;
  padding: 3px 50px 2px;
  border-radius: 27px;
  background: #fff;
}
@media screen and (max-width: 768px) {
  .top-news__items {
    margin-bottom: 29px;
    padding: 0 8.7179487179vw;
  }
}
.top-news__item a {
  display: flex;
  align-items: center;
  gap: 28px;
  min-height: 77px;
  font-size: 16px;
  line-height: 2.125;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .top-news__item a {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    min-height: 0;
    padding: 30px 0 26px;
  }
}
.top-news__item + .top-news__item {
  border-top: 1px solid #C1C6D0;
}
.top-news__heading {
  flex-grow: 1;
}
@media screen and (max-width: 768px) {
  .top-news__heading {
    line-height: 1.5;
  }
}
.top-news__detail {
  display: flex;
  order: -1;
  flex-shrink: 0;
  gap: 23px;
}
@media screen and (max-width: 768px) {
  .top-news__detail {
    line-height: 1;
  }
}
.top-news__date {
  min-width: 90px;
  letter-spacing: 0.05em;
}
.top-news__categories {
  color: #FF44A1;
}
.top-news__categories li::before {
  content: "#";
}

.top-recruit {
  position: relative;
  min-height: 592px;
  margin-bottom: 85px;
  padding-top: 158px;
}
@media screen and (max-width: 768px) {
  .top-recruit {
    min-height: 0;
    margin-bottom: 54px;
    padding-top: 52px;
  }
}
@media screen and (max-width: 768px) {
  .top-recruit__wrap {
    padding: 0 1.0256410256vw 65px;
  }
}
.top-recruit__txt {
  max-width: 466px;
  margin: 32px 0 23px;
  line-height: 2.125;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .top-recruit__txt {
    margin: clamp(26px, 8.2051282051vw, 32px) 0 280px;
    font-size: 16px;
  }
}
.top-recruit__bg {
  z-index: -1;
}
.top-recruit__bg img {
  width: 100%;
}
.top-recruit__bg.-type-1 {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.top-recruit__bg.-type-1 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.top-recruit__bg.-type-2 {
  display: none;
}
@media screen and (max-width: 768px) {
  .top-recruit__bg.-type-2 {
    position: absolute;
    display: block;
    width: 100%;
    bottom: 0;
    left: 0;
  }
}

.top-foot {
  position: relative;
  padding-bottom: 109px;
}
@media screen and (max-width: 768px) {
  .top-foot {
    padding-bottom: 79px;
  }
}
.top-foot::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 578px;
  bottom: 0;
  left: 0;
  background: linear-gradient(180deg, rgba(255, 240, 234, 0) 0%, #FFF0EA 50%, #FFF0EA 100%);
  z-index: -1;
}
.top-foot__item + .top-foot__item {
  margin-top: 96px;
}
@media screen and (max-width: 768px) {
  .top-foot__item + .top-foot__item {
    margin-top: 71px;
  }
}
.top-foot__links {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(245px, 270px));
  justify-content: center;
  gap: 15px;
  margin-top: 42px;
}
@media screen and (max-width: 768px) {
  .top-foot__links {
    grid-template-columns: repeat(2, 1fr);
    gap: 2.5641025641vw;
    margin: 28px -3.3333333333vw 0;
  }
}
.top-foot__link a {
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 122px;
  padding: 17px;
  border: 3px solid #fff;
  border-radius: 40px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  background: #fff;
  transition: border-color 0.3s;
}
@media screen and (max-width: 768px) {
  .top-foot__link a {
    gap: 1.0256410256vw;
    min-height: 79px;
    padding: 0 3.0769230769vw;
  }
}
.top-foot__link a:hover {
  opacity: 1;
  border-color: #FF44A1;
}
.top-foot__link a:hover i {
  background: none;
}
.top-foot__link a:hover i::before {
  opacity: 1;
}
.top-foot__icon {
  flex-shrink: 0;
  width: 80px;
}
@media screen and (max-width: 768px) {
  .top-foot__icon {
    width: 52px;
  }
}
.top-foot__icon img {
  width: 100%;
}
.top-foot__heading {
  position: relative;
  display: flex;
  flex-grow: 1;
  align-items: center;
  min-height: 52px;
  padding-right: 25px;
  font-size: 16px;
  line-height: 1.625;
  font-weight: bold;
  color: #FF44A1;
}
@media screen and (max-width: 768px) {
  .top-foot__heading {
    padding-right: 10px;
    font-size: 13px;
    line-height: 1.6153846154;
  }
}
.top-foot__heading i {
  right: 8px;
}
@media screen and (max-width: 768px) {
  .top-foot__heading i {
    width: 9px;
    right: 0;
  }
}

.top-sns {
  padding: 78px 53px 49px;
  overflow: hidden;
  border-radius: 27px;
  background: linear-gradient(180deg, #FFF8F8, #FFCED9);
}
@media screen and (max-width: 768px) {
  .top-sns {
    margin: 0 -2.5641025641vw;
    padding: 54px 8.4615384615vw 16px;
    border-radius: 40px;
  }
}
.top-sns__intro {
  position: relative;
  display: grid;
  gap: 31px;
  width: 100%;
  max-width: 914px;
  margin: 0 auto 32px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .top-sns__intro {
    display: flex;
    flex-direction: column;
    margin-bottom: -125px;
  }
}
.top-sns__txt {
  max-width: 418px;
  line-height: 2.125;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .top-sns__txt {
    font-size: 16px;
  }
}
.top-sns__image {
  position: absolute;
  width: 543px;
  top: -76px;
  right: -13px;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .top-sns__image {
    position: inherit;
    top: auto;
    right: auto;
    width: 89.7435897436vw;
    max-width: 350px;
    margin: -40px auto 0;
    transform: translateX(-15px);
  }
}
.top-sns__image img {
  width: 100%;
}
.top-sns__items {
  position: relative;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(246px, 1fr));
  gap: 12px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .top-sns__items {
    grid-template-columns: repeat(2, 1fr);
    gap: 2.5641025641vw 2.0512820513vw;
    margin: 0 -5.1282051282vw;
  }
}
.top-sns__item a {
  display: flex;
  align-items: center;
  gap: 22px;
  padding: 10px 15px;
  border: 3px solid #fff;
  border-radius: 40px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  background: #fff;
  transition: border-color 0.3s;
}
@media screen and (max-width: 768px) {
  .top-sns__item a {
    gap: 1.2820512821vw;
    padding: 12px 2.5641025641vw;
  }
}
.top-sns__item a:hover {
  opacity: 1;
  border-color: #FF44A1;
}
.top-sns__item a:hover i {
  background: none;
}
.top-sns__item a:hover i::before {
  opacity: 1;
}
.top-sns__icon {
  flex-shrink: 0;
  width: 50px;
}
@media screen and (max-width: 768px) {
  .top-sns__icon {
    width: 9.7435897436vw;
    max-width: 50px;
  }
}
.top-sns__icon img {
  width: 100%;
}
.top-sns__heading {
  position: relative;
  display: flex;
  flex-grow: 1;
  justify-content: space-between;
  align-items: center;
  font-size: 16px;
  line-height: 2.125;
  font-weight: bold;
  color: #FF44A1;
}
@media screen and (max-width: 768px) {
  .top-sns__heading {
    font-size: min(3.75vw, 15px);
    line-height: 2.2666666667;
  }
}
.top-sns__heading i {
  right: 8px;
}
@media screen and (max-width: 768px) {
  .top-sns__heading i {
    right: 0;
  }
}

.page-mv {
  position: relative;
  margin-bottom: 10px;
  overflow: hidden;
  border-radius: 56px;
}
@media screen and (max-width: 768px) {
  .page-mv {
    margin: 0 -3.0769230769vw 6px;
    border-radius: 24px;
  }
}
.page-mv__item {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 610px;
  max-width: 46%;
  height: 100%;
  top: 0;
  left: 0;
  background: linear-gradient(180deg, #FFF2F5, #FFF4E8);
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .page-mv__item {
    width: 43.5897435897vw;
    min-width: 170px;
    max-width: 48%;
  }
}
.page-mv__head {
  position: relative;
  font-size: 40px;
  line-height: 1.4;
  font-weight: bold;
  font-family: "Zen Maru Gothic", YuGothic, "Yu Gothic", Hiragino Sans, Hiragino Kaku Gothic ProN, Meiryo, Osaka, sans-serif;
  letter-spacing: 0.3em;
  text-indent: 0.3em;
  text-align: center;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .page-mv__head {
    font-size: 22px;
  }
}
.page-mv__head.-narrow {
  letter-spacing: 0;
  text-indent: 0;
}
.page-mv__head.-left {
  text-align: left;
  text-indent: 0;
}
.page-mv__bg {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.page-mv__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-mv__image {
  position: relative;
}
.page-mv__image figcaption {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 46%;
  min-height: 43px;
  bottom: 19px;
  right: 34px;
  padding: 0 21px;
  font-size: 14px;
  line-height: 1.4285714286;
  font-weight: 500;
  color: #000;
  border-radius: 23px;
  background: rgba(255, 255, 255, 0.8);
}
@media screen and (max-width: 768px) {
  .page-mv__image figcaption {
    width: 1px;
    height: 1px;
    bottom: auto;
    right: auto;
    overflow: hidden;
    padding: 0;
    background: none;
  }
}
.page-mv__mv {
  display: block;
  height: 330px;
}
@media screen and (max-width: 768px) {
  .page-mv__mv {
    height: 189px;
  }
}
.page-mv__mv img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (max-width: 768px) {
  .page-mv__mv img {
    object-position: 88% 12%;
  }
}

.company-intro {
  margin-bottom: 132px;
  padding-top: 32px;
}
@media screen and (max-width: 768px) {
  .company-intro {
    margin-bottom: 88px;
    padding-top: 42px;
  }
}
.company-intro__wrap {
  position: relative;
  min-height: 664px;
  padding: 48px 0 58px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .company-intro__wrap {
    min-height: 0;
    padding: 0;
  }
}
.company-intro__head {
  max-width: 600px;
  margin: 0 auto 17px;
}
@media screen and (max-width: 768px) {
  .company-intro__head {
    margin-bottom: 14px;
  }
}
.company-intro__head img {
  width: 100%;
}
.company-intro__content {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.company-intro__txt {
  line-height: 2.4444444444;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .company-intro__txt {
    margin: -3.8461538462vw 0 -1.0256410256vw;
    word-break: auto-phrase;
    line-height: 2.2222222222;
  }
}
.company-intro__bg {
  display: none;
}
@media screen and (max-width: 768px) {
  .company-intro__bg {
    display: block;
  }
}
.company-intro__bg img {
  width: 100%;
}
.company-intro__bg.-type-1 {
  position: absolute;
  display: block;
  width: 1260px;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .company-intro__bg.-type-1 {
    display: none;
  }
}
.company-intro__bg.-type-2 {
  order: -1;
  width: 109.2307692308vw;
}
.company-intro__bg.-type-3 {
  width: 107.1794871795vw;
}

.company {
  margin-bottom: 142px;
}
@media screen and (max-width: 768px) {
  .company {
    margin-bottom: 116px;
  }
}
.company__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 50px;
  max-width: 1228px;
  margin-left: auto;
}
@media screen and (max-width: 768px) {
  .company__row {
    display: grid;
    gap: 0;
    padding: 0 3.0769230769vw;
  }
}
.company__row + .company__row {
  margin-top: 96px;
}
@media screen and (max-width: 768px) {
  .company__row + .company__row {
    margin-top: 84px;
  }
}
.company__row.-reverse {
  margin-left: 0;
}
.company__item {
  flex-grow: 1;
  max-width: 530px;
}
@media screen and (max-width: 768px) {
  .company__item {
    display: contents;
  }
}
.-reverse > .company__item {
  max-width: 502px;
}
.company__txt {
  margin: 48px 0 23px;
  font-size: min(1.8205461638vw, 18px);
}
@media screen and (max-width: 768px) {
  .company__txt {
    margin: 0 0 14px;
    font-size: 16px;
    line-height: 2.125;
  }
}
.company__image {
  position: relative;
  width: 640px;
}
@media screen and (max-width: 768px) {
  .company__image {
    order: -1;
    width: 86.6666666667vw;
    margin: 24px -3.0769230769vw 17px;
  }
}
.company__image::before, .company__image::after {
  content: "";
  position: absolute;
  aspect-ratio: 1;
  background: #FFE4E3;
  opacity: 0.45;
  z-index: -1;
}
.company__image::before {
  width: 190px;
  top: calc(100% - 113px);
  right: -78px;
  border-radius: 40px;
}
@media screen and (max-width: 768px) {
  .company__image::before {
    width: 41.7948717949vw;
    height: 44.358974359vw;
    top: 25.641025641vw;
    right: -20vw;
  }
}
.company__image::after {
  width: 122px;
  top: -43px;
  left: -47px;
  border-radius: 30px;
}
@media screen and (max-width: 768px) {
  .company__image::after {
    width: 25.3846153846vw;
    height: 26.4102564103vw;
    top: -6.1538461538vw;
    left: -9.7435897436vw;
  }
}
.company__image img {
  width: 100%;
  overflow: hidden;
  border-radius: 56px;
}
@media screen and (max-width: 768px) {
  .company__image img {
    border-radius: 38px;
  }
}
.company__image figcaption {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 200px;
  height: 43px;
  right: 33px;
  bottom: 28px;
  font-size: 14px;
  line-height: 1.4285714286;
  font-weight: 500;
  color: #000;
  border-radius: 23px;
  background: rgba(255, 255, 255, 0.8);
}
@media screen and (max-width: 768px) {
  .company__image figcaption {
    width: 1px;
    height: 1px;
    overflow: hidden;
    background: none;
  }
}
.-reverse > .company__image {
  order: -1;
}
.-reverse > .company__image::before {
  right: auto;
  left: -88px;
}
@media screen and (max-width: 768px) {
  .-reverse > .company__image::before {
    top: 23.5897435897vw;
    left: -19.4871794872vw;
  }
}
.-reverse > .company__image::after {
  left: auto;
  right: -45px;
}
@media screen and (max-width: 768px) {
  .-reverse > .company__image::after::after {
    top: -8.9743589744vw;
    right: -10.7692307692vw;
  }
}
.-reverse > .company__image figcaption {
  right: auto;
  left: 33px;
}

.page-nav {
  position: relative;
  padding-bottom: 101px;
}
@media screen and (max-width: 768px) {
  .page-nav {
    padding-bottom: 90px;
  }
}
.page-nav:not(.-bg-none)::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 432px;
  bottom: 0;
  left: 0;
  background: linear-gradient(180deg, rgba(255, 240, 234, 0) 0%, #FFF0EA 50%, #FFF0EA 100%);
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .page-nav:not(.-bg-none)::before {
    height: 100%;
  }
}
.page-nav__columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(4.0118870728vw, 54px);
}
@media screen and (max-width: 768px) {
  .page-nav__columns {
    grid-template-columns: 1fr;
    gap: 52px;
  }
}
.page-nav__column {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  gap: 0;
}
@media screen and (max-width: 768px) {
  .page-nav__column {
    grid-template-rows: inherit;
  }
}
.page-nav__heading {
  margin-bottom: 16px;
  font-size: 24px;
  line-height: 1.4583333333;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .page-nav__heading {
    padding: 0 5px;
    font-size: 20px;
    line-height: 1.45;
  }
}
.page-nav__image {
  position: relative;
  order: -1;
  margin-bottom: 18px;
  overflow: hidden;
  border-radius: 38px;
}
.page-nav__image img {
  width: 100%;
}
.page-nav__image figcaption {
  position: absolute;
  display: flex;
  align-items: center;
  bottom: 21px;
  left: 24px;
  min-height: 43px;
  padding: 8px 20px;
  font-size: 14px;
  line-height: 1.4285714286;
  color: #000;
  border-radius: 43px;
  background: rgba(255, 255, 255, 0.8);
}
@media screen and (max-width: 768px) {
  .page-nav__image figcaption {
    bottom: 11px;
    left: 16px;
  }
}
.page-nav__txt {
  margin-bottom: 12px;
  font-size: min(1.8205461638vw, 18px);
  line-height: 1.8888888889;
}
@media screen and (max-width: 768px) {
  .page-nav__txt {
    margin-bottom: 5px;
    font-size: 16px;
    line-height: 2.125;
  }
}

.greeting {
  margin-top: 80px;
}
@media screen and (max-width: 768px) {
  .greeting {
    margin-top: 40px;
  }
}
.greeting + .greeting {
  margin-top: 124px;
}
@media screen and (max-width: 768px) {
  .greeting + .greeting {
    margin-top: 80px;
  }
}
.greeting__intro {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 50px;
  margin-bottom: 113px;
}
@media screen and (max-width: 768px) {
  .greeting__intro {
    flex-direction: column;
    gap: 0;
    margin-bottom: 50px;
  }
}
.greeting__item {
  flex-grow: 1;
  max-width: 688px;
}
@media screen and (max-width: 768px) {
  .greeting__item {
    display: contents;
  }
}
.greeting__head {
  max-width: 670px;
  margin-bottom: 17px;
  mix-blend-mode: multiply;
}
@media screen and (max-width: 768px) {
  .greeting__head {
    order: -1;
    margin: 0 auto 30px;
  }
}
.-ceo > .greeting__head {
  max-width: 510px;
}
@media screen and (max-width: 768px) {
  .-ceo > .greeting__head {
    position: relative;
    margin-bottom: 20px;
    z-index: 2;
  }
}
.greeting__head img {
  width: 100%;
}
.greeting__txt {
  margin-bottom: 48px;
  line-height: 2.4444444444;
}
@media screen and (max-width: 768px) {
  .greeting__txt {
    margin-bottom: 14px;
    font-size: 16px;
    line-height: 2.125;
  }
}
.greeting__person {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 23px;
  font-size: 18px;
  line-height: 1.6666666667;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .greeting__person {
    flex-direction: column;
    align-items: flex-end;
    gap: 5px;
    margin-left: auto;
    font-size: 15px;
    line-height: 1.6;
  }
}
.greeting__person em {
  width: 179px;
}
@media screen and (max-width: 768px) {
  .greeting__person em {
    width: 139px;
  }
}
.greeting__person em img {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .-ceo > .greeting__person {
    gap: 10px;
  }
}
.-ceo > .greeting__person em {
  width: 139px;
}
.greeting__image {
  position: relative;
  order: -1;
  flex-shrink: 0;
  width: 496px;
  max-width: 44%;
  overflow: hidden;
  border-radius: 56px;
}
@media screen and (max-width: 768px) {
  .greeting__image {
    width: 100%;
    max-width: 496px;
    margin: 0 auto 34px;
  }
}
.greeting__image img {
  width: 100%;
}
.greeting__image figcaption {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 200px;
  height: 43px;
  bottom: 28px;
  left: 33px;
  font-size: 14px;
  line-height: 1.4285714286;
  font-weight: 500;
  border-radius: 23px;
  background: rgba(255, 255, 255, 0.8);
}
@media screen and (max-width: 768px) {
  .greeting__image figcaption {
    width: 1px;
    height: 1px;
    bottom: auto;
    left: auto;
    overflow: hidden;
    background: none;
  }
}
.greeting__wrap {
  position: relative;
  padding: 97px 0 92px;
}
@media screen and (max-width: 768px) {
  .greeting__wrap {
    padding: 50px 0 52px;
  }
}
.greeting__bg {
  position: absolute;
  width: 100vw;
  height: 100%;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.greeting__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.greeting-profile__head {
  margin-bottom: 32px;
  font-size: 26px;
  line-height: 1.4230769231;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .greeting-profile__head {
    margin-bottom: 21px;
    font-size: 24px;
    line-height: 1.4166666667;
  }
}
.greeting-profile__txt {
  font-size: min(1.8205461638vw, 18px);
  line-height: 2.2222222222;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .greeting-profile__txt {
    font-size: 16px;
    line-height: 2.125;
    text-align: left;
  }
}
.greeting-profile__history {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 1020px;
  margin: 32px auto 0;
  padding: 23px 20px;
  border-radius: 43px;
  background: #fff;
}
@media screen and (max-width: 768px) {
  .greeting-profile__history {
    margin-top: 26px;
    padding: 27px 7.6923076923vw;
  }
}
.greeting-profile__history dt {
  width: 3em;
  margin: 0 auto 13px;
  font-size: 20px;
  line-height: 1.45;
  font-weight: bold;
  text-align-last: justify;
}
@media screen and (max-width: 768px) {
  .greeting-profile__history dt {
    margin-bottom: 19px;
  }
}
.greeting-profile__history dd {
  width: 100%;
  max-width: 885px;
  margin: 0 auto;
}
.greeting-profile__list {
  display: grid;
  grid-template-columns: repeat(auto-fit, min(100%, 285px));
  justify-content: center;
  column-gap: 1em;
  font-size: 15px;
  line-height: 2.2666666667;
}
@media screen and (max-width: 768px) {
  .greeting-profile__list {
    line-height: 2;
  }
}
.greeting-profile__list li {
  position: relative;
  padding-left: 1em;
}
.greeting-profile__list li::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}

.greeting-sns {
  max-width: 1020px;
  margin: 58px auto 0;
}
.greeting-sns__head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 23px;
  font-size: 24px;
  line-height: 1.4583333333;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .greeting-sns__head {
    gap: 4px;
    margin-bottom: 15px;
    word-break: auto-phrase;
    font-size: 20px;
    line-height: 1.45;
  }
}
.greeting-sns__head::before, .greeting-sns__head::after {
  content: "";
  flex-grow: 1;
  height: 1px;
  background: #FF44A1;
}
.greeting-sns__items {
  position: relative;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(246px, 1fr));
  gap: 12px;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .greeting-sns__items {
    grid-template-columns: repeat(2, 1fr);
    gap: 2.5641025641vw 2.0512820513vw;
    width: 85.1282051282vw;
    margin: 0 auto;
  }
}
.greeting-sns__item a {
  display: flex;
  align-items: center;
  gap: 22px;
  padding: 10px 15px;
  border: 3px solid #fff;
  border-radius: 40px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  background: #fff;
  transition: border-color 0.3s;
}
@media screen and (max-width: 768px) {
  .greeting-sns__item a {
    gap: 1.2820512821vw;
    padding: 12px 2.5641025641vw;
  }
}
.greeting-sns__item a:hover {
  opacity: 1;
  border-color: #FF44A1;
}
.greeting-sns__item a:hover i {
  background: none;
}
.greeting-sns__item a:hover i::before {
  opacity: 1;
}
.greeting-sns__icon {
  flex-shrink: 0;
  width: 50px;
}
@media screen and (max-width: 768px) {
  .greeting-sns__icon {
    width: 9.7435897436vw;
  }
}
.greeting-sns__icon img {
  width: 100%;
}
.greeting-sns__heading {
  position: relative;
  display: flex;
  flex-grow: 1;
  justify-content: space-between;
  align-items: center;
  font-size: 16px;
  line-height: 2.125;
  font-weight: bold;
  color: #FF44A1;
}
@media screen and (max-width: 768px) {
  .greeting-sns__heading {
    font-size: 15px;
    line-height: 2.2666666667;
  }
}
.greeting-sns__heading i {
  right: 8px;
}
@media screen and (max-width: 768px) {
  .greeting-sns__heading i {
    right: 0;
  }
}

.news {
  margin-top: min(6.2418725618vw, 85px);
  padding-bottom: 135px;
}
@media screen and (max-width: 768px) {
  .news {
    margin-top: 48px;
    padding-bottom: 85px;
  }
}
.news__columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px min(3.9011703511vw, 54px);
  max-width: 1260px;
  margin: 0 auto 63px;
}
@media screen and (max-width: 768px) {
  .news__columns {
    grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
    gap: 20px;
    margin-bottom: 61px;
  }
}
.news__column a {
  display: flex;
  flex-direction: column;
}
.news__heading {
  order: 1;
  line-height: 1.8888888889;
}
@media screen and (max-width: 768px) {
  .news__heading {
    line-height: 2.1111111111;
  }
}
.news__detail {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  margin-bottom: 21px;
}
@media screen and (max-width: 768px) {
  .news__detail {
    margin-bottom: 16px;
  }
}
.news__date {
  font-size: 18px;
  line-height: 1.4444444444;
  font-weight: bold;
}
.news__data dd {
  display: flex;
  justify-content: center;
  align-content: center;
  padding: 0 10px;
  font-size: 15px;
  line-height: 1.7333333333;
  color: #fff;
  border-radius: 13px;
  background: #FF44A1;
}
.news__data dd::before {
  content: "#";
}
.news__image {
  aspect-ratio: 2/1;
  margin-bottom: 20px;
  overflow: hidden;
  border-radius: 38px;
}
.news__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-category {
  max-width: 1110px;
  margin: 0 auto min(7.5422626788vw, 114px);
}
@media screen and (max-width: 768px) {
  .news-category {
    margin: 0 -6.6666666667vw 58px 0;
    padding: 0 6.6666666667vw 20px 0;
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: #FF44A1 #EFEFEF;
  }
}
@media screen and (max-width: 768px) {
  .news-category::-webkit-scrollbar {
    height: 7px;
  }
}
.news-category::-webkit-scrollbar-thumb {
  background: #FF44A1;
  border-radius: 7px;
}
.news-category__items {
  --_width-SP: 157px;
  display: grid;
  grid-template-columns: repeat(var(--_count, 5), 1fr);
  border-radius: 44px;
  background: #EFEFEF;
}
@media screen and (max-width: 768px) {
  .news-category__items {
    display: flex;
    min-width: calc(var(--_width-SP, 157px) * var(--_count, 5));
  }
}
@media screen and (max-width: 768px) {
  .news-category__item {
    flex-shrink: 0;
    width: var(--_width-SP, 157px);
  }
}
.news-category__item a {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 62px;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 500;
  color: #979797;
  border-radius: 44px;
}
@media screen and (max-width: 768px) {
  .news-category__item a {
    font-size: 18px;
    line-height: 1.4444444444;
  }
}
.news-category__item a[aria-current] {
  color: #fff;
  background: #FF44A1;
}

.news-detail {
  margin-top: 90px;
  padding-bottom: 128px;
}
@media screen and (max-width: 768px) {
  .news-detail {
    margin-top: 38px;
    padding-bottom: 68px;
  }
}
.news-detail__intro {
  display: grid;
  gap: 38px;
  max-width: 1110px;
  margin: 0 auto 21px;
}
@media screen and (max-width: 768px) {
  .news-detail__intro {
    gap: 21px;
    margin-bottom: 28px;
  }
}
.news-detail__head {
  order: 1;
  position: relative;
  padding-left: 20px;
  font-size: 24px;
  line-height: 1.8333333333;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .news-detail__head {
    padding-left: 15px;
    font-size: 22px;
    line-height: 1.8181818182;
  }
}
.news-detail__head::before {
  content: "";
  position: absolute;
  width: 4px;
  height: calc(100% - 14px);
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  border-radius: 4px;
  background: #FF44A1;
}
.news-detail__detail {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  font-weight: bold;
}
.news-detail__date {
  font-size: 22px;
  line-height: 1.5;
}
.news-detail__categoroies {
  display: flex;
  flex-wrap: wrap;
}
.news-detail__category a {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 33px;
  padding: 0 13px;
  font-size: 18px;
  line-height: 1.4444444444;
  color: #fff;
  border-radius: 33px;
  background: #FF44A1;
}
.news-detail__category a::before {
  content: "#";
}
.news-detail__wrap {
  max-width: 1110px;
  margin: 0 auto;
}
.news-detail__foot {
  display: grid;
  grid-template-columns: repeat(auto-fit, 259px);
  justify-content: center;
  gap: 22px;
  margin-top: 24px;
}
@media screen and (max-width: 768px) {
  .news-detail__foot {
    gap: 20px;
  }
}

.privacy {
  margin-top: 84px;
  padding-bottom: 151px;
}
@media screen and (max-width: 768px) {
  .privacy {
    margin-top: 47px;
    padding-bottom: 90px;
  }
}
.privacy__lead {
  margin-bottom: 44px;
  font-size: 28px;
  line-height: 2;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .privacy__lead {
    margin-bottom: 35px;
    white-space: nowrap;
    font-size: min(6.1538461538vw, 24px);
    line-height: 1.5;
  }
}
.privacy__item {
  margin-bottom: 49px;
  font-size: 16px;
  line-height: 2.125;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .privacy__item {
    margin-bottom: 18px;
    font-size: 18px;
    line-height: 2.1111111111;
  }
}
.privacy__intro {
  margin-bottom: 34px;
}
@media screen and (max-width: 768px) {
  .privacy__intro {
    margin-bottom: 38px;
  }
}
.privacy__intro dt {
  font-weight: 500;
}
.privacy__row + .privacy__row {
  margin-top: 34px;
}
@media screen and (max-width: 768px) {
  .privacy__row + .privacy__row {
    margin-top: 38px;
  }
}
.privacy__row > *:nth-child(n+3) {
  margin-top: 34px;
}
@media screen and (max-width: 768px) {
  .privacy__row > *:nth-child(n+3) {
    margin-top: 38px;
  }
}
.privacy__heading {
  font-weight: bold;
}
.privacy__heading::before {
  content: "■";
}
.privacy__desc:not(:first-child) {
  margin-top: 68px;
}
@media screen and (max-width: 768px) {
  .privacy__desc:not(:first-child) {
    margin-top: 38px;
  }
}

.privacy-contact__head {
  display: flex;
  justify-content: center;
  margin-bottom: 15px;
  font-size: 24px;
  line-height: 1.4583333333;
}
@media screen and (max-width: 768px) {
  .privacy-contact__head {
    margin-bottom: 20px;
  }
}
.privacy-contact__wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 26px;
  font-weight: 500;
  border-radius: 38px;
  background: linear-gradient(180deg, #FFEFF0, #FFFBED);
}
@media screen and (max-width: 768px) {
  .privacy-contact__wrap {
    padding: 31px 1.5384615385vw 40px;
  }
}
.privacy-contact__heading {
  margin-bottom: 22px;
  font-size: 24px;
  line-height: 1.4583333333;
}
@media screen and (max-width: 768px) {
  .privacy-contact__heading {
    margin-bottom: 11px;
  }
}
.privacy-contact__txt {
  line-height: 1.8888888889;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .privacy-contact__txt {
    margin-bottom: 10px;
    font-size: 16px;
    line-height: 1.5;
  }
}
.privacy-contact__tel {
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .privacy-contact__tel {
    gap: 8px;
  }
}
.privacy-contact__tel a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 19px;
  font-size: 46px;
  line-height: 1.4347826087;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .privacy-contact__tel a {
    gap: 11px;
    font-size: min(7.1794871795vw, 28px);
    line-height: 1.4285714286;
  }
}
.privacy-contact__tel a i {
  display: flex;
  width: 66px;
}
@media screen and (max-width: 768px) {
  .privacy-contact__tel a i {
    width: 40px;
  }
}
.privacy-contact__tel a i svg {
  width: 100%;
}
.privacy-contact__tel small {
  font-size: 18px;
  line-height: 1.4444444444;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .privacy-contact__tel small {
    font-size: 16px;
    line-height: 1.5;
  }
}

.vision {
  margin-top: 48px;
}
.vision + .vision {
  margin-top: 126px;
}
@media screen and (max-width: 768px) {
  .vision + .vision {
    margin-top: 42px;
  }
}
.vision__intro {
  display: grid;
  justify-content: center;
  gap: 45px;
}
@media screen and (max-width: 768px) {
  .vision__intro {
    gap: 34px;
  }
}
.vision__lead {
  font-size: 32px;
  line-height: 1.75;
  font-weight: 500;
  color: #FF44A1;
  font-family: "Zen Maru Gothic", YuGothic, "Yu Gothic", Hiragino Sans, Hiragino Kaku Gothic ProN, Meiryo, Osaka, sans-serif;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .vision__lead {
    font-size: 26px;
    line-height: 1.5384615385;
  }
}
.vision__wrap {
  position: relative;
  margin-top: 34px;
  min-height: 514px;
}
@media screen and (max-width: 768px) {
  .vision__wrap {
    width: 84.6153846154vw;
    margin: 33px auto;
  }
}
.vision__txt {
  line-height: 2.4444444444;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .vision__txt {
    font-size: 16px;
    line-height: 2.125;
    text-align: left;
  }
}
.vision__image {
  position: absolute;
  width: 1034px;
  top: 6px;
  left: 48.2%;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  .vision__image {
    position: inherit;
    display: flex;
    justify-content: center;
    width: 89.7435897436vw;
    top: auto;
    left: auto;
    transform: none;
    margin: 12px -2.5641025641vw 24px;
  }
}
.vision__image img {
  width: 100%;
}
.vision__pic {
  display: flex;
  justify-content: center;
  margin: 36px calc(50% - 50vw) 0;
}
@media screen and (max-width: 768px) {
  .vision__pic {
    margin-top: 14px;
  }
}
.vision__pic img {
  width: 100%;
  min-width: 1670px;
}
@media screen and (max-width: 768px) {
  .vision__pic img {
    min-width: 107.6923076923vw;
  }
}

.about {
  margin-top: 47px;
}
.about + .about {
  margin-top: 95px;
}
@media screen and (max-width: 768px) {
  .about + .about {
    margin-top: 78px;
  }
}
.about:last-child {
  padding-bottom: 130px;
}
@media screen and (max-width: 768px) {
  .about:last-child {
    padding-bottom: 74px;
  }
}
.about__table {
  width: 100%;
  max-width: 900px;
  margin: 54px auto 0;
  font-weight: 500;
  border-top: 1px solid #C1C6D0;
}
@media screen and (max-width: 768px) {
  .about__table {
    width: 84.1025641026vw;
    margin-top: 37px;
    font-size: 16px;
    line-height: 2.125;
  }
}
.about__table th, .about__table td {
  padding: 23px 0 14px;
  vertical-align: middle;
  border-bottom: 1px solid #C1C6D0;
}
.about__table th {
  padding-right: 12%;
  text-align: right;
}
@media screen and (max-width: 768px) {
  .about__table th {
    width: 23.0769230769vw;
    min-width: 90px;
    padding: 23px 0 14px min(2.0512820513vw, 8px);
    text-align: left;
  }
}
.about__table th span {
  display: inline-block;
  min-width: 4em;
  text-align: left;
}
.about__table td {
  width: 55.55%;
}
@media screen and (max-width: 768px) {
  .about__table td {
    width: auto;
  }
}
.about__items {
  display: grid;
  width: fit-content;
}
.about__item {
  display: grid;
  grid-template-columns: subgrid;
  grid-column: span 2;
  gap: 1em;
}
.about__columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(285px, 100%), 1fr));
  gap: 67px min(4.9414824447vw, 54px);
  margin-top: 55px;
}
@media screen and (max-width: 768px) {
  .about__columns {
    grid-template-columns: repeat(auto-fit, minmax(min(250px, 100%), 1fr));
    row-gap: 50px;
    margin-top: 38px;
  }
}
.about__column {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.about__heading {
  margin-bottom: 16px;
  font-size: 24px;
  line-height: 1.4583333333;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .about__heading {
    margin-bottom: 14px;
  }
}
.about__txt {
  margin-bottom: 20px;
  line-height: 1.8888888889;
}
@media screen and (max-width: 768px) {
  .about__txt {
    margin-bottom: 13px;
  }
}
.about__image {
  order: -1;
  margin-bottom: 17px;
  overflow: hidden;
  border-radius: 38px;
}
@media screen and (max-width: 768px) {
  .about__image {
    margin-bottom: 14px;
  }
}
.about__image img {
  width: 100%;
}
.about__map {
  margin-top: auto;
}

.award {
  margin-top: 52px;
  padding-bottom: 98px;
}
@media screen and (max-width: 768px) {
  .award {
    margin-top: 47px;
    padding-bottom: 60px;
  }
}
.award__wrap {
  margin-top: 57px;
}
@media screen and (max-width: 768px) {
  .award__wrap {
    margin-top: 44px;
  }
}
@media screen and (max-width: 768px) {
  .award__intro {
    margin-right: -6.6666666667vw;
    padding: 0 6.6666666667vw 20px 0;
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: #FF44A1 #EFEFEF;
  }
}
@media screen and (max-width: 768px) {
  .award__intro::-webkit-scrollbar {
    height: 7px;
  }
}
.award__intro::-webkit-scrollbar-thumb {
  background: #FF44A1;
  border-radius: 7px;
}
.award__tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-radius: 99px;
  background: #EFEFEF;
}
@media screen and (max-width: 768px) {
  .award__tabs {
    min-width: 927px;
  }
}
.award__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 98px;
  font-size: 22px;
  line-height: 1.4545454545;
  font-weight: 500;
  color: #979797;
  text-align: center;
  border-radius: 99px;
  transition: background 0.3s, color 0.3s;
}
@media screen and (max-width: 768px) {
  .award__btn {
    height: 62px;
    font-size: 18px;
    line-height: 1.4444444444;
  }
}
.award__btn span {
  min-width: 3em;
  text-align-last: justify;
}
.award__btn[aria-selected=true] {
  color: #fff;
  background: #FF44A1;
}
.award__items {
  margin-top: 76px;
}
@media screen and (max-width: 768px) {
  .award__items {
    margin-top: 44px;
  }
}
.award__item {
  display: none;
}
.award__item[aria-hidden=false] {
  display: block;
}
.award__row {
  display: grid;
  gap: 24px;
}
@media screen and (max-width: 768px) {
  .award__row {
    gap: 0;
  }
}
.award__row + .award__row {
  margin-top: 62px;
  padding-top: 55px;
  border-top: 1px solid #C1C6D0;
}
@media screen and (max-width: 768px) {
  .award__row + .award__row {
    margin-top: 41px;
    padding-top: 41px;
  }
}
@media screen and (max-width: 768px) {
  .award__txt {
    font-size: 18px;
    line-height: 2;
    margin: 31px 0 14px;
  }
}
.award__images {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 27px min(5.2015604681vw, 59px);
  max-width: 1059px;
}
@media screen and (max-width: 768px) {
  .award__images {
    grid-template-columns: 1fr;
  }
}
.award__image {
  overflow: hidden;
  border-radius: 38px;
}
.award__image img {
  width: 100%;
}
.award__note {
  margin-top: 6px;
  font-size: 14px;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .award__note {
    margin-top: 22px;
    font-size: 15px;
    line-height: 1.8666666667;
  }
}

.product {
  margin-top: 52px;
  padding-bottom: 138px;
}
@media screen and (max-width: 768px) {
  .product {
    margin-top: 47px;
    padding-bottom: 84px;
  }
}
.product__intro {
  max-width: 885px;
  margin: 40px auto 48px;
}
@media screen and (max-width: 768px) {
  .product__intro {
    margin: 26px 0 66px;
  }
}
.product__lead {
  font-size: min(1.9505851756vw, 18px);
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .product__lead {
    font-size: 18px;
    line-height: 1.8888888889;
    font-weight: 400;
    text-align: left;
  }
}
@media screen and (max-width: 768px) {
  .product__lead + .product__lead {
    margin-top: 39px;
  }
}
.product__rows {
  margin: 85px -14px 0;
}
@media screen and (max-width: 768px) {
  .product__rows {
    margin: 58px 0 0;
  }
}
.product__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 17px;
}
@media screen and (max-width: 768px) {
  .product__row {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }
}
.product__row + .product__row {
  margin-top: 87px;
}
@media screen and (max-width: 768px) {
  .product__row + .product__row {
    margin-top: 54px;
  }
}
.product__row:nth-child(odd) {
  flex-direction: row-reverse;
}
@media screen and (max-width: 768px) {
  .product__row:nth-child(odd) {
    flex-direction: column;
  }
}
.product__item {
  display: grid;
  width: 403px;
  min-width: 340px;
  gap: 34px;
  padding-top: 10px;
}
@media screen and (max-width: 768px) {
  .product__item {
    display: contents;
  }
}
.product__txt {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .product__txt {
    order: 2;
    margin-bottom: 20px;
  }
}
.product__image {
  width: 687px;
  height: 343px;
  overflow: hidden;
  border-radius: 56px;
}
@media screen and (max-width: 768px) {
  .product__image {
    order: 1;
    width: 100%;
    height: auto;
    margin: 34px 0 22px;
    border-radius: 40px;
  }
}
.product__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (max-width: 768px) {
  .product__more {
    order: 2;
    width: 100%;
  }
}

.product-nav__items {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 25px 22px;
  margin: 0 -5px;
  padding: 40px min(3.9011703511vw, 45px);
  overflow: hidden;
  border-radius: 92px;
}
@media screen and (max-width: 768px) {
  .product-nav__items {
    grid-template-columns: 1fr;
    row-gap: 11px;
    margin: 0;
    padding: 25px 6.4102564103vw 29px;
    border-radius: 61px;
  }
}
.product-nav__items::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  opacity: 0.2;
  background: linear-gradient(180deg, #A831FF, #FF389C);
  z-index: -1;
}
.product-nav__item a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 130px;
  font-size: min(3.055916775vw, 26px);
  line-height: 1.4230769231;
  font-weight: bold;
  color: #FF44A1;
  font-family: "Zen Maru Gothic", YuGothic, "Yu Gothic", Hiragino Sans, Hiragino Kaku Gothic ProN, Meiryo, Osaka, sans-serif;
  border-radius: 75px;
  box-shadow: 2px 2px 6px rgba(149, 120, 120, 0.6);
  background: #fff;
}
@media screen and (max-width: 768px) {
  .product-nav__item a {
    height: 82px;
    font-size: 20px;
    line-height: 1.45;
  }
}
.product-nav__item a i {
  right: 30px;
}
@media screen and (max-width: 768px) {
  .product-nav__item a i {
    width: 8px;
    right: 20px;
  }
}

.sdgs {
  margin-top: 50px;
  padding-bottom: 147px;
}
@media screen and (max-width: 768px) {
  .sdgs {
    padding-bottom: 86px;
  }
}
.sdgs__leads {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .sdgs__leads {
    margin-top: 20px;
  }
}
.sdgs__lead {
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .sdgs__lead {
    text-align: left;
  }
}
.sdgs__lead + .sdgs__lead {
  margin-top: 38px;
}
.sdgs__wrap {
  margin-top: 76px;
}
@media screen and (max-width: 768px) {
  .sdgs__wrap {
    margin-top: 34px;
  }
}
@media screen and (max-width: 768px) {
  .sdgs__intro {
    margin-right: -6.6666666667vw;
    padding: 0 6.6666666667vw 20px 0;
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: #FF44A1 #EFEFEF;
  }
}
@media screen and (max-width: 768px) {
  .sdgs__intro::-webkit-scrollbar {
    height: 7px;
  }
}
.sdgs__intro::-webkit-scrollbar-thumb {
  background: #FF44A1;
  border-radius: 7px;
}
.sdgs__tabs {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-radius: 99px;
  background: #EFEFEF;
}
@media screen and (max-width: 768px) {
  .sdgs__tabs {
    min-width: 1120px;
  }
}
.sdgs__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 62px;
  font-size: 16px;
  line-height: 1.1875;
  font-weight: 500;
  color: #979797;
  text-align: center;
  border-radius: 99px;
  transition: background 0.3s, color 0.3s;
}
@media screen and (max-width: 768px) {
  .sdgs__btn {
    height: 62px;
    font-size: 18px;
    line-height: 1.4444444444;
  }
}
.sdgs__btn span {
  min-width: 3em;
  text-align-last: justify;
}
.sdgs__btn[aria-selected=true] {
  color: #fff;
  background: #FF44A1;
}
.sdgs__items {
  margin-top: 70px;
}
@media screen and (max-width: 768px) {
  .sdgs__items {
    margin-top: 49px;
  }
}
.sdgs__item {
  display: none;
}
.sdgs__item[aria-hidden=false] {
  display: block;
}
.sdgs__row {
  display: grid;
  gap: 24px;
}
@media screen and (max-width: 768px) {
  .sdgs__row {
    gap: 0;
  }
}
.sdgs__row + .sdgs__row {
  margin-top: 62px;
  padding-top: 55px;
  border-top: 1px solid #C1C6D0;
}
@media screen and (max-width: 768px) {
  .sdgs__row + .sdgs__row {
    margin-top: 41px;
    padding-top: 41px;
  }
}

.sdgs-detail + .sdgs-detail {
  margin-top: 122px;
}
@media screen and (max-width: 768px) {
  .sdgs-detail + .sdgs-detail {
    margin-top: 62px;
  }
}
.sdgs-detail__intro {
  display: flex;
  align-items: flex-end;
  gap: 62px;
  margin-bottom: 46px;
}
@media screen and (max-width: 768px) {
  .sdgs-detail__intro {
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 25px 20px;
    margin-bottom: 40px;
  }
}
.sdgs-detail__icon {
  height: 70px;
}
@media screen and (max-width: 768px) {
  .sdgs-detail__icon {
    height: 53px;
  }
}
.sdgs-detail__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.sdgs-detail__row {
  display: flex;
  align-items: center;
  gap: min(5.1239669421vw, 62px);
}
@media screen and (max-width: 768px) {
  .sdgs-detail__row {
    flex-direction: column;
    gap: 10px;
  }
}
.sdgs-detail__row + .sdgs-detail__row {
  margin-top: 53px;
}
@media screen and (max-width: 768px) {
  .sdgs-detail__row + .sdgs-detail__row {
    margin-top: 40px;
  }
}
.sdgs-detail__item {
  display: grid;
  flex-shrink: 0;
  gap: 24px;
  width: min(43.3884297521vw, 525px);
  padding-top: 12px;
}
@media screen and (max-width: 768px) {
  .sdgs-detail__item {
    width: 100%;
    gap: 20px;
  }
}
.sdgs-detail__image {
  flex-shrink: 0;
  width: min(46.8066491689vw, 535px);
  margin-bottom: auto;
  overflow: hidden;
  border-radius: 56px;
}
@media screen and (max-width: 768px) {
  .sdgs-detail__image {
    order: -1;
    width: 100%;
    border-radius: 40px;
  }
}
.sdgs-detail__image img {
  width: 100%;
}
.-reverse > .sdgs-detail__image {
  order: -1;
}

.recruit {
  margin: 50px 0 121px;
}
.recruit__lead {
  max-width: 885px;
  margin: 41px auto 60px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .recruit__lead {
    margin: 25px 0 53px;
    text-align: left;
  }
}
.recruit__row {
  position: relative;
  padding: 55px 0 54px;
}
@media screen and (max-width: 768px) {
  .recruit__row {
    padding: 38px 0 52px;
  }
}
.recruit__item {
  width: 629px;
  max-width: 80%;
  padding: 75px 42px 78px;
  border-radius: 46px;
}
@media screen and (max-width: 768px) {
  .recruit__item {
    width: 100%;
    max-width: 100%;
    padding: 0;
  }
}
.recruit__item.-type-1 {
  margin-left: auto;
  background: rgba(227, 240, 255, 0.8);
}
@media screen and (max-width: 768px) {
  .recruit__item.-type-1 {
    background: none;
  }
}
.recruit__item.-type-2 {
  background: rgba(255, 228, 227, 0.8);
}
@media screen and (max-width: 768px) {
  .recruit__item.-type-2 {
    background: none;
  }
}
.recruit__detail {
  display: grid;
  gap: 37px;
  margin-bottom: 25px;
}
@media screen and (max-width: 768px) {
  .recruit__detail {
    gap: 31px;
    margin-bottom: max(71.7948717949vw, 280px);
    padding: 31px 25px;
    border-radius: 46px;
  }
}
@media screen and (max-width: 768px) {
  .-type-1 > .recruit__detail {
    background: rgba(227, 240, 255, 0.8);
  }
}
@media screen and (max-width: 768px) {
  .-type-2 > .recruit__detail {
    background: rgba(255, 228, 227, 0.8);
  }
}
.recruit__txt {
  font-size: 16px;
  line-height: 2.125;
}
@media screen and (max-width: 768px) {
  .recruit__txt {
    font-size: 18px;
    line-height: 2.1111111111;
  }
}
.recruit__image {
  position: absolute;
  width: 100vw;
  height: 100%;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.recruit__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}
@media screen and (max-width: 768px) {
  .recruit__image img {
    object-position: bottom;
  }
}

.contact {
  margin-top: 89px;
  padding-bottom: 130px;
}
@media screen and (max-width: 768px) {
  .contact {
    margin-top: 48px;
    padding-bottom: 74px;
  }
}
.contact.-page {
  margin-top: 102px;
}
@media screen and (max-width: 768px) {
  .contact.-page {
    margin-top: 64px;
  }
}
.contact__row {
  max-width: 963px;
  margin: 80px auto 0;
}
@media screen and (max-width: 768px) {
  .contact__row {
    margin-top: 58px;
  }
}
.contact__row + .contact__row {
  margin-top: 120px;
}
@media screen and (max-width: 768px) {
  .contact__row + .contact__row {
    margin-top: 62px;
  }
}
.contact__lead {
  margin-top: 40px;
  font-size: min(1.8205461638vw, 16px);
  line-height: 2.125;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .contact__lead {
    font-size: 18px;
    line-height: 2.1111111111;
    text-align: left;
  }
}
.contact__lead.-page {
  margin-top: 32px;
  font-size: 18px;
  line-height: 2.2222222222;
}
@media screen and (max-width: 768px) {
  .contact__lead.-page {
    margin-top: 25px;
    line-height: 2.1111111111;
  }
}
.contact__tel {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 10px;
  padding: 62px 20px 32px;
  border-radius: 38px;
  background: linear-gradient(180deg, #FFEFF0, #FFFBED);
}
@media screen and (max-width: 768px) {
  .contact__tel {
    margin-top: 6px;
    padding: 42px 11px;
    text-align: center;
  }
}
.contact__tel a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 29px;
  font-size: 46px;
  line-height: 1.1956521739;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .contact__tel a {
    gap: 13px;
    font-size: min(7.1794871795vw, 33px);
    line-height: 1.2121212121;
  }
}
.contact__tel a i {
  width: 66px;
}
@media screen and (max-width: 768px) {
  .contact__tel a i {
    width: min(12.8205128205vw, 50px);
  }
}
.contact__tel a i svg {
  width: 100%;
}
.contact__tel small {
  margin-top: 16px;
  font-size: 16px;
  line-height: 2.125;
}
@media screen and (max-width: 768px) {
  .contact__tel small {
    margin-top: 8px;
    font-size: 15px;
    line-height: 1.8666666667;
  }
}
.contact__tel span {
  font-size: 16px;
  line-height: 2.125;
}
@media screen and (max-width: 768px) {
  .contact__tel span {
    font-size: 15px;
    line-height: 1.8666666667;
  }
}
.contact__form {
  margin-top: 42px;
}
@media screen and (max-width: 768px) {
  .contact__form {
    margin-top: 32px;
  }
}
.contact__note {
  margin-top: 50px;
  font-size: 16px;
  line-height: 2.125;
}
@media screen and (max-width: 768px) {
  .contact__note {
    position: relative;
    margin-top: 52px;
    padding-top: 48px;
  }
}
@media screen and (max-width: 768px) {
  .contact__note::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    top: 0;
    left: 0;
    background: #C1C6D0;
  }
}
.contact__caution {
  position: relative;
  margin-top: 38px;
  padding-top: 66px;
  font-size: 16px;
  line-height: 2.125;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .contact__caution {
    padding-top: 0;
  }
}
.contact__caution::before {
  content: "";
  position: absolute;
  width: 990px;
  height: 1px;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  background: #C1C6D0;
}
@media screen and (max-width: 768px) {
  .contact__caution::before {
    content: none;
  }
}
.contact__caution dt {
  font-weight: 500;
}
.contact__caution dt::before {
  content: "【";
}
.contact__caution dt::after {
  content: "】";
}

.form.-page {
  max-width: 963px;
  margin: 0 auto;
}
.form__items {
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  .form__items {
    margin-bottom: 42px;
  }
}
.-page > .form__items {
  margin-bottom: 78px;
}
@media screen and (max-width: 768px) {
  .-page > .form__items {
    margin-bottom: 48px;
  }
}
.form__item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .form__item {
    flex-direction: column;
    gap: 6px;
  }
}
.form__item + .form__item {
  margin-top: 36px;
}
@media screen and (max-width: 768px) {
  .form__item + .form__item {
    margin-top: 20px;
  }
}
.form__item.-page {
  gap: 0;
}
.form__heading {
  display: flex;
  flex-shrink: 0;
  flex-direction: column;
  align-items: flex-start;
  min-width: 207px;
  padding-top: 18px;
  font-size: 18px;
  line-height: 1.8888888889;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .form__heading {
    padding-top: 0;
    font-size: 20px;
    line-height: 1.7;
  }
}
.form__heading span {
  display: flex;
  align-items: center;
  gap: 21px;
}
@media screen and (max-width: 768px) {
  .form__heading span {
    gap: 10px;
  }
}
.form__heading span small {
  color: #FF44A1;
}
.form__heading small {
  font-size: 14px;
  line-height: 1.0714285714;
}
@media screen and (max-width: 768px) {
  .form__heading small {
    font-size: 16px;
    line-height: 2.125;
  }
}
.form__heading small::before {
  content: "※";
}
.-career > .form__heading {
  min-width: 137px;
  font-size: 20px;
  line-height: 1.7;
  font-weight: bold;
}
.-page > .form__heading {
  font-size: 20px;
  line-height: 1.7;
  font-weight: bold;
}
.-page > .form__heading span {
  gap: 8px;
}
@media screen and (max-width: 768px) {
  .-page > .form__heading span {
    gap: 12px;
  }
}
.-page > .form__heading small {
  font-weight: 400;
}
@media screen and (max-width: 768px) {
  .-page > .form__heading small {
    font-size: 14px;
    line-height: 3.1428571429;
  }
}
.form__heading.-type-1 span {
  position: relative;
}
.form__heading.-type-1 span small {
  position: absolute;
  top: 10px;
  left: 115px;
}
@media screen and (max-width: 768px) {
  .form__heading.-type-1 span small {
    top: -5px;
    left: 110px;
  }
}
.form__detail {
  flex-grow: 1;
  max-width: 732px;
}
@media screen and (max-width: 768px) {
  .form__detail {
    width: 100%;
  }
}
.-career > .form__detail {
  max-width: 788px;
}
.form__detail .wpcf7-not-valid-tip {
  white-space: pre-line;
}
.-page > .form__detail {
  max-width: 755px;
}
@media screen and (max-width: 768px) {
  .-page > .form__detail {
    max-width: 100%;
  }
}
.form__detail.-radio {
  padding: 16px 0 0 30px;
}
@media screen and (max-width: 768px) {
  .form__detail.-radio {
    padding: 20px 0 0;
  }
}
.form__detail.-radio .wpcf7-form-control {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 57px;
}
@media screen and (max-width: 768px) {
  .form__detail.-radio .wpcf7-form-control {
    flex-direction: column;
    gap: 26px;
  }
}
.form__detail.-radio label span {
  position: relative;
  display: flex;
  align-items: center;
  gap: 15px;
  font-size: 20px;
  line-height: 1.7;
}
@media screen and (max-width: 768px) {
  .form__detail.-radio label span {
    gap: 10px;
  }
}
.form__detail.-radio label span::before {
  content: "";
  aspect-ratio: 1;
  flex-shrink: 0;
  width: 24px;
  border-radius: 50%;
  background: #F2F2F2;
}
@media screen and (max-width: 768px) {
  .form__detail.-radio label span::before {
    width: 39px;
  }
}
.form__detail.-radio label input {
  position: absolute;
  width: 1px;
  height: 1px;
  top: 0;
  left: 0;
  overflow: hidden;
  opacity: 0;
}
.form__detail.-radio label input:checked + span::before {
  box-shadow: inset 0 0 0 4px #F2F2F2;
  background: #FF44A1;
}
@media screen and (max-width: 768px) {
  .form__detail.-radio label input:checked + span::before {
    box-shadow: inset 0 0 0 6px #F2F2F2;
  }
}
.form__check {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 65px;
  font-size: 16px;
  line-height: 1.625;
}
@media screen and (max-width: 768px) {
  .form__check {
    margin-bottom: 32px;
    font-size: 18px;
    line-height: 1.8888888889;
  }
}
.form__check span {
  display: flex;
  gap: 8px;
}
.form__check span::before {
  content: "";
  aspect-ratio: 1;
  width: 26px;
  height: 26px;
  border-radius: 6px;
  box-shadow: inset 3px 3px 4px rgba(0, 0, 0, 0.16);
  background: #F2F2F2;
}
.form__privacy {
  display: flex;
  justify-content: center;
  margin-bottom: 65px;
}
@media screen and (max-width: 768px) {
  .form__privacy {
    margin-bottom: 32px;
  }
}
.form__privacy span {
  margin: 0;
}
.form__privacy label {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  line-height: 1.625;
}
@media screen and (max-width: 768px) {
  .form__privacy label {
    font-size: 18px;
    line-height: 1.8888888889;
  }
}
.form__privacy label span {
  display: flex;
  gap: 8px;
  cursor: pointer;
}
.form__privacy label span::before {
  content: "";
  aspect-ratio: 1;
  width: 26px;
  height: 26px;
  border-radius: 6px;
  box-shadow: inset 3px 3px 4px rgba(0, 0, 0, 0.16);
  background: #F2F2F2;
}
.form__privacy label input:checked + span::before {
  background: #F2F2F2 url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2222.121%22%20height%3D%2217.121%22%20viewBox%3D%220%200%2022.121%2017.121%22%3E%3Cg%20transform%3D%22translate(-7077.439%2013669.561)%22%3E%3Cpath%20d%3D%22M4.939%2C7.061l-6-6L1.061-1.061l6%2C6Z%22%20transform%3D%22translate(7078.5%20-13660.5)%22%20fill%3D%22%23f7449e%22%2F%3E%3Cpath%20d%3D%22M1.061%2C16.061l-2.121-2.121%2C15-15%2C2.121%2C2.121Z%22%20transform%3D%22translate(7083.5%20-13668.5)%22%20fill%3D%22%23f7449e%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center/20px 20px;
}
.form__foot {
  display: flex;
  justify-content: center;
  gap: 20px;
}
.form__btn {
  display: block;
  width: 100%;
  max-width: 259px;
}

.career {
  margin-top: 55px;
  padding-bottom: 115px;
}
@media screen and (max-width: 768px) {
  .career {
    margin-top: 25px;
    padding-bottom: 80px;
  }
}
.career__wrap {
  position: relative;
  margin-bottom: 123px;
  padding-bottom: 102px;
}
@media screen and (max-width: 768px) {
  .career__wrap {
    margin-bottom: 70px;
    padding-bottom: 80px;
  }
}
.career__wrap::before {
  content: "";
  position: absolute;
  width: 100vw;
  height: 100%;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  background: #FFF9F7;
  z-index: -1;
}
.career__heading {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 670px;
  height: 105px;
  margin: 0 auto 18px;
  font-size: 30px;
  line-height: 1.8666666667;
  font-weight: 500;
  text-align: center;
  border: 6px solid #FFF9F7;
  border-radius: 50px;
  transform: translateY(-50px);
  background: #fff;
}
@media screen and (max-width: 768px) {
  .career__heading {
    width: 78.2051282051vw;
    max-width: 305px;
    margin-bottom: -12px;
    height: 132px;
    font-size: 24px;
    line-height: 1.5;
    transform: translateY(-66px);
  }
}
.career__row + .career__row {
  margin-top: 90px;
}
@media screen and (max-width: 768px) {
  .career__row + .career__row {
    margin-top: 72px;
  }
}
.career__list {
  margin-top: 20px;
  padding: 45px 20px 34px;
  border-radius: 53px;
  background: #fff;
}
@media screen and (max-width: 768px) {
  .career__list {
    margin-top: 41px;
    padding: 37px 4.358974359vw 31px;
    border-radius: 38px;
  }
}
.career__list li {
  position: relative;
  max-width: 848px;
  margin: 0 auto;
  padding-left: 1em;
  font-size: 16px;
  line-height: 2.125;
}
@media screen and (max-width: 768px) {
  .career__list li {
    font-size: 18px;
    line-height: 1.8888888889;
  }
}
.career__list li::before {
  content: "";
  position: absolute;
  width: 9px;
  height: 9px;
  top: 12px;
  left: 0;
  border-radius: 50%;
  background: #FF44A1;
}
.career__foot {
  max-width: 963px;
  margin: 0 auto;
}
.career__form {
  margin-top: 54px;
}
@media screen and (max-width: 768px) {
  .career__form {
    margin-top: 28px;
  }
}

.career-nav {
  margin-bottom: 78px;
}
@media screen and (max-width: 768px) {
  .career-nav {
    margin-bottom: 38px;
  }
}
.career-nav__items {
  display: flex;
  justify-content: center;
  gap: 22px;
}
@media screen and (max-width: 768px) {
  .career-nav__items {
    display: grid;
    grid-template-columns: repeat(auto-fill, min(259px, 100%));
    justify-content: center;
    gap: 19px;
  }
}
.career-nav__item {
  width: 100%;
  max-width: 499px;
}
@media screen and (max-width: 768px) {
  .career-nav__item {
    max-width: 259px;
  }
}
.career-nav__item a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 130px;
  font-size: 26px;
  line-height: 1.4230769231;
  font-weight: bold;
  color: #FF44A1;
  border: 3px solid #fff;
  border-radius: 65px;
  box-shadow: 2px 2px 6px rgba(149, 120, 120, 0.6);
  background: #fff;
  transition: border-color 0.3s;
}
@media screen and (max-width: 768px) {
  .career-nav__item a {
    height: 65px;
    font-size: 16px;
    line-height: 2.125;
  }
}
.career-nav__item a:hover {
  opacity: 1;
  border-color: #FF44A1;
}
.career-nav__item a:hover i {
  background: none;
}
.career-nav__item a:hover i::before {
  opacity: 1;
}

.career-intro {
  position: relative;
  max-width: 886px;
  margin: 0 auto 111px;
  padding: 83px 0 66px;
}
@media screen and (max-width: 768px) {
  .career-intro {
    margin-bottom: 56px;
    padding: 58px 0 342px;
  }
}
.career-intro__item {
  max-width: 475px;
}
@media screen and (max-width: 768px) {
  .career-intro__item {
    width: 79.7435897436vw;
    max-width: 100%;
    margin: 0 auto;
  }
}
.career-intro__head {
  width: 460px;
  margin-bottom: 30px;
  font-size: 28px;
  line-height: 2;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .career-intro__head {
    width: 100%;
    margin-bottom: 26px;
    font-size: 24px;
    line-height: 1.6666666667;
  }
}
.career-intro__txt {
  font-size: 16px;
  line-height: 2.125;
}
@media screen and (max-width: 768px) {
  .career-intro__txt {
    font-size: 18px;
    line-height: 2;
  }
}
.career-intro__txt + .career-intro__txt {
  margin-top: 12px;
}
.career-intro__image {
  position: absolute;
  width: 100vw;
  height: 100%;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.career-intro__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.career-message {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
  max-width: 1120px;
  margin: 0 auto 173px;
}
@media screen and (max-width: 768px) {
  .career-message {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    margin-bottom: 114px;
  }
}
.career-message__item {
  width: 518px;
  padding-top: 30px;
}
@media screen and (max-width: 768px) {
  .career-message__item {
    display: contents;
  }
}
.career-message__lead {
  max-width: 515px;
  margin: 35px 0 15px -20px;
}
@media screen and (max-width: 768px) {
  .career-message__lead {
    order: 2;
    max-width: 100%;
    margin: 25px 0 10px;
  }
}
.career-message__lead img {
  width: 100%;
}
.career-message__txt {
  margin-bottom: 33px;
  font-size: 16px;
  line-height: 2.125;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .career-message__txt {
    order: 2;
    margin-bottom: 20px;
    font-size: 18px;
    line-height: 2;
  }
}
.career-message__txt + .career-message__txt {
  margin-top: 34px;
}
@media screen and (max-width: 768px) {
  .career-message__txt + .career-message__txt {
    margin-top: 36px;
  }
}
.career-message__name {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 23px;
  font-size: 18px;
  line-height: 1.6666666667;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .career-message__name {
    order: 2;
    flex-direction: column;
    align-items: flex-end;
    gap: 16px;
    margin-left: auto;
  }
}
.career-message__name em {
  width: 139px;
}
.career-message__name em img {
  width: 100%;
}
.career-message__image {
  order: -1;
  width: 496px;
  margin-bottom: auto;
  overflow: hidden;
  border-radius: 56px;
}
@media screen and (max-width: 768px) {
  .career-message__image {
    order: 1;
    width: 100%;
    margin-top: 36px;
    border-radius: 40px;
  }
}
.career-message__image img {
  width: 100%;
}

.career-detail {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .career-detail {
    margin-top: 36px;
  }
}
.career-detail .splide__pagination {
  position: inherit;
  bottom: auto;
  left: auto;
  right: auto;
  padding: 0;
}
.career-detail__content {
  padding-bottom: 6px;
}
.career-detail__content:not(.is-active) .splide__list:not(:root) {
  display: flex;
}
.career-detail__item {
  display: flex;
  flex-direction: column;
  width: min(29.0909090909vw, 384px);
  margin-right: min(4.0909090909vw, 54px);
}
@media screen and (max-width: 1040px) {
  .career-detail__item {
    width: 48%;
    margin-right: 4%;
  }
}
.career-detail__heading {
  margin-bottom: 16px;
  font-size: 24px;
  line-height: 1.5833333333;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .career-detail__heading {
    margin-bottom: 11px;
  }
}
.career-detail__heading[data-num]::before {
  content: attr(data-num) ".";
}
.career-detail__image {
  order: -1;
  margin-bottom: 12px;
  overflow: hidden;
  border-radius: 38px;
}
.career-detail__image img {
  width: 100%;
}
.career-detail__txt {
  font-size: 16px;
  line-height: 2.125;
  font-weight: 500;
}
.career-detail__data {
  margin-bottom: 14px;
}
.career-detail__data li {
  position: relative;
  padding-left: 1em;
  font-size: 18px;
  line-height: 1.8888888889;
}
.career-detail__data li::before {
  content: "";
  position: absolute;
  width: 9px;
  height: 9px;
  top: 12px;
  left: 0;
  border-radius: 50%;
  background: #FF44A1;
}
.career-detail__data li span {
  display: inline-block;
  min-width: 3em;
  text-align-last: justify;
}
.career-detail__arrows {
  margin-top: 70px;
}
@media screen and (max-width: 768px) {
  .career-detail__arrows {
    margin-top: 46px;
  }
}
.-type-1 > .career-detail__arrows {
  display: none;
}
@media screen and (max-width: 1040px) {
  .-type-1 > .career-detail__arrows {
    display: flex;
  }
}

.business {
  margin-top: 52px;
  padding-bottom: 110px;
}
@media screen and (max-width: 768px) {
  .business {
    margin-top: 48px;
    padding-bottom: 84px;
  }
}
.business__lead {
  margin: 40px 0 32px;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .business__lead {
    margin: 26px 0 7.1794871795vw;
    line-height: 1.8888888889;
    text-align: left;
  }
}
.business__rows {
  max-width: 1122px;
  margin: 0 auto;
}
.business__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
}
@media screen and (max-width: 768px) {
  .business__row {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }
}
.business__row:nth-child(odd) {
  flex-direction: row-reverse;
}
@media screen and (max-width: 768px) {
  .business__row:nth-child(odd) {
    flex-direction: column;
  }
}
.business__row + .business__row {
  margin-top: 67px;
}
@media screen and (max-width: 768px) {
  .business__row + .business__row {
    margin-top: 37px;
  }
}
.business__item {
  width: 526px;
}
@media screen and (max-width: 768px) {
  .business__item {
    display: contents;
  }
}
.business__intro {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 18px;
}
@media screen and (max-width: 768px) {
  .business__intro {
    order: -1;
    margin-bottom: 16px;
  }
}
.business__heading {
  font-size: 28px;
  line-height: 1.3571428571;
  font-weight: 500;
}
.business__type {
  display: flex;
  order: -1;
  flex-direction: column;
  align-items: center;
  line-height: 1.4444444444;
  font-weight: bold;
  color: #FF44A1;
  font-family: "Zen Maru Gothic", YuGothic, "Yu Gothic", Hiragino Sans, Hiragino Kaku Gothic ProN, Meiryo, Osaka, sans-serif;
}
.business__type i {
  width: 125px;
  margin-top: -8px;
}
.business__type i svg {
  width: 100%;
}
.business__txt {
  margin-bottom: 18px;
}
@media screen and (max-width: 768px) {
  .business__txt {
    order: 1;
    margin-bottom: 15px;
  }
}
.business__image {
  width: 535px;
  margin-bottom: auto;
  overflow: hidden;
  border-radius: 56px;
}
@media screen and (max-width: 768px) {
  .business__image {
    width: 100%;
    margin-bottom: 18px;
    border-radius: 40px;
  }
}
.business__image img {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .business__more {
    order: 2;
    width: 100%;
  }
}

.business-nav {
  position: relative;
  aspect-ratio: 1;
  display: flex;
  justify-content: center;
  align-content: center;
  max-width: 889px;
  margin: 0 auto 52px;
}
@media screen and (max-width: 768px) {
  .business-nav {
    margin-bottom: min(10.5128205128vw, 41px);
  }
}
.business-nav::before {
  content: "";
  position: absolute;
  aspect-ratio: 1;
  width: calc(100% - 90px);
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: 50%;
  background: linear-gradient(180deg, #A831FF, #FF389C);
  opacity: 0.2;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .business-nav::before {
    width: 84.1025641026vw;
  }
}
.business-nav::after {
  content: "";
  position: absolute;
  aspect-ratio: 1;
  width: calc(100% - 280px);
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: 50%;
  background: #fff;
  z-index: -1;
}
@media screen and (max-width: 768px) {
  .business-nav::after {
    width: 64.358974359vw;
  }
}
.business-nav__items {
  position: relative;
  width: 100%;
  height: 100%;
}
.business-nav__item {
  position: absolute;
  aspect-ratio: 1;
  width: min(23.2832618026vw, 217px);
  translate: -50% -50%;
  transition: scale 0.3s;
}
@media screen and (max-width: 768px) {
  .business-nav__item {
    width: 24.1025641026vw;
  }
}
.business-nav__item:hover {
  scale: 1.3;
  z-index: 1;
}
.business-nav__item a {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  padding-bottom: 12px;
  font-size: min(2.5751072961vw, 24px);
  line-height: 1.25;
  font-weight: bold;
  color: #FF44A1;
  text-align: center;
  border: 8px solid #FFC3E1;
  border-radius: 50%;
  background: #fff;
}
@media screen and (max-width: 768px) {
  .business-nav__item a {
    font-size: min(3.5897435897vw, 24px);
    line-height: 1.3571428571;
    border-width: 0.7692307692vw;
  }
}
.business-nav__item a:hover {
  opacity: 1;
  border: 20px solid #FF44A1;
}
@media screen and (max-width: 768px) {
  .business-nav__item a:hover {
    border-width: 1.5384615385vw;
  }
}
.business-nav__item a:hover i {
  background: none;
}
.business-nav__item a:hover i::before {
  opacity: 1;
}
.business-nav__item a i {
  top: 82%;
  right: 50%;
  translate: 50% -50%;
}
@media screen and (max-width: 768px) {
  .business-nav__item a i {
    width: 6px;
  }
}
.business-nav__item:nth-child(1) {
  top: 22.5%;
  left: 22%;
}
.business-nav__item:nth-child(2) {
  top: 12%;
  left: 50%;
}
.business-nav__item:nth-child(3) {
  top: 22.5%;
  left: 78%;
}
.business-nav__item:nth-child(4) {
  top: 50%;
  left: 88%;
}
.business-nav__item:nth-child(5) {
  top: 77.5%;
  left: 78%;
}
.business-nav__item:nth-child(6) {
  top: 87%;
  left: 50%;
}
.business-nav__item:nth-child(7) {
  top: 77.5%;
  left: 22%;
}
.business-nav__item:nth-child(8) {
  top: 50%;
  left: 12%;
}
.business-nav__image {
  position: absolute;
  width: 266px;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
}
@media screen and (max-width: 768px) {
  .business-nav__image {
    width: 28.2051282051vw;
  }
}
.business-nav__image svg {
  width: 100%;
}

.history {
  margin-top: 62px;
  padding-bottom: 112px;
}
@media screen and (max-width: 768px) {
  .history {
    margin-top: 51px;
    padding-bottom: 60px;
  }
}
.history__lead {
  max-width: 885px;
  margin: 40px auto 28px;
}
@media screen and (max-width: 768px) {
  .history__lead {
    margin: 15px auto 34px;
  }
}
.history__items {
  position: relative;
  max-width: 1110px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .history__items {
    display: grid;
    gap: 3.5897435897vw;
    padding-left: 9.7435897436vw;
  }
}
.history__items::before {
  content: "";
  position: absolute;
  width: 4px;
  height: calc(100% - 390px);
  top: 70px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 2px;
  background: #FF44A1;
}
@media screen and (max-width: 768px) {
  .history__items::before {
    height: calc(100% - 270px);
    top: 20px;
    left: 2.5641025641vw;
    transform: none;
  }
}
.history__item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 50%;
  padding-right: min(9.8106712565vw, 114px);
}
@media screen and (max-width: 768px) {
  .history__item {
    width: 100%;
    padding-right: 0;
  }
}
.history__item:nth-child(1) {
  margin-bottom: -216px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(1) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(2) {
  margin-bottom: -160px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(2) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(3) {
  margin-bottom: -174px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(3) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(4) {
  margin-bottom: -142px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(4) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(5) {
  margin-bottom: -133px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(5) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(6) {
  margin-bottom: -88px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(6) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(7) {
  margin-bottom: -168px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(7) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(8) {
  margin-bottom: -255px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(8) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(9) {
  margin-bottom: -104px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(9) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(10) {
  margin-bottom: -272px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(10) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(11) {
  margin-bottom: -152px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(11) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(12) {
  margin-bottom: -342px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(12) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(13) {
  margin-bottom: -213px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(13) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(14) {
  margin-bottom: -168px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(14) {
    margin-bottom: 0;
  }
}
.history__item:nth-child(15) {
  margin-bottom: -292px;
}
@media screen and (max-width: 768px) {
  .history__item:nth-child(15) {
    margin-bottom: 0;
  }
}
.history__item.-even {
  margin-left: auto;
  padding: 0 0 0 min(9.8106712565vw, 114px);
}
@media screen and (max-width: 768px) {
  .history__item.-even {
    padding: 0;
  }
}
.history__heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 140px;
  margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
  .history__heading {
    margin-left: 10px;
  }
}
.history__heading span {
  margin-bottom: -8px;
  font-size: 23px;
  line-height: 1.4782608696;
  font-weight: bold;
  color: #FF44A1;
  font-family: "Zen Maru Gothic", YuGothic, "Yu Gothic", Hiragino Sans, Hiragino Kaku Gothic ProN, Meiryo, Osaka, sans-serif;
}
.history__heading span em {
  font-size: 39px;
  line-height: 0.8717948718;
}
.history__heading i {
  display: flex;
}
.history__heading i svg {
  width: 100%;
}
.history__heading.-wide {
  width: 152px;
}
.history__image {
  position: relative;
  margin-bottom: 17px;
  opacity: 1;
}
@media screen and (max-width: 768px) {
  .history__image {
    margin-bottom: 8px;
  }
}
.history__image img {
  width: 100%;
  overflow: hidden;
  border-radius: 38px;
}
.history__image::before, .history__image::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: #FF44A1;
}
.history__image::before {
  width: 9.8106712565vw;
  max-width: 114px;
  height: 2px;
  left: 100%;
}
@media screen and (max-width: 768px) {
  .history__image::before {
    width: 6.6666666667vw;
    left: auto;
    right: 100%;
  }
}
.history__image::after {
  width: 22px;
  height: 22px;
  left: calc(100% + min(9.8106712565vw, 114px) - 11px);
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  .history__image::after {
    left: auto;
    right: calc(100% + 6.6666666667vw - 11px);
  }
}
.-even > .history__image::before, .-even > .history__image::after {
  left: auto;
}
.-even > .history__image::before {
  right: 100%;
}
.-even > .history__image::after {
  right: calc(100% + min(9.8106712565vw, 114px) - 11px);
}
@media screen and (max-width: 768px) {
  .-even > .history__image::after {
    right: calc(100% + 6.6666666667vw - 11px);
  }
}
.history__list {
  font-size: 15px;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .history__list {
    font-size: 18px;
    line-height: 2.1111111111;
  }
}
.history__list li {
  position: relative;
  display: flex;
  align-items: flex-start;
  padding-left: 10px;
}
@media screen and (max-width: 768px) {
  .history__list li {
    padding-left: 12px;
  }
}
.history__list li::before {
  content: "";
  position: absolute;
  aspect-ratio: 1;
  width: 7px;
  top: 11px;
  left: 0;
  border-radius: 50%;
  background: #745E5E;
}
@media screen and (max-width: 768px) {
  .history__list li::before {
    top: 16px;
  }
}
.history__list li span {
  flex-shrink: 0;
  min-width: 62px;
  margin-right: 1em;
}
.history__list li:has(> .visually-hidden)::before {
  content: "";
  position: inherit;
  flex-shrink: 0;
  top: auto;
  left: auto;
  min-width: 79px;
  height: 0;
  background: none;
}
@media screen and (max-width: 768px) {
  .history__list li:has(> .visually-hidden)::before {
    min-width: 92px;
  }
}

.post {
  margin-top: 58px;
  padding-bottom: 140px;
}
@media screen and (max-width: 768px) {
  .post {
    padding-bottom: 82px;
  }
}
.post__intro {
  max-width: 880px;
  margin: 0 auto;
}
.post__txt {
  margin: var(--_margin-PC, 0);
}
@media screen and (max-width: 768px) {
  .post__txt {
    order: var(--_order);
    margin: var(--_margin-SP, 0);
  }
}
.post__txt.-center {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .post__txt.-center {
    text-align: left;
  }
}
.post__wrap {
  margin: var(--_margin-PC, 0);
}
@media screen and (max-width: 768px) {
  .post__wrap {
    margin: var(--_margin-SP, 0);
  }
}
.post__contents {
  max-width: 1122px;
  margin: 42px auto 0;
}
@media screen and (max-width: 768px) {
  .post__contents {
    margin-top: 40px;
  }
}
.post__contents.-type-2 {
  margin-top: 102px;
}
@media screen and (max-width: 768px) {
  .post__contents.-type-2 {
    margin-top: 40px;
  }
}
.post__content {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 62px;
}
@media screen and (max-width: 768px) {
  .post__content {
    flex-direction: column;
    gap: 0;
  }
}
.post__content + .post__content {
  margin-top: 88px;
}
@media screen and (max-width: 768px) {
  .post__content + .post__content {
    margin-top: 64px;
  }
}
.post__content.-reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width: 768px) {
  .post__content.-reverse {
    flex-direction: column;
  }
}
.-type-1 > .post__content {
  align-items: center;
}
@media screen and (max-width: 768px) {
  .-type-1 > .post__content {
    align-items: flex-start;
  }
}
.post__item {
  display: flex;
  flex-direction: column;
  width: 525px;
}
@media screen and (max-width: 768px) {
  .post__item {
    display: contents;
    width: 100%;
  }
}
.post__side {
  width: 535px;
}
@media screen and (max-width: 768px) {
  .post__side {
    order: -1;
    width: 100%;
    margin-top: 26px;
  }
}
.post__side.is-active {
  padding-bottom: 49px;
}
.post__image {
  width: 100%;
  overflow: hidden;
  border-radius: 56px;
}
@media screen and (max-width: 768px) {
  .post__image {
    order: -1;
    border-radius: 40px;
  }
}
.post__image img {
  width: 100%;
}
.post__image.-single {
  width: 535px;
  margin-bottom: auto;
}
@media screen and (max-width: 768px) {
  .post__image.-single {
    order: -1;
    width: 100%;
    margin-top: 22px;
  }
}

.post-flow {
  margin-top: 116px;
}
@media screen and (max-width: 768px) {
  .post-flow {
    margin-top: 88px;
  }
}
.post-flow__items {
  column-count: 2;
  gap: 78px;
  max-width: 1000px;
  margin: 52px auto 0;
}
@media screen and (max-width: 768px) {
  .post-flow__items {
    column-count: 1;
    margin-top: 34px;
  }
}
.post-flow__item {
  display: flex;
  gap: 23px;
}
@media screen and (max-width: 768px) {
  .post-flow__item {
    gap: 14px;
  }
}
.post-flow__item:last-child .post-flow__heading::after {
  content: none;
}
.post-flow__heading {
  display: flex;
  flex-shrink: 0;
  flex-direction: column;
  align-items: center;
  width: 80px;
  white-space: nowrap;
  line-height: 1.8888888889;
  font-weight: 500;
  color: #FF44A1;
}
@media screen and (max-width: 768px) {
  .post-flow__heading {
    width: 46px;
  }
}
.post-flow__heading::after {
  content: "";
  flex-grow: 1;
  width: 1px;
  background: #C1C6D0;
}
.post-flow__detail {
  padding-bottom: 36px;
}
@media screen and (max-width: 768px) {
  .post-flow__detail {
    padding-bottom: 20px;
  }
}
.post-flow__detail dt {
  line-height: 1.8888888889;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .post-flow__detail dt {
    margin-bottom: 6px;
  }
}
.post-flow__detail dd {
  font-size: 16px;
  line-height: 1.875;
}
@media screen and (max-width: 768px) {
  .post-flow__detail dd {
    line-height: 2.375;
  }
}
.post-flow__image {
  margin-top: 14px;
  overflow: hidden;
  border-radius: 25px;
}
.post-flow__image img {
  width: 100%;
}

.post-sales {
  margin-top: 110px;
}
@media screen and (max-width: 768px) {
  .post-sales {
    margin-top: 102px;
  }
}
.post-sales__fig {
  max-width: 992px;
  margin: 26px auto 0;
}
@media screen and (max-width: 768px) {
  .post-sales__fig {
    width: 716px;
    margin-top: 40px;
  }
}
.post-sales__fig img {
  width: 100%;
}
.post-sales__wrap {
  max-width: 971px;
  margin: 22px auto 0;
}
@media screen and (max-width: 768px) {
  .post-sales__wrap {
    max-width: 313px;
  }
}
.post-sales__content {
  max-width: 820px;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .post-sales__content {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
  }
}
.post-sales__columns {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
}
@media screen and (max-width: 768px) {
  .post-sales__columns {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}
.post-sales__columns + .post-sales__columns {
  margin-top: 34px;
}
@media screen and (max-width: 768px) {
  .post-sales__columns + .post-sales__columns {
    margin-top: 0;
  }
}
.post-sales__column {
  display: grid;
  grid-template-columns: 42px 1fr;
  align-items: center;
  gap: min(0.7802340702vw, 14px);
  font-size: clamp(14px, 1.8205461638vw, 18px);
  line-height: 1.4444444444;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .post-sales__column {
    font-size: 18px;
  }
}
.post-sales__note {
  display: block;
  margin-top: 42px;
  font-size: 16px;
  line-height: 1.5;
  color: #6F5555;
  text-align: right;
}
@media screen and (max-width: 768px) {
  .post-sales__note {
    margin-top: 20px;
  }
}
.post-sales__flag img {
  width: 100%;
}

.contact-flow {
  margin-top: 90px;
}
@media screen and (max-width: 768px) {
  .contact-flow {
    margin-top: 60px;
  }
}
.contact-flow__columns {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 25px;
  margin-top: 78px;
}
@media screen and (max-width: 768px) {
  .contact-flow__columns {
    grid-template-columns: 1fr;
    gap: 49px;
    margin-top: 38px;
  }
}
.contact-flow__columns.-type-1 {
  grid-template-columns: repeat(3, 1fr);
  gap: 54px;
}
@media screen and (max-width: 768px) {
  .contact-flow__columns.-type-1 {
    grid-template-columns: 1fr;
    gap: 49px;
  }
}
.contact-flow__column {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 17px;
  padding: 39px 25px;
  border-radius: 50px;
  background: linear-gradient(#EED6FF, #FFD8EC);
}
@media screen and (max-width: 768px) {
  .contact-flow__column {
    gap: 22px;
    padding: 33px 29px 29px;
  }
}
.contact-flow__column + .contact-flow__column::before {
  content: "";
  position: absolute;
  width: 37px;
  height: 37px;
  top: 50%;
  left: -33px;
  transform: translateY(-50%);
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2237%22%20height%3D%2237%22%20viewBox%3D%220%200%2037%2037%22%3E%3Cg%20transform%3D%22translate(-539%20-1226)%22%3E%3Ccircle%20cx%3D%2218.5%22%20cy%3D%2218.5%22%20r%3D%2218.5%22%20transform%3D%22translate(539%201226)%22%20fill%3D%22%23ff44a1%22%2F%3E%3Cg%20transform%3D%22translate(1045.924%20-27.893)%20rotate(45)%22%3E%3Crect%20width%3D%223%22%20height%3D%2213%22%20rx%3D%221.5%22%20transform%3D%22translate(556%201240)%22%20fill%3D%22%23fff%22%2F%3E%3Crect%20width%3D%223%22%20height%3D%2213%22%20rx%3D%221.5%22%20transform%3D%22translate(559%201240)%20rotate(90)%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center/contain;
}
@media screen and (max-width: 768px) {
  .contact-flow__column + .contact-flow__column::before {
    top: -43px;
    left: 50%;
    transform: translateX(-50%) rotate(90deg);
  }
}
.-type-1 > .contact-flow__column + .contact-flow__column::before {
  left: -45px;
}
@media screen and (max-width: 768px) {
  .-type-1 > .contact-flow__column + .contact-flow__column::before {
    left: 50%;
  }
}
.contact-flow__icon {
  position: absolute;
  height: 62px;
  top: -33px;
  left: 0;
}
@media screen and (max-width: 768px) {
  .contact-flow__icon {
    top: -21px;
  }
}
.contact-flow__icon img {
  width: auto;
  height: 100%;
}
.contact-flow__image {
  width: 136px;
  margin: 0 auto;
}
.contact-flow__image img {
  width: 100%;
}
.contact-flow__txt {
  line-height: 1.7777777778;
  color: #745E5E;
}

.contact-theme {
  margin-top: 118px;
}
@media screen and (max-width: 768px) {
  .contact-theme {
    margin-top: 66px;
  }
}
.contact-theme__items {
  margin: 47px 0 96px;
}
@media screen and (max-width: 768px) {
  .contact-theme__items {
    margin: 36px 0 48px;
  }
}
.contact-theme__item {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media screen and (max-width: 768px) {
  .contact-theme__item {
    gap: 26px;
  }
}
.contact-theme__item + .contact-theme__item {
  margin-top: 98px;
}
@media screen and (max-width: 768px) {
  .contact-theme__item + .contact-theme__item {
    margin-top: 52px;
  }
}
.contact-theme__heading {
  display: flex;
  gap: 8px;
  font-size: 24px;
  line-height: 1.8333333333;
  color: #FF44A1;
}
@media screen and (max-width: 768px) {
  .contact-theme__heading {
    font-size: 20px;
    line-height: 1.2;
  }
}
.contact-theme__heading::before {
  content: "⬛︎";
}
.contact-theme__lead {
  font-size: 28px;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .contact-theme__lead {
    font-size: 26px;
    line-height: 1.4615384615;
  }
}
.contact-theme__txt {
  line-height: 2.2222222222;
}
@media screen and (max-width: 768px) {
  .contact-theme__txt {
    line-height: 2.1111111111;
  }
}
.contact-theme__foot {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  line-height: 2.2222222222;
}
@media screen and (max-width: 768px) {
  .contact-theme__foot {
    gap: 24px;
    line-height: 2.1111111111;
  }
}
.contact-theme__foot em {
  font-size: 28px;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .contact-theme__foot em {
    font-size: 26px;
    line-height: 1.4615384615;
  }
}

.contact-result {
  margin-top: 62px;
}
@media screen and (max-width: 768px) {
  .contact-result {
    margin-top: 52px;
  }
}
.contact-result__head {
  display: flex;
  gap: 8px;
  margin-bottom: 38px;
  font-size: 24px;
  line-height: 1.8333333333;
  color: #FF44A1;
}
@media screen and (max-width: 768px) {
  .contact-result__head {
    margin-bottom: 34px;
    font-size: 20px;
    line-height: 1.2;
  }
}
.contact-result__head::before {
  content: "⬛︎";
}
.contact-result__item + .contact-result__item {
  margin-top: 34px;
}
@media screen and (max-width: 768px) {
  .contact-result__item + .contact-result__item {
    margin-top: 50px;
  }
}
.contact-result__heading {
  position: relative;
  margin-bottom: 16px;
  padding-left: 20px;
  font-size: 22px;
  line-height: 1.1818181818;
}
@media screen and (max-width: 768px) {
  .contact-result__heading {
    margin-bottom: 24px;
    font-size: 20px;
    line-height: 1.2;
  }
}
.contact-result__heading::before {
  content: "";
  position: absolute;
  width: 4px;
  height: calc(100% - 5px);
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  border-radius: 4px;
  background: #FF44A1;
}
@media screen and (max-width: 768px) {
  .contact-result__list {
    line-height: 2;
  }
}
.contact-result__list li::before {
  content: "・";
}

.dev-archive {
  margin-top: 53px;
  padding-bottom: 120px;
}
@media screen and (max-width: 768px) {
  .dev-archive {
    margin-top: 20px;
  }
}
.dev-archive__lead {
  margin-top: 34px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .dev-archive__lead {
    margin-top: 30px;
    text-align: left;
  }
}
.dev-archive__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 52px 54px;
  margin-top: 88px;
}
@media screen and (max-width: 768px) {
  .dev-archive__items {
    grid-template-columns: 1fr;
    margin-top: 68px;
  }
}
.dev-archive__item {
  display: flex;
  flex-direction: column;
  gap: 0;
  height: 100%;
}
.dev-archive__heading {
  margin-bottom: 14px;
  font-size: 24px;
  line-height: 1.2083333333;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .dev-archive__heading {
    padding: 0 5px;
    font-size: 20px;
    line-height: 1.2;
    font-weight: 500;
  }
}
.dev-archive__image {
  order: -1;
  margin-bottom: 20px;
  overflow: hidden;
  border-radius: 38px;
}
@media screen and (max-width: 768px) {
  .dev-archive__image {
    margin-bottom: 18px;
  }
}
.dev-archive__image img {
  width: 100%;
}
.dev-archive__txt {
  margin-bottom: 18px;
  line-height: 1.8888888889;
}
@media screen and (max-width: 768px) {
  .dev-archive__txt {
    margin-bottom: 10px;
    font-size: 16px;
    line-height: 2.125;
  }
}

.the_content > * {
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .the_content > * {
    margin-bottom: 16px;
  }
}
.the_content > *:last-child {
  margin-bottom: 0;
}
.the_content p + p {
  margin-top: 38px;
}
.the_content p img {
  width: auto;
  margin-left: auto;
  margin-right: auto;
}
.the_content figure {
  margin-bottom: 42px;
}
@media screen and (max-width: 768px) {
  .the_content figure {
    margin-bottom: 32px;
  }
}
.the_content img {
  overflow: hidden;
  border-radius: 56px;
}
@media screen and (max-width: 768px) {
  .the_content img {
    border-radius: 40px;
  }
}
.the_content ul, .the_content ol {
  padding-left: 50px;
}
@media screen and (max-width: 768px) {
  .the_content ul, .the_content ol {
    padding-left: 20px;
  }
}
.the_content ul li, .the_content ol li {
  padding-left: 50px;
}
@media screen and (max-width: 768px) {
  .the_content ul li, .the_content ol li {
    padding-left: 35px;
  }
}
.the_content ul li + li, .the_content ol li + li {
  margin-top: 12px;
}
.the_content ul li {
  position: relative;
}
.the_content ul li::before {
  content: "";
  position: absolute;
  width: 21px;
  height: 21px;
  top: 5px;
  left: 0;
  border-radius: 50%;
  background: #F8DADA;
}
.the_content ul.row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding-left: 0;
}
.the_content ul.row li {
  margin-right: 50px;
  padding-left: 0;
}
.the_content ul.row li::before {
  content: none;
}
.the_content ul.row li:last-of-type {
  margin-right: 0;
}
.the_content ul.row li img {
  width: 100%;
}
.the_content ul.row li a {
  display: block;
  text-decoration: none;
}
.the_content ol {
  counter-reset: item;
}
.the_content ol li {
  position: relative;
}
.the_content ol li::before {
  content: counter(item) ".";
  counter-increment: item;
  position: absolute;
  top: 0;
  left: 0;
  font-weight: bold;
}
.the_content strong {
  font-weight: bold;
}
.the_content a {
  color: #FF44A1;
}
.the_content a:hover {
  opacity: 1;
  text-decoration: underline;
}

.archive-pager {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .archive-pager {
    gap: 12px;
  }
}
.archive-pager__btn {
  aspect-ratio: 1;
  display: flex;
  width: 43px;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  .archive-pager__btn {
    width: 39px;
  }
}
.archive-pager__btn i {
  display: flex;
}
.archive-pager__btn i svg {
  width: 100%;
}
.archive-pager__btn.-next svg {
  rotate: 180deg;
}
.archive-pager__btn[aria-disabled=true] {
  opacity: 0;
  visibility: hidden;
}
.archive-pager__items {
  display: flex;
  gap: 3px;
}
@media screen and (max-width: 768px) {
  .archive-pager__items {
    gap: 0;
  }
}
.archive-pager__item {
  min-width: 43px;
}
@media screen and (max-width: 768px) {
  .archive-pager__item {
    min-width: 39px;
  }
}
.archive-pager__item a {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 24px;
  line-height: 1.7916666667;
}
@media screen and (max-width: 768px) {
  .archive-pager__item a {
    line-height: 1.625;
  }
}
.archive-pager__item a[aria-current=page] {
  color: #FF44A1;
}

.footer {
  padding-bottom: 20px;
  border-top: 7px solid #FF44A1;
}
@media screen and (max-width: 768px) {
  .footer {
    padding-bottom: 33px;
  }
}
.footer__wrap {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px min(4.9404761905vw, 83px);
  margin-bottom: 58px;
  padding-top: 57px;
}
@media screen and (max-width: 768px) {
  .footer__wrap {
    justify-content: flex-start;
    margin-bottom: 42px;
    padding-bottom: 33px;
  }
}
.footer__head {
  display: block;
  width: 137px;
}
@media screen and (max-width: 768px) {
  .footer__head {
    width: 222px;
  }
}
.footer__head img {
  width: 100%;
}
.footer__copy {
  display: block;
  padding: 0 min(2.2619047619vw, 38px);
  font-size: 15px;
  line-height: 1.4;
  text-align: center;
  color: #383838;
}
@media screen and (max-width: 768px) {
  .footer__copy {
    display: flex;
    justify-content: center;
    white-space: nowrap;
    font-size: min(3.3333333333vw, 13px);
    line-height: 1.4615384615;
  }
}

.footer-nav {
  flex-grow: 1;
  max-width: 1050px;
}
.footer-nav__parent {
  display: flex;
  align-items: center;
  gap: 11px;
  padding-left: 1em;
  min-width: 116px;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .footer-nav__parent {
    gap: 11px;
    padding-left: 0;
  }
}
.footer-nav__parent[href] {
  min-width: 0;
  padding-left: 0;
}
.footer-nav__parent[href]::before {
  content: "";
  aspect-ratio: 1;
  flex-shrink: 0;
  width: 9px;
  border-radius: 50%;
  background: #FF44A1;
}
.footer-nav__children {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  gap: min(0.7142857143vw, 12px) min(1.1904761905vw, 20px);
  padding-left: min(1.25vw, 21px);
  border-left: 1px solid #B9B9B9;
}
@media screen and (max-width: 768px) {
  .footer-nav__children {
    flex-wrap: wrap;
    gap: 5px 2.0512820513vw;
    max-height: 112px;
    padding-left: min(5.641025641vw, 22px);
    border-left: none;
  }
}
.footer-nav__children.-horizontal {
  flex-direction: row;
  width: min(22.9166666667vw, 385px);
}
@media screen and (max-width: 768px) {
  .footer-nav__children.-horizontal {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .footer-nav__children.-type-1 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 7px 5.1282051282vw;
  }
}
@media screen and (max-width: 768px) {
  .footer-nav__children.-type-2 {
    gap: 7px 20px;
    max-width: 328px;
  }
}
.footer-nav__child a {
  display: flex;
  align-items: center;
  gap: min(0.5357142857vw, 9px);
}
@media screen and (max-width: 768px) {
  .footer-nav__child a {
    gap: 8px;
  }
}
.footer-nav__child a::before {
  content: "";
  aspect-ratio: 1;
  flex-shrink: 0;
  width: 7px;
  border-radius: 50%;
  background: #FF44A1;
}
.-type-2 > .footer-nav__child:nth-child(odd) {
  width: 105px;
}
.-type-2 > .footer-nav__child:nth-child(even) {
  flex-grow: 1;
}
.footer-nav__wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 18px min(1.9642857143vw, 33px);
}
@media screen and (max-width: 768px) {
  .footer-nav__wrap {
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    gap: 15px 0;
    height: auto;
  }
}
.footer-nav__items {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
@media screen and (max-width: 768px) {
  .footer-nav__items {
    display: contents;
  }
}
@media screen and (max-width: 1095px) {
  .footer-nav__items:last-child {
    display: flex;
    flex-grow: 1;
    flex-direction: row;
    flex-wrap: wrap;
  }
}
.footer-nav__item {
  display: flex;
  align-items: flex-start;
  gap: min(1.9047619048vw, 32px);
  font-size: 16px;
  line-height: 2.125;
}
@media screen and (max-width: 768px) {
  .footer-nav__item {
    flex-direction: column;
    width: 48.8%;
    font-size: min(4.6153846154vw, 18px);
    line-height: 1.8888888889;
  }
}
@media screen and (max-width: 768px) {
  .-type-1 > .footer-nav__item:first-child {
    order: -2;
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .-type-1 > .footer-nav__item:nth-child(2) {
    order: -1;
  }
}
@media screen and (max-width: 768px) {
  .-type-2 > .footer-nav__item:nth-child(1) {
    position: absolute;
    top: min(55.1282051282vw, 222px);
    left: 0;
  }
}
@media screen and (max-width: 768px) {
  .-type-2 > .footer-nav__item:nth-child(4) {
    order: -2;
  }
}
@media screen and (max-width: 768px) {
  .-type-2 > .footer-nav__item:nth-child(6) {
    order: -1;
  }
}
@media screen and (max-width: 768px) {
  .-type-3 > .footer-nav__item {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .footer-nav__item.-sns {
    width: 100%;
  }
}
.footer-nav__item.-sns:last-child {
  margin-top: 16px;
}
.footer-nav__item.-sns:first-child {
  margin-top: 0;
}

.wp-block-group.is-layout-grid {
  gap: 30px;
}
@media screen and (max-width: 768px) {
  .wp-block-group.is-layout-grid {
    grid-template-columns: 1fr;
  }
}

.wp-block-image .aligncenter {
  display: flex;
  justify-content: center;
}
.wp-block-image .alignleft {
  display: flow-root;
  float: left;
  margin-right: 30px;
}
.wp-block-image .alignright {
  display: flow-root;
  float: right;
  margin-left: 30px;
}
