/*!*********************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[1].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[1].use[3]!./assets/sass/app.scss ***!
  \*********************************************************************************************************************************************************************************************************************************************/
@import url(https://fonts.googleapis.com/css2?family=Ubuntu:wght@400;700&display=swap);
/*!*************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[1].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[1].use[3]!./assets/sass/app.scss (1) ***!
  \*************************************************************************************************************************************************************************************************************************************************/
@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap);
/*!*************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[1].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[1].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[1].use[3]!./assets/sass/app.scss (2) ***!
  \*************************************************************************************************************************************************************************************************************************************************/
html {
  width: 100%;
  height: 100%;
  scroll-behavior: smooth;
}
@media only screen and ( max-width: 374px ) {
  html {
    font-size: 53.3%;
  }
}

body {
  -webkit-text-size-adjust: 100%;
  -webkit-print-color-adjust: exact;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  word-wrap: break-word;
  color: #727272;
  font-family: "Noto Sans JP", sans-serif;
}
body.is-noscroll {
  overflow: hidden;
}

* {
  box-sizing: border-box;
}

img {
  -ms-interpolation-mode: bicubic;
  max-width: 100%;
  height: auto;
}

@media print, only screen and ( min-width: 960px ) {
  .inner {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 66.875);
    margin-left: auto;
    margin-right: auto;
  }
}

@media print, only screen and ( min-width: 960px ) {
  .wide-inner {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 75);
    margin-left: auto;
    margin-right: auto;
  }
}

.wrapper {
  position: relative;
  padding-top: 3.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wrapper {
    padding-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.125);
  }
}

.is-line-bg {
  position: relative;
}
.is-line-bg:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 0.25rem;
  background-image: url(../images/common/line.png);
  background-size: auto 0.25rem;
  background-repeat: repeat-x;
  background-position: left top;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .is-line-bg:after {
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
    background-size: auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 66.25);
    margin: 0 auto;
  }
}

.section-headline {
  color: #23A1D6;
  margin-bottom: 0.625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .section-headline {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
  }
}
.section-headline p {
  margin: 0 0 0.125rem;
  font-weight: 700;
  font-size: 0.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .section-headline p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.8125);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    letter-spacing: 0.16em;
  }
}
.section-headline h2 {
  font-weight: 900;
  font-size: 2rem;
  line-height: 1.3;
  letter-spacing: 0.12em;
  margin: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .section-headline h2 {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
    line-height: 1.2;
  }
}

.section__catch {
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.73;
  margin: 0 0 1.25rem;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .section__catch {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    margin: 0 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
  }
}

.section__text {
  font-size: 0.875rem;
  line-height: 1.86;
  margin: 1.25rem 0 2.25rem;
  color: #3A3A3A;
}
@media print, only screen and ( min-width: 960px ) {
  .section__text {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    line-height: 1.81;
    font-weight: 500;
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
  }
}

.section-btn {
  margin: 0;
}

.section-btn__link {
  border: 2px solid #23A1D6;
  border-radius: 100vmax;
  background-color: #fff;
  box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
  display: block;
  text-decoration: none;
  text-align: center;
  color: #23A1D6;
  font-weight: 700;
  letter-spacing: normal;
  letter-spacing: 0.05em;
  padding: 1.1875rem 0;
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 18.75rem;
  margin: 0 auto;
  gap: 0 0.3125rem;
  font-size: 1.0625rem;
  width: 100%;
}
@media print, only screen and ( min-width: 960px ) {
  .section-btn__link {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 21.875);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.375) 0;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .section-btn__link:where(:any-link, :enabled, summary):hover {
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.08);
  }
}
.section-btn__link:before {
  content: "";
  display: block;
  width: 0.625rem;
  height: 0.875rem;
  background-image: url(../images/common/icon-triangle.svg);
  background-size: 0.625rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .section-btn__link:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
  }
}

.editor-visual-editor.is-scrollable .block-editor-block-canvas {
  background-color: #fff;
}

input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: var(--wp--preset--color--col-txtsubsub, #ABABAB);
}

input::-moz-placeholder, textarea::-moz-placeholder {
  color: var(--wp--preset--color--col-txtsubsub, #ABABAB);
}

input:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: var(--wp--preset--color--col-txtsubsub, #ABABAB);
}

input::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: var(--wp--preset--color--col-txtsubsub, #ABABAB);
}

.snow-monkey-form {
  margin-top: 3rem;
}
@media print, only screen and ( min-width: 960px ) {
  .snow-monkey-form {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75);
  }
}

.smf-form .smf-item {
  margin-bottom: 2rem;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item {
    display: flex;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
  }
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item__col--label {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 13.75);
  }
}
.smf-form .smf-item__label {
  color: #3A3A3A;
  font-size: 0.875rem;
  line-height: 1.8;
  margin: 0 0 0.5rem;
  font-weight: 500;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item__label {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin: 0;
  }
}
.smf-form .smf-item__label__text {
  position: relative;
  display: block;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item__label__text {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5);
  }
}
.smf-form .smf-item__label__text:has(> mark) {
  padding-left: 3.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item__label__text:has(> mark) {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5);
  }
}
.smf-form .smf-item__label__text mark {
  position: absolute;
  height: fit-content;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  z-index: 1;
  padding: 0.125rem 0.75rem;
  line-height: 1.5;
  font-size: 0.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item__label__text mark {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.125) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
  }
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item__col--controls {
    flex: 1;
  }
}
.smf-form .smf-item__controls input {
  border-radius: 10px;
  border: 2px solid #D8D8D8;
  width: 100%;
  font-size: 0.875rem;
  line-height: 1.8;
  font-weight: 500;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item__controls input {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    border: 3px solid #D8D8D8;
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.smf-form .smf-item__controls input:focus {
  border: 2px solid #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item__controls input:focus {
    border: 3px solid #23A1D6;
  }
}
.smf-form .smf-item__controls textarea {
  border-radius: 10px;
  border: 2px solid #D8D8D8;
  width: 100%;
  font-size: 0.875rem;
  line-height: 1.8;
  font-weight: 500;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item__controls textarea {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    border: 3px solid #D8D8D8;
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.smf-form .smf-item__controls textarea:focus {
  border: 2px solid #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-form .smf-item__controls textarea:focus {
    border: 3px solid #23A1D6;
  }
}

.smf-action {
  margin-top: 3rem;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-action {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.9375);
  }
}
.smf-action button.smf-button-control__control {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 0.5rem;
  -webkit-appearance: none;
          appearance: none;
  outline: none;
  border-radius: 100vmax;
  border: 2px solid #23A1D6;
  background: #FFF;
  box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
  font-size: 1.125rem;
  font-weight: 700;
  color: #23A1D6;
  width: 100%;
  max-width: 15rem;
  padding: 1rem;
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-action button.smf-button-control__control {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 16.875);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .smf-action button.smf-button-control__control:where(:any-link, :enabled, summary):hover {
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.08);
  }
}
.smf-action button.smf-button-control__control:before {
  content: "";
  display: block;
  width: 0.625rem;
  height: 0.875rem;
  background-image: url(../images/common/icon-triangle.svg);
  background-size: 0.625rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .smf-action button.smf-button-control__control:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
  }
}

.wp-block-post-content p {
  font-size: 0.875rem;
  line-height: 1.78;
  margin: 1.25rem 0;
  color: #3A3A3A;
  font-weight: 500;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    line-height: 2;
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2) 0;
  }
}
.wp-block-post-content p a {
  color: #23A1D6;
  text-decoration: underline;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content p a {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .wp-block-post-content p a:where(:any-link, :enabled, summary):hover {
    text-decoration: none;
  }
}
.wp-block-post-content h2.wp-block-heading {
  color: #23A1D6;
  font-size: 1.125rem;
  line-height: 1.38;
  margin: 3rem 0 1.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content h2.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    line-height: 1.375;
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
  }
}
.wp-block-post-content .wp-block-list {
  font-size: 0.875rem;
  line-height: 1.78;
  margin: 0;
  color: #3A3A3A;
  padding-left: 1rem;
  font-weight: 500;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content .wp-block-list {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    line-height: 2;
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}
.wp-block-post-content ul.wp-block-list li::marker {
  font-size: 0.625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content ul.wp-block-list li::marker {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
  }
}
.wp-block-post-content p:has(+ .wp-block-list) {
  margin-bottom: 0;
}
.wp-block-post-content .wp-block-columns-is-layout-flex {
  margin: 0.25rem 0;
  gap: 0 0.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content .wp-block-columns-is-layout-flex {
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25) 0;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
  }
}
.wp-block-post-content .wp-block-columns-is-layout-flex .wp-block-column {
  margin: 0.25rem 0;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content .wp-block-columns-is-layout-flex .wp-block-column {
    margin: 0;
  }
}

.wp-pattern-contact-info {
  border-radius: 10px;
  border: 3px solid #AEDBF5;
  padding: 1.5rem 0.75rem;
  margin-top: 2rem;
  max-width: 37.5rem;
  margin-left: auto;
  margin-right: auto;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-contact-info {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.25);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 41.25);
  }
}
.wp-pattern-contact-info .wp-block-group {
  width: fit-content;
  margin: 0 auto;
}
.wp-pattern-contact-info h3.wp-block-heading {
  margin: 0;
  font-weight: 700;
  color: #3A3A3A;
  font-size: 1.125rem;
  line-height: 1.6;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-contact-info h3.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.wp-pattern-contact-info p {
  margin: 0;
  font-size: 0.875rem;
  line-height: 2;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-contact-info p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

.page-heading {
  text-align: center;
  margin-bottom: 3rem;
}
@media print, only screen and ( min-width: 960px ) {
  .page-heading {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5);
  }
}
.page-heading p {
  margin: 0;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  line-height: 1.5;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .page-heading p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.8125);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
  }
}
.page-heading h1 {
  font-size: 1.5rem;
  line-height: 1.5;
  letter-spacing: 0.12em;
  font-weight: 900;
  margin: 0;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .page-heading h1 {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
    line-height: 1;
  }
}

.entry-header__title {
  font-size: 1.125rem;
  line-height: 1.4;
  font-weight: 700;
  margin: 0 0 2rem;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .entry-header__title {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
  }
}

.wp-pattern-section-headline {
  padding-left: 1.25rem;
  border-left: 6px solid #23A1D6;
  margin-bottom: 1.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-section-headline {
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
    border-left: 9px solid #23A1D6;
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75);
  }
}
.wp-pattern-section-headline p {
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.16em;
  color: #23A1D6;
  margin: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-section-headline p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}
.wp-pattern-section-headline h2.wp-block-heading {
  font-size: 1.5rem;
  line-height: 1.3;
  letter-spacing: 0.12em;
  font-weight: 900;
  margin: 0 !important;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-section-headline h2.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
  }
}

.wp-pattern-subheading {
  margin: 2rem 0 1.5rem;
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.72;
  letter-spacing: 0.03em;
  color: #23A1D6;
  padding-left: 1.625rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-subheading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5) auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    width: fit-content;
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.625);
  }
}
.wp-pattern-subheading::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.625rem;
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 50%;
  background-color: #23A1D6;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-subheading::before {
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
  }
}

.wp-pattern-buttons {
  display: flex;
  flex-wrap: wrap;
  margin: 1.25rem 0;
  gap: 1rem 0.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-buttons {
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875) 0;
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}

.wp-pattern-buttons-item {
  width: calc((100% - 0.5rem) / 2);
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-buttons-item {
    width: calc((100% - 2.5rem) / 3);
  }
}
.wp-pattern-buttons-item .wp-block-button__link {
  font-size: 0.75rem;
  line-height: 1.5;
  border-radius: 100vmax;
  border: 1.5px solid #23A1D6;
  background: #FFF;
  box-shadow: 0px 2px 0px 0px rgba(0, 0, 0, 0.08);
  color: #23A1D6;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 0.25rem;
  padding: 0.625rem;
  letter-spacing: 0.05em;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-buttons-item .wp-block-button__link {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
    border: 2px solid #23A1D6;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.375);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .wp-pattern-buttons-item .wp-block-button__link:where(:any-link, :enabled, summary):hover {
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.08);
  }
}
.wp-pattern-buttons-item .wp-block-button__link:before {
  content: "";
  display: block;
  width: 0.5rem;
  min-width: 0.5rem;
  height: 0.6875rem;
  background-image: url(../images/common/icon-triangle.svg);
  background-size: 0.5rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-buttons-item .wp-block-button__link:before {
    min-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.0625);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875) auto;
  }
}
.wp-pattern-buttons-item.is-full {
  width: 100%;
}
.wp-pattern-buttons-item.is-full .wp-block-button__link {
  font-size: 0.8125rem;
  padding: 1rem;
  box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-buttons-item.is-full .wp-block-button__link {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .wp-pattern-buttons-item.is-full .wp-block-button__link:where(:any-link, :enabled, summary):hover {
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.08);
  }
}
.wp-pattern-buttons-item.is-full .wp-block-button__link:before {
  width: 0.6875rem;
  height: 1rem;
  background-size: 0.6875rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-buttons-item.is-full .wp-block-button__link:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875) auto;
  }
}

