@charset "UTF-8";

/* --------------------------------------------------

  サイト全体で共通のスタイル

-------------------------------------------------- */

/* サイト全体で共通のウェブフォント */
/* ==========================================================================

  使用フォント

========================================================================== */

/* Noto Sans JP - Light */
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('https://4250140.fs1.hubspotusercontent-na1.net/hubfs/4250140/raw_assets/public/oneder/01_JP/assets/styles/vendors/fonts/NotoSansJP/NotoSansJP-Light.ttf') format('truetype');
}

/* Noto Sans JP - Regular */
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('https://4250140.fs1.hubspotusercontent-na1.net/hubfs/4250140/raw_assets/public/oneder/01_JP/assets/styles/vendors/fonts/NotoSansJP/NotoSansJP-Regular.ttf') format('truetype');
}

/* Noto Sans JP - Medium */
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('https://4250140.fs1.hubspotusercontent-na1.net/hubfs/4250140/raw_assets/public/oneder/01_JP/assets/styles/vendors/fonts/NotoSansJP/NotoSansJP-Medium.ttf') format('truetype');
}

/* Noto Sans JP - SemiBold */
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('https://4250140.fs1.hubspotusercontent-na1.net/hubfs/4250140/raw_assets/public/oneder/01_JP/assets/styles/vendors/fonts/NotoSansJP/NotoSansJP-SemiBold.ttf') format('truetype');
}

/* Noto Sans JP - Bold */
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('https://4250140.fs1.hubspotusercontent-na1.net/hubfs/4250140/raw_assets/public/oneder/01_JP/assets/styles/vendors/fonts/NotoSansJP/NotoSansJP-Bold.ttf') format('truetype');
}

/* Roboto - Light */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('https://4250140.fs1.hubspotusercontent-na1.net/hubfs/4250140/raw_assets/public/oneder/01_JP/assets/styles/vendors/fonts/Roboto/Roboto-Light.ttf') format('truetype');
}

/* Roboto - Regular */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('https://4250140.fs1.hubspotusercontent-na1.net/hubfs/4250140/raw_assets/public/oneder/01_JP/assets/styles/vendors/fonts/Roboto/Roboto-Regular.ttf') format('truetype');
}

/* Roboto - Medium */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('https://4250140.fs1.hubspotusercontent-na1.net/hubfs/4250140/raw_assets/public/oneder/01_JP/assets/styles/vendors/fonts/Roboto/Roboto-Medium.ttf') format('truetype');
}

/* Roboto - Bold */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('https://4250140.fs1.hubspotusercontent-na1.net/hubfs/4250140/raw_assets/public/oneder/01_JP/assets/styles/vendors/fonts/Roboto/Roboto-Bold.ttf') format('truetype');
}

/* サイト全体で使用する変数 */
/* ==========================================================================

  サイト全体で共通の設定

========================================================================== */

:root {
  /* カラースキーム */
  --color-main: #2A2A2A;
  --color-main-rgb: 42, 42, 42;
  --color-point: #D8FF77;
  --color-point-rgb: 216, 255, 119;
  --color-point2: #B0EA45;
  --color-point2-rgb: 176, 234, 69;
  --color-point3: #93D11F;
  --color-point3-rgb: 147, 209, 31;
  --color-plane: #3F3F3F;
  --color-plane-rgb: 63, 63, 63;
  --color-pale: #C9C9C9;
  --color-bg: #EDEDED;
  --color-art_board1: #595757;
  --color-art_board2: #FAFAFA;
  --color-highlight: #E7FFAC;
  --color-hover: #A2E300;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(201, 201, 201, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(42, 42, 42, .45);
  --color-film-hover: rgba(15, 15, 15, .6);

  /* フォント：基本 */
  --font-default: YakuHanJP, 'Noto Sans JP', sans-serif;
  /* フォント：小塚ゴシック Pr6N */
  --font-kozuka: kozuka-gothic-pr6n, sans-serif;
  /* フォント：英字 */
  --font-en: pragmatica-extended, sans-serif;
  /* フォント：ボタン */
  --font-button: pragmatica-extended, YakuHanJP, 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --fz-h3-desktop: 1.8rem;
  --fz-h4-desktop: 1.7rem;
  --fz-h5-desktop: 1.6rem;
  /* 文字サイズ：見出し(palmtop) */
  --fz-h2-palmtop: 1.8rem;
  --fz-h2-decoration-palmtop: 1.1rem;
  --fz-h3-palmtop: 1.6rem;
  --fz-h4-palmtop: 1.5rem;
  --fz-h5-palmtop: 1.4rem;

  /* 文字ウェイト：日本語テキスト */
  --fw-normal-jp: 400;
  --fw-bold-jp: 500;
  /* 文字ウェイト：英語テキスト */
  --fw-light-en: 200;
  --fw-normal-en: 300;
  --fw-bold-en: 500;

  /* 文字間 */
  --ls-root: 0;
  --ls-root-en: 0;

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 1.8;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --lh-blog: 1.5;

  /* ヘッダーの高さ */
  --header-height: 80px;
  --header-height-sp: 66px;

  /* メインコンテンツ幅 */
  --main-content-width: 1050px;

  /* .containerの左右のpadding */
  --container-padding-hr-desktop: 100px;
  --container-padding-hr-laptop: 50px;
  --container-padding-hr-palmtop: 20px;

  /*
    line-height分の余白を相殺する
    使用例 : margin-top: calc(30px + var(--leading-trim));
  */
  --leading-trim: calc((1em - 1lh) / 2);

  /* transitionの設定 */
  --transition-ptn01: .6s cubic-bezier(0.03, 0.98, 0.52, 0.99);
}

/* サイト全体で共通のアニメーション */
/* ==========================================================================

  アニメーション

========================================================================== */

/* tableのswipeアイコンの動き */

@keyframes table-swipe {
  0% {
    opacity: 0;
    transform: translate(-20px, 5px) rotate(0);
  }
  75% {
    opacity: 1;
    transform: translate(20px, -5px) rotate(15deg);
  }
  100% {
    opacity: 1;
    transform: translate(20px, -5px) rotate(15deg);
  }
}

/* リンクフェードイン */
@keyframes link-underline {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}

