@charset "UTF-8";
/*
Theme Name: theme name
Description: description
Author:yashibous
Author URI: https://yashibous.com
*/
/*
 * Foundation
 * --------------------------
 */
/*
 * Layout
 * --------------------------
 */
/*
 * header.scss
 */
/*
 * Commoon.scss
 */
/*
 * text-setting.scss
 */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Roboto:wght@100..900&display=swap");
/*
 * base.scss
 */
html {
  scroll-snap-type: y proximity;
  scroll-padding-top: var(--layout-header-height);
}

body {
  margin: 0 auto;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", Arial, Verdana, sans-serif;
  font-weight: 500;
  overflow-x: hidden;
}

img {
  display: block;
  object-fit: contain;
  object-position: top left;
}

.image img {
  width: 100%;
  height: auto;
}

a {
  --a-hover-color: var(--color-hover);
}
a:hover, a:focus, a.active {
  text-decoration: none;
}

/*
 * responsive.scss
 */
.sp-first {
  width: 300px;
}
@media screen and (min-width: 1170px) {
  .sp-first {
    width: 1200px;
  }
}

.sp-first-tab {
  width: 300px;
}
@media screen and (min-width: 1170px) and (max-width: 1365px) {
  .sp-first-tab {
    width: 800px;
  }
}
@media screen and (min-width: 1170px) {
  .sp-first-tab {
    width: 1200px;
  }
}

.pc-first {
  width: 1200px;
}
@media screen and (max-width: 1169px) {
  .pc-first {
    width: 300px;
  }
}

.pc-fitst-tab {
  width: 1200px;
}
@media screen and (max-width: 1169px) {
  .pc-fitst-tab {
    width: 300px;
  }
}
@media screen and (min-width: 1170px) and (max-width: 1365px) {
  .pc-fitst-tab {
    width: 800px;
  }
}

/*
 * function.scss
 */
/*
 * variables.scss
 */