.wp-pattern-link-button a {
  display: flex;
  border-radius: 100vmax;
  border: 2px solid #23A1D6;
  background: #FFF;
  box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
  align-items: center;
  justify-content: center;
  gap: 0 0.375rem;
  padding: 1.25rem 1rem;
  max-height: 4.375rem;
  text-decoration: none;
  color: #23A1D6;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  max-width: 21.25rem;
  line-height: 1.2;
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-link-button a {
    width: fit-content;
    max-width: 100%;
    min-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 21.25);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
    max-height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.625);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
@media print, only screen and ( min-width: 960px ) and ( min-width: 960px ) {
  .wp-pattern-link-button a {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and ( min-width: 960px ) and (hover: hover) {
  .wp-pattern-link-button a:where(:any-link, :enabled, summary):hover {
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.08);
  }
}
.wp-pattern-link-button a:before {
  content: "";
  display: block;
  width: 0.5rem;
  height: 0.6875rem;
  background-image: url(../images/common/icon-triangle.svg);
  background-size: 0.5rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-link-button a:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.0625);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875) auto;
  }
}

.wp-pattern-cards {
  margin: 2rem 0;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-cards {
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2) 0;
  }
}

.wp-pattern-card {
  padding: 3rem 0;
  background-image: url(../images/common/line.png);
  background-size: auto 0.25rem;
  background-repeat: repeat-x;
  background-position: left bottom;
  margin: 0 !important;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-card {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.375) 0;
    background-size: auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
  }
}
.wp-pattern-card:last-of-type {
  background: none;
}

.wp-pattern-card__contents {
  flex-direction: column-reverse;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-card__contents {
    flex-direction: row;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
  }
}
.wp-pattern-card__contents h3.wp-block-heading {
  color: #00AF97;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.37;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-card__contents h3.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
  }
}
.wp-pattern-card__contents p {
  font-size: 0.875rem;
  color: #3A3A3A;
  line-height: 2;
  font-weight: 500;
  margin-top: 0.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-card__contents p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin-top: 1.5rem;
  }
}
.wp-pattern-card__contents .wp-block-image {
  overflow: hidden;
  border-radius: 10px;
  text-align: center;
}

@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content .wp-block-columns-is-layout-flex.wp-pattern-card__contents {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
  }
}

.site-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.625rem;
  padding: 0.9375rem 1.25rem 1.0625rem;
  background-image: url("../images/common/line.svg"), linear-gradient(180deg, rgb(255, 255, 255) 0%, rgb(255, 255, 255) 95%, rgba(252, 244, 217, 0) 100%);
  background-size: auto 0.25rem, auto;
  background-position: bottom;
  background-repeat: repeat-x;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  transition: transform 0.3s ease;
}
.site-header.is-hidden {
  transform: translateY(-100%);
}
@media print, only screen and ( min-width: 960px ) {
  .site-header {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.625) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.25);
    background-size: auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375), auto;
    align-items: flex-end;
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 43.75);
  }
  .site-header.is-hidden {
    transform: translateY(0);
  }
}

.site-branding {
  margin: 0;
  line-height: 0;
  max-width: 8.0625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .site-branding {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 11.5);
  }
}

.site-branding__link {
  display: block;
}
@media print, only screen and ( min-width: 960px ) {
  .site-branding__link {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .site-branding__link:where(:any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
}

.site-footer {
  padding-top: 4.1875rem;
  background-image: url(../images/common/footer-decoration.png);
  background-repeat: repeat-x;
  background-size: auto 4.1875rem;
  background-position: left top;
}
@media print, only screen and ( min-width: 960px ) {
  .site-footer {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.375) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.125);
    background-size: auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.375);
  }
}

.footer-contents {
  padding: 3.375rem 1rem 0;
}
@media print, only screen and ( min-width: 960px ) {
  .footer-contents {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.8125) 0 0;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 73.75);
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
  }
}

.footer-information {
  margin-bottom: 0.3125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .footer-information {
    margin-bottom: 0;
  }
}

.footer-logo {
  max-width: 11.5rem;
  margin: 0 auto 2.125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .footer-logo {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 11.5);
    margin: 0 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
  }
}
.footer-logo a {
  display: block;
  line-height: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .footer-logo a {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .footer-logo a:where(:any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
}

.footer-address {
  margin: 2.125rem 0 1.6875rem;
  text-align: center;
}
@media print, only screen and ( min-width: 960px ) {
  .footer-address {
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    text-align: left;
  }
}
.footer-address p {
  font-size: 0.875rem;
  line-height: 1.64;
  margin: 0;
  color: #000;
}
@media print, only screen and ( min-width: 960px ) {
  .footer-address p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    line-height: 1.92;
  }
}
.footer-address p:not(:last-of-type) {
  margin-bottom: 1.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .footer-address p:not(:last-of-type) {
    margin-bottom: 0;
  }
}

.site-footer .site-sns-lists {
  justify-content: center;
}
@media print, only screen and ( min-width: 960px ) {
  .site-footer .site-sns-lists {
    justify-content: flex-start;
  }
}

.copyright {
  margin: 1.6875rem 0 0;
  text-align: center;
}
@media print, only screen and ( min-width: 960px ) {
  .copyright {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.0625);
    text-align: left;
  }
}
.copyright small {
  display: block;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 2.41;
}
@media print, only screen and ( min-width: 960px ) {
  .copyright small {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
  }
}

.footer-image {
  max-width: 22.5rem;
  margin: 0 auto;
  line-height: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .footer-image {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 20.1875);
    margin: 0;
  }
}

@media print, only screen and ( min-width: 960px ) {
  .footer-navigation {
    padding-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 21.875);
  }
}

@media print, only screen and ( min-width: 960px ) {
  .footer-navigation-list {
    list-style: none;
    margin: 0 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
    padding: 0;
    display: flex;
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    flex-wrap: wrap;
    justify-content: space-between;
  }
}

@media print, only screen and ( min-width: 960px ) {
  .footer-navigation-list__item {
    width: calc((100% - clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) / 2);
  }
}

.footer-navigation-list__link {
  color: #727272;
}
@media print, only screen and ( min-width: 960px ) {
  .footer-navigation-list__link {
    display: block;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.8125);
    line-height: 1.5;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .footer-navigation-list__link:where(:any-link, :enabled, summary):hover {
    text-decoration: underline;
  }
}

.footer-links__item {
  color: #727272;
}
@media print, only screen and ( min-width: 960px ) {
  .footer-links__item {
    display: block;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.8125);
    line-height: 1.5;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .footer-links__item:where(:any-link, :enabled, summary):hover {
    text-decoration: underline;
  }
}
@media print, only screen and ( min-width: 960px ) {
  .footer-links__item:not(:last-of-type) {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
  }
}

@media print, only screen and ( min-width: 960px ) {
  .footer-navigation-sublist {
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
    padding-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
  }
}

@media print, only screen and ( min-width: 960px ) {
  .footer-navigation-sublist__item {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.8125);
    color: #727272;
    text-decoration: none;
    display: block;
    line-height: 1.5;
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    position: relative;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
  .footer-navigation-sublist__item:before {
    content: "";
    position: absolute;
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.0625);
    background-color: #727272;
    top: 0;
    bottom: 0;
    margin: auto;
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -0.625);
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .footer-navigation-sublist__item:where(:any-link, :enabled, summary):hover {
    text-decoration: underline;
  }
}

.site-navigation {
  position: absolute;
  z-index: 10;
  top: 3.875rem;
  height: calc(100vh - 3.875rem);
  background-color: #fff;
  width: 100%;
  left: 0;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  backface-visibility: hidden;
  padding: 1rem 1.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation {
    display: block;
    background-color: transparent;
    position: absolute;
    height: auto;
    inset: 0;
    padding: 0;
    max-width: fit-content;
    margin: auto;
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.125);
    overflow: initial;
    opacity: 1;
    visibility: visible;
  }
}
.site-navigation.is-open {
  opacity: 1;
  visibility: visible;
}

.site-navigation-lists {
  margin: 0;
  padding: 0;
  list-style: none;
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists {
    display: flex;
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
    align-items: center;
    height: 100%;
  }
}

@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists__item {
    position: relative;
  }
  .site-navigation-lists__item:has(> span.site-navigation-lists__link):hover > .site-navigation-lists-nav {
    opacity: 1;
    visibility: visible;
  }
}

.site-navigation-lists__link {
  color: #727272;
  text-decoration: none;
  display: block;
  transition: all 0.3s;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.5;
  padding: 1rem 0.875rem;
  border-bottom: 1px solid #CCCCCC;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists__link {
    padding: 0;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    letter-spacing: 0.02em;
    border: none;
  }
  .site-navigation-lists__link:hover {
    color: #23A1D6;
    cursor: pointer;
  }
}
.site-navigation-lists__link:after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  bottom: 0;
  margin: auto;
  right: 1rem;
  width: 0.5rem;
  height: 0.75rem;
  background-image: url(../images/common/icon-triangle.svg);
  background-size: 0.5rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists__link:after {
    display: none;
  }
}

span.site-navigation-lists__link:after {
  transition: all 0.5s;
  transform: rotate(90deg);
}
@media print, only screen and ( min-width: 960px ) {
  span.site-navigation-lists__link:after {
    display: none;
  }
}
span.site-navigation-lists__link.is-active:after {
  transform: rotate(-90deg);
}

.site-navigation-lists-nav {
  transition: all 0.7s ease;
}
@media only screen and ( max-width: 959px ) {
  .site-navigation-lists-nav {
    max-height: 0;
    overflow: hidden;
  }
  .site-navigation-lists-nav.is-active {
    max-height: fit-content;
    margin-top: 1.25rem;
    overflow: visible;
  }
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists-nav {
    position: absolute;
    bottom: 1px;
    transform: translateY(100%);
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -3);
    padding-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    opacity: 0;
    visibility: hidden;
  }
  .site-navigation-lists-nav * {
    white-space: nowrap;
  }
}
.site-navigation-lists-nav div {
  background-color: #23A1D6;
  border-radius: 10px;
  padding: 1.75rem 1.5rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists-nav div {
    padding: 1.25rem;
  }
}
.site-navigation-lists-nav div:after {
  content: "";
  position: absolute;
  z-index: 1;
  width: 0.75rem;
  height: 0.5rem;
  background-color: #23A1D6;
  clip-path: polygon(50% 0, 0 100%, 100% 100%);
  top: 1px;
  transform: translateY(-100%);
  left: 2.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists-nav div:after {
    display: none;
  }
}
.site-navigation-lists-nav a {
  display: flex;
  align-items: center;
  gap: 0 0.75rem;
  color: #fff;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.02em;
  text-decoration: none;
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists-nav a {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5625);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .site-navigation-lists-nav a:where(:any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
}
.site-navigation-lists-nav a:not(:first-of-type) {
  margin-top: 1.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists-nav a:not(:first-of-type) {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.site-navigation-lists-nav a:before {
  content: "";
  display: block;
  width: 0.5rem;
  height: 0.5rem;
  background-image: url(../images/common/icon-triangle-yellow.svg);
  background-size: 0.5rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists-nav a:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375) auto;
  }
}
.site-navigation-lists-nav p {
  color: #FFF200;
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.5;
  padding: 1rem 1rem 0;
  border-top: 1px solid #FFF200;
}
@media print, only screen and ( min-width: 960px ) {
  .site-navigation-lists-nav p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) 0;
  }
}

.site-secondary-navigation {
  display: flex;
  gap: 1.5625rem;
  align-items: center;
}
@media print, only screen and ( min-width: 960px ) {
  .site-secondary-navigation {
    display: block;
  }
}

.site-sns-lists {
  display: flex;
  gap: 0.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .site-sns-lists {
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}

.site-sns-lists__item {
  display: block;
  max-width: 1.625rem;
  line-height: 0;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .site-sns-lists__item {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .site-sns-lists__item:where(:any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
}
.site-sns-lists__item span {
  position: absolute;
  font-size: 0.4375rem;
  white-space: nowrap;
  left: 50%;
  transform: translateX(-50%);
  bottom: -0.5rem;
  color: #000;
}
@media print, only screen and ( min-width: 960px ) {
  .site-sns-lists__item span {
    font-size: 0.5rem;
  }
}

.site-menu-button.is-open .dropdown-icon__line {
  opacity: 0;
}
.site-menu-button.is-open .dropdown-icon__line:first-of-type {
  opacity: 1;
  bottom: 0;
  transform: rotate(35deg);
}
.site-menu-button.is-open .dropdown-icon__line:last-of-type {
  opacity: 1;
  top: 0;
  transform: rotate(-35deg);
}

.dropdown-icon {
  display: block;
  width: 1.5rem;
  height: 1.1875rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .dropdown-icon {
    display: none;
  }
}

.dropdown-icon__line {
  position: absolute;
  inset: 0;
  height: 0.25rem;
  width: 100%;
  margin: auto;
  background-color: #23A1D6;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  backface-visibility: hidden;
}
.dropdown-icon__line:first-of-type {
  bottom: auto;
}
.dropdown-icon__line:last-of-type {
  top: auto;
}

.wp-block-post-content {
  padding: 2.875rem 1.25rem 5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.6875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 11.25);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 50);
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content.is-full {
    max-width: 100%;
  }
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content.is-desktop-preview {
    max-width: 100%;
  }
}

.has-bg-blue {
  padding: 2.5rem 1.6875rem 3.75rem;
  background-image: url(../images/top/overview-bg.png);
  background-size: cover;
}
@media print, only screen and ( min-width: 960px ) {
  .has-bg-blue {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.5);
  }
}