@-webkit-keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/* フェードイン */
@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/* scroll */
@-webkit-keyframes scroll {
  0% {
    -webkit-transform: translateY(-10px);
    transform: translateY(-10px);
  }
  75% {
    -webkit-transform: translateY(25px);
    transform: translateY(25px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(25px);
    transform: translateY(25px);
    opacity: 0;
  }
}

@keyframes scroll {
  0% {
    -webkit-transform: translateY(-10px);
    transform: translateY(-10px);
  }
  75% {
    -webkit-transform: translateY(25px);
    transform: translateY(25px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(25px);
    transform: translateY(25px);
    opacity: 0;
  }
}

/* サイト全体で共通のHTML要素、汎用的なスタイル */
/* ==========================================================================

  サイト全体で共通の要素のスタイル

========================================================================== */

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  line-break: strict;
  overflow-wrap: break-word;
  word-break: break-word;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, main, menu, nav, section {
  display: block;
}

html {
  font-family: var(--font-default);
  font-size: 62.5%;
  font-weight: 400;
  letter-spacing: var(--ls-root);
  line-height: 1.78em;
  scroll-behavior: smooth;
}
/* 多言語対応 */
html:lang(ja) {
  font-family: var(--font-default);
}

html.is-hamburger-nav-open {
  overflow: hidden;
}

body {
  background-color: var(--color-art_board2);
  font-size: 1.4rem;
  letter-spacing: var(--ls-root);
  line-height: 1;
}

::selection {
  background-color: rgba(var(--color-point3-rgb), .18);
}

a {
  color: inherit;
  text-decoration: none;
}

/* :focus & :hover */
a:focus {
  text-decoration: none;
}
@media screen and (min-width: 1050px) {
  a:hover{
    text-decoration: none;
  }
}

button {
  color: var(--color-main);
  font-size: 1.4rem;
  font-family: var(--font-default);
  letter-spacing: var(--ls-root);
  line-height: 1;
}

img {
  max-width: 100%;
  image-rendering: -webkit-optimize-contrast;
  vertical-align: top;
}

sub {
  font-size: 1.1rem;
  vertical-align: sub;
}

sup {
  font-size: 1.1rem;
  vertical-align: super;
}

blockquote, q {
  quotes: none;
}

blockquote::before, blockquote::after,
q::before, q::after {
  content: '';
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

ol, ul {
  list-style: none;
}

iframe {
  vertical-align: top;
}

/* === アクセシビリティ対応 */

/* キーボード操作時のみ[outline]を表示 */
:focus:not(:focus-visible) {
  outline: 0;
}

/* アクセシビリティ対応 === */

/* 旧CTA使用時、 SP/TB時のヘッダーを閉じてる状態でもヘッダー内のCTAリンクのクリック範囲が表示されてしまうのを防ぐため */

.hs-cta-node {
  visibility: unset !important;
}
/* ==========================================================================

  utility

========================================================================== */

.block {
  display: block;
  text-decoration: none;
}

.block, .block:active, .block:visited {
  color: inherit;
}

.inline-block {
  display: inline-block;
}

.break {
  word-wrap: break-word;
}

.full {
  box-sizing: border-box;
  width: 100%;
}

.stick {
  margin: 0 !important;
}

.stick-bottom {
  margin-bottom: 0 !important;
}

.stick-left {
  margin-left: 0 !important;
}

.stick-right {
  margin-right: 0 !important;
}

.stick-top {
  margin-top: 0 !important;
}

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

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

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

.text-lower {
  text-transform: lowercase;
}

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

.word {
  display: inline-block;
}

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

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

.hs_cos_wrapper_type_icon {
  display: none;
}

.hs_error_rollup {
  color: red;
  margin-top: 50px;
  text-align: center;
}

/* === アクセシビリティ対応用 */

/*
  視覚的に非表示にしつつ、スクリーンリーダーで読み上げ可能にする。
  UIコンポーネントであってもキーボードフォーカスは不可だが、スクリーンリーダーではフォーカス可能。
*/
.visually-hidden-element {
  width: 1px !important;
  height: 1px !important;
  margin: 0px !important;
  padding: 0 !important;
  overflow: hidden !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  clip-path: inset(0 0 99.9% 99.9%) !important;
  border: 0 !important;
  white-space: nowrap !important;
}

/* アクセシビリティ対応用 === */

/* リッチテキスト用スタイル */
/* ==========================================================================

  ベースのスタイル

========================================================================== */

.natural {
  display: block;
  margin-top: 20px;
  margin-bottom: 20px;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  &:first-child {
    margin-top: 0;
  }
  &:last-child {
    margin-bottom: 0;
  }
}

.natural {

  /* heading */
  h2 {
    margin-top: 60px;
    margin-bottom: 25px;
    font-size: var(--fz-h2-palmtop);
    font-weight: var(--fw-normal-jp);
    letter-spacing: var(--ls-root);
    line-height: var(--lh-heading);
    @media (min-width: 768px) {
      & {
        margin-top: 80px;
        margin-bottom: 45px;
        font-size: var(--fz-h2-desktop);
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }
  }

  h3 {
    margin-top: 25px;
    margin-bottom: 20px;
    font-size: var(--fz-h3-palmtop);
    font-weight: var(--fw-bold-jp);
    letter-spacing: var(--ls-root);
    line-height: var(--lh-heading);
    @media (min-width: 768px) {
      & {
        margin-top: 55px;
        margin-bottom: 30px;
        font-size: var(--fz-h3-desktop);
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }
  }

  h4 {
    margin-top: 30px;
    margin-bottom: 20px;
    color: var(--color-plane);
    font-size: var(--fz-h4-palmtop);
    font-weight: var(--fw-bold-jp);
    letter-spacing: var(--ls-root);
    line-height: var(--lh-heading);
    @media (min-width: 768px) {
      & {
        margin-top: 45px;
        margin-bottom: 25px;
        font-size: var(--fz-h4-desktop);
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }
  }

  h5 {
    margin-top: 30px;
    margin-bottom: 20px;
    color: var(--color-plane);
    font-size: var(--fz-h5-palmtop);
    font-weight: var(--fw-bold-jp);
    letter-spacing: var(--ls-root);
    line-height: var(--lh-heading);
    @media (min-width: 768px) {
      & {
        font-size: var(--fz-h5-desktop);
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }
  }

  /* paragraph */
  p {
    margin-top: 20px;
    margin-bottom: 20px;
    color: var(--color-plane);
    font-size: var(--fz-root-palmtop);
    letter-spacing: var(--ls-root);
    line-height: var(--lh-paragraph);
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    @media (min-width: 768px) {
      & {
        font-size: var(--fz-root-desktop);
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }
  }

  /* text decoration tags */
  strong {
    font-weight: 700;
  }
  em {
    font-style: italic;
  }

  /* figure / caption / image */
  figure {
    max-width: 750px;
    margin: 20px auto;
    @media (min-width:768px) {
      & {
        margin-top: 30px;
        margin-bottom: 30px;
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }
  }

  figure figcaption {
    margin-top: 20px;
    font-size: 1.5rem;
    font-weight: var(--fw-bold-jp);
    letter-spacing: var(--ls-root);
    @media (max-width:767px) {
      & {
        font-size: 1.2rem;
        line-height: 1.9;
      }
    }
    &:first-child {
      margin-top: 0
    }
  }

  img {
    max-width: 100%;
    height: auto;
    min-height: 10px;
    vertical-align: top;
    @media (min-width:768px) {
      & {
        max-width: 650px;
      }
    }
  }

  /* link */
  a:not(.cta_button):not(.js-no-icon) {
    position: relative;
    border-bottom: 1px solid var(--color-point3);
    color: var(--color-plane);
    text-decoration: none;
    word-break: break-all;
    transition: .3s;
    /* :focus & :hover */
    &:focus-visible {
      color: var(--color-point3);
    }
    @media (min-width: 1050px) {
      &:hover {
        color: var(--color-point3);
      }
    }
    /*
      external link
      ※.js-no-iconは_natural.jsで付与している
    */
    &[target="_blank"] {
      padding-left: 14px;
      @media (min-width: 768px) {
        & {
          padding-left: 15px;
        }
      }
      /* 外部アイコン */
      &::before {
        content: "";
        position: absolute;
        top: 5px;
        left: 2px;
        width: 11px;
        height: 11px;
        mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMS45NjkiIGhlaWdodD0iMTEuOTY5IiB2aWV3Qm94PSIwIDAgMTEuOTY5IDExLjk2OSI+CiAgPHBhdGggaWQ9IuODkeOCuV82NDIxIiBkYXRhLW5hbWU9IuODkeOCuSA2NDIxIiBkPSJNLTc4OC41MjksMGgtNi4zNDJhLjUyOC41MjgsMCwwLDAtLjUyOC41MjlWMi4xNjdoLTMuODdhLjcuNywwLDAsMC0uNy43djguNGEuNy43LDAsMCwwLC43LjdoOC40YS43LjcsMCwwLDAsLjctLjdWNy40aDEuNjM4QS41MjguNTI4LDAsMCwwLTc4OCw2Ljg3MVYuNTI5QS41MjkuNTI5LDAsMCwwLTc4OC41MjksMFptLTIuNjM4LDEwLjk2OWgtNy44di03LjhoMy41N3YzLjdhLjUyNy41MjcsMCwwLDAsLjUyOC41MjhoMy43Wk0tNzg5LDYuNGgtNS40VjFoNS40WiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNzk5Ljk2OSkiIGZpbGw9IiM0MTQxNDEiLz4KPC9zdmc+Cg==");
        mask-position: center;
        mask-repeat: no-repeat;
        mask-size: cover;
        background-color: var(--color-plane);
        transition: background-color .3s;
      }
      @media (min-width: 768px) {
        &::before {
          top: 8px;
        }
      }
      /* :focus & :hover */
      &:focus-visible::before {
        background-color: var(--color-point3);
      }
      @media (min-width: 1050px) {
        &:hover::before {
          background-color: var(--color-point3);
        }
      }
    }
  }

  /* list */
  & > ul,
  & > ol,
  & > .hs_cos_wrapper_type_rich_text > ul,
  & > .hs_cos_wrapper_type_rich_text > ol {
    margin-top: 30px;
    margin-bottom: 30px;
    margin-left: 0;
    padding: 20px 20px 20px 42px;
    border: 1px solid var(--color-pale);
    border-radius: 5px;
    @media (min-width: 768px) {
      & {
        margin-top: 35px;
        margin-bottom: 35px;
        padding: 30px 35px 30px 55px;
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }

    ul,
    ol {
      margin-top: 10px;
      margin-left: 1.3em;
    }
  }

  & > ul li,
  & > .hs_cos_wrapper_type_rich_text > ul li {
    position: relative;
    margin-top: calc(20px + var(--leading-trim));
    margin-bottom: calc(20px + var(--leading-trim));
    color: var(--color-plane);
    font-size: var(--fz-root-palmtop);
    font-weight: var(--fw-normal-jp);
    letter-spacing: var(--ls-root);
    line-height: var(--lh-normal-text);
    @media (min-width: 768px) {
      & {
        font-size: var(--fz-root-desktop);
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }
  }

  /* normal list style */
  & > ul:not([style*="list-style-type"]),
  & > .hs_cos_wrapper_type_rich_text > ul:not([style*="list-style-type"]) {
    padding-left: 35px;
    @media (min-width: 768px) {
      & {
        padding-left: 51px;
      }
    }
    li::before {
      content: "";
      display: block;
      position: absolute;
      top: .8em;
      left: -15px;
      width: 5px;
      height: 5px;
      background-color: var(--color-pale);
    }
  }

  /* 番号付きリスト */
  ol,
  & > .hs_cos_wrapper_type_rich_text > ol {
    list-style-type: decimal;
  }

  & > ol li,
  & > .hs_cos_wrapper_type_rich_text > ol li {
    display: list-item;
    margin-top: calc(20px + var(--leading-trim));
    margin-bottom: calc(20px + var(--leading-trim));
    color: var(--color-plane);
    font-size: var(--fz-root-palmtop);
    font-weight: var(--fw-normal-jp);
    letter-spacing: var(--ls-root);
    line-height: var(--lh-normal-text);
    list-style: inherit;
    @media (min-width: 768px) {
      & {
        font-size: var(--fz-root-desktop);
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }
  }

  /* pre */
  pre {
    margin-top: 30px;
    margin-bottom: 30px;
    padding: 20px 20px 18px;
    border: 1px solid var(--color-pale);
    border-radius: 5px;
    color: var(--color-plane);
    font-size: var(--fz-root-palmtop);
    font-weight: var(--fw-normal-jp);
    letter-spacing: var(--ls-root);
    line-height: var(--lh-normal-text);
    white-space: normal;
    @media (min-width: 768px) {
      & {
        margin-top: 35px;
        margin-bottom: 35px;
        padding: 30px 35px;
        font-size: var(--fz-root-desktop);
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }
  }

  /* table */
  table {
    width: 100%;
    height: auto !important;
    border: 1px solid var(--color-pale) !important;
    @media (min-width: 768px) {
      & {
        max-width: 100%;
      }
    }
  }

  table tr {
    height: auto !important;
    &:not(:last-child) {
      border-bottom: 1px solid var(--color-pale);
    }
    &:first-of-type td {
      background-color: var(--color-pale-light);
    }
  }

  table td {
    height: auto !important;
    padding: 10px 15px !important;
    color: var(--color-plane);
    font-size: var(--fz-root-palmtop);
    letter-spacing: var(--ls-root);
    line-height: var(--lh-paragraph);
    text-align: left;
    vertical-align: middle;
    border: 1px solid var(--color-pale);
    @media (min-width: 768px) {
      & {
        font-size: var(--fz-root-desktop);
      }
    }

    strong {
      font-weight: var(--fw-bold-jp);
    }
  }

  /* リッチテキスト内のテーブル */
  .js-table-scroll {
    margin-top: 30px !important;
    margin-bottom: 30px !important;
    @media (min-width: 768px) {
      & {
        margin-top: 40px !important;
        margin-bottom: 40px !important;
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }
    table {
      min-width: 610px;
    }
  }

  /* SWIPE icon */
  @media (min-width:601px) {
    .js-table-scroll__icon {
      display: none;
    }
  }
  .js-table-scroll__icon__arrow {
    display: none;
  }
  @media (max-width:600px) {
    .js-table-scroll {
      margin-right: -20px;
      overflow-x: scroll;
      overflow-y: hidden;
      position: relative;
      & > .table {
        width: 600px
      }
    }
    .js-table-scroll__icon {
      box-sizing: border-box;
      position: absolute;
      top: 50%;
      left: 50%;
      z-index: 1;
      width: 120px;
      height: 120px;
      padding-top: 35px;
      border-radius: 5px;
      background-color: var(--color-film);
      color: #ffffff;
      font-family: var(--font-en);
      font-size: 20px;
      font-weight: bold;
      line-height: 60px;
      letter-spacing: .1em;
      text-align: center;
      opacity: 1;
      transform: translate(-50%, -50%);
      transition: opacity .5s;
    }

    .js-table-scroll__icon__arrow {
      display: block;
      position: absolute;
      top: calc(50% - 20px);
      left: calc(50% - 30px);
      z-index: 2;
      width: 61px;
      height: 8px;
      transition: opacity .5s;
    }
    .js-table-scroll__icon__path {
      fill: #ffffff;
    }

    /* is-checked */
    .js-table-scroll.is-checked .js-table-scroll__icon,
    .js-table-scroll.is-checked .js-table-scroll__icon__arrow {
      opacity: 0;
    }
  }

  /* blockquote */
  blockquote {
    position: relative;
    margin-top: 30px;
    margin-bottom: 30px;
    padding: 16px 45px;
    border-top: 1px solid var(--color-pale);
    border-bottom: 1px solid var(--color-pale);
    line-height: var(--lh-normal-text);
    @media (min-width: 768px) {
      & {
        margin-top: 40px;
        margin-bottom: 40px;
        padding: 25px 60px;
      }
    }
    &:first-child {
      margin-top: 0;
    }
    &:last-child {
      margin-bottom: 0;
    }

    /* 装飾 */
    &::before,
    &::after {
      content: "";
      position: absolute;
      width: 18.65px;
      height: 13.09px;
      background: url("https://4250140.fs1.hubspotusercontent-na1.net/hubfs/4250140/raw_assets/public/oneder/01_JP/assets/images/common/ico_blockquote.svg") no-repeat;
      background-size: contain;
    }
    &::before {
      top: 16px;
      left: 16px;
    }
    &::after {
      top: 16px;
      right: 16px;
      transform: rotate(180deg);
    }
    @media (min-width: 768px) {
      &::before,
      &::after {
        position: absolute;
        width: 25.87px;
        height: 18.16px;
      }
      &::before {
        left: 20px;
      }
      &::after {
        right: 20px;
        transform: rotate(180deg);
      }
    }

    p {
      line-height: inherit;
    }
  }

  /* hr */
  hr {
    margin-top: 30px;
    margin-bottom: 30px;
    @media (min-width: 768px) {
      & {
        margin-top: 40px;
        margin-bottom: 40px;
      }
    }
  }

}

/* サイト全体で共通のレイアウトスタイル */
/* ==========================================================================

  パンくず

========================================================================== */

.elevator {
  box-sizing: border-box;
  display: grid;
  place-items: center end;
  position: relative;
  height: 40px;
  background-color: #4B4B4B;
  overflow: hidden;
  @media (min-width: 768px) {
    & {
      height: 66px;
    }
  }

  /* 三角 */
  &::before {
    content: "";
    display: block;
    position: absolute;
    right: -8px;
    bottom: -2px;
    width: 25px;
    height: 12px;
    background-color: var(--color-point);
    clip-path: polygon(50% 0, 0 12px, 25px 12px);
    transform: rotate(135deg);
    transition: background-color .3s;
  }
  @media (min-width: 768px) {
    &::before {
      right: -14px;
      bottom: -3px;
      width: 42px;
      height: 21px;
      clip-path: polygon(50% 0, 0 21px, 42px 21px);
    }
  }
}

.elevator__container {
  box-sizing: border-box;
  width: 100%;
  max-width: 1250px;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 20px;
  @media (min-width: 768px) {
    & {
      padding-right: 50px;
      padding-left: 50px;
    }
  }
}

.is-no-breadcrumb .elevator__nav {
  justify-content: flex-end;
}

.elevator__nav {
  box-sizing: border-box;
  max-width: 100%;
  overflow: auto;
  scrollbar-width: none;       /* Firefox 対応 */
  &::-webkit-scrollbar {  /* Chrome, Safari 対応 */
    display:none;
  }
}

.elevator__nav .hs-breadcrumb-menu {
  display: flex;
  align-items: center;
  width: fit-content;
  margin: 0 0 0 auto;
  padding: 0;
  font-size: 1.2rem;
  letter-spacing: .02em;
  line-height: 2;
  @media (min-width: 768px) {
    & {
      font-size: 1.4rem;
    }
  }
}

.elevator__nav .hs-breadcrumb-menu__item,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item {
  float: none;
  padding: 0;
  color: var(--color-point);
  white-space: nowrap;
}

.elevator__nav .hs-breadcrumb-menu__item:not(:first-child),
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item:not(:first-child) {
  position: relative;
  margin-left: 10px;
  padding-left: 11px;
  @media (min-width: 768px) {
    & {
      margin-left: 13px;
      padding-left: 14px;
    }
  }
}

.elevator__nav .hs-breadcrumb-menu__item:not(:first-child)::before,
.elevator__nav .hs-breadcrumb-menu__item:not(:first-child)::after,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item:not(:first-child)::before,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item:not(:first-child)::after {
  content: '';
  display: block;
  position: absolute;
  top: calc(50% - 2px);
  left: 0;
  width: 2px;
  height: 4px;
  background-color: var(--color-point);
  transform: skewX(45deg);
}

.elevator__nav .hs-breadcrumb-menu__item:not(:first-child)::before,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item:not(:first-child)::before {
  top: calc(50% - 4px);
}

.elevator__nav .hs-breadcrumb-menu__item:not(:first-child)::after,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item:not(:first-child)::after {
  top: calc(50% - 0px);
  transform: scale(1, -1) skewX(45deg);
}

.elevator__nav .hs-breadcrumb-menu__item:first-child span.hs-breadcrumb-label,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item:first-child span.hs-breadcrumb-label {
  color: var(--color-plane);
}

.elevator__nav .hs-breadcrumb-menu__item__anchor,
.elevator__nav .hs-breadcrumb-menu__item a.hs-breadcrumb-label,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item__anchor,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item a.hs-breadcrumb-label {
  color: var(--color-bg);
  transition: all .3s;
}

.elevator__nav .hs-breadcrumb-menu__item__anchor__icon,
.elevator__nav .hs-breadcrumb-menu__item a.hs-breadcrumb-label__icon,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item__anchor__icon,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item a.hs-breadcrumb-label__icon {
  display: block;
  position: absolute;
  top: calc(50% - 4px);
  left: 0;
  width: 6px;
  height: 8px;
}

.elevator__nav .hs-breadcrumb-menu__item__anchor__icon__arrow,
.elevator__nav .hs-breadcrumb-menu__item a.hs-breadcrumb-label__icon__arrow,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item__anchor__icon__arrow,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item a.hs-breadcrumb-label__icon__arrow {
  fill: var(--color-point);
}

/* :focus & :hover */
.elevator__nav .hs-breadcrumb-menu__item__anchor:focus,
.elevator__nav .hs-breadcrumb-menu__item a.hs-breadcrumb-label:focus,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item__anchor:focus,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item a.hs-breadcrumb-label:focus {
  color: var(--color-point);
}
@media (min-width: 1050px) {
  .elevator__nav .hs-breadcrumb-menu__item__anchor:hover,
  .elevator__nav .hs-breadcrumb-menu__item a.hs-breadcrumb-label:hover,
  .elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item__anchor:hover,
  .elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item a.hs-breadcrumb-label:hover {
    color: var(--color-point);
  }
}

.elevator__nav .hs-breadcrumb-menu__item .hs-breadcrumb-menu-divider,
.elevator__nav .hs-breadcrumb-menu .hs-breadcrumb-menu-item .hs-breadcrumb-menu-divider {
  display: none;
}
/* ==========================================================================

  フッター

========================================================================== */

#footer {
  position: relative;
}

/* ページトップボタン */
.footer__nav__page-top {
  box-sizing: border-box;
  position: fixed;
  right: 10px;
  bottom: 15px;
  z-index: 5;
  @media (min-width: 768px) {
    & {
      right: 20px;
      bottom: 20px;
    }
  }
}

/* ページトップボタン - アンカー */
.footer__nav__page-top__anchor {
  box-sizing: border-box;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  box-shadow: 0 0 20px rgba(145, 145, 145, 0.5);
  border-radius: 50%;
  background-color: #ffffff;
  color: var(--color-main);
  transition: background-color .3s;
  @media (min-width: 768px) {
    & {
      width: 70px;
      height: 70px;
    }
  }
  /* :focus & :hover */
  @media (min-width: 1050px) {
    &:hover {
      background-color: var(--color-hover);
    }
  }
  &:focus-visible {
    background-color: var(--color-hover);
  }
}

/* ページトップボタン - アンカーインナー */
.page-top__anchor__inner {
  display: block;
  position: relative;
  top: -1px;
  text-align: center;
}

/* ページトップボタン - SVGアイコン */
.page-top__anchor__inner__icon {
  display: block;
  margin: 0 auto 3px;
  @media (min-width: 768px) {
    & {
      margin-bottom: 8px;
    }
  }
}

/* ページトップボタン - テキスト */
.page-top__anchor__inner__text {
  font-family: var(--font-en);
  font-size: 1.3rem;
  font-weight: 200;
  letter-spacing: .06em;
  line-height: 1;
  @media (min-width: 768px) {
    & {
      font-size: 1.6rem;
    }
  }
}

/*　フッター メインコンテンツ　*/
.footer {
  padding: 60px 25px 40px;
  background-color: var(--color-main);
  color: #ffffff;
  text-align: center;
  overflow: hidden;
  @media (min-width: 768px) {
    & {
      padding: 58px 50px 55px;
    }
  }
  @media (min-width: 1050px) {
    & {
      padding: 58px 50px 15px;
    }
  }
}

/* コピーライト */
.footer__copyright {
  margin-top: 30px;
  color: #D5D5D5;
  font-family: var(--font-en);
  font-size: 1rem;
  font-weight: 200;
  letter-spacing: var(--ls-en);
  text-align: center;
  @media (min-width: 768px) {
    & {
      margin-top: 23px;
      font-size: 1.2rem;
    }
  }
}
/* ==========================================================================

  ヘッダー

========================================================================== */

/* ヘッダー全体 */
.header:not(p) {
  width: 100%;
  background-color: var(--color-point);
}

/* ヘッダーコンテナー */
.header__columns {
  display: grid;
  grid-template-columns: 1fr 53px;
  @media (min-width: 768px) {
    & {
      grid-template-columns: 1fr 80px;
    }
  }
  @media (min-width: 1050px) {
    & {
      grid-template-columns: 700px 1fr;
      justify-content: space-between;
    }
  }
  @media (min-width: 1350px) {
    & {
      align-items: center;
    }
  }
}

/* ナビゲーションなし ver */
.header--no-nav {
  position: relative;
  .header__columns {
    @media (min-width: 1050px) {
      & {
        min-height: 90px;
      }
    }
  }
}

/* ロゴエリア（ヘッダー左側カラム） */
.header__logo-area {
  display: grid;
  align-items: center;
  grid-template-columns: 95px 1fr;
  min-height: var(--header-height-sp);
  @media (min-width: 768px) {
    & {
      grid-template-columns: 175px 1fr;
      min-height: var(--header-height);
    }
  }
}

/* ロゴ */
.header__logo {
  display: grid;
  place-items: center;
  position: relative;
  width: 100%;
  height: 100%;
  background-color: #fff;
  a {
    display: block;
    img {
      width: 65px !important;
      max-width: 100%;
      vertical-align: bottom;
      @media (min-width: 768px) {
        & {
          width: 122px !important;
        }
      }
    }
  }
}

/* ロゴテキスト */
.header__logo-text-area {
  box-sizing: border-box;
  height: 100%;
  padding: 12px 11px 8px 15px;
  color: var(--color-main);
  font-size: 1rem;
  line-height: 1.3;
  @media (min-width: 768px) {
    & {
      padding: 22px 3px 17px 15px;
      font-size: 1.6rem;
    }
  }

  /* 「ONEDER（ワンダー）」 */
  .header__logo-text02 {
    display: block;
    @media (min-width: 768px) {
      & {
        display: inline;
      }
      &::before {
        content: "";
        display: inline-block;
        width: 1px;
        height: 15px;
        margin-inline: 8px;
        background-color: var(--color-main);
        vertical-align: middle;
      }
    }
  }
  /* 「produce by...」 */
  .header__logo-text03 {
    display: block;
    margin-top: 3px;
    color: #595757;
    font-family: var(--font-en);
    font-weight: var(--fw-light-en);
    @media (min-width: 768px) {
      & {
        font-size: 1.2rem;
      }
    }
  }
}

/* ヘッダーコンテンツエリア（ヘッダー右側カラム） */
.header__contents-area {
  min-height: var(--header-height-sp);
  @media (min-width: 768px) {
    & {
      min-height: var(--header-height);
    }
  }
  @media (min-width: 1050px) {
    & {
      position: relative;
      min-height: 125px;
    }
  }
  @media (min-width: 1350px) {
    & {
      position: relative;
      min-height: var(--header-height);
    }
  }
}

/* 検索エリア */
.header__search-area {
  display: none;
  position: relative;
  @media (min-width: 1050px) {
    & {
      display: block;
      position: absolute;
      top: 0;
      right: 0;
      z-index: 1;
      height: 100%;
    }
  }
}

/* 検索エリア開閉ボタン */
.header__search-trigger {
  display: grid;
  place-items: center;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
  width: 80px;
  height: 100%;
  margin: 0;
  padding: 0;
  border: none;
  background-color: transparent;
  cursor: pointer;

  /* 閉じるアイコン */
  .header__search-trigger__icon--close {
    position: absolute;
    left: 1px;
    width: 22px;
    height: 22px;
    transition: left .3s;
  }

  /* 検索エリアが開いてる時 */
  &.is-open {
    /* 閉じるアイコン */
    .header__search-trigger__icon--close {
      left: calc(50% - 11px);
    }
  }
}

/* Googleカスタム検索 */
.header__search-box {
  // position: absolute;
  // top: 0;
  // right: 0;
  // z-index: 0;
  display: grid;
  align-items: center;
  height: 100%;
  background: linear-gradient(90deg,rgba(240, 240, 240, 0) 0%, var(--color-point) 10%);
  // width: 80px;
  // height: 100%;
  // transition:
  //   top .3s,
  //   right .3s,
  //   height .3s;
  /* 検索エリアが開いてる時 */
  &.is-open {
    // top: 13px;
    // right: 80px;
    // width: 515px;
    // height: 54px;
    padding-left: 90px;
  }

  .header__search-box__inner {
    width: 80px;
    height: 100%;
    transition:
      width .3s,
      height .3s,
      margin-right .3s;
    .is-open & {
      width: 515px;
      height: 54px;
      margin-right: 80px;
    }
  }

  & * {
    height: 100%;
  }

  form.gsc-search-box {
    margin: 0;
  }
  table.gsc-search-box {
    height: 100%;
    margin: 0;
    td.gsc-input {
      padding: 0;
      font-size: inherit;
    }
  }
  /* 検索フィールド */
  .gsc-input-box {
    box-sizing: border-box;
    opacity: 0;
    visibility: hidden;
    position: relative;
    width: 100%;
    height: 100%;
    padding: 0;
    border: 1px solid var(--color-main);
    border-right: none;
    border-radius: 0;
    transition: opacity .3s;
  }
  /* 検索エリアが開いてる時 */
  &.is-open .gsc-input-box {
    opacity: 1;
    visibility: visible;
    padding: 14px 45px 15px 19px;
  }
  .gsib_a {
    padding: 0;
  }
  input.gsc-input {
    color: var(--color-main);
    font-family: var(--font-default);
    font-size: 1.7rem;
    font-weight: 400;
    letter-spacing: .06em;
    &::placeholder {
      color: #898989;
    }
  }
  /* 検索ボックスをクリア「✗」 */
  .gsst_b {
    padding: 0;
  }
  .gsst_a {
    padding: 0;
    .gscb_a {
      display: block;
      position: absolute;
      top: 50%;
      right: -30px;
      color: var(--color-main);
      line-height: 1;
      transform: translateY(-50%);
    }
  }

  /* 検索ボタン */
  .gsc-search-button {
    margin: 0;
  }
  .gsc-search-button-v2 {
    position: relative;
    width: 80px;
    height: 100%;
    margin: 0;
    border: 1px solid var(--color-main);
    border-radius: 0;
    background-color: var(--color-main);
    cursor: pointer;
    /* hover & focus */
    &:hover,
    &:focus-visible {
      border-color: var(--color-main);
      background-color: var(--color-main);
    }
    /* 虫眼鏡アイコン */
    &::before {
      content: "";
      display: block;
      position: absolute;
      top: 50%;
      left: 50%;
      width: 28px;
      height: 28px;
      mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB3aWR0aD0iMjgiIGhlaWdodD0iMjgiIHZpZXdCb3g9IjAgMCAyOCAyOCI+IDxkZWZzPiA8Y2xpcFBhdGggaWQ9ImxvdXBlLWljb24tY2xpcFBhdGgiPiA8cmVjdCBmaWxsPSJub25lIiB3aWR0aD0iMjgiIGhlaWdodD0iMjgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0wLjA4IDAuMDQpIiAvPiA8L2NsaXBQYXRoPiA8L2RlZnM+IDxnIGNsaXAtcGF0aD0idXJsKCNsb3VwZS1pY29uLWNsaXBQYXRoKSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMC4wOCAtMC4wNCkiPiA8cGF0aCBmaWxsPSIjZmZmIiBkPSJNMTEuNDUzLjAxMUExMS4yNjMsMTEuMjYzLDAsMCwxLDE5LjU2NSwzLjQ1YTExLjksMTEuOSwwLDAsMSwwLDE2LjU1NiwxMS4yODksMTEuMjg5LDAsMCwxLTE2LjIyNSwwLDExLjksMTEuOSwwLDAsMSwwLTE2LjU1NkExMS4yNjUsMTEuMjY1LDAsMCwxLDExLjQ1My4wMTFabTAsMjEuNzExYTkuODgxLDkuODgxLDAsMCwwLDkuNzQtOS45OTUsOS44ODEsOS44ODEsMCwwLDAtOS43NC05Ljk5NSw5Ljg4Miw5Ljg4MiwwLDAsMC05Ljc0Miw5Ljk5NUE5Ljg4Miw5Ljg4MiwwLDAsMCwxMS40NTMsMjEuNzIyWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMC4wMjcgMC4zMjQpIiAvPiA8cGF0aCBmaWxsPSIjZmZmIiBkPSJNMjcuNzk0LDI3LjA3MmwtLjcuNzE4YS42OTQuNjk0LDAsMCwxLTEsMGwtNy4zMDgtNy40ODQsMS43LTEuNzM3LDcuMzA4LDcuNDgzYS43MzQuNzM0LDAsMCwxLDAsMS4wMjEiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAuMDI3IDAuMzI0KSIgLz4gPC9nPjwvc3ZnPg==");
      mask-position: center;
      mask-repeat: no-repeat;
      mask-size: contain;
      background-color: #fff;
      transform: translate(-50%, -50%);
      transition:
        width .3s,
        height .3s,
        background-color .3s;
    }
    /* hover & focus */
    &:hover::before,
    &:focus-visible::before,
    .header__search-area:hover .header__search-box:not(.is-open) &::before,
    .header__search-area:focus .header__search-box:not(.is-open) &::before {
      background-color: var(--color-hover);
    }
    /* 初期値で読み込まれるアイコン */
    svg {
      display: none;
    }
  }
  /* 検索エリアが開いてる時 */
  &.is-open .gsc-search-button-v2 {
    &::before {
      width: 24px;
      height: 24px;
    }
  }
}
/* Googleカスタム検索 - 検索サジェスト */
td.gssb_a {
  color: var(--color-main);
}

/* ハンバーガーナビボタン */
.header__hamburger {
  box-sizing: border-box;
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  padding: 0;
  border: none;
  border-radius: 0;
  background-color: var(--color-main);
  appearance: none;
  cursor: pointer;
  z-index: 101;
  overflow: hidden;
  @media (min-width: 768px) {
    & {
      width: 80px;
    }
  }
  @media (min-width: 1050px) {
    & {
      display: none;
    }
  }
}

/* ハンバーガーナビボタン - 三本ライン ラッパー */
.header__hamburger__inner {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  width: 19px;
  height: 17px;
  @media (min-width: 768px) {
    & {
      width: 30px;
      height: 19px;
    }
  }
}

/* ハンバーガーナビボタン - 三本ライン */
.header__hamburger__inner__line {
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  transition: all .3s;

  /* active */
  .is-active & {
    position: absolute;
    top: 50%;
    left: 0;
  }
  /* １本目 */
  .is-active &:nth-child(1) {
    width: 21px;
    transform: rotate(45deg);
    @media (min-width: 768px) {
      & {
        width: 30px;
      }
    }
  }
  /* 2本目 */
  .is-active &:nth-child(2) {
    opacity: 0;
    transform: translateX(10px);
  }
  /* 3本目 */
  .is-active &:nth-child(3) {
    width: 21px;
    transform: rotate(-45deg);
    @media (min-width: 768px) {
      & {
        width: 30px;
      }
    }
  }
}

/* サイト全体で共通のエレメント */
/* ==========================================================================

  カラム

========================================================================== */

/* variables */
.columns {
  --column-margin-horizon: 25px; /* 各カラムの余白：左右 */
  --column-margin-horizon-narrow: 15px; /* 各カラムの余白(狭)：左右 */
  --column-margin-top: 55px; /* 各カラムの余白：上 */
  --column-margin-top-narrow: 35px; /* 各カラムの余白(狭)：上 */
}

/* [.columns] wrapper element */
@media screen and (min-width: 768px) {
  .columns:not(.columns--one) {
    display: grid;
    gap: 55px 50px;
    grid-template-columns: 1fr 1fr;
  }
}

/* [.columns] item element */
@media screen and (max-width: 767px) {
  .columns__column:not(:first-child) {
    margin-top: var(--column-margin-top-narrow);
  }
}
@media screen and (min-width: 768px) {
  .columns:not(.columns--one) .columns__column {
    box-sizing: border-box;
  }
}

/* 1カラム */
@media screen and (min-width: 768px) {
  .columns.columns--one {
    grid-template-columns: 1fr;
  }
}

/* 2カラム */
@media screen and (min-width:768px) {
  .columns.columns--two {
    grid-template-columns: 1fr 1fr;
  }
}

/* 3カラム */
@media screen and (min-width:1050px) {
  .columns.columns--three {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

/* 4カラム */
@media screen and (min-width:1050px) {
  .columns.columns--four {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}

/* 1:2カラム */

@media screen and (min-width:768px) {
  .columns.columns--one-two {
    display: flex;
    flex-wrap: wrap;
    margin-left: calc(var(--column-margin-horizon) * -1);
    margin-right: calc(var(--column-margin-horizon) * -1);
    gap: 0;
  }
  .columns--one-two {
    margin-right: calc(var(--column-margin-horizon-narrow) * -1);
    margin-left: calc(var(--column-margin-horizon-narrow) * -1);
  }
}
@media screen and (min-width:1050px) {
  .columns--one-two {
    margin-right: calc(var(--column-margin-horizon) * -1);
    margin-left: calc(var(--column-margin-horizon) * -1);
  }
}

@media screen and (max-width:767px) {
  .columns--one-two > .columns__column:nth-child(2) {
    margin-top: 25px;
  }
}
@media screen and (min-width:768px) {
  .columns--one-two > .columns__column {
    padding-left: var(--column-margin-horizon-narrow);
    padding-right: var(--column-margin-horizon-narrow);
  }
  .columns--one-two > .columns__column:nth-child(odd) {
    flex: 1;
  }
  .columns--one-two > .columns__column:nth-child(even) {
    flex: 2;
  }
}
@media screen and (min-width:1050px) {
  .columns--one-two > .columns__column {
    padding-left: var(--column-margin-horizon);
    padding-right: var(--column-margin-horizon);
  }
}

/* カラム左右反転 */
@media screen and (min-width:768px) {
  .columns--reverse > .columns__column:nth-child(1) {
    order: 2;
  }
  .columns--reverse > .columns__column:nth-child(2) {
    order: 1;
  }
}
/* ==========================================================================

  コンテナ

========================================================================== */

.container {
  box-sizing: border-box;
  max-width: calc(var(--main-content-width) + var(--container-padding-hr-palmtop) * 2);
  margin-left: auto;
  margin-right: auto;
  padding-right: var(--container-padding-hr-palmtop);
  padding-left: var(--container-padding-hr-palmtop);
}

@media screen and (min-width: 768px) {
  .container {
    max-width: calc(var(--main-content-width) + var(--container-padding-hr-laptop) * 2);
    padding-right: var(--container-padding-hr-laptop);
    padding-left: var(--container-padding-hr-laptop);
  }
}

@media screen and (min-width: 1050px) {
  .container {
    max-width: calc(var(--main-content-width) + var(--container-padding-hr-desktop) * 2);
    padding-right: var(--container-padding-hr-desktop);
    padding-left: var(--container-padding-hr-desktop);
  }
}

.container--full {
  max-width: none;
}
/* ==========================================================================

  エントリーボタン

========================================================================== */

.entry-button.rich-button-center {
  text-align: center;
}

.entry-button a {
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  min-width: 288px;
  max-width: 450px;
  margin: 0 auto;
  padding: 20px 60px 17px 30px;
  box-shadow: 0 6px 10px rgba(0, 0, 0, .15);
  border-radius: 40px;
  background-color: var(--color-point);
  color: var(--color-main);
  font-size: 1.8rem;
  font-weight: var(--fw-normal-text);
  letter-spacing: var(--ls-root);
  line-height: 1.5;
  text-align: left;
  transition: box-shadow .3s;
  @media (min-width: 768px) {
    & {
      min-width: 450px;
      padding: 21px 53px 14px 35px;
      font-size: 2.1rem;
    }
  }
  /* :focus & :hover */
  &:focus-visible {
    box-shadow: none;
    background-color: var(--color-point);
  }
  @media (min-width: 1050px) {
    &:hover {
      box-shadow: none;
      background-color: var(--color-point);
    }
  }
}

.entry-button.is-active a {
  pointer-events: inherit;
}

/* 装飾テキスト */
.entry-button__decoration-text {
  content: attr(data-entry);
  display: block;
  width: 100%;
  font-family: var(--font-en);
  font-size: 1.1rem;
  font-weight: var(--fw-normal-en);
  letter-spacing: var(--ls-root);
  line-height: 1;
  text-transform: uppercase;
  @media (min-width: 768px) {
    & {
      font-size: 1.4rem;
    }
  }
}

/* link icon */
.entry-button .link-icon {
  top: 50%;
  right: 27px;
  left: auto;
  width: 24px;
  height: 24px;
  transform: translateY(-50%);
  @media (min-width: 768px) {
    & {
      right: 25px;
      width: 28px;
      height: 28px;
    }
  }

  &:not(.is-pdf, .is-exlink)::before {
    width: 12px;
  }

  svg {
    left: 2px;
    width: 6.2px;
    height: 10.69px;
    @media (min-width: 768px) {
      & {
        width: 7.19px;
        height: 12.39px;
      }
    }
    /* hover & focus */
    a:focus :not(.is-pdf,.is-exlink) & {
      left: 4px;
    }
    @media (min-width: 1050px) {
      a:hover :not(.is-pdf,.is-exlink) & {
        left: 4px;
      }
    }
  }
}

/* link icon : external link */
.entry-button .entry-button__icon.is-exlink {
  width: 20px;
  height: 20px;
}
@media (min-width: 768px) {
  .entry-button .entry-button__icon.is-exlink {
    width: 22px;
    height: 22px;
  }
}
.entry-button .entry-button__icon.is-exlink .entry-button__icon__path {
  fill: #ffffff;
}
/* ==========================================================================

    画像（figure）

========================================================================== */

.section-image-caption {
  margin-bottom: 40px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .section-image-caption {
    margin-bottom: 25px;
    margin-top: 25px;
  }
}

.figure:not(:first-child) {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .figure:not(:first-child) {
    margin-top: 30px;
  }
}

.figure {
  text-align: center;
  margin: 0 auto;
}

.figure img {
  max-width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .figure img {
    max-width: 100% !important;
  }
}

.figcaption {
  margin-top: 15px;
  font-size: 1.4rem;
  letter-spacing: var(--ls-root);
  line-height: 1.4;
  text-align: left;
  color: #403434;
}
@media screen and (max-width: 767px) {
  .figcaption {
    font-size: 1.2rem;
  }
}
.figure.figure--smallbottom:not(:last-child) {
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .figure.figure--smallbottom:not(:last-child) {
    margin-bottom: 25px;
  }
}
/* ==========================================================================

  見出し1

========================================================================== */

.heading-1 {
  font-size: 38px;
  font-weight: bold;
  letter-spacing: 0.3em;
  line-height: 1.4;
}
/* ==========================================================================

    見出し2

========================================================================== */

.section-heading2 {
  margin-top: calc(60px + var(--leading-trim));
  margin-bottom: calc(25px + var(--leading-trim));
  /* --leading-trimの計算を.heading-2と揃えるために設定 */
  line-height: var(--lh-heading);
  font-size: var(--fz-h2-palmtop);
  @media (min-width: 768px) {
    & {
      margin-top: calc(80px + var(--leading-trim));
      margin-bottom: calc(35px + var(--leading-trim));
      /* --leading-trimの計算を.heading-2と揃えるために設定 */
      font-size: var(--fz-h2-desktop);
    }
  }
}

.heading-2 {
  margin-top: calc(30px + var(--leading-trim));
  margin-bottom: calc(25px + var(--leading-trim));
  color: var(--color-main);
  font-size: var(--fz-h2-palmtop);
  font-weight: var(--fw-normal-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
  @media (min-width: 768px) {
    & {
      margin-bottom: calc(35px + var(--leading-trim));
      font-size: var(--fz-h2-desktop);
    }
  }
  &:first-child {
    margin-top: 0;
  }
  &:last-child {
    margin-bottom: 0;
  }
}

/* インナー(h2) */
.heading-2__inner {
  display: inline-block;
  position: relative;
  padding-bottom: 3px;
  /* 装飾の線 */
  &::before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: var(--color-point2);
  }
}

/*
  === child elements in modules
  モジュール内に配置する際のエレメントスタイルとは異なる場合のスタイル
*/
.heading-2.heading--child {
  margin-top: 25px;
  margin-bottom: 25px;
  @media (min-width: 768px) {
    & {
      margin-top: 35px;
      margin-bottom: 30px;
    }
  }
  &:first-child {
    margin-top: 0;
  }
  &:last-child {
    margin-bottom: 0;
  }
  & + * {
    margin-top: 0;
  }
}
/* child elements in modules === */

.heading-2--reverse {
  color: #ffffff;
}

/*
  大きい装飾テキストのスタイル
  14：h2セクションB、16：h2セクションD、13：h2セクションA+画像スライダーで使用
*/
.heading-2__deco--large {
  margin-bottom: 0;
  color: var(--color-point3);
  font-family: var(--font-en);
  font-size: 3rem;
  font-weight: var(--fw-normal-en);
  letter-spacing: var(--ls-root-en);
  line-height: var(--lh-heading);
  opacity: .15;
  text-transform: uppercase;
  @media (min-width: 768px) {
    & {
      font-size: 7rem;
    }
  }
}
/* ==========================================================================

    見出し3

========================================================================== */

.section-heading3 {
  margin-top: calc(40px + var(--leading-trim));
  margin-bottom: calc(20px + var(--leading-trim));
  /* --leading-trimの計算を.heading-3と揃えるために設定 */
  line-height: var(--lh-heading);
  font-size: var(--fz-h3-palmtop);
}
@media (min-width: 768px) {
  .section-heading3 {
    margin-top: calc(55px + var(--leading-trim));
    margin-bottom: calc(25px + var(--leading-trim));
    /* --leading-trimの計算を.heading-3と揃えるために設定 */
    font-size: var(--fz-h3-desktop);
  }
}

.heading-3 {
  margin-top: calc(40px + var(--leading-trim));
  margin-bottom: calc(20px + var(--leading-trim));
  color: var(--color-main);
  font-size: var(--fz-h3-palmtop);
  font-weight: var(--fw-normal-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
  @media (min-width: 768px) {
    & {
      margin-top: calc(55px + var(--leading-trim));
      margin-bottom: calc(25px + var(--leading-trim));
      font-size: var(--fz-h3-desktop);
    }
  }
  &:first-child {
    margin-top: 0;
  }
  &:last-child {
    margin-bottom: 0;
  }
}

.heading-3__inner {
  display: inline-block;
  position: relative;
  padding-bottom: 2px;
  /* 装飾の線 */
  &::before {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: var(--color-point2);
  }
}

/*
  === child elements in modules
  モジュール内に配置する際のエレメントスタイルとは異なる場合のスタイル
*/
.heading-3.heading--child {
  margin-top: 25px;
  margin-bottom: 20px;
}
@media (min-width: 768px) {
  .heading-3.heading--child {
    margin-top: 30px;
    margin-bottom: 25px;
  }
}
.heading-3.heading--child:first-child {
  margin-top: 0;
}
.heading-3.heading--child:last-child {
  margin-bottom: 0;
}
.heading-3.heading--child + * {
  margin-top: 0;
}
/* child elements in modules === */
/* ==========================================================================

    見出し4

========================================================================== */

.section-heading4 {
  margin-top: calc(30px + var(--leading-trim));
  margin-bottom: calc(20px + var(--leading-trim));
  /* --leading-trimの計算を.heading-4と揃えるために設定 */
  font-size: var(--fz-h4-palmtop);
  line-height: var(--lh-heading);
  @media (min-width: 768px) {
    & {
      margin-top: calc(45px + var(--leading-trim));
      margin-bottom: calc(25px + var(--leading-trim));
      /* --leading-trimの計算を.heading-4と揃えるために設定 */
      font-size: var(--fz-h4-desktop);
    }
  }
}

.heading-4 {
  position: relative;
  margin-top: calc(30px + var(--leading-trim));
  margin-bottom: calc(20px + var(--leading-trim));
  padding-left: 12px;
  color: var(--color-main);
  font-size: var(--fz-h4-palmtop);
  font-weight: var(--fw-normal-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
  @media (min-width: 768px) {
    & {
      margin-top: calc(45px + var(--leading-trim));
      margin-bottom: calc(25px + var(--leading-trim));
      font-size: var(--fz-h4-desktop);
    }
  }
  &:first-child {
    margin-top: 0;
  }
  &:last-child {
    margin-bottom: 0;
  }
  &::before {
    content: "";
    display: block;
    position: absolute;
    top: 8px;
    left: 0;
    width: 5px;
    height: 5px;
    background-color: var(--color-point2);
  }
  @media (min-width: 768px) {
    &::before {
      top: 11px;
    }
  }
}

/*
  === child elements in modules
  モジュール内に配置する際のエレメントスタイルとは異なる場合のスタイル
*/
.heading-4.heading--child {
  margin-top: 25px;
  margin-bottom: 20px;
  @media (min-width: 768px) {
    & {
      margin-top: 30px;
      margin-bottom: 25px;
    }
  }
  &:first-child {
    margin-top: 0;
  }
  &:last-child {
    margin-bottom: 0;
  }
  & + * {
    margin-top: 0;
  }
}
/* child elements in modules === */
/* ==========================================================================

    見出し5

========================================================================== */

.section-heading5 {
  margin-top: calc(30px + var(--leading-trim));
  margin-bottom: calc(20px + var(--leading-trim));
  /* --leading-trimの計算を.heading-5と揃えるために設定 */
  font-size: var(--fz-h5-palmtop);
  line-height: var(--lh-heading);
  @media (min-width: 768px) {
    & {
      /* --leading-trimの計算を.heading-5と揃えるために設定 */
      font-size: var(--fz-h5-desktop);
    }
  }
}

.heading-5 {
  position: relative;
  margin-top: calc(30px + var(--leading-trim));
  margin-bottom: calc(20px + var(--leading-trim));
  padding-left: 12px;
  color: var(--color-main);
  font-size: var(--fz-h5-palmtop);
  font-weight: var(--fw-normal-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
  @media (min-width: 768px) {
    & {
      font-size: var(--fz-h5-desktop);
    }
  }
  &:first-child {
    margin-top: 0;
  }
  &:last-child {
    margin-bottom: 0;
  }
  &::before {
    content: "";
    display: block;
    position: absolute;
    top: 8px;
    left: 0;
    width: 4px;
    height: 4px;
    background-color: var(--color-point2);
  }
  @media (min-width: 768px) {
    &::before {
      top: 11px;
    }
  }
}

/*
  === child elements in modules
  モジュール内に配置する際のエレメントスタイルとは異なる場合のスタイル
*/
.heading-5.heading--child {
  margin-top: 25px;
  margin-bottom: 20px;
  &:first-child {
    margin-top: 20px;
  }
  &:last-child {
    margin-bottom: 20px;
  }
  & + * {
    margin-top: 0;
  }
}
/* child elements in modules === */
/* ==========================================================================

  見出しリンク

========================================================================== */

.section-heading-link {
  margin-top: 20px;
  margin-bottom: 30px;
  @media (min-width: 768px) {
    & {
      margin-top: 30px;
      margin-bottom: 30px;
    }
  }
}

/* 基本スタイル */
.heading-link {
  position: relative;
  &:not(:first-child) {
    margin-top: 20px;
  }
  &:not(:last-child) {
    margin-bottom: 20px;
  }
  @media (min-width: 768px) {
    &:not(:first-child) {
      margin-top: 30px;
    }
    &:not(:last-child) {
      margin-bottom: 30px;
    }
  }

  a {
    color: var(--color-main);
    display: inline-block;
    text-decoration: none;
    transition: color .5s;
    /* :focus & :hover */
    &:focus-visible {
      color: var(--color-point);
    }
    @media (min-width: 1050px) {
      .bl-hover &,
      &:hover {
        color: var(--color-point);
      }
    }
  }
}

/* 見出しレベル別　アイコン位置調整 */
.heading-2.heading-link {
  padding-left: 30px;
  @media (min-width: 768px) {
    & {
      padding-left: 33px;
    }
  }
  .link-icon {
    top: 13px;
    width: 24px;
    height: 24px;
    @media (min-width: 768px) {
      & {
        top: 15px;
      }
    }
    svg {
      width: 6.17px;
      height: 12.22px;
    }
  }
}

.heading-3.heading-link {
  padding-left: 27px;
  @media (min-width: 768px) {
    & {
      padding-left: 33px;
    }
  }
  .link-icon {
    top: 13px;
    width: 21px;
    height: 21px;
    @media (min-width: 768px) {
      & {
        top: 14px;
        width: 24px;
        height: 24px;
      }
    }
    svg {
      width: 6.22px;
      height: 10.86px;
    }
  }
}

.heading-4.heading-link {
  padding-left: 23px;
  @media (min-width: 768px) {
    & {
      padding-left: 26px;
    }
  }
  &::before {
    content: none;
  }
  .link-icon {
    top: 11px;
    width: 17px;
    height: 17px;
    @media (min-width: 768px) {
      & {
        top: 14px;
      }
    }
  }
}

.heading-5.heading-link {
  padding-left: 23px;
  @media (min-width: 768px) {
    & {
      padding-left: 25px;
    }
  }
  &::before {
    content: none;
  }
  .link-icon {
    top: 10px;
    width: 17px;
    height: 17px;
    @media (min-width: 768px) {
      & {
        top: 13px;
      }
    }
  }
}

/* link heading : PDFアイコン */
.heading-2.heading-link.is-pdf {
  padding-left: 30px;
  @media (min-width: 768px) {
    & {
      padding-left: 31px;
    }
  }
  .link-icon {
    top: 13px;
    width: 24px;
    height: 24px;
    svg {
      width: 11px;
      height: 11px;
    }
  }
}

.heading-3.heading-link.is-pdf {
  padding-left: 27px;
  @media (min-width: 768px) {
    & {
      padding-left: 30px;
    }
  }
  .link-icon {
    top: 13px;
    width: 21px;
    height: 21px;
    @media (min-width: 768px) {
      & {
        width: 24px;
        height: 24px;
      }
    }
    svg {
      width: 11px;
      height: 11px;
    }
  }
}

.heading-4.heading-link.is-pdf {
  padding-left: 23px;
  .link-icon {
    top: 11px;
    width: 17px;
    height: 17px;
    svg {
      width: 9px;
      height: 9px;
    }
  }
}

.heading-5.heading-link.is-pdf {
  padding-left: 24px;
  .link-icon {
    top: 11px;
    width: 17px;
    height: 17px;
    svg {
      width: 9px;
      height: 9px;
    }
  }
}

/* link heading : 外部リンクアイコン */
.heading-2.heading-link.is-exlink {
  padding-left: 30px;
  @media (min-width: 768px) {
    & {
      padding-left: 31px;
    }
  }
  .link-icon {
    top: 13px;
    width: 24px;
    height: 24px;
    svg {
      width: 9.94px;
      height: 9.94px;
    }
  }
}

.heading-3.heading-link.is-exlink {
  padding-left: 27px;
  @media (min-width: 768px) {
    & {
      padding-left: 30px;
    }
  }
  .link-icon {
    top: 13px;
    width: 21px;
    height: 21px;
    @media (min-width: 768px) {
      & {
        width: 24px;
        height: 24px;
      }
    }
    svg {
      width: 10px;
      height: 9.94px;
    }
  }
}

.heading-4.heading-link.is-exlink {
  padding-left: 23px;
  .link-icon {
    top: 11px;
    width: 17px;
    height: 17px;
    svg {
      width: 8px;
      height: 7.86px;
      @media (min-width: 768px) {
        & {
          width: 9px;
          height: 8.92px;
        }
      }
    }
  }
}

.heading-5.heading-link.is-exlink {
  padding-left: 24px;
  .link-icon {
    top: 11px;
    width: 17px;
    height: 17px;
    svg {
      width: 8px;
      height: 7.86px;
      @media (min-width: 768px) {
        & {
          width: 9px;
          height: 8.92px;
        }
      }
    }
  }
}

/* 反転 */
.heading-link.link-text--reverse {
  color: #fff;
  /* アイコン */
  .link-icon {
    border-color: #fff;
    &::before {
      background-color: var(--color-point);
    }
    svg path {
      fill: #fff;
    }
    /* hover & focus */
    a:focus & {
      background-color: var(--color-main);
      svg path {
        fill: var(--color-point);
      }
    }
    @media (min-width: 1050px) {
      a:hover & {
        background-color: var(--color-main);
        svg path {
          fill: var(--color-point);
        }
      }
    }
  }
}
/* ==========================================================================

    リード文

========================================================================== */

.section-lead {
  margin-top: 40px;
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) {
  .section-lead {
    margin-top: 55px;
    margin-bottom: 55px;
  }
}

.lead {
  color: var(--color-plane);
  font-size: 1.5rem;
  font-weight: var(--fw-normal-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-paragraph);
}
@media screen and (min-width: 768px) {
  .lead {
    font-size: 1.7rem;
  }
}

.lead:not(:first-child) {
  margin-top: 75px;
}
@media screen and (min-width: 768px) {
  .lead:not(:first-child) {
    margin-top: 55px;
  }
}
.lead:not(:last-child) {
  margin-bottom: 55px;
}

.lead.text-center {
  margin-right: auto;
  margin-left: auto;
}
.lead.text-right {
  margin-left: auto;
}
/* ==========================================================================

  リンクボタン

========================================================================== */

.link-button {
  &:not(:first-child) {
    margin-top: 30px;
  }
  &:not(:last-child) {
    margin-bottom: 30px;
  }
  @media (min-width: 768px) {
    &:not(:first-child) {
      margin-top: 40px;
    }
    &:not(:last-child) {
      margin-bottom: 40px;
    }
  }
}

.link-button__anchor {
  box-sizing: border-box;
  display: inline-block;
  position: relative;
  max-width: 340px;
  padding: 5px 15px 3px 41px;
  border: 1px solid var(--color-main);
  border-radius: 28px;
  color: var(--color-main);
  font-family: var(--font-button);
  font-size: 1.5rem;
  font-weight: 300;
  line-height: var(--lh-button);
  letter-spacing: var(--ls-root-en);
  word-break: break-all;
  transition:
    background-color .3s,
    border-color .3s;
  @media (min-width: 768px) {
    max-width: 390px;
    & {
      padding: 7px 23px 4px 45px;
      font-size: 1.8rem;
    }
  }
  /* :focus & :hover */
  &:focus,
  a:focus & {
    border-color: var(--color-point);
    background-color: var(--color-point);
  }
  @media (min-width: 1050px) {
    &:hover,
    :where(a:hover, .bl-hover) & {
      border-color: var(--color-point);
      background-color: var(--color-point);
    }
  }
}

.link-button__anchor__inner {
  position: relative;
  z-index: 1;
}

/* link icon */
.link-button__anchor__icon {
  display: block;
  position: absolute;
  top: 50%;
  left: 18px;
  transform: translateY(-50%);
  @media (min-width: 768px) {
    & {
      left: 23px;
    }
  }

  .link-icon {
    position: static;
    transform: none;
  }

  .link-button__anchor__icon__path {
    fill: var(--color-main);
    transition: fill .3s;
  }
  .link-button__anchor__icon__path--reverse {
    fill: #ffffff;
    transition: fill .3s;
  }
  /* :focus & :hover */
  &:focus-visible .link-button__anchor__icon__path {
    fill: #ffffff;
  }
  &:focus-visible .link-button__anchor__icon__path--reverse {
    fill: var(--color-point);
  }
  @media (min-width: 1050px) {
    &:hover .link-button__anchor__icon__path,
    :where(.bl-hover, a:hover) .link-button__anchor__icon__path {
      fill: #ffffff;
    }
    &:hover .link-button__anchor__icon__path--reverse,
    :where(.bl-hover, a:hover) .link-button__anchor__icon__path--reverse {
      fill: var(--color-point);
    }
  }
}

/* link icon : PDF */
.link-button__anchor.is-pdf .link-button__anchor__icon svg {
  position: relative;
  top: 2px;
  width: 13.13px;
  height: 13.47px;
}

/* link icon : external link */
.link-button__anchor.is-exlink .link-button__anchor__icon svg {
  position: relative;
  top: 2px;
  width: 12.52px;
  height: 12.52px;
}

/* icon reverse */
.link-button--reverse {
  .link-button__anchor:not(:hover, :focus-visible) {
    border-color: #ffffff;
    color: #ffffff;
    @media (min-width: 1050px) {
      .bl-hover & {
        border-color: transparent;
        color: var(--color-main);
      }
    }
  }

  .link-icon {
    border-color: #fff;
    svg {
      path {
        fill: #fff;
      }
    }
  }
}

/* align center */
.link-button.rich-button-center {
  margin-right: auto;
  margin-left: auto;
}
/* ==========================================================================

  リンクアイコン

========================================================================== */

/* アイコン */
.link-icon {
  box-sizing: border-box;
  display: grid;
  position: absolute;
  top: 12px;
  left: 0;
  width: 16px;
  height: 16px;
  place-items: center;
  border: 1px solid var(--color-main);
  border-radius: 50%;
  transform: translateY(-50%);
  transition:
    border-color .3s,
    background-color .3s;
  /* :focus & :hover */
  a:focus-visible &:not(.is-reverse) {
    border-color: var(--color-point);
    background-color: var(--color-point);
  }
  @media (min-width: 1050px) {
    :is(a:hover, .bl-hover) &:not(.is-reverse) {
      border-color: var(--color-point);
      background-color: var(--color-point);
    }
  }
  /* ホバー時反転 */
  a:focus-visible &.is-hover-reverse {
    background-color: var(--color-main);
  }
  @media (min-width: 1050px) {
    :is(a:hover, .bl-hover) &.is-hover-reverse {
      background-color: var(--color-main);
    }
  }

  /* アイコン用border */
  &:not(.is-pdf, .is-exlink)::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 8px;
    height: 1px;
    background-color: var(--color-main);
    opacity: 0;
    transform: translate(calc(-50% - 1px), -50%);
    transition: opacity .3s;
  }
  /* hover & focus */
  a:focus &:not(.is-pdf, .is-exlink)::before {
    opacity: 1;
  }
  @media (min-width: 1050px) {
    :is(a:hover, .bl-hover) &:not(.is-pdf, .is-exlink)::before {
      opacity: 1;
    }
  }
  /* ホバー時反転 */
  &:not(.is-pdf, .is-exlink).is-hover-reverse::before {
    background-color: var(--color-point);
  }

  /* SVG */
  svg {
    display: block;
    position: relative;
    left: 0;
    width: 5px;
    height: 10px;
    transition: left .3s;
    /* hover & focus */
    a:focus-visible :not(.is-pdf, .is-exlink) & {
      left: 2px;
    }
    @media (min-width: 1050px) {
      :is(a:hover, .bl-hover) :not(.is-pdf, .is-exlink) & {
        left: 2px;
      }
    }

    path {
      fill: var(--color-main);
      transition: fill .3s;
      /* ホバー時反転 */
      a:focus-visible .link-icon.is-hover-reverse:not(.is-reverse) & {
        fill: var(--color-point);
      }
      @media (min-width: 1050px) {
        :is(a:hover, .bl-hover) .link-icon.is-hover-reverse:not(.is-reverse) & {
          fill: var(--color-point);
        }
      }
    }
  }
}

/* 反転 */
.link-icon.is-reverse {
  background-color: var(--color-main);
  &:not(.is-pdf, .is-exlink)::before {
    background-color: var(--color-point);
  }
  svg {
    path {
      fill: var(--color-point);
    }
  }
}

/* PDF */
.link-icon.is-pdf {
  width: 20px;
  height: 20px;
  @media (min-width: 768px) {
    & {
      width: 22px;
      height: 22px;
    }
  }
  svg {
    width: 10px;
    height: 10px;
    @media (min-width: 768px) {
      & {
        width: 11px;
        height: 11px;
      }
    }
  }
}

/* 外部リンク */
.link-icon.is-exlink {
  width: 20px;
  height: 20px;
  @media (min-width: 768px) {
    & {
      width: 22px;
      height: 22px;
    }
  }
  svg {
    width: 8px;
    height: 8px;
    @media (min-width: 768px) {
      & {
        width: 9px;
        height: 9px;
      }
    }
  }
}

/* pathの色 */
.link-icon svg path.link-icon__path {
  fill: var(--color-main);
}
.link-icon svg path.link-icon__path--reverse {
  fill: #fff;
}

/* link icon : white color */
.link-icon.link-icon--white {
  border-color: #fff;
  &::before {
    background-color: #fff;
  }
  svg path {
    fill: #fff;
  }
  /* hover & focus */
  @media (min-width: 1050px) {
    :is(a:hover, .bl-hover) & {
      border-color: transparent;
      &::before {
        background-color: var(--color-main);
      }
      svg path {
        fill: var(--color-main);
      }
    }
  }
}
/* ==========================================================================

  テキストボタン

========================================================================== */

.section-text-button {
  margin-top: 12px;
  margin-bottom: 12px;
  @media (min-width: 768px) {
    & {
      margin-top: 20px;
      margin-bottom: 20px;
    }
  }
}

.link-text {
  font-family: var(--font-button);
  font-size: 1.6rem;
  font-weight: var(--fw-normal-en);
  letter-spacing: var(--ls-root-en);
  line-height: var(--lh-button);
  &:not(:first-child) {
    margin-top: calc(18px + var(--leading-trim));
    @media (min-width: 768px) {
      & {
        margin-top: 20px;
      }
    }
  }
  &:not(:last-child) {
    margin-bottom: calc(18px + var(--leading-trim));
    @media (min-width: 768px) {
      & {
        margin-bottom: 20px;
      }
    }
  }
}

.link-text__anchor {
  display: inline-block;
  position: relative;
  padding-left: 22px;
  color: var(--color-main);
  font-size: 1.5rem;
  transition: padding-left .3s;
  /* hover & focus */
  &:focus-visible {
    padding-left: 24px;
  }
  @media (min-width: 1050px) {
    &:hover,
    .bl-hover {
      padding-left: 24px;
    }
  }
}

/* アイコン */
.link-text__anchor__icon {
  /* アイコン */
  .link-icon {
    top: 11px;
    /* hover & focus */
    a:focus-visible & {
      border-color: var(--color-point);
      background-color: var(--color-point);
    }
    @media (min-width: 1050px) {
      a:hover &,
      .bl-hover & {
        border-color: var(--color-point);
        background-color: var(--color-point);
      }
    }
    &:not(.is-pdf, .is-exlink)::before {
      background-color: var(--color-main);
    }
    svg {
      /* hover & focus */
      a:focus-visible & {
        path {
          fill: var(--color-main);
        }
      }
      @media (min-width: 1050px) {
        a:hover &,
        .bl-hover & {
          path {
            fill: var(--color-main);
          }
        }
      }
    }
  }
}

/* 色反転時 */
.link-text__anchor__icon__path--reverse {
  fill: #ffffff;
}

/* link icon : PDF */
.link-text__anchor.is-pdf {
  --icon-margin: 26px; /* 位置調整用の変数 */

  padding-left: var(--icon-margin);
  &::before {
    left: var(--icon-margin);
    width: calc(100% - var(--icon-margin));
  }
  & .link-text__anchor__icon__svg {
    width: 16px;
    height: 16.4px;
  }
}

/* link icon : external link */
.link-text__anchor.is-exlink {
  --icon-margin: 26px; /* 位置調整用の変数 */

  padding-left: var(--icon-margin);
  &::before {
    left: var(--icon-margin);
    width: calc(100% - var(--icon-margin));
  }
  & .link-text__anchor__icon__svg {
    left: 2px;
    width: 14px;
    height: 14px;
  }
}

/* reverse style */
.link-text.link-text--reverse {
  .link-text__anchor {
    color: #ffffff;
  }
  /* アイコン */
  .link-text__anchor__icon {
    .link-icon {
      border-color: #fff;
      &::before {
        background-color: var(--color-point);
      }
      svg path {
        fill: #fff;
      }
      /* hover & focus */
      a:focus-visible & {
        background-color: var(--color-main);
        svg path {
          fill: var(--color-point);
        }
      }
      @media (min-width: 1050px) {
        a:hover &,
        .bl-hover & {
          border-color: transparent;
          background-color: var(--color-main);
          svg path {
            fill: var(--color-point);
          }
        }
      }
    }
  }
}

/* align center */
.link-text.link-text--center {
  text-align: center;
}
/* ==========================================================================

  段落

========================================================================== */

/* variables */
.section-paragraph,
.paragraph {
  --p-margin: calc(20px + var(--leading-trim));
}

.section-paragraph {
  margin-top: var(--p-margin);
  margin-bottom: var(--p-margin);
}

.paragraph {
  margin-top: calc(1px * var(--leading-trim));
  margin-bottom: calc(1px * var(--leading-trim));
  color: var(--color-plane);
  font-size: var(--fz-root-palmtop);
  font-weight: var(--fw-normal-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-paragraph);
}
@media screen and (min-width: 768px) {
  .paragraph {
    font-size: var(--fz-root-desktop);
  }
}
.paragraph:not(:first-child) {
  margin-top: var(--p-margin);
}
.paragraph:not(:last-child) {
  margin-bottom: var(--p-margin);
}

.paragraph--reverse {
  color: #ffffff;
}

.paragraph.text-center {
  margin-right: auto;
  margin-left: auto;
}
.paragraph.text-right {
  margin-left: auto;
}
/* ==========================================================================

  セクション

========================================================================== */

.section {
  margin-top: 60px;
  margin-bottom: 80px;
}

@media screen and (min-width: 1050px) {
  .section {
    margin-top: 80px;
    margin-bottom: 120px;
  }
}

.section:not(:last-child) {
  margin-bottom: 60px;
}

@media screen and (min-width: 1050px) {
  .section:not(:last-child) {
    margin-bottom: 80px;
  }
}

.dnd-section-color {
  padding-top: 70px;
  padding-bottom: 70px;
}
/* 最初のセクション */
.dnd-section-color--first {
  padding-top: 60px;
}
/* 最後のセクション */
.dnd-section-color--last {
  padding-bottom: 80px;
}
@media screen and (min-width: 768px) {
  .dnd-section-color {
    padding-top: 100px;
    padding-bottom: 100px;
  }
  .dnd-section-color--first {
    padding-top: 100px;
  }
  .dnd-section-color--last {
    padding-bottom: 110px;
  }
}

/* 最初のモジュール */
.dnd-section-color .hs_cos_wrapper_type_module--first>div {
  margin-top: 0;
}
/* 最後のモジュール */
.dnd-section-color .hs_cos_wrapper_type_module--last>div {
  margin-bottom: 0;
}

/* 背景色ありセクション */
.dnd-section-color--bg {
  background-color: var(--color-bg);
}
/* ==========================================================================

  アクセシビリティ対策：本文へのスキップリンク

========================================================================== */

.skip-link-to-main {
  position: absolute;
}
.skip-link-to-main:not(:focus) {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  clip: rect(1px, 1px, 1px,1px);
  overflow: hidden;
}
.skip-link-to-main:focus {
  display: block;
  top: 6px;
  left: 10px;
  z-index: 9999;
  margin: 0;
  padding: 13px 20px;
  border-right: 1px solid var(--color-pale);
  border-bottom: 1px solid var(--color-pale);
  border-left: 1px solid var(--color-pale);
  border-radius: 0 0 3px 3px;
  background-color: var(--color-bg);
  text-decoration: underline;
}
/* ==========================================================================

    view

========================================================================== */

.view--is-desktop {
	display: block;
}
@media screen and (max-width:1049px) {
	.view--is-desktop {
		display: none !important;
	}
}
.view--is-desktop-lower {
		display: block
}
@media screen and (max-width:767px) {
	.view--is-desktop-lower {
		display: none !important;
	}
}

.view--is-laptop {
	display: none
}
@media screen and (min-width:768px) and (max-width:1049px) {
	.view--is-laptop {
		display: block
	}
}

.view--is-laptop-lower {
	display: none
}
@media screen and (max-width:1049px) {
	.view--is-laptop-lower {
		display: block
	}
}

.view--is-palmtop {
	display: none !important;
}
@media screen and (max-width:767px) {
	.view--is-palmtop {
		display: block !important;
	}
}