:root {
  /*
   * ブレイクポイント
   */
  --breakpoint-tablet: 950px;
  --breakpoint-pc: 864px;
  --fluid-max: 750;
  --fluid-min: 375;
  /*
   * レイアウト
   */
  --layout-width-max: 750px;
  --layout-content-width: 750px;
  --layout-header-height: clamp(160px / 2, calc(160px / 2 + ((160 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 160px);
  /*
   * 余白
   */
  /* スペースプリセット */
  --space-preset-xs: clamp(10px, calc(12px + ((12 - 10) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 12px);
  --space-preset-s: clamp(16px, calc(18px + ((18 - 16) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 18px);
  --space-preset-m: clamp(20px / 2, calc(20px / 2 + ((20 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 20px);
  --space-preset-l: clamp(80px / 2, calc(80px / 2 + ((80 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 80px);
  --space-preset-xl: clamp(40px, calc(70px + ((70 - 40) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 70px);
  --space-preset-xxl: clamp(60px, calc(100px + ((100 - 60) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --space-block-gap: 1.8em;
  /* 基本のpadding */
  --content-padding-block: clamp(60px / 2, calc(60px / 2 + ((60 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 60px);
  --content-padding-inline: var(--space-preset-m);
  /*
   * タイポグラフィ
   */
  --font-size-s: 30;
  --font-size-m: 32;
  --font-size-l: 34;
  --font-size-xl: 36;
  --font-size-xxl: 40;
  --font-size-title: 72;
  /*
   * カラーパレット
   */
  /* カラープリセット */
  --color-base: #ffffff;
  --color-contrast: #333333;
  --color-primary: #a70806;
  --color-secondary: #fff902;
  --color-tertiary: #fab700;
  --color-primary-pale1: #e21419;
  --color-primary-pale2: color-mix(in srgb, var(--color-primary) 25%, var(--color-base));
  --color-secondary-pale1: color-mix(in srgb, var(--color-secondary) 50%, var(--color-base));
  --color-secondary-pale2: color-mix(in srgb, var(--color-secondary) 25%, var(--color-base));
  --color-tertiary-pale1: color-mix(in srgb, var(--color-tertiary) 50%, var(--color-base));
  --color-tertiary-pale2: color-mix(in srgb, var(--color-tertiary) 25%, var(--color-base));
  --color-gray: #e6e6e6;
  --color-dark-gray: #777777;
  --color-light-gray: #f5f5f5;
  --color-cta-button: #f06707,
  #ff8414;
  --color-gradient-primary: var(--color-primary-pale1),
  var(--color-primary);
  /* テキスト */
  --color-title: var(--color-contrast);
  --color-text: var(--color-contrast);
  --color-text-shadow: var(--color-gray);
  --color-hover: var(--color-primary);
  /* 背景 */
  --color-bg-primary: var(--color-white);
  --color-bg-secondary: var(--color-gray);
  --color-bg-tertiary: var(--color-light-gray);
  --color-bg-header: #191919;
  --color-bg-footer: #191919;
  --color-bg-fixed: transparent;
  --color-bg-cta: var(--color-base);
  /* マーカー */
  --color-marker: #ffc002aa;
  /*
   * z-index
   */
  --z-index-base: 100;
  --z-index-header: 1000;
  --z-index-fixed: 900;
  --z-index-to-top: 3000;
  --z-index-overlay: 4000;
}
@media screen and (min-width: 1170px) {
  :root {
    --layout-width-max: 1920px;
    --layout-content-width: 866px;
    --layout-header-height: 90px;
  }
}
@media screen and (min-width: 1170px) {
  :root {
    --content-padding-block: 60px;
    --content-padding-inline: 40px;
  }
}
@media screen and (min-width: 1170px) {
  :root {
    --font-size-title: 54;
  }
}

/*
 * function.scss
 */
.l-header {
  --m-padding-block: clamp(48px / 2, calc(48px / 2 + ((48 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 48px);
  --m-padding-inline: var(--content-padding-inline);
  --m-height: var(--layout-header-height);
  --m-width: var(--layout-width-max);
  z-index: var(--z-index-header);
}
.l-header[data-type*=fixed] {
  height: var(--m-height);
  background-color: var(--color-bg-header);
  position: sticky;
  top: 0;
  left: 0;
}
.l-header[data-type*=fixed] .l-header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: var(--m-width);
  height: 100%;
  padding-block: var(--m-padding-block);
  padding-inline: var(--m-padding-inline);
  margin-inline: auto;
}
@media screen and (min-width: 1170px) {
  .l-header[data-type*=fixed] {
    position: relative;
    top: 0;
    left: 0;
  }
  .l-header[data-type*=fixed] .l-header__inner {
    --m-padding-block: 22px;
    --m-padding-inline: 231px;
  }
}
.l-header[data-type*=fixed] .l-header__button {
  display: none;
}
@media screen and (min-width: 1170px) {
  .l-header[data-type*=floating] {
    --gnav-display: block;
    background-color: var(--color-base);
    width: 190px;
    position: fixed;
    top: 0;
    left: 0;
    animation: slidein 0.3s ease-in-out;
    border-radius: 0 12px 12px 0;
    filter: drop-shadow(0 2px 12px rgba(0, 0, 0, 0.12));
  }
  .l-header[data-type*=floating] .l-header__button {
    display: block;
    background-image: linear-gradient(to left, var(--color-cta-button));
    font-size: 15px;
    color: var(--color-base);
    font-weight: 400;
    text-align: center;
    padding-block: 30px;
    border-radius: 0 0 12px 0;
  }
  .l-header[data-type*=floating] .l-header__button span {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
  .l-header[data-type*=floating] .l-header__button span::before {
    content: "";
    display: block;
    width: 19px;
    height: 9px;
    background-image: url(../image/l-header-button-icon.svg);
    background-size: contain;
    background-repeat: no-repeat;
  }
  .l-header[data-type*=floating] .l-header__button:hover {
    opacity: 0.9;
  }
}

@keyframes slidein {
  from {
    transform: translateX(-100%);
  }
}
.l-header.slide-out {
  transform: translateX(-100%);
  transition: transform 0.3s ease-in-out;
}

/*
 * footer.scss
 */
.l-footer {
  --m-padding-block: clamp(55px / 2, calc(55px / 2 + ((55 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 55px);
  --m-padding-inline: var(--content-padding-inline);
  --m-font-size: clamp(24px / 2, calc(24px / 2 + ((24 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 24px);
  --m-copyright-font-size: clamp(18px / 2, calc(18px / 2 + ((18 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 18px);
  --m-color: var(--color-base);
  width: 100%;
  background-color: var(--color-bg-footer);
  padding-block: var(--m-padding-block);
}
@media screen and (min-width: 1170px) {
  .l-footer {
    --m-padding-block: 35px;
    --m-font-size: 16px;
    --m-copyright-font-size: 12px;
  }
}

.l-footer__inner {
  display: grid;
  place-items: center;
  gap: clamp(17.5px, 17.5px + 17.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 35px);
  width: fit-content;
  margin-inline: auto;
}
@media screen and (min-width: 1170px) {
  .l-footer__inner {
    gap: 30px;
  }
}

.l-footer__list {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: var(--m-font-size);
  color: var(--m-color);
  text-align: center;
}

.l-footer__item:nth-child(1)::after {
  content: "/";
}

.l-footer__copyright {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: var(--m-copyright-font-size);
  color: var(--m-color);
}

/*
 * mainvisual.scss
 */
.l-mainvisual {
  --mainvisual-height: auto;
  --m-content-width: var(--layout-content-width);
  width: 100%;
  height: var(--mainvisual-height);
  margin-inline: auto;
  background-image: url(../image/mainvisual-bg1.webp), url(../image/mainvisual-bg2.webp);
  background-size: clamp(220px, 220px + 220 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 440px), cover;
  background-position: right bottom, top center;
  background-repeat: no-repeat;
}
@media screen and (min-width: 1170px) {
  .l-mainvisual {
    background-image: url(../image/mainvisual-bg1-pc.webp), url(../image/mainvisual-bg2-pc.webp);
    background-size: 350px, cover;
    background-position: right calc(50% - 210px) bottom, top center;
  }
}
.l-mainvisual__inner {
  max-width: var(--m-content-width);
  margin-inline: auto;
}

.l-mainvisual__contents {
  padding-block-start: clamp(40px, 40px + 40 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 80px);
  padding-block-end: clamp(12.5px, 12.5px + 12.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 25px);
}

.l-mainvisual__header {
  font-weight: 900;
  font-size: clamp(14.5px, 14.5px + 14.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 29px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.08em;
  padding-block: 0.15em;
  width: clamp(355px, 355px + 355 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 710px);
  margin-inline: auto;
  margin-block-end: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
  background-color: var(--color-base);
}
.l-mainvisual__header .sub1 {
  color: var(--color-primary-pale1);
}
@media screen and (min-width: 1170px) {
  .l-mainvisual__header {
    width: 490px;
    font-size: 20px;
    margin-inline: 30px auto;
    margin-block-end: 0;
  }
}

.l-mainvisual__copy1 {
  width: clamp(255px, 255px + 255 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 510px);
  margin-block-end: clamp(18px, 18px + 18 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 36px);
}
@media screen and (min-width: 1170px) {
  .l-mainvisual__copy1 {
    width: 540px;
    margin-block-end: -10px;
  }
}

.l-mainvisual__copy2 {
  width: clamp(240px, 240px + 240 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 480px);
  margin-block-end: clamp(86px, 86px + 86 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 172px);
}
@media screen and (min-width: 1170px) {
  .l-mainvisual__copy2 {
    width: 500px;
    margin-block-end: 40px;
    translate: 18px 0;
  }
}

.l-mainvisual__footer {
  font-weight: 500;
  font-size: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px);
  line-height: 1.6;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: left;
  width: fit-content;
  margin-inline: auto clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  text-shadow: 0.167em 0 0 #fff, -0.167em 0 0 #fff, 0 0.167em 0 #fff, 0 -0.167em 0 #fff, 0.125em 0.125em 0 #fff, -0.125em 0.125em 0 #fff, 0.125em -0.125em 0 #fff, -0.125em -0.125em 0 #fff, 0 0 0.333em #fff;
}

/*
 * section.scss
 */
.l-section {
  --m-contents-width: var(--layout-content-width);
  --m-padding-block: var(--content-padding-block);
  --m-padding-inline: var(--content-padding-inline);
  --m-content-gap: var(--space-block-gap);
  max-width: 100%;
  margin-inline: auto;
}
.l-section[data-type*=full] {
  --m-contents-width: 100%;
  --m-padding-inline: 0;
}

.l-section__inner {
  max-width: var(--m-contents-width);
  margin-inline: auto;
  padding-inline: var(--m-padding-inline);
}
@media screen and (min-width: 1170px) {
  .l-section__inner {
    margin-inline: auto;
  }
}
@media screen and (min-width: 1170px) {
  .l-section__inner[data-layout=center] {
    margin-inline: auto;
  }
}

.l-section__contents {
  padding-block: var(--m-padding-block);
  width: 100%;
}

/*
* 個別セクションレイアウト
*/
.l-section[data-sec=cta] {
  background-image: url(../image/sec-cta-bg.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.l-section[data-sec=cta].--no-bg-sp {
  background-image: none;
}
@media screen and (min-width: 1170px) {
  .l-section[data-sec=cta].--no-bg-sp {
    background-image: url(../image/sec-cta-bg-pc.webp);
  }
}
.l-section[data-sec=cta] .l-section__contents {
  padding-block: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px) clamp(28px, 28px + 28 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 56px);
}
@media screen and (min-width: 1170px) {
  .l-section[data-sec=cta] {
    background-image: url(../image/sec-cta-bg-pc.webp);
  }
  .l-section[data-sec=cta] .l-section__contents {
    padding-block: 60px;
  }
}

/*
 * fixed.scss
 */
.l-fixed {
  --m-bg-color: var(--color-bg-fixed);
  --m-content-max: var(--layout-width-max);
  display: none;
  position: sticky;
  bottom: 0;
  left: 0;
  z-index: var(--z-index-fixed);
  width: 100%;
  background-color: var(--m-bg-color);
}
@media screen and (max-width: 1169px) {
  .l-fixed {
    display: block;
  }
}

.l-fixed__inner {
  width: 100%;
  height: 100%;
  display: grid;
  justify-content: center;
  align-items: center;
  grid-template-columns: repeat(1, 1fr);
  max-width: var(--m-content-max);
  margin-inline: auto;
  padding-block: clamp(7.5px, 7.5px + 7.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 15px);
}

.l-fixed__buttonc-button {
  background-image: url(../image/fixed-bg.webp);
  width: clamp(355px, 355px + 355 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 710px);
  height: clamp(45px, 45px + 45 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 90px);
  margin-inline: auto;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: var(--color-base);
  text-align: center;
  font-size: clamp(16px, 16px + 16 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 32px);
  font-weight: 700;
  line-height: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-block-end: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
}

/*
 * Component
 * --------------------------
 */
/*
 * logo.scss
 */
.c-logo {
  --m-height: 40px; /* 高さでサイズを決める */
  height: var(--m-height);
}
.c-logo[data-type*=header] {
  --m-height: 100%;
}
.c-logo__image {
  display: block;
  position: relative;
  height: 100%;
}
.c-logo__image img {
  width: auto;
  height: 100%;
}

.l-header[data-type*=floating] .c-logo {
  display: none;
  background-color: var(--color-bg-header);
  padding-inline: 30px;
  padding-block: 15px;
}
.l-header[data-type*=floating] .c-logo .c-logo__image img {
  width: 100%;
}

/*
 * hamburger.scss
 */
.c-hamburger {
  --m-width: clamp(50px / 2, calc(50px / 2 + ((50 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 50px);
  --m-padding-block: clamp(3px / 2, calc(3px / 2 + ((3 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 3px);
  --m-padding-inline: clamp(3px / 2, calc(3px / 2 + ((3 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 3px);
  --m-line-width: clamp(3px / 2, calc(3px / 2 + ((3 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 3px);
  --m-line-color: var(--color-base);
  display: none;
  width: var(--m-width);
  height: var(--m-width);
  padding-block: var(--m-padding-block);
  padding-inline: var(--m-padding-inline);
  z-index: calc(var(--z-index-header) + 1);
  cursor: pointer;
}
@media screen and (max-width: 1169px) {
  .c-hamburger {
    display: block;
    position: relative;
  }
}

.c-hamburger.active {
  top: var(--m-padding-block);
  right: var(--m-padding-inline);
  scale: 1.4;
}

.c-hamburger__inner {
  position: relative;
}

.c-hamburger__line {
  display: block;
  width: 100%;
  height: var(--m-line-width);
  background-color: var(--m-line-color);
  border-radius: 0;
}
.c-hamburger__line:nth-child(2) {
  margin-block: clamp(8px, 8px + 8 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 16px);
}

.c-hamburger.active .c-hamburger__line {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
}
.c-hamburger.active .c-hamburger__line:nth-of-type(1) {
  transform: translateY(-10px) rotate(45deg);
}
.c-hamburger.active .c-hamburger__line:nth-of-type(2) {
  background-color: transparent;
  bottom: unset;
  top: clamp(2.5px, 2.5px + 2.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 5px);
}
.c-hamburger.active .c-hamburger__line:nth-of-type(2)::after {
  content: "close";
  text-transform: uppercase;
  display: block;
  width: 100%;
  height: auto;
  color: var(--m-line-color);
  font-size: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.24em;
}
.c-hamburger.active .c-hamburger__line:nth-of-type(3) {
  transform: translateY(-10px) rotate(-45deg);
}

/*
 * gnav.scss
 */
.c-gnav {
  --m-color: var(--color-text);
  --m-font-size: clamp(38px / 2, calc(38px / 2 + ((38 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 38px);
  --m-element-gap: 20px;
  display: none;
  opacity: 0;
}
@media screen and (min-width: 1170px) {
  .c-gnav {
    display: var(--gnav-display, none);
    opacity: 1;
    --m-font-size: 14px;
  }
}

.c-gnav.panelactive {
  display: flex;
  position: fixed;
  top: var(--layout-header-height);
  right: 0;
  width: 100%;
  height: calc(100% - var(--layout-header-height));
  z-index: 1;
  background-color: var(--color-base);
  flex-direction: column;
  animation: fadein 0.6s forwards 0s;
  padding-block: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
}

.c-gnav__pages {
  flex-direction: column;
  align-items: center;
  gap: var(--m-element-gap);
  height: auto;
  padding-inline: clamp(40px, 40px + 40 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 80px);
  overflow-y: auto;
}
@media screen and (min-width: 1170px) {
  .c-gnav__pages {
    padding-inline: 50px 10px;
    padding-block: 30px;
  }
}

.c-gnav__menu {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: var(--m-font-size);
  color: var(--m-color);
  text-align: left;
  position: relative;
}
.c-gnav__menu a {
  display: block;
  width: 100%;
  padding-block: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
}
.c-gnav__menu:not(:last-child) {
  border-bottom: 1px solid var(--color-contrast);
}
@media screen and (min-width: 1170px) {
  .c-gnav__menu {
    font-weight: 500;
  }
  .c-gnav__menu:hover {
    font-weight: 700;
  }
  .c-gnav__menu.active::before {
    content: "";
    position: absolute;
    left: -20px;
    top: 50%;
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    background-color: #ff8414;
    border-radius: 50%;
    opacity: 1;
    transition: opacity 0.3s ease-in-out;
  }
  .c-gnav__menu.active {
    font-weight: 700;
  }
  .c-gnav__menu a {
    padding-block: 10px;
  }
  .c-gnav__menu:not(:last-child) {
    border-bottom: none;
  }
  .c-gnav__menu.active::before {
    left: -15px;
    width: 8px;
    height: 8px;
  }
}

.c-gnav__icons {
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: center;
}

@keyframes fadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
body:has(.c-gnav.panelactive) {
  overflow: hidden;
}

/*
 * cta.scss
 */
.c-cta {
  background-color: var(--color-bg-cta);
  background-image: linear-gradient(to right, var(--color-gradient-primary));
  padding: 4px;
  width: 100%;
  max-width: 950px;
  margin-left: auto;
  margin-right: auto;
}
.c-cta__title {
  padding-block: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px) clamp(9px, 9px + 9 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 18px);
}

.c-cta__contents {
  position: relative;
  background-color: var(--color-base);
  padding-block: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px) clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
}
@media screen and (min-width: 1170px) {
  .c-cta__contents {
    padding-block: 20px 20px;
  }
}

.c-cta__text1 {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(16px, 16px + 16 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 32px);
  line-height: 1.4;
  color: var(--color-base);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.08em;
}
@media screen and (min-width: 1170px) {
  .c-cta__text1 {
    font-size: 28px;
    letter-spacing: 0.05em;
  }
}

.c-cta__text2 {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(14px, 14px + 14 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 28px);
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.08em;
  margin-block-end: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
}

.c-cta__text3 {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: clamp(26px, 26px + 26 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 52px);
  line-height: 1;
  color: var(--color-primary);
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.15em;
  margin-block-end: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
}
.c-cta__text3 .sub1 {
  display: block;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: clamp(13px, 13px + 13 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 26px);
  line-height: 1;
  color: var(--color-base);
  text-align: center;
  padding-inline: 0.5em 0.9em;
  padding-block: 0.75em;
  background-color: var(--color-primary);
  border-radius: 0.25em;
  clip-path: polygon(0 0, calc(100% - 0.9em) 0, 100% 50%, calc(100% - 0.9em) 100%, 0 100%);
}
@media screen and (min-width: 1170px) {
  .c-cta__text3 {
    font-size: 48px;
  }
  .c-cta__text3 .sub1 {
    font-size: 26px;
  }
}

.c-cta__text4 {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px);
  line-height: 1;
  text-align: center;
  margin-block-end: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
}
@media screen and (min-width: 1170px) {
  .c-cta__text4 {
    font-size: 24px;
  }
}

.c-cta__button {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(21px, 21px + 21 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 42px);
  line-height: 1;
  color: var(--color-base);
  text-align: center;
  background-image: linear-gradient(to top, var(--color-cta-button));
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 1.5em;
  width: clamp(315px, 315px + 315 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 630px);
  margin-inline: auto;
  padding-block: 0.35em;
  padding-inline: 0.35em;
  border-radius: 5em;
  border: 0.1em solid var(--color-base);
  box-shadow: 0 0.1em 0.3em rgba(0, 0, 0, 0.17);
}
.c-cta__button::after {
  content: "";
  display: inline-block;
  width: clamp(57.5px, 57.5px + 57.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 115px);
  height: clamp(57.5px, 57.5px + 57.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 115px);
  background-color: var(--color-base);
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB3aWR0aD0iMjdweCIgaGVpZ2h0PSIyN3B4Ij48cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHN0cm9rZT0icmdiKDAsIDAsIDApIiBzdHJva2Utd2lkdGg9IjFweCIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49ImJldmVsIiBmaWxsPSJyZ2IoMCwgMCwgMCkiIGQ9Ik00LjAxNCw0LjAyOSBMNC4wMTQsMS4yNTYgTDI1LjIzMiwxLjI1NiBMMjUuMjMyLDQuMDI5IEw0LjAxNCw0LjAyOSBaIi8+PHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBzdHJva2U9InJnYigwLCAwLCAwKSIgc3Ryb2tlLXdpZHRoPSIxcHgiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIgZmlsbD0icmdiKDAsIDAsIDApIiBkPSJNMjIuNjgyLDEuMjgzIEwyNS4yOTIsMS4zMjEgTDI1LjA0OSwyMy4zOTIgTDIyLjQzOSwyMy4zNTQgTDIyLjY4MiwxLjI4MyBaIi8+PHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBmaWxsPSJyZ2IoMCwgMCwgMCkiIGQ9Ik0yMC43MTAsMy4xODMgTDIzLjMyNCw1Ljc5OCBMMi45OTAsMjYuMTMyIEwwLjM3NiwyMy41MTggTDIwLjcxMCwzLjE4MyBaIi8+PC9zdmc+");
  background-repeat: no-repeat;
  background-position: left calc(50% - 0px) top calc(50% - 0px);
  background-size: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px) clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px);
  border-radius: 200px;
}
@media screen and (min-width: 1170px) {
  .c-cta__button {
    font-size: 34px;
    width: 474px;
    padding-block: 0.2em;
    padding-inline: 0.15em;
    gap: 1.1em;
    position: relative;
    overflow: hidden;
  }
  .c-cta__button::before {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    display: block;
    border-radius: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.17);
    -webkit-transition: 0.2s ease;
    transition: 0.2s ease;
    z-index: 2;
  }
  .c-cta__button::after {
    width: 86px;
    height: 86px;
    background-size: 18px 18px;
    -webkit-transition: 0.2s ease-in-out;
    transition: 0.2s ease-in-out;
    z-index: 1;
    position: relative;
  }
  .c-cta__button:hover {
    box-shadow: 0 0 0 rgba(0, 0, 0, 0.1);
  }
  .c-cta__button:hover::before {
    top: 0;
  }
  .c-cta__button:hover::after {
    background-size: 20px 20px;
  }
}

/*
 * faq.scss
 */
.c-faq {
  --m-q-icon: "Q";
  --m-a-icon: "A";
  --m-q-icon-color: var(--color-base);
  --m-a-icon-color: var(--color-primary);
  --m-q-font-size: clamp(32px / 2, calc(32px / 2 + ((32 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 32px);
  --m-a-font-size: clamp(28px / 2, calc(28px / 2 + ((28 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 28px);
  --m-q-color: var(--color-base);
  --m-a-color: var(--color-text);
  --m-q-bg-color: var(--color-primary);
  --m-a-bg-color: var(--color-base);
}
@media screen and (min-width: 1170px) {
  .c-faq {
    --m-q-font-size: 24px;
    --m-a-font-size: 20px;
  }
}

.c-faq > * {
  background-color: var(--faq-bg-color);
  padding-block: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
  padding-inline: clamp(18px, 18px + 18 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 36px) clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
  position: relative;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: var(--faq-font-size);
  color: var(--faq-color);
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: clamp(13px, 13px + 13 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 26px);
}
@media screen and (min-width: 1170px) {
  .c-faq > * {
    font-weight: 500;
    padding-block: 8px;
  }
}
.c-faq > *::before {
  content: var(--faq-icon);
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-weight: 500;
  font-size: clamp(16px, 16px + 16 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 32px);
  color: var(--faq-icon-color);
}
@media screen and (min-width: 1170px) {
  .c-faq > *::before {
    font-size: 30px;
    line-height: 1.2;
  }
}
.c-faq > *:first-child {
  --faq-font-size: var(--m-q-font-size);
  --faq-color: var(--m-q-color);
  --faq-bg-color: var(--m-q-bg-color);
  --faq-icon: var(--m-q-icon);
  --faq-icon-color: var(--m-q-icon-color);
}
.c-faq > *:last-child {
  --faq-font-size: var(--m-a-font-size);
  --faq-color: var(--m-a-color);
  --faq-bg-color: var(--m-a-bg-color);
  --faq-icon: var(--m-a-icon);
  --faq-icon-color: var(--m-a-icon-color);
  padding-block-end: 0;
  --m-padding-unit: clamp(20px / 2, calc(20px / 2 + ((20 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 20px) 0;
}

/*
 * form.scss
 */
.c-form {
  --form-list-gap: clamp(30px / 2, calc(30px / 2 + ((30 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 30px);
  --form-main-bg-color: #f6f4f4;
  --form-item-font-size: clamp(29px / 2, calc(29px / 2 + ((29 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 29px);
  --form-item-label-width: 25%;
  --form-input-font-size: clamp(30px / 2, calc(30px / 2 + ((30 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 30px);
}
@media screen and (min-width: 1170px) {
  .c-form {
    --form-item-font-size: 15px;
  }
}
.c-form fieldset {
  display: contents;
}
.c-form label,
.c-form legend {
  display: inline-block;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: var(--form-item-font-size);
  color: var(--color-text);
  text-align: left;
}
.c-form label span,
.c-form legend span {
  display: inline-block;
}
.c-form input[type=text],
.c-form input[type=tel],
.c-form input[type=email],
.c-form input[type=password],
.c-form textarea,
.c-form select {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-size: var(--form-input-font-size);
  color: var(--color-text);
  border: 1px solid #d8d8d8;
  border-radius: clamp(2.5px, 2.5px + 2.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 5px);
  padding: 0.4em 1.1em;
  width: 100%;
}
@media screen and (min-width: 1170px) {
  .c-form input[type=text],
  .c-form input[type=tel],
  .c-form input[type=email],
  .c-form input[type=password],
  .c-form textarea,
  .c-form select {
    font-size: 16px;
  }
}
.c-form input:focus,
.c-form textarea:focus {
  border-color: var(--color-accent-main);
}
.c-form textarea {
  vertical-align: top;
  height: 14.7em;
  resize: vertical;
}
@media screen and (min-width: 1170px) {
  .c-form textarea {
    height: 10em;
  }
}
.c-form button {
  margin-block: 20px;
  background-color: #fff;
}

.c-form__main {
  width: 100%;
}

.c-form__list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--form-list-gap);
  justify-content: space-between;
}

.c-form__item {
  flex: 1 1 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  position: relative;
}
@media screen and (min-width: 1170px) {
  .c-form__item:nth-child(2), .c-form__item:nth-child(3), .c-form__item:nth-child(6), .c-form__item:nth-child(7) {
    flex: 0 1 45%;
  }
}
.c-form__item:has(select) {
  position: relative;
}
.c-form__item:has(select)::after {
  content: "";
  position: absolute;
  top: clamp(40px, 40px + 40 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 80px);
  right: clamp(24px, 24px + 24 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 48px);
  width: clamp(12px, 12px + 12 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 24px);
  height: clamp(12px, 12px + 12 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 24px);
  border-right: clamp(1px, 1px + 1 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 2px) solid #d8d8d8;
  border-bottom: clamp(1px, 1px + 1 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 2px) solid #d8d8d8;
  transform: rotate(45deg) translateY(-50%);
}
@media screen and (min-width: 1170px) {
  .c-form__item:has(select)::after {
    top: 3em;
    right: 1.2em;
    width: 0.6em;
    height: 0.6em;
  }
}

.c-form__item-title {
  margin-block-end: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
}

.c-form__item-required {
  color: #dd0000;
  font-size: 1em;
  margin-left: 0.2em;
  font-weight: bold;
}

.c-form__item-desc {
  display: block;
  font-size: clamp(11px, 11px + 11 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 22px);
  font-weight: 400;
  margin-block-end: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
}
@media screen and (min-width: 1170px) {
  .c-form__item-desc {
    font-size: 12px;
  }
}

.c-form__error-message {
  color: var(--color-primary-pale1);
  font-size: clamp(13px, 13px + 13 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 26px);
  font-weight: 400;
  line-height: 1.2;
  display: none;
  margin-block-start: 0.2em;
}
@media screen and (min-width: 1170px) {
  .c-form__error-message {
    font-size: 16px;
  }
}
.c-form__error-message.show {
  display: block;
}

input[type=text],
input[type=email],
input[type=tel],
select,
textarea {
  background: #f7f8fa;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  padding: 14px 16px;
  font-size: 1em;
  color: #222;
  transition: border-color 0.2s;
  box-sizing: border-box;
}
input[type=text].error,
input[type=email].error,
input[type=tel].error,
select.error,
textarea.error {
  border-color: var(--color-primary);
}

input[type=text]:focus,
input[type=email]:focus,
input[type=tel]:focus,
select:focus,
textarea:focus {
  border-color: var(--color-dark-gray);
  outline: none;
}

input::placeholder,
textarea::placeholder {
  color: #bbb;
  opacity: 1;
}

select {
  color: #333;
  position: relative;
}

select option {
  color: #333;
}

select option:first-child,
select option[value=""] {
  color: #bbb;
}

textarea {
  min-height: 100px;
  resize: vertical;
}

.c-button[type=submit], .c-form__main button[type=submit] {
  display: block;
  width: clamp(235px, 235px + 235 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 470px);
  margin: clamp(50px, 50px + 50 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 100px) auto 0;
  padding-block: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  background-color: #fa7a10;
  color: #fff;
  font-size: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
  border: clamp(2px, 2px + 2 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 4px) solid var(--color-base);
  border-radius: 100px;
  box-shadow: 0 clamp(3.5px, 3.5px + 3.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 7px) clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px) rgba(0, 0, 0, 0.17);
  cursor: pointer;
  transition: background 0.2s, box-shadow 0.2s;
}
@media screen and (min-width: 1170px) {
  .c-button[type=submit], .c-form__main button[type=submit] {
    font-size: 18px;
    border-width: 3px;
    padding-block: 12px;
    width: 350px;
    font-weight: 500;
  }
}

/*
* checkbox, radio-button
*/
.checkbox {
  --checkbox-size: 30px;
  --checkbox-color: #fff;
  --checkbox-border-color: #999;
  --checkbox-background: #f0f0f0;
  --checkbox-checked-color: var(--color-accent-main);
  --checkbox-checked-background: #ffffff;
  --checkbox-checked-border-color: var(--color-accent-main);
  --checkbox-hover-border-color: var(--color-accent-main);
  --checkbox-transition: 0.3s ease;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-size: 16px;
  color: var(--color-text);
}
.checkbox:has(:focus-visible) {
  outline: auto var(--checkbox-border-color);
  outline-offset: 4px;
  text-decoration: underline;
  text-underline-offset: 0.25em;
}
@media (any-hover: hover) {
  .checkbox:hover {
    text-decoration: underline;
    text-underline-offset: 0.25em;
  }
}
.checkbox input {
  position: absolute;
  opacity: 0;
}
.checkbox label {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  position: relative;
  height: var(--checkbox-size);
  padding-left: calc(var(--checkbox-size) + 10px);
  cursor: pointer;
}
.checkbox label::before {
  content: "";
  position: absolute;
  line-height: 1.2;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: var(--checkbox-size);
  height: var(--checkbox-size);
  background-color: var(--checkbox-background);
  border: 1px solid var(--checkbox-border-color);
  border-radius: 3px;
  transition: background var(--checkbox-transition), border-color var(--checkbox-transition);
}
.checkbox label:hover::before {
  border-color: var(--checkbox-hover-border-color);
}
.checkbox input:checked + label {
  color: var(--color-accent-main);
}
.checkbox input:checked + label::before {
  content: "✔";
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--checkbox-checked-background);
  border-color: var(--checkbox-checked-border-color);
  color: var(--checkbox-checked-color);
}
.checkbox[data-type=radio] input + label::before {
  border-radius: 50%;
}
.checkbox[data-type=radio] input:checked + label::before {
  content: "●";
}

/*==================================================
スライダーのためのcss
https://glidejs.com/
===================================*/
.c-slider {
  --m-bullet-color: var(--color-gray);
  --m-bullet-color-active: var(--color-primary-pale1);
  --m-bullet-size: 0.7em;
  --m-arrow-color: var(--color-contrast);
  --m-arrow-size: 3em;
  --m-icon-arrow-right: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><polyline points="8,4 16,12 8,20" fill="none" stroke="black" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>') no-repeat center;
  --m-icon-arrow-left: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><polyline points="16,4 8,12 16,20" fill="none" stroke="black" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>') no-repeat center;
  --m-content-gap: 2em;
  padding-block: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px) clamp(45px, 45px + 45 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 90px);
  width: clamp(260px, 260px + 260 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 520px);
  max-width: 750px;
  margin-inline: auto;
  overflow: visible;
}
@media screen and (min-width: 1170px) {
  .c-slider {
    overflow: hidden;
    padding-block: 10px 50px;
    width: 1180px;
    width: auto;
    max-width: 1156px;
    margin-inline-start: 210px;
  }
}
@media screen and (min-width: 1170px) and (max-width: 1365px) {
  .c-slider {
    width: auto;
    margin-inline-start: 210px;
  }
}
@media screen and (min-width: 1550px) {
  .c-slider {
    margin-inline: auto;
  }
}

@media screen and (min-width: 1170px) {
  .p-thanks__voice .c-slider {
    margin-inline: auto;
  }
}

.c-slider__item {
  box-shadow: 2px 2px 10px 0 rgba(0, 0, 0, 0.1);
}

.swiper {
  --swiper-pagination-bottom: 0;
  --swiper-pagination-color: var(--color-primary-pale1);
  --swiper-pagination-bullet-size: clamp(25px / 2, calc(25px / 2 + ((25 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 25px);
  --swiper-pagination-bullet-horizontal-gap: clamp(15px / 2, calc(15px / 2 + ((15 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 15px);
  --swiper-navigation-top-offset: 37%;
}
@media screen and (min-width: 1170px) {
  .swiper {
    --swiper-pagination-bullet-size: 12px;
    --swiper-navigation-top-offset: 38%;
  }
}

.swiper-wrapper {
  transform: translate3d(0, 0, 0);
  display: flex;
  flex-direction: row;
}

.swiper-slide {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: auto;
}

.swiper-button-next, .swiper-button-prev {
  width: clamp(48px, 48px + 48 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 96px);
  height: clamp(48px, 48px + 48 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 96px);
  --swiper-navigation-sides-offset: calc(-1 * clamp(108px / 2, calc(108px / 2 + ((108 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 108px));
}
@media screen and (min-width: 1170px) {
  .swiper-button-next, .swiper-button-prev {
    width: 40px;
    height: 40px;
    --swiper-navigation-sides-offset: 20px;
  }
}

.swiper-button-next:after, .swiper-button-prev:after {
  content: "";
  background-image: url(../image/c-slider-button-prev.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 100%;
}

.swiper-button-next {
  scale: -1 1;
}

/*
 * table.scss
 */
.c-table {
  --m-head-font-size: 18px;
  --m-head-color: var(--color-text);
  --m-head-bg-color: #f6f4f4;
  --m-data-font-size: 18px;
  --m-data-color: var(--color-text);
  --m-data-bg-color: #ffffff;
  --m-border-color: #e6e5e5;
  width: 100%;
}

.c-table__data {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: var(--m-data-font-size);
  color: var(--m-data-color);
  background-color: var(--m-data-bg-color);
  padding: 1em 1.5em;
}

.c-table__head {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: var(--m-head-font-size);
  color: var(--m-head-color);
  background-color: var(--m-head-bg-color);
  padding: 1em 1.5em;
}

.c-table[data-type=border] .c-table__data {
  border: 1px solid var(--m-border-color);
}
.c-table[data-type=border] .c-table__head {
  border: 1px solid var(--m-border-color);
}

/*
 * parts.scss
 */
/*
* button
*/
.c {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  border-radius: 3px;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 1.6px;
  position: relative;
  width: 100%;
  height: 54px;
}
.c::after {
  position: absolute;
  content: "";
  background-image: url(../image/button-icon.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  width: 14px;
  height: 6px;
  top: calc(50% - 2px);
  right: 15px;
}

/*
* tag
*/
.tag {
  color: var(--color-white);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.84px;
  display: flex;
  padding: 5px 10px;
  align-items: center;
  gap: 10px;
  background-color: var(--color-accent-main);
  border-radius: 5px;
  width: fit-content;
}
.tag::before {
  content: "";
  background-image: url(../image/tag-xmark.svg);
  background-size: 100% 100%;
  width: 10px;
  height: 10px;
}
.tag--small {
  font-size: 12px;
  letter-spacing: 0.84px;
}

/*
* accordion
*/
/* アコーディオン全体の設定 */
.accordion {
  --m-color: var(--color-base);
  --m-size: clamp(20px / 2, calc(20px / 2 + ((20 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 20px);
  --m-transition: 0.4s ease-in-out;
  position: relative;
}
@media screen and (min-width: 1170px) {
  .accordion {
    --m-size: 12px;
  }
}
.accordion::before, .accordion::after {
  content: "";
  position: absolute;
  top: clamp(16px, 16px + 16 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 32px);
  right: clamp(18px, 18px + 18 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 36px);
  width: var(--m-size);
  height: clamp(1.5px, 1.5px + 1.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 3px);
  background-color: var(--m-color);
  transition: transform var(--m-transition);
  transform-origin: center;
  z-index: 1;
  transform: rotate(-45deg);
}
@media screen and (min-width: 1170px) {
  .accordion::before, .accordion::after {
    top: 28px;
    height: 2px;
    right: 39px;
  }
}
.accordion::after {
  transform: rotate(45deg);
  right: clamp(24.5px, 24.5px + 24.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 49px);
}
@media screen and (min-width: 1170px) {
  .accordion::after {
    right: 46px;
  }
}
.accordion:is(.open)::before {
  transform: rotate(45deg);
}
.accordion:is(.open):after {
  transform: rotate(-45deg);
}
.accordion > :first-child {
  cursor: pointer;
}
.accordion > :last-child {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--m-transition);
  padding-block: 0;
  margin: 0;
}
.accordion > :last-child span {
  padding-block: var(--m-padding-unit, 20px);
}
.accordion > :last-child::before {
  padding-block: var(--m-padding-unit, 20px);
}
@media screen and (min-width: 1170px) {
  .accordion > :last-child::before {
    padding-block-start: 18px;
  }
}
.accordion.open > :last-child {
  max-height: clamp(100px, 100px + 100 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 200px);
}

/*
*
* sorting
*/
.sorting {
  position: relative;
  width: 114px;
}
.sorting.dashboard-info__top-right {
  width: 100px;
}
.sorting.dashboard-info__top-right .sorting__select {
  padding: 7px 10px 7px 30px;
}
.sorting::before {
  position: absolute;
  content: "";
  display: inline-block;
  background-image: url(../image/parts__icon--sorting.svg);
  background-size: 100% 100%;
  width: 15px;
  height: 15px;
  top: 7px;
  left: 10px;
}
.sorting__select {
  display: flex;
  align-items: flex-end;
  flex-shrink: 0;
  gap: 5px;
  width: 100%;
  height: 29px;
  padding: 7px 10px 7px 30px;
  color: var(--color-accent-main);
  font-size: 13px;
  font-weight: 400;
  line-height: 15px;
  letter-spacing: 0.91px;
  text-align: left;
  border-radius: 43px;
  background: var(--color-gray1);
  cursor: pointer;
}

/*
* icons
*/
.icons {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  gap: 0;
}

.icon::before {
  display: inline-block;
  content: "";
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}
.icon--visible::before {
  background-image: url(../image/parts__icon--invisible.svg);
  width: 1em;
  height: 1em;
}
.icon--visible.active::before {
  background-image: url(../image/parts__icon--visible.svg);
}
.icon--open-in-new {
  position: relative;
  display: inline;
}
.icon--open-in-new::before {
  content: none;
}
.icon--open-in-new::after {
  content: none;
  display: inline-block;
  margin-left: 5px;
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url(../image/parts__icon--open-in-new.svg);
  width: 1em;
  height: 1em;
  position: relative;
  top: 2px;
}
.icon--open-in-new:hover::after {
  content: "";
}

/*
* textlink
*/
.textlink {
  color: var(--color-accent-main);
  transition: color 0.3s ease-out;
}
.textlink:hover {
  color: var(--color-black);
}

/*
* form-icon
*/
.form-icon {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
}
.form-icon::after {
  display: flex;
  padding: 4px 6px;
  justify-content: center;
  align-items: center;
  border-radius: 11px;
  background-color: var(--color-accent-sub);
  content: "任意";
  color: var(--color-white);
  text-align: justify;
  font-size: 0.8em;
  letter-spacing: 0.1em;
  line-height: 1;
}
.form-icon--required::after {
  content: "必須";
  background-color: #f24e1e;
}

/*
* fuchi
*/
.fuchi {
  display: inline-block;
  font-weight: 900;
  font-size: 16px;
  line-height: 1;
  font-family: "Noto Sans JP";
  /* 設定値サンプル */
  fill: #fff;
  stroke: var(--blue);
  stroke-width: 0.3em;
  filter: drop-shadow(4px 4px 0 rgba(0, 0, 0, 0.4));
}

.fuchi svg {
  width: 100%;
  height: auto;
}

.fuchi text {
  font-weight: inherit;
  font-size: inherit;
  font-family: inherit;
  fill: inherit;
  stroke: none;
  text-anchor: start;
  dominant-baseline: alphabetic;
  filter: inherit;
}

.fuchi text.bg {
  stroke: inherit;
  stroke-width: inherit;
  paint-order: stroke;
  stroke-linejoin: round;
}

.parts__text.fuchi {
  fill: #fff;
  stroke: blue;
  width: 240px;
  filter: none;
}

/*
 * c-title.scss
 */
.c-title {
  --m-title-font-size: var(--font-size-l);
  --m-title-color: var(--color-title);
  font-weight: 700;
  font-size: clamp(36px, 36px + 36 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 72px);
  color: var(--m-title-color);
  font-feature-settings: "palt";
  text-align: center;
  padding-block-start: 0.65em;
  letter-spacing: 0.04em;
  position: relative;
  z-index: 1;
}
.c-title .sub1 {
  font-size: 0.85em;
}
.c-title::before {
  content: "";
  background-image: var(--m-title-en-image);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  display: block;
  width: var(--m-title-en-width, 5em);
  height: var(--m-title-en-height, 2em);
  position: absolute;
  inset-inline: 0;
  inset-block-start: 0;
  margin: auto;
  opacity: 0.2;
  z-index: -1;
}
@media screen and (min-width: 1170px) {
  .c-title {
    font-size: 54px;
    padding-block-start: 1.2em;
  }
}

/*
 * c-title.scss
 */
.c-text {
  --m-font-size: var(--font-size-m);
  --m-color: var(--color-text);
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: var(--m-font-size);
  line-height: 1.8;
  color: var(--m-color);
  text-align: left;
}

/*
 * c-title.scss
 */
.c-image {
  max-width: var(--m-width);
  height: auto;
}
.c-image img {
  width: 100%;
  height: auto;
}

/*
 * stack.scss
 */
.c-stack {
  --m-content-gap: clamp(42px / 2, calc(42px / 2 + ((42 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 42px);
  display: block grid;
  width: 100%;
  row-gap: var(--m-content-gap);
}

/*
 * c-tab-view.scss
 */
/*
  <div class="tab-view">
    <ul class="tab-view__tab">
      <li data-current="true"></li>
      <li></li>
    </ul>
    <ul class="tab-view__content">
      <li data-current="true"></li>
      <li></li>
    </ul>
  </div>
*/
.c-tab-view {
  --m-bg-color: var(--color-bg-secondary);
  --m-bg-color-active: var(--color-bg-tertiary);
  --m-color: var(--color-text);
  --m-color-active: var(--color-text);
  width: 100%;
}
.c-tab-view__tab {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.c-tab-view__tab li {
  width: fit-content;
  padding-block: var(--space-preset-xs);
  padding-inline: var(--space-preset-m);
  background-color: var(--m-bg-color);
  cursor: pointer;
  text-align: center;
}
.c-tab-view__tab li[data-current=true] {
  background-color: var(--m-bg-color-active);
  font-weight: 700;
  cursor: default;
}
.c-tab-view__content {
  position: relative;
  transition: height 0.3s ease-out;
}
.c-tab-view__content li {
  background-color: var(--m-bg-color-active);
  position: relative;
  top: 0;
  left: 0;
  display: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease-out, visibility 0.3s ease-out;
  padding-block: var(--space-preset-m);
  padding-inline: var(--space-preset-m);
}
.c-tab-view__content li[data-current=true] {
  display: block;
  opacity: 1;
  visibility: visible;
}

/*
 * c-button.scss
 */
.c-button {
  --m-font-size: var(--font-size-m);
  --m-color: var(--color-base);
  --m-bg-color: var(--color-bg-secondary);
  display: block flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  background-color: var(--m-bg-color);
  -webkit-transition: 0.2s ease;
  transition: 0.2s ease;
}
.c-button:hover {
  box-shadow: 0 0 0 rgba(0, 0, 0, 0.1);
  opacity: 0.9;
}
.c-button:hover::before {
  top: 0;
}
.c-button p {
  font-size: var(--m-font-size);
  line-height: 1.5;
  color: var(--m-color);
  text-align: center;
  padding-block: 0.8em;
}

/*
 * Pages
 * --------------------------
 */
/*
 * p-index.scss
 */
/* sec01 */
.sec01 {
  background-color: var(--color-primary);
}
.sec01 .c-title {
  --m-title-en-image: url(../image/sec01__title-en.webp);
  --m-title-en-width: clamp(530px / 2, calc(530px / 2 + ((530 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 530px);
  --m-title-en-height: clamp(100px / 2, calc(100px / 2 + ((100 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --m-title-color: var(--color-base);
  margin-block-end: clamp(12.5px, 12.5px + 12.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 25px);
}
.sec01 .l-section__contents {
  padding-block: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px) clamp(35px, 35px + 35 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 70px);
}
@media screen and (min-width: 1170px) {
  .sec01 .c-title {
    margin-block-end: 30px;
  }
  .sec01 .l-section__contents {
    padding-block: 40px 80px;
  }
}

.sec01__contents {
  background-color: var(--color-base);
  padding-block: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px) clamp(25px, 25px + 25 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 50px);
  position: relative;
  z-index: 1;
}
.sec01__contents::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px) * -1);
  z-index: -1;
  background-image: url(../image/sec01__contents-after.webp);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  height: clamp(27px, 27px + 27 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 54px);
  opacity: 0.3;
}
.sec01__contents::after {
  content: "";
  background-color: var(--color-base);
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.sec01__img1 {
  width: clamp(330px, 330px + 330 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 660px);
  max-width: 100%;
  margin-inline: auto;
}
@media screen and (min-width: 1170px) {
  .sec01__img1 {
    width: 560px;
    margin-block-end: 10px;
  }
}

.sec01__text1 {
  font-weight: 700;
  font-size: clamp(27px, 27px + 27 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 54px);
  line-height: 1.5;
  color: var(--color-primary);
  font-feature-settings: "palt";
  text-align: center;
  margin-block-end: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  position: relative;
  width: fit-content;
  margin-inline: auto;
  padding-inline: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
}
.sec01__text1::before, .sec01__text1::after {
  content: "";
  position: absolute;
  top: 0;
  width: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px);
  height: 100%;
  border: clamp(2px, 2px + 2 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 4px) solid var(--color-text);
}
.sec01__text1::before {
  left: 0;
  border-right: none;
}
.sec01__text1::after {
  right: 0;
  border-left: none;
}
@media screen and (min-width: 1170px) {
  .sec01__text1 {
    font-size: 42px;
    padding-inline: 20px;
  }
}

.sec01__text2 {
  font-size: clamp(17px, 17px + 17 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 34px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.08em;
}
.sec01__text2 .sub1 {
  font-weight: 700;
  color: var(--color-secondary);
  display: inline-block;
  background-image: linear-gradient(to left, var(--color-primary), var(--color-primary-pale1));
  padding-inline: 0.6em;
  margin-inline: 0.1em;
  clip-path: polygon(0.3em 0, 100% 0, calc(100% - 0.3em) 100%, 0 100%);
  text-box-trim: initial;
  text-box-edge: text;
  line-height: 1;
  padding-block: clamp(4px, 4px + 4 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 8px) clamp(4.5px, 4.5px + 4.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 9px);
}
.sec01__text2:not(:last-child) {
  margin-block-end: clamp(12.5px, 12.5px + 12.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 25px);
}
@media screen and (min-width: 1170px) {
  .sec01__text2 {
    font-size: 24px;
  }
}

/* sec02 */
.sec02 .c-title {
  --m-title-en-image: url(../image/sec02__title-en.webp);
  --m-title-en-width: clamp(375px / 2, calc(375px / 2 + ((375 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 375px);
  --m-title-en-height: clamp(100px / 2, calc(100px / 2 + ((100 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --m-title-color: var(--color-text);
  margin-block-end: clamp(12.5px, 12.5px + 12.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 25px);
}
.sec02 .l-section__contents {
  padding-block: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px) clamp(35px, 35px + 35 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 70px);
}
@media screen and (min-width: 1170px) {
  .sec02 .c-title {
    margin-block-end: 30px;
  }
  .sec02 .l-section__inner {
    max-width: calc(var(--layout-content-width) + 250px);
    padding-inline: 10px;
  }
  .sec02 .l-section__contents {
    padding-block: 40px 60px;
    padding-inline: 0;
  }
}

@media screen and (min-width: 1170px) {
  .sec02__contents {
    padding-inline: 0;
  }
}

@media screen and (min-width: 1170px) and (max-width: 1500px) {
  .sec02 .sec02__contents {
    margin-inline-start: calc(160px - (100vw - 1170px) * 160 / 330);
  }
}
.sec02__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px);
}
@media screen and (min-width: 1170px) {
  .sec02__list {
    gap: 20px 40px;
  }
}

.sec02__item {
  flex-basis: 100%;
  background-image: linear-gradient(to bottom, var(--color-gradient-primary));
  box-shadow: 0 clamp(4px, 4px + 4 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 8px) clamp(3px, 3px + 3 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 6px) rgba(0, 0, 0, 0.12);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
}
.sec02__item:nth-child(1) .sec02__item-icon img {
  width: clamp(26px, 26px + 26 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 52px);
}
.sec02__item:nth-child(2) .sec02__item-icon img {
  width: clamp(33px, 33px + 33 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 66px);
}
.sec02__item:nth-child(3) .sec02__item-icon img {
  width: clamp(34px, 34px + 34 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 68px);
}
.sec02__item:nth-child(4) .sec02__item-icon img {
  width: clamp(39.5px, 39.5px + 39.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 79px);
}
.sec02__item:nth-child(5) .sec02__item-icon img {
  width: clamp(40px, 40px + 40 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 80px);
}
@media screen and (min-width: 1170px) {
  .sec02__item {
    flex-shrink: 1;
    flex-basis: calc(50% - 20px);
    padding: 10px;
  }
  .sec02__item:nth-child(1) .sec02__item-icon img {
    width: 47px;
  }
  .sec02__item:nth-child(2) .sec02__item-icon img {
    width: 51px;
  }
  .sec02__item:nth-child(3) .sec02__item-icon img {
    width: 53px;
  }
  .sec02__item:nth-child(4) .sec02__item-icon img {
    width: 50px;
  }
  .sec02__item:nth-child(5) .sec02__item-icon img {
    width: 60px;
  }
}

.sec02__item-icon {
  flex: 0 0 clamp(50px, 50px + 50 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 100px);
}
.sec02__item-icon img {
  margin-inline: auto;
  height: auto;
}
@media screen and (min-width: 1170px) {
  .sec02__item-icon {
    flex: 0 1 70px;
  }
}

.sec02__item-text {
  flex: 1 1 auto;
  font-weight: 700;
  font-size: clamp(16px, 16px + 16 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 32px);
  line-height: 1.6;
  color: var(--color-base);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.04em;
}
.sec02__item-text .sub1 {
  color: var(--color-secondary);
}
@media screen and (min-width: 1170px) {
  .sec02__item-text {
    font-size: 22px;
    flex: 1 0 auto;
  }
}

/* sec03 */
.sec03 {
  background-color: #e6e6e6;
}
.sec03 .c-title {
  --m-title-en-image: url(../image/sec03__title-en.webp);
  --m-title-en-width: clamp(493px / 2, calc(493px / 2 + ((493 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 493px);
  --m-title-en-height: clamp(100px / 2, calc(100px / 2 + ((100 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --m-title-color: var(--color-text);
  margin-block-end: clamp(12.5px, 12.5px + 12.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 25px);
  padding-block-start: clamp(40px, 40px + 40 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 80px);
}
.sec03 .c-title::before {
  opacity: 0.5;
}
.sec03 .c-title .sub2 {
  display: block;
  font-weight: 700;
  font-size: clamp(18px, 18px + 18 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 36px);
  line-height: 1.5;
  color: var(--color-base);
  font-feature-settings: "palt";
  text-align: center;
  width: fit-content;
  padding-inline: 1.05em;
  padding-block-end: 0.1em;
  margin-inline: auto;
  background-image: linear-gradient(to left, var(--color-primary), var(--color-primary-pale1));
}
.sec03 .l-section__contents {
  padding-block: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px) clamp(25px, 25px + 25 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 50px);
}
@media screen and (min-width: 1170px) {
  .sec03 .c-title {
    padding-block-start: 60px;
    margin-block-end: 35px;
  }
  .sec03 .c-title .sub2 {
    font-size: 28px;
    padding-inline: 0.8em;
  }
}

.sec03__top {
  position: relative;
  z-index: 2;
}

.sec03__contents {
  position: relative;
  z-index: 1;
}

.sec03__top-area {
  margin-block-end: clamp(25px, 25px + 25 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 50px);
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 1170px) {
  .sec03__top-area {
    margin-block-end: 30px;
  }
}

.sec03__text1 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  width: fit-content;
  margin-inline: auto;
  position: relative;
  padding-inline: clamp(32.5px, 32.5px + 32.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 65px);
  margin-block-end: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px);
}
.sec03__text1 .sub1 {
  display: block;
  font-weight: 700;
  font-size: clamp(18px, 18px + 18 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 36px);
  line-height: 1.5;
  color: var(--color-secondary);
  font-feature-settings: "palt";
  text-align: center;
  width: fit-content;
  padding-inline: 1.05em;
  padding-block-end: 0.1em;
  margin-inline: auto;
  background-image: linear-gradient(to left, var(--color-primary), var(--color-primary-pale1));
  clip-path: polygon(0.3em 0, 100% 0, calc(100% - 0.3em) 100%, 0 100%);
  text-box-trim: initial;
  text-box-edge: text;
  line-height: 1;
  padding-block: clamp(4px, 4px + 4 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 8px) clamp(5.5px, 5.5px + 5.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 11px);
}
.sec03__text1 .sub2 {
  display: block;
  background-image: url(../image/sec03__text1-sub2.webp);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: clamp(289.5px, 289.5px + 289.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 579px);
  height: clamp(27px, 27px + 27 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 54px);
  color: transparent;
  margin-inline: auto;
}
.sec03__text1::before, .sec03__text1::after {
  content: "";
  width: clamp(35px, 35px + 35 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 70px);
  height: clamp(75px, 75px + 75 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 150px);
  background-image: url(../image/sec03__text1-before.webp);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  position: absolute;
  top: calc(clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px) * -1);
}
.sec03__text1::before {
  left: 0;
}
.sec03__text1::after {
  right: 0;
  transform: scaleX(-1);
}
@media screen and (min-width: 1170px) {
  .sec03__text1 {
    padding-inline: 50px;
    margin-block-end: 22px;
    gap: 10px;
  }
  .sec03__text1 .sub1 {
    font-size: 25px;
  }
  .sec03__text1 .sub2 {
    width: 410px;
  }
  .sec03__text1::before, .sec03__text1::after {
    content: "";
    width: 50px;
    height: 110px;
  }
}

.sec03__text2 {
  font-weight: 700;
  font-size: clamp(17px, 17px + 17 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 34px);
  line-height: 1.8;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.04em;
}
.sec03__text2 .sub1 {
  font-size: 1.1em;
}
@media screen and (min-width: 1170px) {
  .sec03__text2 {
    font-size: 24px;
    line-height: 1.5;
  }
  .sec03__text2 .sub1 {
    font-size: 30px;
  }
}

.sec03__list {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px);
  margin-block-end: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
  position: relative;
}
.sec03__list::before {
  content: "";
  background-image: url(../image/sec03__list-before.webp);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: clamp(148.5px, 148.5px + 148.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 297px);
  height: clamp(113.5px, 113.5px + 113.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 227px);
  position: absolute;
  top: calc(clamp(95px, 95px + 95 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 190px) * -1);
  right: 0;
}
@media screen and (min-width: 1170px) {
  .sec03__list::before {
    width: 300px;
    height: 227px;
    top: -150px;
    right: 70px;
  }
}

.sec03__item {
  flex: 1 1 calc(50% - clamp(3px, 3px + 3 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 6px));
  background-color: var(--color-base);
  padding-block: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: clamp(12.5px, 12.5px + 12.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 25px);
}
.sec03__item:last-child {
  padding-block: clamp(17.5px, 17.5px + 17.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 35px);
  flex: 1 1 100%;
  gap: clamp(7.5px, 7.5px + 7.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 15px);
}
@media screen and (min-width: 1170px) {
  .sec03__item {
    gap: 10px;
    flex: 1 1 calc(33% - 10px);
  }
  .sec03__item:last-child {
    padding-block: 40px 65px;
    gap: 15px;
    flex-basis: calc(33% - 10px);
  }
}

.sec03__item-title {
  font-weight: 900;
  font-size: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px);
  line-height: 1.1;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: -0.02em;
}
@media screen and (min-width: 1170px) {
  .sec03__item-title {
    font-size: 22px;
  }
}

.sec03__item-text1 {
  font-size: clamp(14px, 14px + 14 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 28px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.02em;
}
.sec03__item-text1 .sub1 {
  font-size: clamp(30px, 30px + 30 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 60px);
  font-weight: 900;
  background: linear-gradient(to right, var(--color-gradient-primary));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}
.sec03__item-text1 .image1 {
  background-image: url(../image/sec03__item-text1-1.webp);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: clamp(130.5px, 130.5px + 130.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 261px);
  height: clamp(42.5px, 42.5px + 42.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 85px);
  display: block;
  margin-inline: auto;
  color: transparent;
}
.sec03__item-text1 .image2 {
  background-image: url(../image/sec03__item-text1-2.webp);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: clamp(84px, 84px + 84 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 168px);
  height: clamp(56.5px, 56.5px + 56.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 113px);
  display: block;
  margin-inline: auto;
  color: transparent;
}
@media screen and (min-width: 1170px) {
  .sec03__item-text1 {
    font-size: 20px;
  }
  .sec03__item-text1 .sub1 {
    font-size: 50px;
    display: block;
    margin-block-start: 15px;
  }
  .sec03__item-text1 .image1 {
    width: 160px;
    height: 60px;
  }
  .sec03__item-text1 .image2 {
    width: 138px;
    height: 100px;
  }
}

.sec03__item-text2 {
  font-size: clamp(12px, 12px + 12 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 24px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 1170px) {
  .sec03__item-text2 {
    font-size: 18px;
  }
}

.sec03__text3 {
  font-weight: 700;
  font-size: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: right;
  margin-block-end: clamp(14px, 14px + 14 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 28px);
}
@media screen and (min-width: 1170px) {
  .sec03__text3 {
    font-size: 14px;
  }
}

.sec03__text4 {
  font-size: clamp(17px, 17px + 17 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 34px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.08em;
}
.sec03__text4 .sub1 {
  color: var(--color-base);
  font-weight: 700;
  display: inline-block;
  background-image: linear-gradient(to right, var(--color-gradient-primary));
  width: fit-content;
  padding-inline: 0.3em;
  margin-inline: 0.1em;
  text-box-trim: initial;
  text-box-edge: text;
  line-height: 1;
  padding-block: clamp(4px, 4px + 4 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 8px) clamp(4.5px, 4.5px + 4.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 9px);
}
@media screen and (min-width: 1170px) {
  .sec03__text4 {
    font-size: 24px;
    line-height: 1.7;
  }
}

/* sec04 */
.sec04 {
  background-image: linear-gradient(216deg, transparent 26%, color-mix(in srgb, var(--color-primary) 80%, transparent) 26%), url(../image/sec04-bg1.webp), url(../image/sec04-bg2.webp);
  background-size: cover, clamp(269px, 269px + 269 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 538px), cover;
  background-position: center, top right, top center;
  background-repeat: no-repeat;
}
.sec04 .c-title {
  --m-title-en-image: none;
  --m-title-en-width: clamp(493px / 2, calc(493px / 2 + ((493 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 493px);
  --m-title-en-height: clamp(100px / 2, calc(100px / 2 + ((100 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --m-title-color: var(--color-text);
  margin-block-end: clamp(7.5px, 7.5px + 7.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 15px);
  padding-block-start: 0;
  font-weight: 700;
  font-size: clamp(36px, 36px + 36 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 72px);
  line-height: 1.1;
  color: var(--color-base);
  font-feature-settings: "palt";
  text-align: center;
  text-shadow: 0 0 clamp(7.5px, 7.5px + 7.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 15px) var(--color-text);
}
.sec04 .c-title .sub1 {
  font-size: 0.5em;
  display: block;
  margin-inline: auto;
  margin-block-end: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
}
.sec04 .c-title .sub2 {
  font-size: 1.2em;
  vertical-align: text-bottom;
}
.sec04 .l-section__contents {
  padding-block: clamp(40px, 40px + 40 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 80px) clamp(43px, 43px + 43 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 86px);
}
@media screen and (min-width: 1170px) {
  .sec04 {
    background-image: linear-gradient(222deg, transparent 31%, color-mix(in srgb, var(--color-primary) 80%, transparent) 31%), url(../image/sec04-bg1-pc.webp), url(../image/sec04-bg2-pc.webp);
    background-size: cover, 850px, cover;
    background-position: center, top left calc(50% + 250px), top center;
  }
  .sec04 .c-title {
    font-size: 54px;
    margin-block-end: 20px;
  }
  .sec04 .c-title .sub1 {
    font-size: 42px;
    margin-block-end: 10px;
  }
  .sec04 .l-section__contents {
    padding-block: 55px 60px;
  }
}

@media screen and (min-width: 1366px) {
  .sec04 {
    background-position: center, top right, top center;
  }
}
.sec04__text1 {
  font-weight: 700;
  font-size: clamp(17px, 17px + 17 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 34px);
  line-height: 1.8;
  color: var(--color-base);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.08em;
  margin-inline: calc(clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px) * -1);
  text-shadow: 0 clamp(2px, 2px + 2 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 4px) clamp(7.5px, 7.5px + 7.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 15px) var(--color-text);
  margin-block-end: clamp(14px, 14px + 14 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 28px);
}
@media screen and (min-width: 1170px) {
  .sec04__text1 {
    font-size: 24px;
    line-height: 1.7;
  }
}

.sec04__list {
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
}
@media screen and (min-width: 1170px) {
  .sec04__list {
    padding-inline: 140px;
  }
}

.sec04__item {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px);
  padding-block: clamp(8px, 8px + 8 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 16px);
  padding-inline: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
  background-color: var(--color-base);
  clip-path: polygon(clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px) 0, 100% 0, calc(100% - clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px)) 100%, 0 100%);
}
.sec04__item::before {
  content: "";
  background-image: url(../image/sec04__item-icon.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: clamp(25px, 25px + 25 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 50px);
  height: clamp(24px, 24px + 24 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 48px);
}
@media screen and (min-width: 1170px) {
  .sec04__item {
    padding-block: 10px;
  }
  .sec04__item::before {
    width: 32px;
    height: 32px;
  }
}

.sec04__item-text {
  font-size: clamp(16px, 16px + 16 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 32px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: left;
  letter-spacing: 0.04em;
}
.sec04__item-text .sub1 {
  color: var(--color-primary);
  font-weight: 700;
}
@media screen and (min-width: 1170px) {
  .sec04__item-text {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.8;
  }
}

/* sec05 */
.sec05 {
  overflow: hidden;
}
.sec05 .c-title {
  --m-title-en-image: url(../image/sec05__title-en.webp);
  --m-title-en-width: clamp(375px / 2, calc(375px / 2 + ((375 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 375px);
  --m-title-en-height: clamp(100px / 2, calc(100px / 2 + ((100 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --m-title-color: var(--color-text);
  margin-block-end: clamp(12.5px, 12.5px + 12.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 25px);
}
.sec05 .l-section__contents {
  padding-block: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px) clamp(50px, 50px + 50 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 100px);
}
.sec05 .l-section__inner {
  padding-inline: 0;
  max-width: unset;
}
@media screen and (min-width: 1170px) {
  .sec05 .l-section__contents {
    padding-block: 40px 60px;
  }
}

.sec05__image img {
  aspect-ratio: 485/315;
  width: 100%;
  height: auto;
  object-fit: cover;
}
@media screen and (min-width: 1170px) {
  .sec05__image img {
    aspect-ratio: 314/198;
  }
}

.sec05__textarea {
  padding-block: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px);
  padding-inline: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px) clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
}
@media screen and (min-width: 1170px) {
  .sec05__textarea {
    padding-inline: 10px;
    padding-block: 18px;
  }
}

.sec05__content {
  height: clamp(110px, 110px + 110 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 220px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border-left: clamp(2px, 2px + 2 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 4px) solid var(--color-primary-pale1);
  padding-left: clamp(7.5px, 7.5px + 7.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 15px);
}
@media screen and (min-width: 1170px) {
  .sec05__content {
    height: 128px;
    padding-left: 8px;
    border-left: 3px solid var(--color-primary-pale1);
  }
}

.sec05__content-name {
  font-weight: 500;
  font-size: clamp(13px, 13px + 13 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 26px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: left;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 1170px) {
  .sec05__content-name {
    font-size: 18px;
  }
}

.sec05__content-title {
  font-weight: 700;
  font-size: clamp(12px, 12px + 12 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 24px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: left;
  letter-spacing: 0.08em;
  background: linear-gradient(90deg, var(--color-gradient-primary));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 1170px) {
  .sec05__content-title {
    font-size: 18px;
    letter-spacing: -0.02em;
    font-weight: 500;
    line-height: 1.4;
  }
}

.sec05__content-text {
  font-size: clamp(9px, 9px + 9 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 18px);
  line-height: 1.6;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: left;
  letter-spacing: 0.02em;
}
@media screen and (min-width: 1170px) {
  .sec05__content-text {
    font-size: 15px;
  }
}

/* sec06 */
.sec06 {
  --m-background-color: color-mix(in srgb, var(--color-primary) 76%, transparent);
  background-image: linear-gradient(to bottom, var(--m-background-color), var(--m-background-color)), url(../image/sec06-bg.webp);
  background-size: cover, cover;
  background-position: center, center top;
  background-repeat: no-repeat;
}
.sec06 .c-title {
  --m-title-en-image: url(../image/sec06__title-en.webp);
  --m-title-en-width: clamp(375px / 2, calc(375px / 2 + ((375 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 375px);
  --m-title-en-height: clamp(100px / 2, calc(100px / 2 + ((100 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --m-title-color: var(--color-text);
  margin-block-end: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  color: var(--color-base);
  font-size: clamp(29px, 29px + 29 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 58px);
  margin-inline: -0.3em;
  padding-block-start: 1em;
}
.sec06 .l-section__contents {
  padding-block: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px) clamp(40px, 40px + 40 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 80px);
}
@media screen and (min-width: 1170px) {
  .sec06 {
    background-image: linear-gradient(to bottom, var(--m-background-color), var(--m-background-color)), url(../image/sec06-bg-pc.webp);
  }
  .sec06 .c-title {
    font-size: 54px;
  }
  .sec06 .l-section__inner {
    max-width: calc(var(--m-contents-width) + 170px);
  }
  .sec06 .l-section__contents {
    padding-block: 30px 60px;
  }
}
@media screen and (min-width: 1170px) and (max-width: 1365px) {
  .sec06 .l-section__inner {
    margin-inline-start: 160px;
  }
}

.sec06__contents {
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
}

.sec06__text1 {
  font-weight: 700;
  font-size: clamp(17px, 17px + 17 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 34px);
  line-height: 1.8;
  color: var(--color-base);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.08em;
}
@media screen and (min-width: 1170px) {
  .sec06__text1 {
    font-size: 24px;
  }
}

.sec06__list {
  display: flex;
  flex-direction: column;
  gap: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px);
  padding-inline: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
}
@media screen and (min-width: 1170px) {
  .sec06__list {
    flex-direction: row;
    gap: 10px;
    padding-inline: 0;
  }
}

.sec06__item {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  background-color: var(--color-base);
  padding-block: clamp(17.5px, 17.5px + 17.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 35px);
  padding-inline: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px) 0;
  --step-width: clamp(108px / 2, calc(108px / 2 + ((108 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 108px);
  --m-sec06-maincolor: var(--color-text);
  --m-sec06-title-color: var(--color-primary);
}
.sec06__item:nth-child(1) {
  --step-width: clamp(105px / 2, calc(105px / 2 + ((105 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 105px);
}
.sec06__item:nth-child(3) {
  --m-sec06-maincolor: var(--color-base);
  --m-sec06-title-color: var(--color-secondary);
  margin-inline: calc(clamp(7.5px, 7.5px + 7.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 15px) * -1);
  background-image: linear-gradient(to right, var(--color-gradient-primary));
  border: clamp(2px, 2px + 2 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 4px) solid var(--m-sec06-maincolor);
}
@media screen and (min-width: 1170px) {
  .sec06__item {
    --step-width: 62px;
    flex-direction: column;
    justify-content: flex-start;
    padding-block: 20px;
    padding-inline: 0;
    flex: 1 1 230px;
  }
  .sec06__item:nth-child(1) {
    --step-width: 59px;
  }
  .sec06__item:nth-child(3) {
    margin-inline: 0;
    border-width: 3px;
    padding-block: 17px;
  }
  .sec06__item:nth-child(3) .sec06__item-text-text {
    text-align: left;
  }
  .sec06__item:nth-child(4) .sec06__item-text-title {
    padding-block: 16px;
  }
}

.sec06__item-icon {
  flex: 0 0 clamp(85px, 85px + 85 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 170px);
  filter: drop-shadow(0 0 clamp(3px, 3px + 3 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 6px) rgba(0, 0, 0, 0.12));
}
.sec06__item-icon img {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 1170px) {
  .sec06__item-icon {
    flex: 0 0 100px;
    width: 100px;
  }
}

.sec06__item-text-step {
  width: var(--step-width);
  padding-block-end: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  border-bottom: clamp(2px, 2px + 2 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 4px) solid var(--m-sec06-maincolor);
  margin-block-end: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px);
}
.sec06__item-text-step img {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 1170px) {
  .sec06__item-text-step {
    padding-block-end: 4px;
    border-bottom: 3px solid var(--m-sec06-maincolor);
    margin-block-end: 4px;
    margin-inline: auto;
  }
}

.sec06__item-text-title {
  font-weight: 700;
  font-size: clamp(17.5px, 17.5px + 17.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 35px);
  line-height: 1.5;
  color: var(--m-sec06-title-color);
  font-feature-settings: "palt";
  text-align: left;
  margin-block-end: clamp(2.5px, 2.5px + 2.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 5px);
}
.sec06__item-text-title .sub1 {
  font-size: 0.85em;
}
@media screen and (min-width: 1170px) {
  .sec06__item-text-title {
    font-size: 22px;
    text-align: center;
  }
}

.sec06__item-text-text {
  font-weight: 700;
  font-size: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px);
  line-height: 1.67;
  color: var(--m-sec06-maincolor);
  font-feature-settings: "palt";
  text-align: left;
}
@media screen and (min-width: 1170px) {
  .sec06__item-text-text {
    font-size: 16px;
    text-align: center;
  }
}

/* sec07 */
.sec07 {
  background-image: url(../image/sec07-bg0.webp), url(../image/sec07-bg1.webp);
  background-size: clamp(180px, 180px + 180 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 360px), 100%;
  background-position: top clamp(120px, 120px + 120 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 240px) right, center top;
  background-repeat: no-repeat;
}
.sec07 .c-title {
  --m-title-en-image: url(../image/sec07__title-en.webp);
  --m-title-en-width: clamp(616px / 2, calc(616px / 2 + ((616 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 616px);
  --m-title-en-height: clamp(100px / 2, calc(100px / 2 + ((100 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --m-title-color: var(--color-text);
  margin-block-end: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  color: var(--color-base);
  font-size: clamp(29px, 29px + 29 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 58px);
  padding-block-start: calc(1em + clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px));
  padding-block-end: clamp(30px, 30px + 30 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 60px);
  background-color: var(--color-primary);
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px)), 50% 100%, 0 calc(100% - clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px)));
}
.sec07 .c-title::before {
  inset-block-start: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px);
}
.sec07 .l-section__contents {
  padding-block: 0 clamp(30px, 30px + 30 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 60px);
}
@media screen and (min-width: 1170px) {
  .sec07 {
    background-image: url(../image/sec07-bg0-pc.webp), url(../image/sec07-bg1-pc.webp);
    background-size: 350px, 100%;
    background-position: top 250px right calc(50% - 210px), center top;
  }
  .sec07 .c-title {
    --m-title-en-width: 660px;
    --m-title-en-height: 100px;
    margin-block-end: 30px;
    padding-block-start: calc(1em + 30px);
    padding-block-end: 90px;
    background-color: var(--color-primary);
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 80px), 50% 100%, 0 calc(100% - 80px));
  }
  .sec07 .c-title::before {
    inset-block-start: 40px;
  }
  .sec07 .l-section__contents {
    padding-block: 0 60px;
  }
}

.sec07__contents {
  padding-inline: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
}

.sec07__main-copy {
  transform: translateX(-20px);
}
@media screen and (min-width: 1170px) {
  .sec07__main-copy {
    width: 530px;
    margin-block-end: 20px;
  }
}

.sec07__text1 {
  width: clamp(230px, 230px + 230 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 460px);
  padding-inline: clamp(22.5px, 22.5px + 22.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 45px);
  margin-block-end: clamp(25px, 25px + 25 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 50px);
  position: relative;
  display: flex;
  align-items: center;
  filter: drop-shadow(0 0 clamp(4px, 4px + 4 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 8px) var(--color-base)) drop-shadow(0 0 clamp(4px, 4px + 4 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 8px) var(--color-base)) drop-shadow(0 0 clamp(4px, 4px + 4 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 8px) var(--color-base));
}
.sec07__text1 img {
  width: 100%;
  height: auto;
}
.sec07__text1::before, .sec07__text1::after {
  content: "";
  background-image: url(../image/sec03__text1-before.webp);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  position: absolute;
  width: clamp(26.5px, 26.5px + 26.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 53px);
  height: clamp(56.5px, 56.5px + 56.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 113px);
}
.sec07__text1::before {
  inset-inline-start: 0;
}
.sec07__text1::after {
  inset-inline-end: 0;
  transform: scaleX(-1);
}

.sec07__text2 {
  font-weight: 500;
  font-size: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px);
  line-height: 1.6;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: left;
  width: fit-content;
  margin-inline: 0 auto;
  margin-block-end: 46px;
  text-shadow: 0.167em 0 0 #fff, -0.167em 0 0 #fff, 0 0.167em 0 #fff, 0 -0.167em 0 #fff, 0.125em 0.125em 0 #fff, -0.125em 0.125em 0 #fff, 0.125em -0.125em 0 #fff, -0.125em -0.125em 0 #fff, 0 0 0.333em #fff;
}

.sec07__text3 {
  font-weight: 700;
  font-size: clamp(17px, 17px + 17 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 34px);
  line-height: 1.6;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  padding-inline: clamp(7.5px, 7.5px + 7.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 15px);
  padding-block: clamp(2.5px, 2.5px + 2.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 5px) clamp(2.5px, 2.5px + 2.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 5px);
  margin-inline: auto;
  margin-block-end: clamp(25px, 25px + 25 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 50px);
  background-color: #d4d4d8;
  position: relative;
}
.sec07__text3::before {
  content: "";
  position: absolute;
  top: 100%;
  inset-inline: 0;
  margin-inline: auto;
  border-left: clamp(22.5px, 22.5px + 22.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 45px) solid transparent;
  border-right: clamp(22.5px, 22.5px + 22.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 45px) solid transparent;
  border-top: clamp(10.5px, 10.5px + 10.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 21px) solid #d4d4d8;
  width: clamp(45px, 45px + 45 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 90px);
}
@media screen and (min-width: 1170px) {
  .sec07__text3 {
    width: 610px;
    font-size: 24px;
  }
}

.sec07__image {
  margin-block-end: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
}
@media screen and (min-width: 1170px) {
  .sec07__image {
    width: 610px;
    margin-inline: auto;
  }
}

.sec07__text4 {
  font-weight: 500;
  font-size: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  letter-spacing: 0.08em;
}
.sec07__text4 .text-deco-overdot::after {
  font-size: 0.6em;
}
.sec07__text4 .sub2 {
  font-weight: 700;
}
.sec07__text4 .sub1 {
  font-weight: 700;
  display: inline-block;
  background-image: linear-gradient(to right, var(--color-gradient-primary));
  padding-inline: 0.4em;
  color: var(--color-secondary);
  margin-inline-end: 0.2em;
  text-box-trim: initial;
  text-box-edge: text;
  line-height: 1;
  padding-block: clamp(4px, 4px + 4 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 8px) clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
}
@media screen and (min-width: 1170px) {
  .sec07__text4 {
    font-size: 28px;
    line-height: 1.8;
  }
}

/* sec08 */
.sec08 .c-title {
  --m-title-en-image: url(../image/sec07__title-en.webp);
  --m-title-en-width: clamp(616px / 2, calc(616px / 2 + ((616 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 616px);
  --m-title-en-height: clamp(100px / 2, calc(100px / 2 + ((100 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --m-title-color: var(--color-text);
  margin-block-end: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  padding-block-start: 0;
  padding-block-end: 0;
}
.sec08 .c-title::before {
  content: none;
}
.sec08 .l-section__contents {
  padding-block: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px) clamp(40px, 40px + 40 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 80px);
}

.sec08__text1 {
  font-weight: 700;
  font-size: clamp(17px, 17px + 17 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 34px);
  line-height: 1.5;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  margin-block-end: clamp(15px, 15px + 15 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 30px);
}
.sec08__text1 .sub1 {
  color: var(--color-primary);
  font-size: 1.4em;
}
.sec08__text1 .sub2 {
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-weight: 700;
  font-size: 1.5em;
  line-height: 1.5;
  color: var(--color-primary);
  font-feature-settings: "palt";
  text-align: left;
}
@media screen and (min-width: 1170px) {
  .sec08__text1 {
    font-size: 24px;
    margin-block-end: 40px;
  }
  .sec08__text1 .sub1 {
    font-size: 1em;
  }
  .sec08__text1 .sub2 {
    font-size: 1.4em;
  }
}

.sec08__list-wrapper {
  overflow-x: hidden;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  background: var(--color-base);
}

@media (min-width: 1500px) {
  .sec08__list-wrapper {
    max-width: 1500px;
    margin-left: calc(50% - 750px);
  }
}
.sec08__list {
  display: flex;
  width: max-content;
  min-width: 100%;
  animation: sec08-logo-scroll 60s linear infinite;
  align-items: center;
}

.sec08__item {
  flex: 0 0 auto;
  margin-right: clamp(30px, 30px + 30 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 60px);
}
.sec08__item:last-child {
  margin-right: 0;
}

.sec08__image img {
  width: 100%;
  height: auto;
  display: block;
}
.sec08__image img[src$="sec08__image1.webp"] {
  width: clamp(50px, 50px + 50 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 100px);
}
.sec08__image img[src$="sec08__image2.webp"] {
  width: clamp(100px, 100px + 100 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 200px);
}
.sec08__image img[src$="sec08__image3.webp"] {
  width: clamp(43.5px, 43.5px + 43.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 87px);
}
.sec08__image img[src$="sec08__image4.webp"] {
  width: clamp(132px, 132px + 132 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 264px);
}
.sec08__image img[src$="sec08__image5.webp"] {
  width: clamp(127.5px, 127.5px + 127.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 255px);
}
.sec08__image img[src$="sec08__image6.webp"] {
  width: clamp(75px, 75px + 75 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 150px);
}
.sec08__image img[src$="sec08__image7.webp"] {
  width: clamp(50px, 50px + 50 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 100px);
}
.sec08__image img[src$="sec08__image8.webp"] {
  width: clamp(150px, 150px + 150 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 300px);
}

@keyframes sec08-logo-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
/* sec09 */
.sec09 .c-title {
  --m-title-en-image: url(../image/sec09__title-en.webp);
  --m-title-en-width: clamp(616px / 2, calc(616px / 2 + ((616 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 616px);
  --m-title-en-height: clamp(100px / 2, calc(100px / 2 + ((100 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --m-title-color: var(--color-text);
  margin-block-end: clamp(17.5px, 17.5px + 17.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 35px);
  padding-block-start: clamp(25px, 25px + 25 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 50px);
  padding-block-end: 0;
  font-feature-settings: none;
  letter-spacing: 0.08em;
}
.sec09 .c-title::before {
  inset-block-start: 0;
  opacity: 0.14;
}
.sec09 .l-section__contents {
  padding-block: 0 clamp(30px, 30px + 30 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 60px);
}
@media screen and (min-width: 1170px) {
  .sec09 .l-section__contents {
    padding-block: 40px 60px;
  }
}

/* sec10 */
.sec10 .c-title {
  --m-title-en-image: url(../image/sec10__title-en.webp);
  --m-title-en-width: clamp(649px / 2, calc(649px / 2 + ((649 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 649px);
  --m-title-en-height: clamp(100px / 2, calc(100px / 2 + ((100 / 2) / (var(--fluid-max) - var(--fluid-min))) * (100vw - var(--fluid-min) * 1px)), 100px);
  --m-title-color: var(--color-text);
  margin-block-end: clamp(22.5px, 22.5px + 22.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 45px);
  padding-block-start: clamp(25px, 25px + 25 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 50px);
  padding-block-end: 0;
  letter-spacing: 0.08em;
}
.sec10 .c-title::before {
  inset-block-start: 0;
  opacity: 0.14;
}
.sec10 .l-section__contents {
  padding-block: clamp(20px, 20px + 20 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 40px) clamp(50px, 50px + 50 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 100px);
}

.sec10__message {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(7.5px, 7.5px + 7.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 15px);
  margin-block-end: clamp(25px, 25px + 25 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 50px);
}

.sec10__message-text {
  font-weight: 700;
  font-size: clamp(12px, 12px + 12 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 24px);
  line-height: 1.8;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
  border-radius: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px);
  background-color: #eff1f4;
  flex: 0 0 clamp(165px, 165px + 165 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 330px);
  padding-block: clamp(7.5px, 7.5px + 7.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 15px);
  margin-inline-end: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px);
  position: relative;
}
.sec10__message-text::before {
  content: "";
  position: absolute;
  inset-block: 0;
  inset-inline-end: calc(clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px) * -1);
  margin: auto;
  width: clamp(6px, 6px + 6 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 12px);
  height: clamp(12.5px, 12.5px + 12.5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 25px);
  background-color: #eff1f4;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}
@media screen and (min-width: 1170px) {
  .sec10__message-text {
    flex: 1 0 350px;
  }
}

.sec10__message-image1 {
  flex: 0 1 clamp(55px, 55px + 55 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 110px);
}
.sec10__message-image1 img {
  aspect-ratio: 1/1;
  object-fit: cover;
}

.p-thanks {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-top: clamp(50px, 50px + 50 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 100px);
  font-size: clamp(13px, 13px + 13 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 24px);
  font-family: "Noto Sans JP", sans-serif;
  color: #333333;
}

.p-thanks a.l-fixed__buttonc-button {
  width: clamp(280px, 280px + 280 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 450px);
  background-size: 100%;
  font-size: clamp(16px, 16px + 16 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 24px);
  text-decoration: none;
  color: #fff;
}

/*
 * Utility
 * --------------------------
 */
/*
 * animation.scss
 */
/* modaal */
/*全て共通：hideエリアをはじめは非表示*/
.hide-area {
  display: none;
}

/*全て共通：モーダルのボタンの色を変更したい場合*/
.modaal-close:after,
.modaal-close:before {
  background: #ccc;
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before {
  background: #666;
}

/*確認を促すモーダル：タイトルの色を変更したい場合*/
#modaal-title {
  font-size: 1.2rem;
  text-align: center;
  margin: 0 0 20px 0;
}

/*動画表示のモーダル：余白を変更したい場合*/
.modaal-inner-wrapper {
  padding: 30px 0;
}

.modaal-container {
  width: 90%;
  max-width: 480px;
  border-radius: 30px;
}

.modaal-content-container {
  padding: 30px;
}

/* 下からふわっと */
.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 0.8s;
  animation-fill-mode: forwards;
  animation-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
  opacity: 0;
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(clamp(25px, 25px + 25 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 50px));
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeUpTrigger {
  opacity: 0;
}

/* キラッと */
.shine {
  position: relative;
  overflow: hidden;
}
.shine::before {
  content: "";
  position: absolute;
  top: 0;
  left: -180px;
  background: rgba(255, 255, 255, 0.5333333333);
  width: 30px;
  height: 100%;
  animation: shineanime 5s ease-in-out infinite;
  z-index: 30;
}

@keyframes shineanime {
  0% {
    transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  30% {
    transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  31% {
    transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  50% {
    transform: scale(80) rotate(45deg);
    opacity: 0;
  }
  100% {
    transform: scale(80) rotate(45deg);
    opacity: 0;
  }
}
/* 中央Y軸回転アニメーション */
.rotateY {
  animation-name: rotateYAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0;
  transform-style: preserve-3d;
  backface-visibility: hidden;
}

@keyframes rotateYAnime {
  from {
    opacity: 0;
    transform: perspective(600px) rotateY(45deg);
  }
  to {
    opacity: 1;
    transform: perspective(600px) rotateY(0deg);
  }
}
.rotateYTrigger {
  opacity: 0;
}

/* YouTube動画モーダル */
.youtube-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.youtube-modal.show {
  opacity: 1;
}

.youtube-modal__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

.youtube-modal__content {
  position: relative;
  width: 90%;
  max-width: 800px;
  aspect-ratio: 16/9;
  background: #000;
  overflow: hidden;
  transform: scale(0.9);
  transition: transform 0.3s ease;
}

.youtube-modal.show .youtube-modal__content {
  transform: scale(1);
}

.youtube-modal__close {
  position: absolute;
  top: -40px;
  right: 0;
  background: none;
  border: none;
  color: white;
  font-size: 30px;
  font-weight: bold;
  cursor: pointer;
  z-index: 10000;
  transition: opacity 0.3s ease;
}

.youtube-modal__close:hover {
  opacity: 0.7;
}

.youtube-modal__video-container {
  width: 100%;
  height: 100%;
}

.youtube-modal__video-container iframe {
  width: 100%;
  height: 100%;
  border: none;
}

/* sec05 スライダー内の動画要素用スタイル */
.sec05__image {
  position: relative;
  overflow: hidden;
}

.sec05__image img {
  transition: transform 0.3s ease;
}

.sec05__text1 {
  text-align: right;
  margin-top: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  font-size: clamp(10px, 10px + 10 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 20px);
  color: var(--color-text);
  margin-inline: calc(clamp(47px, 47px + 47 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 94px) * -1);
}
@media screen and (min-width: 1170px) {
  .sec05__text1 {
    margin-inline: 0;
    font-size: 14px;
  }
}

.p-thanks__voice .sec05__text1 {
  font-size: clamp(13px, 13px + 13 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 26px);
  text-align: center;
}
@media screen and (min-width: 1170px) {
  .p-thanks__voice .sec05__text1 {
    font-size: 22px;
  }
}

.sec05__play-button {
  display: none;
}

.voice-trigger .sec05__play-button {
  position: absolute;
  top: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
  right: clamp(5px, 5px + 5 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 10px);
  width: clamp(48px, 48px + 48 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 96px);
  height: clamp(48px, 48px + 48 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 96px);
  background: rgb(255, 255, 255);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(16px, 16px + 16 / (var(--fluid-max) - var(--fluid-min)) * (100vw - var(--fluid-min) * 1px), 32px);
  color: var(--color-primary-pale1);
  font-weight: bold;
  transition: all 0.3s ease;
  border: 2px solid rgba(255, 255, 255, 0.8);
  filter: drop-shadow(2px 2px 6px rgba(0, 0, 0, 0.1));
}
.voice-trigger .sec05__play-button span {
  transform: translate(2px, -1px);
}
@media screen and (min-width: 1170px) {
  .voice-trigger .sec05__play-button {
    top: 10px;
    right: 10px;
    width: 40px;
    height: 40px;
    font-size: 16px;
  }
}

.voice-trigger {
  cursor: pointer;
  transition: transform 0.3s ease;
}

/*
 * util.scss
 */
@media screen and (min-width: 1170px) {
  .sp {
    display: none;
  }
}

.pc {
  display: none;
}
@media screen and (min-width: 1170px) {
  .pc {
    display: inherit;
  }
}

.box-shadow {
  box-shadow: 0px 0px 14px 6px rgba(0, 0, 0, 0.2);
  width: fit-content;
}

.box-bg-grad {
  background-image: linear-gradient(30deg, var(--color-accent-main), var(--color-white) 30%, var(--color-white) 70%, var(--color-accent-main));
}

.text-capitalize {
  text-transform: capitalize;
}

.text-uppercase {
  text-transform: uppercase;
}

.text-accent {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  color: var(--color-accent-main);
}

.text-color--black {
  color: var(--color-black);
}
.text-color--green {
  color: var(--color-green);
}
.text-color--pink {
  color: var(--color-pink);
}
.text-color--orange {
  color: var(--color-orange);
}
.text-color--yellow {
  color: var(--color-yellow);
}

.text-deco-marker {
  background: linear-gradient(transparent 85%, var(--color-marker) 85%, var(--color-marker) 100%, transparent 100%);
}

.text-deco-marker2 {
  background: linear-gradient(transparent 85%, var(--color-marker) 2 85%, var(--color-marker) 2 100%, transparent 100%);
}

.text-deco-dash--accent, .text-deco-dash {
  text-decoration: underline;
  text-decoration-style: dashed;
  text-decoration-thickness: 2px;
  text-underline-offset: 8px;
}

.text-deco-dash--accent {
  text-decoration-color: var(--color-accent-main);
}

.text-deco-regular {
  font-weight: 400;
}

.text-deco-medium {
  font-weight: 500;
}

.text-deco-bold {
  font-weight: 700;
}

.text-deco-black {
  font-weight: 900;
}

.text-deco-underline--accent, .text-deco-underline {
  text-decoration: underline;
  text-decoration-style: solid;
  text-decoration-thickness: 2px;
  text-underline-offset: 8px;
}

.text-deco-underline--accent {
  text-decoration-color: var(--color-accent-main);
}

.text-deco-overdot--small, .text-deco-overdot--accent, .text-deco-overdot {
  position: relative;
}
.text-deco-overdot--small::after, .text-deco-overdot--accent::after, .text-deco-overdot::after {
  position: absolute;
  content: "・";
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 500;
  line-height: 1;
  color: var(--color-primary-pale1);
  font-feature-settings: "palt";
  top: -0.4em;
  left: 0;
  right: 0;
  margin-inline: auto;
}

.text-deco-overdot--accent::after {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 500;
  line-height: 1;
  color: var(--color-accent-main);
  font-feature-settings: "palt";
}
.text-deco-overdot--small::after {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: 0.5em;
  line-height: 1;
  font-feature-settings: "palt";
  top: -0.3em;
  left: 0.8em;
}

.text-deco-wave {
  text-decoration: underline;
  text-decoration-style: wavy;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
  text-decoration-color: #a27e8a;
}

.text-deco-wave2 {
  text-decoration: underline;
  text-decoration-style: wavy;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
  text-decoration-color: #ff0000;
}

.text-shadow {
  text-shadow: 3px 3px 0px var(--color-accent-main);
}
.text-shadow--blur {
  text-shadow: 5px 5px 8px var(--color-accent-main), 5px -5px 8px var(--color-accent-main), -5px 5px 8px var(--color-accent-main), -5px -5px 8px var(--color-accent-main);
}
.text-shadow--box {
  background-color: rgba(0, 0, 0, 0.2);
  border-radius: 12px;
  padding: 8px;
  box-shadow: inset 3px 3px 20px var(--color-white), inset -3px -3px 20px var(--color-white);
}

.text-num {
  font-weight: 700;
  font-size: 1.4em;
  font-feature-settings: "palt";
}

.text-fz60 {
  font-size: 0.6em;
}

.text-fz70 {
  font-size: 0.7em;
}

.text-fz80 {
  font-size: 0.8em;
}

.text-fz90 {
  font-size: 0.9em;
}

.text-fz110 {
  font-size: 1.1em;
}

.text-fz120 {
  font-size: 1.2em;
}

.text-fz130 {
  font-size: 1.3em;
}

.text-fz140 {
  font-size: 1.4em;
}

.text-fz150 {
  font-size: 1.5em;
}

.text-fz200 {
  font-size: 2em;
  line-height: 1.3;
}

.text-fz250 {
  font-size: 2.5em;
}

.mb_vw0 {
  margin-bottom: unset;
}

.mb_vw10 {
  margin-bottom: 10px;
}

.mb_vw20 {
  margin-bottom: 20px;
}

.mb_vw30 {
  margin-bottom: 30px;
}

.mb_vw40 {
  margin-bottom: 40px;
}

.mb_vw50 {
  margin-bottom: 50px;
}

.mb_vw60 {
  margin-bottom: 60px;
}

.mb_vw70 {
  margin-bottom: 70px;
}

.mb_vw80 {
  margin-bottom: 80px;
}

.mb_vw90 {
  margin-bottom: 90px;
}

.mb_vw100 {
  margin-bottom: 100px;
}

.plr_vw10 {
  padding-left: 10px;
  padding-right: 10px;
}

.plr_vw20 {
  padding-left: 20px;
  padding-right: 20px;
}

.plr_vw30 {
  padding-left: 30px;
  padding-right: 30px;
}

.plr_vw40 {
  padding-left: 40px;
  padding-right: 40px;
}

.plr_vw60 {
  padding-left: 60px;
  padding-right: 60px;
}

.nanameline--accent, .nanameline {
  position: relative;
}
.nanameline--accent::before, .nanameline::before {
  content: "";
  position: absolute;
  display: block;
  width: 4px;
  height: 100%;
  background-color: var(--color-black);
  left: -20px;
  bottom: -0.1em;
  transform: rotate(-40deg);
}
.nanameline--accent::after, .nanameline::after {
  content: "";
  position: absolute;
  display: block;
  width: 4px;
  height: 100%;
  background-color: var(--color-black);
  right: -20px;
  bottom: -0.1em;
  transform: rotate(40deg);
}

.nanameline--accent::before, .nanameline--accent::after {
  background-color: var(--color-accent-main);
  width: 2px;
}
.nanameline--accent::before {
  left: -0.6em;
}
.nanameline--accent::after {
  right: -0.6em;
}

.dummy {
  background-color: rgba(0, 0, 0, 0.2);
  outline: 1px solid rgba(0, 0, 17, 0.2);
  padding: 10px;
}

.dummy100 {
  width: 100%;
  height: 100px;
  background-color: rgba(0, 0, 0, 0.2);
  outline: 1px solid rgba(0, 0, 17, 0.2);
  padding: 10px;
}

.dummy200 {
  width: 100%;
  height: 200px;
  background-color: rgba(0, 0, 0, 0.2);
  outline: 1px solid rgba(0, 0, 17, 0.2);
}

.dummy300 {
  width: 100%;
  height: 300px;
  background-color: rgba(0, 0, 0, 0.2);
  outline: 1px solid rgba(0, 0, 17, 0.2);
}

.dummy500 {
  width: 100%;
  height: 500px;
  background-color: rgba(0, 0, 0, 0.2);
  outline: 1px solid rgba(0, 0, 17, 0.2);
}

.dummy1000 {
  width: 100%;
  height: 1000px;
  background-color: rgba(0, 0, 0, 0.2);
  outline: 1px solid rgba(0, 0, 17, 0.2);
}

.ellipsis {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ellipsis--oneline {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ellipsis--line3 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  align-self: stretch;
}/*# sourceMappingURL=style.css.map */