.has-bg-blue-inner {
  padding: 2.5rem 1.5rem 1.875rem;
  background-color: #fff;
  border-radius: 10px;
}
@media print, only screen and ( min-width: 960px ) {
  .has-bg-blue-inner {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 75);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.25);
  }
}

.local-navigation-items {
  margin-top: 3.75rem;
  padding-top: 3.25rem;
  padding-bottom: 6.25rem;
  display: flex;
  justify-content: space-between;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .local-navigation-items {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75);
    padding-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    padding-bottom: 0;
  }
}
.local-navigation-items:before {
  content: "";
  position: absolute;
  width: 100vw;
  left: -1.25rem;
  right: -1.25rem;
  height: 0.25rem;
  background-image: url(../images/common/line.png);
  background-size: auto 0.25rem;
  background-repeat: repeat-x;
  top: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .local-navigation-items:before {
    left: 0;
    right: 0;
    width: 100%;
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
    background-size: auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
  }
}

@media print, only screen and ( min-width: 960px ) {
  .local-navigation-item {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.875);
  }
}

.local-navigation-item__link {
  display: block;
  text-decoration: none;
  font-size: 1rem;
  font-weight: 700;
  color: #23A1D6;
  line-height: 1.5;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .local-navigation-item__link {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}
.local-navigation-item__link:after {
  content: "";
  position: absolute;
  z-index: 1;
  width: 0.5rem;
  height: 0.75rem;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="9" height="12" fill="none"><path stroke="%2323A1D6" stroke-width="2" d="m1 1.059 6 5-6 5"/></svg>');
  background-size: 0.53125rem auto;
  top: 0.125rem;
  bottom: 0;
  margin: auto;
}
@media print, only screen and ( min-width: 960px ) {
  .local-navigation-item__link:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}

.is-prev .local-navigation-item__link {
  padding-left: 1.625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .is-prev .local-navigation-item__link {
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.375);
  }
}
.is-prev .local-navigation-item__link:after {
  left: 0;
  transform: rotate(180deg);
}

.is-next .local-navigation-item__link {
  padding-right: 1.625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .is-next .local-navigation-item__link {
    padding-right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.375);
  }
}
.is-next .local-navigation-item__link:after {
  right: 0;
}

.local-navigation-button {
  position: absolute;
  bottom: 0;
  width: fit-content;
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .local-navigation-button {
    position: initial;
  }
}

.back-button {
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 700;
  color: #23A1D6;
  text-decoration: none;
  padding: 0 0.5rem 0.6875rem;
  border-bottom: 2px solid #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .back-button {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    letter-spacing: 0.02em;
    line-height: 1.3;
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
  }
}

.pager {
  margin-top: 4rem;
}
@media print, only screen and ( min-width: 960px ) {
  .pager {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5);
  }
}

.pager-lists {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 0.5rem;
  width: fit-content;
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .pager-lists {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
  }
}

.page-numbers {
  font-size: 0.875rem;
  color: #727272;
  display: flex;
  width: 2rem;
  height: 1.875rem;
  justify-content: center;
  align-items: center;
  border-radius: 5px;
  font-weight: 500;
  text-decoration: none;
  background-color: #D8D8D8;
  color: #3A3A3A;
}
@media print, only screen and ( min-width: 960px ) {
  .page-numbers {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.3125);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.0625);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
.page-numbers.is-current {
  background-color: #23A1D6;
  color: #fff;
}

.prev,
.next {
  display: none;
}

span.prev,
span.next {
  opacity: 0;
  visibility: hidden;
}

.archive-contents {
  margin: 0;
}
.archive-contents .entry-loop {
  display: flex;
  gap: 1.5rem 1rem;
  flex-wrap: wrap;
}
@media print, only screen and ( min-width: 960px ) {
  .archive-contents .entry-loop {
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.25);
  }
}
.archive-contents .entry-item {
  width: calc((100% - 1rem) / 2);
}
@media print, only screen and ( min-width: 960px ) {
  .archive-contents .entry-item {
    width: calc((100% - clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.75) / 4);
  }
}
.archive-contents .entry-item__link {
  display: block;
  border-radius: 20px 20px 0px 0px;
  border: 1px solid #00A8DE;
  padding: 0.75rem 0.75rem 1.25rem;
  text-decoration: none;
  color: #23A1D6;
  height: 100%;
}
@media print, only screen and ( min-width: 960px ) {
  .archive-contents .entry-item__link {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .archive-contents .entry-item__link:where(:any-link, :enabled, summary):hover .entry-item__thumbnail img {
    transform: scale(1.08);
  }
  .archive-contents .entry-item__link:where(:any-link, :enabled, summary):hover .entry-item__title {
    color: #23A1D6;
  }
}
.archive-contents .entry-item__thumbnail {
  overflow: hidden;
  border-radius: 20px 20px 0px 0px;
  margin-bottom: 0.9375rem;
}
@media print, only screen and ( min-width: 960px ) {
  .archive-contents .entry-item__thumbnail {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.9375);
  }
}
@media print, only screen and ( min-width: 960px ) {
  .archive-contents .entry-item__thumbnail img {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
.archive-contents .entry-item__detail {
  padding: 0 0.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .archive-contents .entry-item__detail {
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
  }
}
.archive-contents .entry-item__date {
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 2;
}
@media print, only screen and ( min-width: 960px ) {
  .archive-contents .entry-item__date {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
  }
}
.archive-contents .entry-item__title {
  font-size: 1rem;
  line-height: 1.8;
  color: #727272;
  font-weight: 700;
}
@media print, only screen and ( min-width: 960px ) {
  .archive-contents .entry-item__title {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}

.front-mainvisual {
  height: auto;
  aspect-ratio: 375/530;
  position: relative;
  overflow: hidden;
  background-image: url(../images/top/main-visual-bg_sp.png);
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: left bottom;
}
@media print, only screen and ( min-width: 960px ) {
  .front-mainvisual {
    aspect-ratio: 1440/735;
    background-image: url(../images/top/main-visual-bg_pc.png);
  }
}

.front-mainvisual-contents {
  padding: 0 6.4%;
  position: absolute;
  top: 22%;
  left: 0;
  right: 0;
  z-index: 1;
  line-height: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .front-mainvisual-contents {
    padding: 0;
    top: 9.8%;
    left: 5%;
    max-width: 50.69%;
  }
}

.front-mainvisual__catch {
  margin: 0 0 1.125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-mainvisual__catch {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.375);
  }
}

.front-mainvisual__btn {
  display: block;
  border: 2px solid #23A1D6;
  box-shadow: 0px 3px 0px 0px rgba(0, 0, 0, 0.08);
  border-radius: 100vmax;
  max-width: 10.625rem;
  margin: auto;
  text-decoration: none;
  color: #23A1D6;
  display: flex;
  gap: 0 0.8125rem;
  align-items: center;
  font-size: 0.8125rem;
  font-weight: 700;
  justify-content: center;
  line-height: 2;
  padding: 0.25rem 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-mainvisual__btn {
    margin: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 8.375);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 15.125);
    box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    font-weight: 700;
    line-height: 1.5;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .front-mainvisual__btn:where(:any-link, :enabled, summary):hover {
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.08);
  }
}
.front-mainvisual__btn:after {
  content: "";
  display: block;
  width: 0.5rem;
  height: 0.6875rem;
  background-image: url(../images/common/icon-triangle.svg);
  background-size: 0.5rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .front-mainvisual__btn:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.0625);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875) auto;
  }
}

.front-mainvisual-image {
  position: absolute;
  z-index: 1;
}

.front-mainvisual-image-01 {
  max-width: 33.6%;
  top: 0;
  left: 7.2%;
}
@media print, only screen and ( min-width: 960px ) {
  .front-mainvisual-image-01 {
    max-width: 17.91%;
    left: auto;
    right: -0.8%;
    rotate: 30deg;
    top: 6.25%;
  }
}

.front-mainvisual-image-02 {
  max-width: 38%;
  top: 9%;
  right: 5.6%;
  rotate: 14deg;
}
@media print, only screen and ( min-width: 960px ) {
  .front-mainvisual-image-02 {
    top: 9.5%;
    right: 23.75%;
    max-width: 22.36%;
    rotate: 15deg;
  }
}

.front-mainvisual-image-03 {
  max-width: 20.53%;
  bottom: 11.69%;
  right: 37.6%;
}
@media print, only screen and ( min-width: 960px ) {
  .front-mainvisual-image-03 {
    max-width: 15.69%;
    right: 19.16%;
    bottom: 23.4%;
  }
}

.front-mainvisual-image-04 {
  max-width: 16.53%;
  bottom: 26.93%;
  right: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .front-mainvisual-image-04 {
    bottom: 32.38%;
    max-width: 11.45%;
    right: -1%;
  }
}

.front-mainvisual-image-05 {
  max-width: 23.4%;
  bottom: 22.26%;
  left: 0;
}

.front-news {
  padding: 2.0625rem 1.6875rem 3.5625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-news {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.375);
  }
}

.front-news-contents {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
}
@media print, only screen and ( min-width: 960px ) {
  .front-news-contents {
    display: block;
  }
}

.front-news-head {
  display: contents;
}
@media print, only screen and ( min-width: 960px ) {
  .front-news-head {
    display: flex;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    justify-content: space-between;
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
    align-items: flex-end;
  }
}

.front-news-heading {
  order: 0;
  display: flex;
  align-items: flex-end;
  gap: 0 0.875rem;
  margin-bottom: 1.375rem;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .front-news-heading {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
    margin-bottom: 0;
  }
}
.front-news-heading h2 {
  margin: 0;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.15;
  font-family: "Ubuntu", sans-serif;
}
@media print, only screen and ( min-width: 960px ) {
  .front-news-heading h2 {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
  }
}
.front-news-heading p {
  font-size: 0.75rem;
  line-height: 2;
  margin: 0;
  font-weight: 700;
}
@media print, only screen and ( min-width: 960px ) {
  .front-news-heading p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    line-height: 2.5;
  }
}

.front-news__link {
  order: 2;
  margin-top: 2.1875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-news__link {
    margin: 0;
  }
}

.component-text__link {
  font-size: 1rem;
  font-weight: 700;
  display: block;
  padding: 0 1.25rem 0.6875rem;
  margin: 0 auto;
  width: fit-content;
  border-bottom: 2px solid #23A1D6;
  text-decoration: none;
  color: #23A1D6;
  position: relative;
  display: flex;
  gap: 0 1.125rem;
  align-items: center;
}
@media print, only screen and ( min-width: 960px ) {
  .component-text__link {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .component-text__link:where(:any-link, :enabled, summary):hover:after {
    transform: translateX(calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25));
  }
}
.component-text__link:after {
  content: "";
  width: 0.5rem;
  height: 0.75rem;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="9" height="12" fill="none"><path stroke="%2323A1D6" stroke-width="2" d="m1 1.059 6 5-6 5"/></svg>');
  background-size: cover;
}
@media print, only screen and ( min-width: 960px ) {
  .component-text__link:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
.component-text__link.is-white {
  border-bottom: 2px solid #fff;
  color: #fff;
}
.component-text__link.is-white:after {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="9" height="12" fill="none"><path stroke="%23fff" stroke-width="2" d="m1 1.059 6 5-6 5"/></svg>');
}

.front-entry-loop {
  order: 1;
  display: flex;
  flex-direction: column;
  gap: 1.125rem 0;
}
@media print, only screen and ( min-width: 960px ) {
  .front-entry-loop {
    flex-direction: row;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.25);
  }
}
.front-entry-loop .entry-item {
  border-radius: 10px;
  border: 1px solid #00A8DE;
}
@media print, only screen and ( min-width: 960px ) {
  .front-entry-loop .entry-item {
    border-radius: 20px 20px 0 0;
    overflow: hidden;
    width: calc((100% - clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.75) / 3);
  }
}
.front-entry-loop .entry-item__link {
  padding: 0.625rem;
  display: flex;
  gap: 0 1.125rem;
  text-decoration: none;
}
@media print, only screen and ( min-width: 960px ) {
  .front-entry-loop .entry-item__link {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.375);
    display: block;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .front-entry-loop .entry-item__link:where(:any-link, :enabled, summary):hover .entry-item__thumbnail img {
    transform: scale(1.1);
  }
  .front-entry-loop .entry-item__link:where(:any-link, :enabled, summary):hover .entry-item__title {
    color: #23A1D6;
  }
}
.front-entry-loop .entry-item__thumbnail {
  max-width: 5rem;
  height: auto;
  line-height: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .front-entry-loop .entry-item__thumbnail {
    max-width: 100%;
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    overflow: hidden;
    border-radius: 16px 16px 0 0;
  }
}
.front-entry-loop .entry-item__thumbnail img {
  object-fit: cover;
  object-position: center;
  aspect-ratio: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .front-entry-loop .entry-item__thumbnail img {
    aspect-ratio: 213/163;
    border-radius: 20px 20px 0 0;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
.front-entry-loop .entry-item__date time {
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 2.16;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .front-entry-loop .entry-item__date time {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    line-height: 2.07;
  }
}
.front-entry-loop .entry-item__title {
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.73;
  color: #727272;
}
@media print, only screen and ( min-width: 960px ) {
  .front-entry-loop .entry-item__title {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    line-height: 1.81;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}

.front-service {
  padding: 3.75rem 1.6875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-service {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.5);
  }
}

.front-service-container {
  width: fit-content;
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .front-service-container {
    display: flex;
    flex-direction: row-reverse;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.625);
    justify-content: center;
    width: 100%;
  }
}

.front-service-image {
  max-width: 20rem;
  padding-left: 3.125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-service-image {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 29.25);
    padding-left: 0;
  }
}

.front-service-detail {
  margin-top: -0.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-service-detail {
    margin-top: 0;
    flex: 1;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 21.875);
  }
}

.front-quality {
  padding: 3.75rem 1.6875rem;
  padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.375);
}

.front-quality-container {
  width: fit-content;
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .front-quality-container {
    display: flex;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.375);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 66.25);
    width: 100%;
  }
}

.front-quality-image {
  max-width: 18.75rem;
  margin-bottom: 1.5625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-quality-image {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 31.25);
    margin-bottom: 0;
  }
}

.front-quality-detail {
  flex: 1;
  max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 26.25);
}

.front-wom {
  padding: 3.75rem 1.6875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-wom {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.375) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.3125);
  }
}

@media print, only screen and ( min-width: 960px ) {
  .front-wom-container {
    display: flex;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 58.4375);
    margin: 0 auto;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.8125);
    flex-direction: row-reverse;
    align-items: center;
  }
}

.front-wom-image {
  max-width: 11.625rem;
  margin: 0 auto 1.5625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-wom-image {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 19.5);
    margin: 0;
  }
}

@media print, only screen and ( min-width: 960px ) {
  .front-wom-detail {
    flex: 1;
  }
}

.front-wom-detail__link {
  display: block;
  padding: 0 2.5rem 0.8125rem 1.25rem;
  width: fit-content;
  margin: 2.8125rem auto 0;
  border-bottom: 2px solid #23A1D6;
  text-decoration: none;
  font-weight: 700;
  font-size: 0.9375rem;
  color: #23A1D6;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .front-wom-detail__link {
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875) 0 0;
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.4375) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.9375);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .front-wom-detail__link:where(:any-link, :enabled, summary):hover:after {
    transform: translateX(calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25));
  }
}
.front-wom-detail__link:after {
  content: "";
  position: absolute;
  z-index: 1;
  width: 0.5rem;
  height: 0.75rem;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="9" height="12" fill="none"><path stroke="%2323A1D6" stroke-width="2" d="m1 1.059 6 5-6 5"/></svg>');
  background-size: 0.53125rem auto;
  top: 0;
  bottom: 0.5625rem;
  right: 0.875rem;
  margin: auto;
}
@media print, only screen and ( min-width: 960px ) {
  .front-wom-detail__link:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5625);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.3125);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}

.front-overview {
  padding: 3.125rem 1.125rem 2.1875rem;
  background-image: url(../images/top/overview-bg.png);
  background-size: cover;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.875);
  }
}

.front-overview-head {
  color: #FFF200;
  text-align: center;
  margin-bottom: 2.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-head {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 66.875);
    margin: 0 auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
    display: flex;
    gap: 0 3.375rem;
    text-align: left;
  }
}

.front-overview-heading {
  margin-bottom: 0.9375rem;
  letter-spacing: 0.02em;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-heading {
    margin: 0;
    letter-spacing: 0.15em;
  }
}
.front-overview-heading p {
  font-family: "Ubuntu", sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 0.3125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-heading p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.9375);
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
  }
}
.front-overview-heading h2 {
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.58;
  margin: 0;
  letter-spacing: 0.2em;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-heading h2 {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    line-height: 1;
    border-left: 9px solid #FFF200;
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

@media print, only screen and ( min-width: 960px ) {
  .front-overview-head-contents {
    flex: 1;
  }
}

.front-overview-head__catch {
  margin: 0.9375rem 0;
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.88;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-head__catch {
    margin: 0;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    line-height: 1.29;
  }
}

.front-overview-head__text {
  margin: 0;
  text-align: left;
  font-size: 0.875rem;
  line-height: 2;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-head__text {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    font-weight: 700;
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.3125);
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
  }
}

.front-overview-lists {
  border-radius: 0.9375rem;
  background-color: #fff;
  padding: 0 0.375rem;
  list-style: none;
  margin: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-lists {
    border-radius: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.9375);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
    display: flex;
  }
}

.front-overview-lists__item {
  padding: 2.8125rem 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-lists__item {
    flex: 1;
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
    display: flex;
    flex-direction: column;
  }
}
.front-overview-lists__item:not(:last-of-type) {
  position: relative;
}
.front-overview-lists__item:not(:last-of-type):after {
  content: "";
  position: absolute;
  width: 100%;
  height: 0.25rem;
  background-image: url(../images/common/line.png);
  background-size: auto 0.25rem;
  left: 0;
  bottom: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-lists__item:not(:last-of-type):after {
    background-image: url(../images/common/line-vertical.png);
    left: auto;
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
    right: 0;
    transform-origin: right;
    height: 100%;
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25) auto;
  }
}

.front-overview-lists__image {
  max-width: 16.5625rem;
  margin: 0 auto 0.9375rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-lists__image {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 16.5625);
    margin: 0 auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.9375);
  }
}

.front-overview-lists__title {
  text-align: center;
  font-size: 0.75rem;
  line-height: 1.4375rem;
  letter-spacing: 0.02em;
  font-weight: 700;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-lists__title {
    text-align: left;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    line-height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.4375);
  }
}
.front-overview-lists__title strong {
  font-size: 1rem;
  display: block;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-lists__title strong {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

.front-overview-lists__text {
  color: #3A3A3A;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.64;
  margin: 0.9375rem 0 1.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-lists__text {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
  }
}

.front-overview-lists__btn {
  display: block;
  max-width: 15.125rem;
  width: 100%;
  border: 2px solid #23A1D6;
  border-radius: 100vmax;
  padding: 1.125rem;
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 1.25rem;
  color: #23A1D6;
  text-decoration: none;
  box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-lists__btn {
    margin-top: auto;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 15.125);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .front-overview-lists__btn:where(:any-link, :enabled, summary):hover {
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.08);
  }
}
.front-overview-lists__btn:before {
  content: "";
  display: block;
  width: 0.6875rem;
  height: 1rem;
  background-image: url(../images/common/icon-triangle.svg);
  background-size: 0.6875rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .front-overview-lists__btn:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875) auto;
  }
}

.front-brand {
  padding: 2.875rem 1.25rem 3.125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-brand {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4);
  }
}

.front-brand__title {
  margin: 0 0 2.5rem;
  text-align: center;
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.3;
  letter-spacing: 0.03em;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .front-brand__title {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.125);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.4375);
    line-height: 1.34;
  }
}

.front-brand-lists {
  display: flex;
  flex-wrap: wrap;
  max-width: 20.1875rem;
  gap: 0.875rem 0.75rem;
  list-style: none;
  padding: 0;
  margin: 2.5rem auto 3.125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-brand-lists {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 65.375);
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.8125) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.125) auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.375);
  }
}

.front-brand-lists__item {
  width: calc((100% - 0.875rem) / 2);
  line-height: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .front-brand-lists__item {
    width: calc((100% - clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5) / 5);
  }
}

.front-sdgs {
  background-image: url(../images/common/sdgs-bg.jpg);
  background-size: cover;
  padding: 3.4375rem 0 2.875rem;
  color: #FFF200;
  position: relative;
  overflow: hidden;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) 0;
  }
}

.front-sdgs-illust01 {
  display: block;
  position: absolute;
  max-width: 16.875rem;
  right: -3.125rem;
  top: 0;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-illust01 {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 18.75);
    right: 0;
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}

.front-sdgs-container {
  padding-bottom: 8.5625rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-container {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 66.25);
    margin: 0 auto;
    padding-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.125);
  }
}

.front-sdgs-illust02 {
  display: block;
  position: absolute;
  max-width: 12.5rem;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-illust02 {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 29.6875);
    right: auto;
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -0.625);
  }
}

.front-sdgs-head {
  margin-bottom: 2.25rem;
  padding: 0 2rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-head {
    display: flex;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.8125);
    align-items: flex-end;
    margin: 0 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
  }
}

.front-sdgs-heading {
  padding-left: 1.125rem;
  border-left: 7px solid #FFF200;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-heading {
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.125);
    border-left: none;
    position: relative;
  }
  .front-sdgs-heading:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5625);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.625);
    background-color: #FFF200;
    z-index: 1;
  }
}
.front-sdgs-heading p {
  line-height: 1;
  font-size: 0.75rem;
  font-weight: 700;
  margin: 0;
  letter-spacing: 0.06em;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-heading p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    letter-spacing: 0.16em;
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}
.front-sdgs-heading h2 {
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.8;
  margin: 0;
  letter-spacing: 0.15em;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-heading h2 {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    line-height: 1;
  }
}

.front-sdgs-head__catch {
  font-weight: 900;
  font-size: 1.125rem;
  line-height: 1.77;
  padding: 0 1.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-head__catch {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    padding: 0;
    margin: 0;
    flex: 1;
  }
}

@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-contents {
    max-width: fit-content;
    margin-left: auto;
  }
}

.front-sdgs-contents__detail {
  padding: 0 3.25rem 6.25rem;
  position: relative;
  overflow: hidden;
  margin-bottom: 1.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-contents__detail {
    margin: 0 auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
    padding: 0 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5);
    text-align: center;
    overflow: visible;
  }
}
.front-sdgs-contents__detail p {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 2.14;
  letter-spacing: 0.09em;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-contents__detail p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    letter-spacing: 0.15em;
  }
}
.front-sdgs-contents__detail p:not(:last-of-type) {
  margin-bottom: 1.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-contents__detail p:not(:last-of-type) {
    margin: 0;
  }
}
.front-sdgs-contents__detail:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 3.25rem;
  aspect-ratio: 341/149;
  height: auto;
  max-width: 21.3125rem;
  background-image: url(../images/top/sdgs-illust03.png);
  background-size: cover;
  width: 100%;
}
@media print, only screen and ( min-width: 960px ) {
  .front-sdgs-contents__detail:after {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 29.375);
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75);
  }
}

.front-recruit {
  padding: 6.875rem 1.25rem 20rem;
  position: relative;
  text-align: center;
  background-image: url(../images/common/footer-decoration.png);
  background-size: auto 4.1875rem;
  background-repeat: repeat-x;
  background-position: left top;
  overflow: hidden;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 11.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.3125);
    background-size: auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.375);
  }
}

.front-recruit__image01 {
  display: block;
  position: absolute;
  left: -0.5rem;
  bottom: 10.3125rem;
  max-width: 7.6875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit__image01 {
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.8125);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 15.1875);
  }
}

.front-recruit__image02 {
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  bottom: 7.9375rem;
  max-width: 7.3125rem;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit__image02 {
    right: auto;
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.8125);
    bottom: auto;
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 10.1875);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 12.0625);
  }
}

.front-recruit__image03 {
  display: block;
  position: absolute;
  right: -1rem;
  bottom: 2.5rem;
  max-width: 9.3125rem;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit__image03 {
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -3.75);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 10.375);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 21.75);
  }
}

.front-recruit-heading {
  color: #23A1D6;
  font-weight: 700;
  margin-bottom: 0.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit-heading {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
  }
}
.front-recruit-heading p {
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  line-height: 1.2;
  margin: 0 0 0.125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit-heading p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}
.front-recruit-heading h2 {
  font-size: 1.5rem;
  line-height: 1.6;
  letter-spacing: 0.11em;
  font-weight: 900;
  margin: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit-heading h2 {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    line-height: 1;
  }
}

.front-recruit__catch {
  color: #23A1D6;
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.72;
  margin: 0.875rem 0;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit__catch {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    line-height: 1.95;
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.4375) 0;
  }
}

.front-recruit__text {
  font-size: 0.875rem;
  line-height: 2.14;
  font-weight: 700;
  margin: 0.9375rem 0 1.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit__text {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.4375) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.75);
  }
}

.front-recruit__btn {
  display: block;
  max-width: 15.125rem;
  width: 100%;
  border: 2px solid #23A1D6;
  border-radius: 100vmax;
  padding: 1.125rem;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 0.8125rem;
  color: #23A1D6;
  text-decoration: none;
  box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit__btn {
    margin-top: auto;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 15.125);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.8125);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .front-recruit__btn:where(:any-link, :enabled, summary):hover {
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.08);
  }
}
.front-recruit__btn:after {
  content: "";
  display: block;
  width: 0.6875rem;
  height: 1rem;
  background-image: url(../images/common/icon-triangle.svg);
  background-size: 0.6875rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .front-recruit__btn:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875) auto;
  }
}

.recruit-main {
  position: relative;
  padding: 2.875rem 1.25rem 3.625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-main {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.9375);
  }
}
.recruit-main .page-heading {
  margin-bottom: 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-main .page-heading {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.25);
  }
}

.recruit-main__catch {
  margin: 0;
  text-align: center;
  font-weight: 900;
  font-size: 1.125rem;
  line-height: 2.1;
  letter-spacing: 0.03em;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-main__catch {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
    line-height: 1.8;
  }
}

.recruit-main-images {
  display: flex;
  gap: 0 1.625rem;
  align-items: flex-end;
  justify-content: center;
  margin-top: 1.375rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-main-images {
    display: block;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 73.125);
    margin: 0 auto;
    position: relative;
  }
}

.recruit-main__image01 {
  line-height: 0;
  max-width: 7.6875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-main__image01 {
    position: absolute;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 17.125);
    left: 0;
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -4.0625);
    z-index: 1;
  }
}

.recruit-main__image02 {
  line-height: 0;
  padding-bottom: 0.625rem;
  max-width: 9.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-main__image02 {
    position: absolute;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 20.6875);
    right: 0;
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -1.875);
    z-index: 1;
  }
}

.recruit-message {
  padding: 2.5rem 1.5rem 3.75rem;
  background-image: url(../images/common/footer-decoration.png);
  background-size: 5rem;
  background-position: -1.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-message {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.5);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 8.75);
    background-position: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -0.625);
  }
}

.recruit-message-inner {
  background-color: #fff;
  padding: 2.8125rem 1.5rem 2rem;
  border-radius: 10px;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-message-inner {
    display: flex;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75);
    justify-content: center;
    align-items: center;
  }
}

.recruit-message__catch {
  color: #23A1D6;
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.94;
  letter-spacing: 0.03em;
  margin: 0 0 2rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-message__catch {
    flex: 1;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    line-height: 1.91;
    margin: 0;
  }
}

.recruit-message__detail {
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.78;
  margin: 0;
  color: #3A3A3A;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-message__detail {
    flex: 1;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    line-height: 2.1;
  }
}

.recruit-requirements {
  padding: 2.5rem 1rem 3.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-requirements {
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5);
  }
}

.recruit-requirements__image {
  max-width: 21.25rem;
  margin: 0 auto 1.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-requirements__image {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 85.625);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0);
  }
}

.recruit-requirements__catch {
  text-align: center;
  font-weight: 900;
  font-size: 1.125rem;
  line-height: 1.88;
  letter-spacing: 0.03em;
  margin: 0 0 1.875rem;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-requirements__catch {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -6.25);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
  }
}

.recruit-requirements-lists {
  padding: 0;
  margin: 0 auto;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 1.25rem 0;
  max-width: 37.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-requirements-lists {
    flex-direction: row;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.0625);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 47.5);
  }
}

.recruit-requirements-lists__link {
  display: block;
  border-radius: 10px;
  border: 2px solid #D8D8D8;
  background: #FFF;
  overflow: hidden;
  position: relative;
  color: #23A1D6;
  text-decoration: none;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-requirements-lists__link {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .recruit-requirements-lists__link:where(:any-link, :enabled, summary):hover {
    color: #FFF200;
  }
  .recruit-requirements-lists__link:where(:any-link, :enabled, summary):hover:after {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="40" height="35" fill="none"><path fill="%23FFF200" d="M39.045 32.842a2 2 0 0 1-2 2H2.824c-1.847 0-2.707-2.29-1.317-3.505L35.728 1.4c1.293-1.13 3.317-.212 3.317 1.506z"/></svg>');
  }
}
.recruit-requirements-lists__link:after {
  content: "";
  width: 2.5rem;
  height: 2.1875rem;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="40" height="35" fill="none"><path fill="%2300A8DE" d="M39.045 32.842a2 2 0 0 1-2 2H2.824c-1.847 0-2.707-2.29-1.317-3.505L35.728 1.4c1.293-1.13 3.317-.212 3.317 1.506z"/></svg>');
  background-size: 2.5rem 2.1875rem;
  position: absolute;
  bottom: 0.625rem;
  right: 0.625rem;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-requirements-lists__link:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}

.recruit-requirements-lists__title {
  text-align: center;
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.7;
  letter-spacing: 0.03em;
  margin: 0;
  padding: 1.5625rem 0 3.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .recruit-requirements-lists__title {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.75) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.25);
  }
}

.sdgs-main {
  padding: 2.625rem 1.6875rem 0;
  background-image: url(../images/common/sdgs-bg.jpg);
  background-size: cover;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) 0;
    position: relative;
  }
}
.sdgs-main .page-heading {
  padding-bottom: 2.5rem;
  margin-bottom: 0.75rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main .page-heading {
    padding-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.sdgs-main .page-heading p {
  color: #FFF200;
}
.sdgs-main .page-heading h1 {
  color: #FFF200;
}
.sdgs-main .page-heading:after {
  content: "";
  position: absolute;
  width: 8.9375rem;
  height: 1.5625rem;
  background-image: url(../images/sdgs/title-deco.png);
  background-size: 100%;
  left: 0;
  right: 0;
  margin: auto;
  bottom: 0;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main .page-heading:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 12.9375);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
  }
}

.sdgs-main__catch {
  text-align: center;
  color: #FFF200;
  font-size: 1.125rem;
  line-height: 1.83;
  font-weight: 900;
  margin: 0.75rem 0 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main__catch {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.8125);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
  }
}

.sdgs-main-images {
  max-width: 19.25rem;
  margin: 0 auto;
  aspect-ratio: 308/243;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main-images {
    max-width: 100%;
    position: initial;
    aspect-ratio: auto;
  }
}

.sdgs-main-images__item01 {
  position: absolute;
  max-width: 4.375rem;
  left: 0;
  top: 0;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main-images__item01 {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.125);
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 10.5);
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 8.125);
  }
}

.sdgs-main-images__item02 {
  position: absolute;
  max-width: 7.9375rem;
  right: 0;
  top: 0;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main-images__item02 {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 14.75);
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5625);
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4);
  }
}

.sdgs-main-images__item03 {
  position: absolute;
  max-width: 8.4375rem;
  left: 1.5rem;
  bottom: -0.5rem;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main-images__item03 {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 17.375);
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -0.5);
  }
}

.sdgs-main-images__item04 {
  position: absolute;
  max-width: 6.25rem;
  right: 1.5rem;
  bottom: -2rem;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main-images__item04 {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 13.8125);
    bottom: 0;
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6);
  }
}

.sdgs-main-description {
  background-color: #fff;
  border-radius: 60px 60px 0 0;
  padding: 2.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main-description {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 41.875);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.375) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    margin: 0 auto;
  }
}
.sdgs-main-description p {
  margin: 0;
  font-size: 0.875rem;
  line-height: 2;
  text-align: center;
  font-weight: 500;
  color: #3A3A3A;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main-description p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}
.sdgs-main-description p:not(:last-of-type) {
  margin-bottom: 1.8125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .sdgs-main-description p:not(:last-of-type) {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
  }
}

.wp-pattern-sdgs-cards {
  padding: 2.5rem 2rem 3.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-sdgs-cards {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 69.375);
    margin: 0 auto;
  }
}

@media print, only screen and ( min-width: 960px ) {
  .wp-block-post-content .wp-block-columns-is-layout-flex.wp-pattern-sdgs-cards {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
  }
}

.wp-pattern-sdgs-card {
  padding: 2.5rem 0 !important;
  background-image: url(../images/common/line.png);
  background-position: left bottom;
  background-size: auto 0.25rem;
  background-repeat: repeat-x;
  margin: 0;
}
.wp-pattern-sdgs-card:last-of-type {
  background: none;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-sdgs-card {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) 0 !important;
    background-size: auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
    align-items: center !important;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.375);
  }
  .wp-pattern-sdgs-card:nth-of-type(2n) {
    flex-direction: row-reverse !important;
  }
}
.wp-pattern-sdgs-card .wp-block-image {
  border-radius: 10px;
  overflow: hidden;
}
.wp-pattern-sdgs-card h3.wp-block-heading {
  color: #00AF97;
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.37;
  padding-left: 1.5rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-sdgs-card h3.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.75);
  }
}
.wp-pattern-sdgs-card h3.wp-block-heading:before {
  content: "";
  position: absolute;
  width: 1rem;
  height: 1rem;
  top: 0.25rem;
  margin: auto;
  left: 0;
  z-index: 1;
  background-image: url(../images/sdgs/icon-leaf.png);
  background-size: 1rem auto;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-sdgs-card h3.wp-block-heading:before {
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125) auto;
  }
}
.wp-pattern-sdgs-card p {
  font-size: 0.875rem;
  color: #3A3A3A;
  line-height: 2;
  font-weight: 500;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-pattern-sdgs-card p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin-top: 2rem;
  }
}

.oem-main {
  padding: 2.625rem 1.25rem 1.25rem;
  background-image: url(../images/oem/main-bg_sp.png);
  background-size: 98% auto;
  background-repeat: no-repeat;
  background-position: center bottom 2.1875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-main {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.625);
    background-image: url(../images/oem/main-bg_pc.png);
    background-size: 92% auto;
    background-position: center bottom 10%;
  }
}
.oem-main .page-heading {
  margin-bottom: 1.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-main .page-heading {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4);
  }
}

.oem-main__fukidashi {
  text-align: center;
  width: fit-content;
  background-color: #23A1D6;
  font-size: 0.875rem;
  font-weight: 900;
  color: #fff;
  border-radius: 100vmax;
  max-width: 16.375rem;
  width: 100%;
  padding: 0.5rem;
  line-height: 1.5;
  margin: 0 auto 1.625rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-main__fukidashi {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 33.125);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.625);
  }
}
.oem-main__fukidashi:after {
  content: "";
  position: absolute;
  bottom: 1px;
  transform: translateY(100%);
  left: 0;
  right: 0;
  margin: auto;
  z-index: 1;
  clip-path: polygon(0 0, 100% 0, 60% 100%);
  background-color: #23A1D6;
  width: 0.5rem;
  height: 0.625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-main__fukidashi:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5625);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
  }
}

.oem-main__catch {
  margin: 0;
  font-weight: 900;
  font-size: 1.125rem;
  line-height: 1.6;
  color: #23A1D6;
  text-align: center;
  letter-spacing: 0.03em;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-main__catch {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.8125);
  }
}

.oem-worries-head {
  background-color: #AEDBF5;
  padding: 2rem 1rem 4.5625rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-head {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.625) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 11.25);
  }
}
.oem-worries-head:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  background-color: #fff;
  height: 2.125rem;
  width: 100%;
  clip-path: polygon(50% 0, 0 100%, 100% 100%);
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-head:after {
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 8.125);
  }
}

.oem-worries__title {
  text-align: center;
  color: #23A1D6;
  font-weight: 900;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
  margin: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries__title {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
  }
}

.oem-worries-head-lists {
  margin: 2rem auto 0;
  padding: 0;
  list-style: none;
  max-width: 33.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-head-lists {
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4) auto 0;
    display: flex;
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 60.75);
    flex-wrap: wrap;
  }
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-head-lists li {
    width: calc((100% - clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6) / 3);
  }
}
.oem-worries-head-lists li:nth-of-type(1) {
  max-width: 16.4375rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-head-lists li:nth-of-type(1) {
    max-width: 100%;
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.8125);
  }
}
.oem-worries-head-lists li:nth-of-type(2) {
  max-width: 15.8125rem;
  margin-left: auto;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-head-lists li:nth-of-type(2) {
    max-width: 100%;
  }
}
.oem-worries-head-lists li:nth-of-type(3) {
  max-width: 14.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-head-lists li:nth-of-type(3) {
    max-width: 100%;
  }
}
.oem-worries-head-lists li:nth-of-type(4) {
  max-width: 15.625rem;
  margin-left: auto;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-head-lists li:nth-of-type(4) {
    max-width: 100%;
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
  }
}
.oem-worries-head-lists li:nth-of-type(5) {
  max-width: 15.3125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-head-lists li:nth-of-type(5) {
    max-width: 100%;
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}
.oem-worries-head-lists li:nth-of-type(6) {
  max-width: 15.625rem;
  margin-left: auto;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-head-lists li:nth-of-type(6) {
    max-width: 100%;
  }
}

.oem-worries-contents {
  padding: 0.5rem 1.25rem 3.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-contents {
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.375);
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -2.5);
    position: relative;
    z-index: 5;
  }
}

.oem-worries__logo {
  margin: 1.75rem auto 2.5rem;
  max-width: 17.6875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries__logo {
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.875) auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 21);
  }
}

.oem-worries-detail {
  padding: 0.375rem 1.6875rem 1.25rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-detail {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 45);
    margin: 0 auto;
  }
}
.oem-worries-detail:before, .oem-worries-detail:after {
  content: "";
  position: absolute;
  z-index: 1;
  width: 2.1875rem;
  height: 2rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-detail:before, .oem-worries-detail:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
  }
}
.oem-worries-detail:before {
  top: 0;
  left: 0;
  border-top: 2px solid #23A1D6;
  border-left: 2px solid #23A1D6;
}
.oem-worries-detail:after {
  bottom: 0;
  right: 0;
  border-bottom: 2px solid #23A1D6;
  border-right: 2px solid #23A1D6;
}
.oem-worries-detail h4 {
  text-align: center;
  line-height: 1.5;
  font-size: 1.125rem;
  color: #23A1D6;
  letter-spacing: 0.03em;
  margin: 0 0 1.5rem;
  font-weight: 900;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-detail h4 {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.8125);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.6875);
  }
}
.oem-worries-detail p {
  color: #3A3A3A;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 2;
  margin: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-worries-detail p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

.oem-flow {
  padding: 3.75rem 1.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-flow {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4);
  }
}

@media print, only screen and ( min-width: 960px ) {
  .oem-flow-inner {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 62.5);
    margin: 0 auto;
  }
}

.oem-flow-lits {
  padding: 0 0 5.625rem;
  margin: 3.375rem 0 1rem;
  list-style: none;
  counter-reset: number 0;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-flow-lits {
    padding-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 8.75);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.625) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
  }
}
.oem-flow-lits:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 20rem;
  height: 3.375rem;
  background-image: url(../images/oem/flow-deco.png);
  background-size: 100%;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-flow-lits:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 29.0625);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.875);
  }
}
.oem-flow-lits li {
  padding: 0 0.625rem 2rem 3.75rem;
  position: relative;
  background-image: url(../images/oem/flow-line.svg);
  background-repeat: repeat-y;
  background-position: 1.5rem top;
  background-size: 0.3125rem auto;
  font-size: 0.875rem;
  line-height: 1.5;
  font-weight: 500;
  color: #3A3A3A;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-flow-lits li {
    padding: 0 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4) 0;
    display: flex;
    align-items: center;
    flex: 1;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
    background-position: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.875) 0.5rem;
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.3125) auto;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    line-height: 2;
  }
}
.oem-flow-lits li:before {
  content: "";
  position: absolute;
  top: -0.75rem;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background-color: #23A1D6;
  color: #fff;
  left: 0.125rem;
  counter-increment: number 1;
  content: counter(number) " ";
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-flow-lits li:before {
    min-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.8125);
    min-height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.8125);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
    position: initial;
  }
}
.oem-flow-lits li:last-of-type {
  padding-bottom: 0;
}
.oem-flow-lits li strong {
  display: block;
  font-size: 1.125rem;
  line-height: 1.33;
  font-weight: 900;
  color: #23A1D6;
  margin-bottom: 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-flow-lits li strong {
    min-width: 9.375rem;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    line-height: 1;
    margin: 0;
  }
}
.oem-flow-lits li strong + br {
  display: none;
}

.oem-flow__catch {
  margin: 1rem 0;
  padding-bottom: 6.5rem;
  position: relative;
  font-size: 1rem;
  font-weight: 900;
  line-height: 2;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-flow__catch {
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875) auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    width: fit-content;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
    line-height: 1.74;
    padding-bottom: 0;
  }
}
.oem-flow__catch:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  width: 7.4375rem;
  height: atuo;
  aspect-ratio: 119/113;
  margin: auto;
  background-image: url(../images/oem/flow-illust.png);
  background-size: 100%;
}
@media print, only screen and ( min-width: 960px ) {
  .oem-flow__catch:after {
    left: auto;
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 13.375);
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -10.3125);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -5.3125);
  }
}

.quarity-main {
  padding: 2.5rem 1.25rem;
  background-image: url(../images/quality/main-bg.png);
  background-size: 40%;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-main {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.5) 0;
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 23.4375) auto;
  }
}

.quarity-main-inner {
  background-image: url(../images/top/overview-bg.png);
  background-size: 100%;
  padding: 2rem 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-main-inner {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75);
  }
}
.quarity-main-inner .page-heading {
  margin-bottom: 1.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-main-inner .page-heading {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
  }
}
.quarity-main-inner .page-heading p {
  color: #FFF200;
}
.quarity-main-inner .page-heading h1 {
  color: #FFF200;
}

.quarity-main__fukidashi {
  text-align: center;
  width: fit-content;
  background-color: #FFF200;
  font-size: 0.875rem;
  font-weight: 900;
  color: #23A1D6;
  border-radius: 100vmax;
  max-width: 16.375rem;
  width: 100%;
  padding: 0.5rem;
  line-height: 1.5;
  margin: 0 auto 1.625rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-main__fukidashi {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 14.625);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.quarity-main__fukidashi:after {
  content: "";
  position: absolute;
  bottom: 1px;
  transform: translateY(100%);
  left: 0;
  right: 0;
  margin: auto;
  z-index: 1;
  clip-path: polygon(0 0, 100% 0, 60% 100%);
  background-color: #FFF200;
  width: 0.5rem;
  height: 0.625rem;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-main__fukidashi:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5625);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
  }
}

.quarity-main__catch {
  color: #FFF200;
  font-size: 0.875rem;
  font-weight: 900;
  line-height: 1.33;
  letter-spacing: 0.03em;
  text-align: center;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-main__catch {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.quarity-main__catch strong {
  display: block;
  font-size: 1.375rem;
  margin-bottom: 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-main__catch strong {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
  }
}

.quarity-main__text {
  font-size: 0.875rem;
  font-weight: 700;
  margin: 0;
  color: #fff;
  line-height: 1.8;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-main__text {
    margin: 0 auto;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 42.5);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

.quarity-navigation {
  margin: 2.5rem auto;
  padding: 0 1.5rem;
  gap: 0.75rem;
  max-width: 30rem;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-navigation {
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) auto;
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 71.875);
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
    justify-content: center !important;
  }
}
.quarity-navigation .wp-block-button {
  width: 100%;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-navigation .wp-block-button {
    width: calc((100% - clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) / 3);
  }
}
.quarity-navigation .wp-block-button .wp-block-button__link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 0.5rem;
  border-radius: 100vmax;
  border: 2px solid #23A1D6;
  background: #FFF;
  box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 700;
  padding: 1rem;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-navigation .wp-block-button .wp-block-button__link {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.quarity-navigation .wp-block-button .wp-block-button__link:before {
  content: "";
  display: block;
  width: 0.5rem;
  height: 0.6875rem;
  background-image: url(../images/common/icon-triangle.svg);
  background-size: 0.5rem auto;
  transform: rotate(90deg);
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-navigation .wp-block-button .wp-block-button__link:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.0625);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875) auto;
  }
}

.quarity-contents {
  padding: 0 1.75rem 5rem;
  margin-top: 6.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-contents {
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) 12.5rem;
  }
}
.quarity-contents h2.wp-block-heading {
  color: #23A1D6;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.3;
  padding: 0.5rem 1.125rem;
  border-left: 6px solid #23A1D6;
  margin-top: 3.75rem !important;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-contents h2.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
    line-height: 1.17;
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    border-left: 9px solid #23A1D6;
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.5) !important;
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875) !important;
  }
}
.quarity-contents .wp-pattern-cards {
  margin: 1rem 0;
}

.quarity-method {
  margin: 3rem 0 0 !important;
  gap: 6.25rem 0;
  padding: 1.25rem;
  border-radius: 10px;
  border: 4px solid #00A8DE;
  background: #FFF;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-method {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.375) !important;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 8.75);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    border: 6px solid #00A8DE;
  }
}
.quarity-method .wp-block-column:first-of-type {
  position: relative;
}
.quarity-method .wp-block-column:first-of-type:after {
  content: "";
  position: absolute;
  width: 2.5rem;
  height: 2.3125rem;
  background-image: url(../images/quality/icon-arrow.png);
  background-size: cover;
  left: 0;
  right: 0;
  margin: auto;
  bottom: -3.125rem;
  transform: translateY(50%) rotate(90deg);
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-method .wp-block-column:first-of-type:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.3125);
    bottom: 0;
    top: 0;
    left: auto;
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -4.375);
    transform: translateX(50%);
  }
}
.quarity-method h4.wp-block-heading {
  color: #23A1D6;
  font-weight: 900;
  font-size: 1.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-method h4.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
  }
}
.quarity-method p {
  font-size: 0.875rem;
  font-weight: 500;
  color: #3A3A3A;
  line-height: 1.875;
  margin: 1rem 0;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-method p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5) 0;
  }
}

.quarity-oem {
  border-radius: 16px;
  border: 4px solid #23A1D6;
  padding: 2rem 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-oem {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) !important;
    align-items: center;
  }
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-oem .wp-block-column:first-of-type {
    flex: initial;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 21);
  }
}
.quarity-oem .wp-block-image {
  max-width: 21.25rem;
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-oem .wp-block-image {
    max-width: 100%;
  }
}
.quarity-oem h4.wp-block-heading {
  color: #23A1D6;
  font-weight: 900;
  font-size: 1.125rem;
  line-height: 1.7;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-oem h4.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
  }
}
.quarity-oem p {
  font-size: 0.875rem;
  line-height: 1.8;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-oem p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}
.quarity-oem p a {
  margin-left: auto;
  width: fit-content;
  text-decoration: none;
  color: #23A1D6;
  font-size: 0.9375rem;
  font-weight: 700;
  padding: 0 0.75rem 0.375rem;
  border-bottom: 2px solid #23A1D6;
  position: relative;
  display: flex;
  align-items: center;
  gap: 0 0.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-oem p a {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .quarity-oem p a:where(:any-link, :enabled, summary):hover:after {
    transform: translate(calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.1875), calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.0625));
  }
}
.quarity-oem p a:after {
  content: "";
  width: 0.5rem;
  height: 0.75rem;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="9" height="12" fill="none"><path stroke="%2323A1D6" stroke-width="2" d="m1 1.059 6 5-6 5"/></svg>');
  background-size: cover;
  transform: translate(0rem, 0.0625rem);
}
@media print, only screen and ( min-width: 960px ) {
  .quarity-oem p a:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    transform: translate(calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0), calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.0625));
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}

.service-main {
  padding-top: 3rem;
}
@media print, only screen and ( min-width: 960px ) {
  .service-main {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.875);
  }
}
.service-main .page-heading {
  margin-bottom: 0.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .service-main .page-heading {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
  }
}

.service-main-contents {
  background-image: url(../images/service/service-main-bg.png);
  background-size: auto 50%;
  padding: 3rem 1.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .service-main-contents {
    background-size: cover;
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}

.service-main-inner {
  background-color: #fff;
  border-radius: 10px;
  padding: 2rem 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .service-main-inner {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 64.25);
    margin: 0 auto;
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.375) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
  }
}

@media print, only screen and ( min-width: 960px ) {
  .service-main-detail {
    display: flex;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.625);
    justify-content: center;
  }
}

.service-main__catch {
  margin: 0 auto 1.25rem;
  max-width: 17.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .service-main__catch {
    margin: 0;
    padding-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 22.5);
  }
}

.service-main__text {
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.875;
  color: #3A3A3A;
  margin: 2rem 0 3rem;
}
@media print, only screen and ( min-width: 960px ) {
  .service-main__text {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin: 0;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 29.6875);
  }
}

.service-main-buttons {
  display: flex;
  flex-direction: column;
  gap: 1.5rem 0;
  margin-top: 3rem;
}
@media print, only screen and ( min-width: 960px ) {
  .service-main-buttons {
    flex-direction: row;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.25);
    justify-content: center;
  }
}
.service-main-buttons a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 0.5rem;
  text-decoration: none;
  border-radius: 100vmax;
  border: 2px solid #23A1D6;
  background: #FFF;
  box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
  font-size: 1rem;
  line-height: 1.5;
  font-weight: 700;
  padding: 1rem;
  max-width: 21.25rem;
  width: 100%;
  margin: 0 auto;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .service-main-buttons a {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 21.875);
    margin: 0;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .service-main-buttons a:where(:any-link, :enabled, summary):hover {
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.08);
  }
}
.service-main-buttons a:before {
  content: "";
  display: block;
  width: 0.5rem;
  height: 0.6875rem;
  background-image: url(../images/common/icon-triangle.svg);
  background-size: 0.5rem auto;
  transform: rotate(90deg);
}
@media print, only screen and ( min-width: 960px ) {
  .service-main-buttons a:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.0625);
    background-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875) auto;
  }
}

.service-business {
  padding: 3.375rem 1.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .service-business {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.625) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 8.75);
  }
}

.service-head {
  text-align: center;
  color: #23A1D6;
  letter-spacing: 0.05em;
  margin-bottom: 2rem;
}
@media print, only screen and ( min-width: 960px ) {
  .service-head {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5);
    letter-spacing: 0.12em;
  }
}
.service-head p {
  margin: 0 0 0.375rem !important;
  font-weight: 700;
  font-size: 0.875rem;
  line-height: 1.5;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .service-head p {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5) !important;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}
.service-head h2 {
  margin: 0 !important;
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.17;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .service-head h2 {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.1875);
  }
}

.service-business-lists {
  margin: 3rem auto 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 2rem 0;
  max-width: 21.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .service-business-lists {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 75);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4) auto 0;
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.25);
    flex-direction: row;
    flex-wrap: wrap;
  }
}
@media print, only screen and ( min-width: 960px ) {
  .service-business-lists li {
    width: calc((100% - clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5) / 3);
  }
}

.service-bland {
  padding: 3rem 1.75rem 3.5rem;
  background-color: #AEDBF5;
}
@media print, only screen and ( min-width: 960px ) {
  .service-bland {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.625) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.25);
  }
}

.wp-block-brand-cards {
  display: flex;
  flex-direction: column;
  max-width: 26.25rem;
  margin: 3.75rem auto 0;
  gap: 1.5rem 0;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-brand-cards {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5);
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.375) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.25);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 75);
    flex-direction: row;
    flex-wrap: wrap;
  }
}

.wp-block-bland-card {
  background-color: #fff;
  border-radius: 10px;
  padding: 1.25rem 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-bland-card {
    width: calc((100% - clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.25) / 2);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.25);
  }
}

.wp-block-bland-card__logo {
  line-height: 0;
  margin: 0 auto 1.5rem;
  width: fit-content;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-bland-card__logo {
    margin: 0 auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.wp-block-bland-card__logo img {
  height: 3.5rem;
  width: auto;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-bland-card__logo img {
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.5);
  }
}

.wp-block-bland-card-head {
  display: flex;
  align-items: center;
  gap: 0 1rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-bland-card-head {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

.wp-block-bland-card__title {
  flex: 1;
  font-size: 1rem;
  font-weight: 900;
  line-height: 1.5;
  margin: 0;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-bland-card__title {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}

.wp-block-bland-card__sns {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0 0.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-bland-card__sns {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
  }
}
.wp-block-bland-card__sns a {
  display: block;
  max-width: 1.5rem;
  line-height: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-bland-card__sns a {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .wp-block-bland-card__sns a:where(:any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
}

.wp-block-bland-card__detail {
  font-size: 0.875rem;
  font-weight: 500;
  color: #3A3A3A;
  line-height: 1.875;
  margin: 1rem 0 0.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-bland-card__detail {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
  }
}

.wp-block-bland-card__url {
  display: block;
  color: #23A1D6;
  font-size: 0.875rem;
  font-weight: 500;
  width: fit-content;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-bland-card__url {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .wp-block-bland-card__url:where(:any-link, :enabled, summary):hover {
    text-decoration: none;
  }
}

.group-main {
  padding: 2.5rem 0 0;
}
@media print, only screen and ( min-width: 960px ) {
  .group-main {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.4375);
    background-image: url(../images/group/mian-bg_pc.png);
    background-size: cover;
    background-position: center;
  }
}
.group-main .page-heading {
  margin-bottom: 2rem;
}
@media print, only screen and ( min-width: 960px ) {
  .group-main .page-heading {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.75);
  }
}

.group-main-contents {
  background-image: url(../images/group/mian-bg_sp.png);
  background-size: cover;
  background-position: center;
  padding: 2.125rem 1rem 3.375rem 2.5rem;
  max-width: 26.25rem;
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .group-main-contents {
    background: none;
    padding: 0;
    max-width: 100%;
  }
}

.group-main__catch {
  font-size: 1.125rem !important;
  font-weight: 900 !important;
  line-height: 1.83;
  color: #23A1D6;
  margin: 0;
  letter-spacing: 0.03em;
}
@media print, only screen and ( min-width: 960px ) {
  .group-main__catch {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875) !important;
    line-height: 1.63;
  }
}

.group-main__text {
  text-align: left;
  margin-top: 1rem;
  font-size: 0.875rem;
  line-height: 1.92;
  font-weight: 500;
}
@media print, only screen and ( min-width: 960px ) {
  .group-main__text {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.25);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    text-align: center;
  }
}

.group-navigation {
  margin: 1.75rem 0 5rem;
  padding: 0 0.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .group-navigation {
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.875) auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.25);
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}

.group-navigation__logo {
  max-width: 15.625rem;
  margin: 0 auto 3.875rem;
  border: 2px solid #D8D8D8;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .group-navigation__logo {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 21.75);
    border: 3px solid #D8D8D8;
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.625);
  }
}
.group-navigation__logo:before {
  content: "";
  position: absolute;
  width: 0.125rem;
  height: 2.5rem;
  background-color: #D8D8D8;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 1;
  bottom: 0;
  transform: translateY(100%);
}
@media print, only screen and ( min-width: 960px ) {
  .group-navigation__logo:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.1875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75);
  }
}

.group-navigation-buttons {
  display: flex;
  gap: 0 0.375rem;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .group-navigation-buttons {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.875);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 75);
  }
}
.group-navigation-buttons:before {
  content: "";
  position: absolute;
  width: calc(66.6666666667% + 0.375rem);
  height: 0.125rem;
  background-color: #D8D8D8;
  left: 0;
  right: 0;
  margin: auto;
  top: -1.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .group-navigation-buttons:before {
    width: calc(66.6666666667% + clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.1875);
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -2.375);
  }
}
.group-navigation-buttons .wp-block-button {
  width: calc((100% - 0.75rem) / 3);
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .group-navigation-buttons .wp-block-button {
    width: calc((100% - clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.75) / 3);
  }
}
.group-navigation-buttons .wp-block-button:before {
  content: "";
  position: absolute;
  width: 0.125rem;
  height: 1.5rem;
  background-color: #D8D8D8;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 1;
  top: 0;
  transform: translateY(-100%);
}
@media print, only screen and ( min-width: 960px ) {
  .group-navigation-buttons .wp-block-button:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.1875);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.75);
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -0.625);
  }
}
.group-navigation-buttons .wp-block-button__link {
  font-size: 0.75rem;
  line-height: 1.5;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 0.625rem 0.5rem;
  text-align: left;
  border-radius: 0;
  display: flex;
  gap: 0 0.5rem;
  align-items: center;
  justify-content: center;
}
@media print, only screen and ( min-width: 960px ) {
  .group-navigation-buttons .wp-block-button__link {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    letter-spacing: 0.16em;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .group-navigation-buttons .wp-block-button__link:where(:any-link, :enabled, summary):hover {
    opacity: 0.7;
  }
}
.group-navigation-buttons .wp-block-button__link:before {
  content: "";
  display: block;
  width: 0.4375rem;
  height: 0.4375rem;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}
@media print, only screen and ( min-width: 960px ) {
  .group-navigation-buttons .wp-block-button__link:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5625);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5625);
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
  }
}
@media print, only screen and ( min-width: 960px ) {
  .group-navigation-buttons .wp-block-button__link br {
    display: none;
  }
}

.group-lists-item {
  padding: 2.5rem 1.5rem;
  width: calc(100% - 2.5rem);
  margin: 6.25rem auto;
  position: relative;
  border-width: 3px !important;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-item {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 75);
    width: 100%;
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.1875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 8.125) auto;
    border-width: 4px !important;
  }
}
.group-lists-item hr.wp-block-separator {
  background-image: url(../images/common/line.png);
  background-size: auto 100%;
  border: none;
  height: 0.25rem;
  margin: 2.5rem 0;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-item hr.wp-block-separator {
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.5) 0;
  }
}
.group-lists-item h3.wp-block-heading {
  text-align: center;
  color: #23A1D6;
  font-size: 1.125rem;
  line-height: 1.5;
  font-weight: 900;
  margin-bottom: 2.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-item h3.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.4375);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
  }
  .group-lists-item h3.wp-block-heading br {
    display: none;
  }
}
.group-lists-item .wp-block-columns {
  margin: 0;
  gap: 3.125rem 0;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-item .wp-block-columns {
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    align-items: center !important;
  }
}
.group-lists-item .wp-block-columns h4.wp-block-heading {
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.54;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-item .wp-block-columns h4.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
  }
}
.group-lists-item .wp-block-columns p {
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 2;
  color: #3A3A3A;
  margin: 1.25rem 0 2rem;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-item .wp-block-columns p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
  }
}
.group-lists-item .wp-block-columns .wp-block-image {
  max-width: 21.25rem;
  width: 70%;
  margin-left: auto;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-item .wp-block-columns .wp-block-image {
    width: 100%;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 21.875);
  }
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-item .wp-block-columns .wp-pattern-link-button a {
    margin: 0;
  }
}

.group-lists__link a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 0.5rem;
  color: #23A1D6;
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.5;
  padding: 0 0.75rem 0.5rem;
  border-bottom: 2px solid #23A1D6;
  width: fit-content;
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists__link a {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.9375);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .group-lists__link a:where(:any-link, :enabled, summary):hover:after {
    transform: translate(calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25), calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.0625));
  }
}
.group-lists__link a:after {
  content: "";
  width: 0.5rem;
  height: 0.75rem;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="9" height="12" fill="none"><path stroke="%2323A1D6" stroke-width="2" d="m1 1.059 6 5-6 5"/></svg>');
  transform: translate(0, 0.125rem);
  background-size: cover;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists__link a:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
    transform: translate(0, calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.0625));
  }
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists__link.is-left a {
    margin: 0;
  }
}

.group-lists-head {
  position: absolute;
  z-index: 1;
  width: fit-content;
  left: 0;
  right: 0;
  top: -2.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-head {
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -4.5);
  }
}
.group-lists-head p {
  font-size: 0.875rem;
  line-height: 1.5;
  font-weight: 500;
  margin: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-head p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
  }
}
.group-lists-head .wp-block-image {
  margin: 0 auto;
  max-width: 20rem;
}
@media print, only screen and ( min-width: 960px ) {
  .group-lists-head .wp-block-image {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 43.75);
  }
}

.wp-block-logo-lists {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 1.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-logo-lists {
    gap: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.625);
    justify-content: center;
  }
}

.wp-block-logo-item {
  width: calc((100% - 0.75rem) / 2);
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-logo-item {
    width: calc((100% - clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2) / 5);
  }
}

.wp-block-logo-item__image {
  line-height: 0;
  text-align: center;
}

.wp-block-factory-item {
  padding: 0 0.5rem 1rem;
  color: #3A3A3A;
}
.wp-block-factory-item:not(:first-of-type) {
  padding-top: 1rem;
  border-top: 2px solid #D8D8D8;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-factory-item {
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    display: flex;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
  .wp-block-factory-item:not(:first-of-type) {
    padding-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

.wp-block-factory-item__name {
  font-size: 0.875rem;
  line-height: 2;
  margin: 0;
  font-weight: 700;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-factory-item__name {
    width: 30%;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

.wp-block-factory-item__address {
  font-size: 0.875rem;
  line-height: 2;
  margin: 0;
  font-weight: 500;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-factory-item__address {
    width: 40%;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

.wp-block-factory-item__tel {
  font-size: 0.875rem;
  line-height: 2;
  margin: 0;
  font-weight: 500;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-factory-item__tel {
    width: 30%;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

.about-main {
  padding: 2.875rem 0 7.5rem;
  background-color: #AEDBF5;
  background-image: url(../images/about/about-main-bg.png);
  background-position: center bottom;
  background-size: auto 8.125rem;
  background-repeat: no-repeat;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 10);
    background-size: 100% auto;
    overflow: hidden;
  }
}
.about-main .page-heading {
  margin-bottom: 1.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main .page-heading {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.625);
  }
}

.about-main-inner {
  padding: 0 1.25rem;
  margin: 0 auto;
  max-width: 32.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-inner {
    padding: 0;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 42);
    position: relative;
  }
}

.about-main-contents {
  background-color: #fff;
  border-radius: 10px;
  padding: 2rem 1.25rem 3.25rem;
  width: calc(100% - 1rem);
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-contents {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.375) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5);
    width: 100%;
    margin: 0;
  }
}

.about-main-head {
  padding-bottom: 2.0625rem;
  margin-bottom: 1.875rem;
  background-image: url(../images/common/line.png);
  background-size: auto 0.25rem;
  background-position: left bottom;
  background-repeat: repeat-x;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-head {
    padding: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.125);
    background-size: auto calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.25);
  }
}

.about-main-head__fukidashi {
  margin: 0 0 0.375rem;
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.16em;
  padding: 0.375rem 0.75rem;
  background-color: #23A1D6;
  border-radius: 100vmax;
  width: fit-content;
  color: #fff;
  position: relative;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-head__fukidashi {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.about-main-head__fukidashi:after {
  content: "";
  position: absolute;
  width: 0.4375rem;
  height: 0.3125rem;
  background-color: #23A1D6;
  clip-path: polygon(0 0, 95% 0, 100% 100%);
  left: 1.6875rem;
  bottom: 1px;
  transform: translateY(100%);
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-head__fukidashi:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.5);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.3125);
  }
}

.about-main-head__catch {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.73;
  letter-spacing: 0.27em;
  color: #23A1D6;
  position: relative;
  width: fit-content;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-head__catch {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.875);
  }
}
.about-main-head__catch strong {
  font-size: 1.875rem;
  line-height: 1.33;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-head__catch strong {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.0625);
  }
}
.about-main-head__catch span {
  max-width: 4.5rem;
  display: block;
  position: absolute;
  bottom: 0.25rem;
  right: 0;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-head__catch span {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.5);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
  }
}

@media print, only screen and ( min-width: 960px ) {
  .about-main-body {
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75);
  }
}
.about-main-body p {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.71;
  font-weight: 500;
  color: #3A3A3A;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-body p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}
.about-main-body p:not(:last-of-type) {
  margin-bottom: 1.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-body p:not(:last-of-type) {
    margin-bottom: 2.25rem;
  }
}
.about-main-body p b {
  color: #23A1D6;
  font-size: 1rem;
  line-height: 1.75;
  font-weight: 900;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-body p b {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}

.about-main-illust01 {
  max-width: 13rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-illust01 {
    position: absolute;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 17.875);
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -3.875);
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -10.9375);
    z-index: 1;
  }
}
@media only screen and ( max-width: 959px ) {
  .about-main-illust01 {
    display: none;
  }
}

.about-main-illust02 {
  max-width: 12.5rem;
  margin-left: auto;
  margin-top: -3.125rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-illust02 {
    position: absolute;
    z-index: 1;
    margin: 0;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 17.125);
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 11.625);
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -20.75);
  }
}
@media only screen and ( max-width: 959px ) {
  .about-main-illust02 {
    display: none;
  }
}

.about-main-illust03 {
  max-width: 13.75rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-illust03 {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 18.875);
    position: absolute;
    z-index: 1;
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.3125);
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -17.125);
  }
}
@media only screen and ( max-width: 959px ) {
  .about-main-illust03 {
    display: none;
  }
}

.about-main-illust04 {
  max-width: 14.375rem;
  margin-left: auto;
  margin-top: -1.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-illust04 {
    position: absolute;
    z-index: 1;
    margin: 0;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 19.75);
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 31.5);
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -11.4375);
  }
}
@media only screen and ( max-width: 959px ) {
  .about-main-illust04 {
    display: none;
  }
}

.about-main-illust05 {
  max-width: 11.5rem;
  margin-top: -2.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-illust05 {
    position: absolute;
    z-index: 1;
    margin: 0;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 15.8125);
    top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 18.9375);
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -20.4375);
  }
}
@media only screen and ( max-width: 959px ) {
  .about-main-illust05 {
    display: none;
  }
}

.about-main-illust06 {
  max-width: 9.375rem;
  margin-left: auto;
  margin-top: -10rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-illust06 {
    position: absolute;
    z-index: 1;
    margin: 0;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 12.9375);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 19.0625);
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -17.5);
  }
}
@media only screen and ( max-width: 959px ) {
  .about-main-illust06 {
    display: none;
  }
}

.about-main-illust07 {
  max-width: 11.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-illust07 {
    position: absolute;
    z-index: 1;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 16.4375);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 22.0625);
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -15);
  }
}
@media only screen and ( max-width: 959px ) {
  .about-main-illust07 {
    display: none;
  }
}

.about-main-illust08 {
  max-width: 11.875rem;
  margin-left: auto;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-illust08 {
    position: absolute;
    z-index: 1;
    margin: 0;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 16.4375);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.75);
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -13.75);
  }
}
@media only screen and ( max-width: 959px ) {
  .about-main-illust08 {
    display: none;
  }
}

.about-main-illust09 {
  max-width: 11.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-main-illust09 {
    position: absolute;
    z-index: 1;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 16.25);
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75);
    left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -20);
  }
}
@media only screen and ( max-width: 959px ) {
  .about-main-illust09 {
    display: none;
  }
}

.about-method {
  background-image: url(../images/top/overview-bg.png);
  background-size: cover;
  padding: 10rem 0 3.75rem;
  overflow: hidden;
}
@media print, only screen and ( min-width: 960px ) {
  .about-method {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.875) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.5) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 4.25);
    position: relative;
  }
}

.about-method__image {
  max-width: 26.875rem;
  margin: 0 auto;
}
@media print, only screen and ( min-width: 960px ) {
  .about-method__image {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 70.625);
    margin: 0;
  }
}

.about-method-detail {
  margin: 4.5rem auto 0;
  max-width: 21.875rem;
  padding-bottom: 5.8125rem;
  position: relative;
  z-index: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .about-method-detail {
    position: absolute;
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 70.625);
    left: 0;
    margin: auto;
    right: 0;
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.25);
    padding: 0;
  }
}
.about-method-detail:after {
  content: "";
  position: absolute;
  z-index: -1;
  width: 21rem;
  height: auto;
  aspect-ratio: 336/196;
  background-image: url(../images/about/about-method-deco.png);
  background-size: cover;
  bottom: 0.625rem;
  right: -1.875rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-method-detail:after {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 37.8125);
    bottom: 0;
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * -8.75);
  }
}
.about-method-detail p {
  margin: 0;
  color: #FFF200;
  font-weight: 900;
  font-size: 1rem;
  line-height: 1.625;
  text-align: center;
}
@media print, only screen and ( min-width: 960px ) {
  .about-method-detail p {
    position: absolute;
    bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.5);
    right: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5);
    z-index: 1;
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    font-weight: 900;
    line-height: 1.7;
  }
}

.about-message {
  padding: 5rem 1.25rem;
  background-image: url(../images/service/service-main-bg.png);
  background-size: 100% auto;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 7.5);
  }
}

.about-message-contents {
  background-color: #fff;
  padding: 2.5rem 1.25rem;
  border-radius: 10px;
  flex-wrap: wrap !important;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-contents {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 3.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5);
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 75);
    gap: 0 4.375rem;
    flex-wrap: nowrap !important;
  }
}
.about-message-contents .wp-block-column {
  display: contents;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-contents .wp-block-column {
    display: block;
    flex: 1;
  }
  .about-message-contents .wp-block-column:first-of-type {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 26.25);
  }
}
.about-message-contents .wp-block-image {
  order: 1;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-contents .wp-block-image {
    max-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 33.875);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.3125);
  }
}
.about-message-contents p {
  order: 3;
  font-size: 0.875rem;
  margin-top: 0;
  font-weight: 500;
  line-height: 1.8;
  color: #3A3A3A;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-contents p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
  }
}

.about-message-head {
  order: 0;
}
.about-message-head h3.wp-block-heading {
  font-size: 1.375rem;
  font-weight: 900;
  line-height: 1.95;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-head h3.wp-block-heading {
    padding-left: 1.5rem;
    font-size: 1.5rem;
    letter-spacing: 0.17em;
  }
}
.about-message-head .wp-pattern-section-headline p {
  color: #23A1D6;
}

.about-message-info {
  order: 2;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-info {
    margin-top: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2.625);
    padding-left: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
  }
}
.about-message-info p {
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.78;
  margin-bottom: 0.625rem;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-info p {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.875);
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
  }
}
.about-message-info h4.wp-block-heading {
  margin: 0 0 2rem;
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.45;
  color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-info h4.wp-block-heading {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.about-message-info .wp-block-buttons {
  gap: 0 0.625rem;
  flex-wrap: wrap;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-info .wp-block-buttons {
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.6875);
  }
}
.about-message-info .wp-block-button__link {
  border: 2px solid #23A1D6;
  background: #FFF;
  box-shadow: 0px 4px 0px 0px rgba(0, 0, 0, 0.08);
  border-radius: 0;
  padding: 0.875rem 0.25rem;
  width: 100%;
  min-width: 8.75rem;
  color: #23A1D6;
  font-size: 1rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 0.25rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-info .wp-block-button__link {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.625);
    min-width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 10.625);
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.375);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    backface-visibility: hidden;
  }
}
@media print and (hover: hover), only screen and ( min-width: 960px ) and (hover: hover) {
  .about-message-info .wp-block-button__link:where(:any-link, :enabled, summary):hover {
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.08);
  }
}
.about-message-info .wp-block-button__link:before {
  content: "";
  display: block;
  width: 1.5rem;
  height: 1.5rem;
  background-image: url(../images/about/icon-pdf.jpg);
  background-size: cover;
}
@media print, only screen and ( min-width: 960px ) {
  .about-message-info .wp-block-button__link:before {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
  }
}

.about-profile {
  padding: 5rem 1.25rem 7.5rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-profile {
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 6.25) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.25);
  }
}
.about-profile .wp-pattern-section-headline {
  margin-bottom: 3rem;
}
@media print, only screen and ( min-width: 960px ) {
  .about-profile .wp-pattern-section-headline {
    margin-bottom: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5);
  }
}
.about-profile h3.wp-block-heading {
  font-size: 1.25rem;
  font-weight: 900;
  line-height: 1.3;
  margin: 4rem 0 1rem;
  color: #23A1D6;
  letter-spacing: 0.03em;
  display: flex;
  gap: 0 0.75rem;
  align-items: center;
}
@media print, only screen and ( min-width: 960px ) {
  .about-profile h3.wp-block-heading {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.5);
    margin: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5) 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1.125);
  }
}
.about-profile h3.wp-block-heading:before {
  content: "";
  display: block;
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 50%;
  background-color: #23A1D6;
}
@media print, only screen and ( min-width: 960px ) {
  .about-profile h3.wp-block-heading:before {
    height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
  }
}

.wp-block-profile-lists {
  margin: 0;
}

.wp-block-profile-item {
  border-bottom: 2px solid #D8D8D8;
  padding: 1.125rem 1rem;
  line-height: 1.4;
  color: #3A3A3A;
  font-size: 1rem;
  margin: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-profile-item {
    font-size: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 1);
    line-height: 2;
    padding: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75) calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 2);
    display: flex;
    gap: 0 calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 0.75);
    min-height: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 5.375);
    align-items: center;
  }
}

.wp-block-profile-item__title {
  margin: 0 0 0.5rem;
  font-weight: 700;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-profile-item__title {
    width: calc(clamp(0.75rem, -1.132rem + 2.94vw, 1rem) * 8.75);
    margin: 0;
  }
}

.wp-block-factory-item__detail {
  margin: 0;
}
@media print, only screen and ( min-width: 960px ) {
  .wp-block-factory-item__detail {
    flex: 1;
  }
}

body.post-type-post .wp-block-separator, .single-post-content .wp-block-separator {
  width: 100% !important;
  color: #eee;
  margin: 40px 0;
}

body.post-type-post .editor-styles-wrapper {
  font-size: 16px;
}
body.post-type-post .editor-styles-wrapper p {
  font-size: 16px;
  line-height: 1.8;
}
body.post-type-post .editor-styles-wrapper h1 {
  font-size: 32px;
}
body.post-type-post .editor-styles-wrapper h2 {
  font-size: 28px;
}
body.post-type-post .editor-styles-wrapper h3 {
  font-size: 24px;
}
body.post-type-post .editor-styles-wrapper h4 {
  font-size: 20px;
}
body.post-type-post .editor-styles-wrapper h5 {
  font-size: 18px;
}
body.post-type-post .editor-styles-wrapper h6 {
  font-size: 16px;
}
body.post-type-post .editor-styles-wrapper ul,
body.post-type-post .editor-styles-wrapper ol {
  font-size: 16px;
  line-height: 1.8;
}
body.post-type-post .editor-styles-wrapper blockquote {
  font-size: 16px;
  line-height: 1.8;
}

.hidden {
  display: none !important;
}

@media only screen and ( max-width: 959px ) {
  .sm\:hidden {
    display: none !important;
  }
}

@media print, only screen and ( min-width: 960px ) {
  .md\:hidden {
    display: none !important;
  }
}

.bg-none {
  background: none;
}

.left {
  text-align: left !important;
}

.center {
  text-align: center !important;
}

@media print, only screen and ( min-width: 960px ) {
  .md\:center {
    text-align: center !important;
  }
}

@media only screen and ( max-width: 959px ) {
  .sm\:center {
    text-align: center !important;
  }
}

.mx-0 {
  margin: 0 !important;
}

.mx-auto {
  margin: auto !important;
}

.mb-auto {
  margin-bottom: auto;
}

.mt-auto {
  margin-top: auto;
}

.ml-auto {
  margin-left: auto;
}

.mr-auto {
  margin-right: auto;
}

@media only screen and ( max-width: 959px ) {
  .sm\:mb-auto {
    margin-bottom: auto;
  }
  .sm\:mt-auto {
    margin-top: auto;
  }
  .sm\:ml-auto {
    margin-left: auto;
  }
  .sm\:mr-auto {
    margin-right: auto;
  }
}
@media print, only screen and ( min-width: 960px ) {
  .md\:mb-auto {
    margin-bottom: auto;
  }
  .md\:mt-auto {
    margin-top: auto;
  }
  .md\:ml-auto {
    margin-left: auto;
  }
  .md\:mr-auto {
    margin-right: auto;
  }
}
.px-0 {
  padding: 0 !important;
}

/*# sourceMappingURL=app.css.map*/