@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://50443322.fs1.hubspotusercontent-na2.net/hubfs/50443322/raw_assets/public/toyota-kai_or_jp/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://50443322.fs1.hubspotusercontent-na2.net/hubfs/50443322/raw_assets/public/toyota-kai_or_jp/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://50443322.fs1.hubspotusercontent-na2.net/hubfs/50443322/raw_assets/public/toyota-kai_or_jp/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://50443322.fs1.hubspotusercontent-na2.net/hubfs/50443322/raw_assets/public/toyota-kai_or_jp/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://50443322.fs1.hubspotusercontent-na2.net/hubfs/50443322/raw_assets/public/toyota-kai_or_jp/01_JP/assets/styles/vendors/fonts/NotoSansJP/NotoSansJP-Bold.ttf') format('truetype');
}


/* Quattrocento Sans - Regular */
@font-face {
  font-family: 'Quattrocento Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('https://50443322.fs1.hubspotusercontent-na2.net/hubfs/50443322/raw_assets/public/toyota-kai_or_jp/01_JP/assets/styles/vendors/fonts/QuattrocentoSans/QuattrocentoSans-Regular.ttf') format('truetype');
}

/* Quattrocento Sans - Bold */
@font-face {
  font-family: 'Quattrocento Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('https://50443322.fs1.hubspotusercontent-na2.net/hubfs/50443322/raw_assets/public/toyota-kai_or_jp/01_JP/assets/styles/vendors/fonts/QuattrocentoSans/QuattrocentoSans-Bold.ttf') format('truetype');
}

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

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #000C2E;
  --color-main-rgb: 0, 12, 46;
  --color-sub: #B77F01;
  --color-sub-rgb: 183, 127, 1;
  --color-point: #144F7B;
  --color-point-rgb: 20, 79, 123;
  --color-plane: #2D3B48;
  --color-plane-rgb: 45, 59, 72;
  --color-pale: #E7EDF1;
  --color-bg: #F2F8FF;
  --color-bg2: linear-gradient(223deg, #95C6F7, #1861A0);
  --color-bg3: linear-gradient(247deg, #F9FCFF, #E2F1FF 20%);
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(231, 237, 241, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(0, 21, 54, .45);
  --color-film-hover: rgba(0, 21, 54, .6);
  /* テーブルボーダーカラー（point colorの25%） */
  --table-border-color: rgba(var(--color-point-rgb), .25);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Quattrocento Sans', sans-serif;
  /* フォント:日本語・英語両方 */
  --font-all: 'Quattrocento Sans', 'Noto Sans JP', sans-serif;

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

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

  /* 文字間 */
  --ls-root: .1em;
  --ls-root-en: .08em;

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

  /* メインコンテンツ幅 */
  --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: .3s;
}

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

  アニメーション

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

/* 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 {
  background-color: #ffffff;
  color: var(--color-main);
  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 {
  font-size: 1.4rem;
  letter-spacing: var(--ls-root);
  line-height: 1;
}

::selection {
  background-color: rgba(var(--color-point-rgb), .2);
}

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 {
  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%;
}
.natural:first-child {
  margin-top: 0;
}
.natural:last-child {
  margin-bottom: 0;
}

.natural--bg {
  box-sizing: border-box;
  padding: 30px;
  background-color: var(--color-bg);
}
@media screen and (max-width:767px) {
  .natural--bg {
    padding: 20px;
  }
}
/* 背景色ありのスタイル */
.dnd-section-color--bg .natural--bg {
  background-color: #ffffff;
}

.natural pre, .natural h1, .natural h2, .natural h3, .natural h4, .natural h5, .natural h6, .natural .solid, .natural hr, .natural blockquote {
  display: block;
}

/* elements settings */
.natural pre+pre,.natural h1+pre,.natural h2+pre,.natural h3+pre,.natural h4+pre,.natural h5+pre,.natural h6+pre,
.natural .solid+pre,.natural hr+pre,.natural blockquote+pre,.natural table+pre,
.natural pre+h1,.natural h1+h1,.natural h2+h1,.natural h3+h1,.natural h4+h1,.natural h5+h1,.natural h6+h1,
.natural .solid+h1,.natural hr+h1,.natural blockquote+h1,.natural table+h1,
.natural pre+h2,.natural h1+h2,.natural h2+h2,.natural h3+h2,.natural h4+h2,.natural h5+h2,.natural h6+h2,
.natural .solid+h2,.natural hr+h2,.natural blockquote+h2,.natural table+h2,
.natural pre+h3,.natural h1+h3,.natural h2+h3,.natural h3+h3,.natural h4+h3,.natural h5+h3,.natural h6+h3,
.natural .solid+h3,.natural hr+h3,.natural blockquote+h3,.natural table+h3,
.natural pre+h4,.natural h1+h4,.natural h2+h4,.natural h3+h4,.natural h4+h4,.natural h5+h4,.natural h6+h4,
.natural .solid+h4,.natural hr+h4,.natural blockquote+h4,.natural table+h4,
.natural pre+h5,.natural h1+h5,.natural h2+h5,.natural h3+h5,.natural h4+h5,.natural h5+h5,.natural h6+h5,
.natural .solid+h5,.natural hr+h5,.natural blockquote+h5,.natural table+h5,
.natural pre+h6,.natural h1+h6,.natural h2+h6,.natural h3+h6,.natural h4+h6,.natural h5+h6,.natural h6+h6,
.natural .solid+h6,.natural hr+h6,.natural blockquote+h6,.natural table+h6,
.natural pre+.solid,.natural h1+.solid,.natural h2+.solid,.natural h3+.solid,.natural h4+.solid,.natural h5+.solid,.natural h6+.solid,
.natural .solid+.solid,.natural hr+.solid,.natural blockquote+.solid,.natural table+.solid,
.natural pre+hr,.natural h1+hr,.natural h2+hr,.natural h3+hr,.natural h4+hr,.natural h5+hr,.natural h6+hr,
.natural .solid+hr,.natural hr+hr,.natural blockquote+hr,.natural table+hr,
.natural pre+blockquote,.natural h1+blockquote,.natural h2+blockquote,.natural h3+blockquote,.natural h4+blockquote,.natural h5+blockquote,.natural h6+blockquote,
.natural .solid+blockquote,.natural hr+blockquote,.natural blockquote+blockquote,.natural table+blockquote,
.natural pre+table,.natural h1+table,.natural h2+table,.natural h3+table,.natural h4+table,.natural h5+table,.natural h6+table,
.natural .solid+table,.natural hr+table,.natural blockquote+table,.natural table+table {
  margin-top: 35px;
}

.natural ol:not(:first-child),
.natural ul:not(:first-child),
.natural dl:not(:first-child),
.natural figure:not(:first-child) {
  display: block;
}
.natural p:not(:last-child),
.natural ol:not(:last-child),
.natural ul:not(:last-child),
.natural dl:not(:last-child),
.natural figure:not(:last-child) {
  display: block;
}


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

.natural 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 screen and (min-width: 768px) {
  .natural h3 {
    margin-top: 55px;
    margin-bottom: 30px;
    font-size: var(--fz-h3-desktop);
  }
}
.natural h3:first-child {
  margin-top: 0;
}
.natural h3:last-child {
  margin-bottom: 0;
}

.natural 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 screen and (min-width: 768px) {
  .natural h4 {
    margin-top: 45px;
    margin-bottom: 25px;
    font-size: var(--fz-h4-desktop);
  }
}
.natural h4:first-child {
  margin-top: 0;
}
.natural h4:last-child {
  margin-bottom: 0;
}

.natural 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 screen and (min-width: 768px) {
  .natural h5 {
    font-size: var(--fz-h5-desktop);
  }
}
.natural h5:first-child {
  margin-top: 0;
}
.natural h5:last-child {
  margin-bottom: 0;
}

/* paragraph */
.natural 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 screen and (min-width: 768px) {
  .natural p {
    font-size: var(--fz-root-desktop);
  }
}
.natural p:first-child {
  margin-top: 0;
}
.natural p:last-child {
  margin-bottom: 0;
}

.natural--white p {
  color: #ffffff;
}

/* text decoration tags */
.natural strong {
  font-weight: 700;
}

.natural em {
  font-style: italic;
}

/* figure / caption / image */
.natural figure figcaption,
.natural caption {
  margin-top: 20px;
  font-size: 1.5rem;
  font-weight: var(--fw-bold-jp);
  letter-spacing: var(--ls-root);
}
@media screen and (max-width:767px) {
  .natural figure figcaption,
  .natural caption {
    font-size: 1.2rem;
    line-height: 1.9;
  }
}
.natural figure figcaption:first-child,
.natural caption:first-child {
  margin-top: 0
}

.natural figure {
  max-width: 750px;
  margin: 20px auto;
}
@media screen and (min-width:768px) {
  .natural figure {
    margin-top: 30px;
    margin-bottom: 30px;
  }
}
.natural figure:first-child {
  margin-top: 0;
}
.natural figure:last-child {
  margin-bottom: 0;
}

.natural img {
  max-width: 100%;
  min-height: 10px;
  vertical-align: top;
}
@media screen and (min-width:768px) {
  .natural img {
    max-width: 650px;
  }
}

/* link */
.natural a:not(.cta_button):not(.js-no-icon) {
  display: inline;
  position: relative;
  border-bottom: 1px solid var(--color-point);
  color: var(--color-plane);
  font-weight: var(--fw-bold-jp);
  text-decoration: none;
  word-break: break-all;
  transition: .3s;
}
/* :focus & :hover */
.natural a:not(.cta_button):not(.js-no-icon):focus {
  color: var(--color-point);
}
@media screen and (min-width: 1050px) {
  .natural a:not(.cta_button):not(.js-no-icon):hover {
    color: var(--color-point);
  }
}

/*
  external link
  ※.js-no-iconは_natural.jsで付与している
*/
.natural a:not(.cta_button):not(.js-no-icon)[target="_blank"] {
	padding-left: 16px;
}
@media screen and (max-width: 767px) {
  .natural a:not(.cta_button):not(.js-no-icon)[target="_blank"] {
    padding-left: 14px;
  }
}
.natural a:not(.cta_button):not(.js-no-icon)[target="_blank"]::before {
  content: "";
  position: absolute;
  top: 8px;
  left: 2px;
  width: 12px;
  height: 12px;
  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 screen and (max-width: 767px) {
  .natural a:not(.cta_button):not(.js-no-icon)[target="_blank"]::before {
    top: 6px;
    width: 10px;
    height: 10px;
  }
}
/* :focus & :hover */
.natural a:not(.cta_button):not(.js-no-icon)[target="_blank"]:focus::before {
  background-color: var(--color-point);
}
@media screen and (min-width: 1050px) {
  .natural a:not(.cta_button):not(.js-no-icon)[target="_blank"]:hover::before {
    background-color: var(--color-point);
  }
}

/* list */
.natural ul,
.natural ol {
  margin-top: 10px;
  margin-left: 1.3em;
}

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

.natural > ul li,
.natural > .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: 1.5rem;
  font-weight: var(--fw-normal-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-paragraph);
}
@media screen and (min-width: 768px) {
  .natural > ul li,
  .natural > .hs_cos_wrapper_type_rich_text > ul li {
    font-size: var(--fz-root-desktop);
  }
}
.natural > ul li:first-child,
.natural > .hs_cos_wrapper_type_rich_text > ul li:first-child,
.natural > ol li:first-child,
.natural > .hs_cos_wrapper_type_rich_text > ol li:first-child {
  margin-top: 0;
}
.natural > ul li:last-child,
.natural > .hs_cos_wrapper_type_rich_text > ul li:last-child,
.natural > ol li:last-child,
.natural > .hs_cos_wrapper_type_rich_text > ol li:last-child, {
  margin-bottom: 0;
}

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

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

@media screen and (min-width: 768px) {
  .natural > ul li,
  .natural > .hs_cos_wrapper_type_rich_text > ul li {
    font-size: var(--fz-root-desktop);
  }
}

.natural ol li,
.natural > .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));
  font-size: 1.5rem;
  font-weight: var(--fw-normal-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-paragraph);
  list-style: inherit;
  color: var(--color-plane);
}
@media screen and (min-width: 768px) {
  .natural ol li,
  .natural > .hs_cos_wrapper_type_rich_text > ol li {
    font-size: var(--fz-root-desktop);
  }
}

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

/* table */
.natural .js-table-scroll {
  margin-top: 30px !important;
  margin-bottom: 30px !important;
}
@media screen and (min-width: 768px) {
  .natural .js-table-scroll {
    margin-top: 40px !important;
    margin-bottom: 40px !important;
  }
}
.natural .js-table-scroll:first-child {
  margin-top: 0;
}
.natural .js-table-scroll:last-child {
  margin-bottom: 0;
}

.natural table {
  width: 100%;
  height: auto !important;
  border: 1px solid var(--color-pale) !important;
}
@media screen and (min-width: 768px) {
  .natural table {
    max-width: 100%;
  }
}
.natural .js-table-scroll table {
  min-width: 610px;
}

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

.natural table td {
  height: auto !important;
  padding-right: 20px !important;
  padding-left: 20px !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 screen and (min-width: 768px) {
  .natural table td {
    padding: 15px !important;
    font-size: var(--fz-root-desktop);
  }
}

/* blockquote */
.natural blockquote {
  position: relative;
  margin-top: 30px;
  margin-bottom: 30px;
  padding: 20px 45px;
  border-top: 1px solid var(--color-pale);
  border-bottom: 1px solid var(--color-pale);
}
@media screen and (min-width: 768px) {
  .natural blockquote {
    margin-top: 40px;
    margin-bottom: 40px;
    padding: 25px 60px;
  }
}
.natural blockquote:first-child {
  margin-top: 0;
}
.natural blockquote:last-child {
  margin-bottom: 0;
}

.natural blockquote::before,
.natural blockquote::after {
  content: "";
  position: absolute;
  width: 18.65px;
  height: 13.09px;
  background: url(https://50443322.fs1.hubspotusercontent-na2.net/hubfs/50443322/raw_assets/public/toyota-kai_or_jp/01_JP/assets/images/common/ico_blockquote.svg) no-repeat;
  background-size: contain;
}
.natural blockquote::before {
  top: 16px;
  left: 16px;
}
.natural blockquote::after {
  top: 16px;
  right: 16px;
  transform: rotate(180deg);
}
@media screen and (min-width: 768px) {
  .natural blockquote::before,
  .natural blockquote::after {
    position: absolute;
    width: 25.87px;
    height: 18.16px;
  }
  .natural blockquote::before {
    left: 20px;
  }
  .natural blockquote::after {
    right: 20px;
    transform: rotate(180deg);
  }
}

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


/* リッチテキスト内のテーブル */

/* SWIPE icon */
@media screen and (min-width:601px) {
  .js-table-scroll__icon {
    display: none;
  }
}
.js-table-scroll__icon__arrow {
  display: none;
}
@media screen and (max-width:600px) {
  .js-table-scroll {
    margin-right: -20px;
    overflow-x: scroll;
    overflow-y: hidden;
    position: relative;
  }
  .js-table-scroll > .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;
  }
}

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

  パンくず

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

.elevator {
  margin-top: 7px;
}

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

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

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

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

.elevator__nav__breadcrumb .hs-breadcrumb-menu__item:not(:first-child),
.elevator__nav__breadcrumb .hs-breadcrumb-menu .hs-breadcrumb-menu-item:not(:first-child) {
  position: relative;
  margin-left: 15px;
  padding-left: 16px;
}

.elevator__nav__breadcrumb .hs-breadcrumb-menu__item:not(:first-child)::before,
.elevator__nav__breadcrumb .hs-breadcrumb-menu__item:not(:first-child)::after,
.elevator__nav__breadcrumb .hs-breadcrumb-menu .hs-breadcrumb-menu-item:not(:first-child)::before,
.elevator__nav__breadcrumb .hs-breadcrumb-menu .hs-breadcrumb-menu-item:not(:first-child)::after {
  content: '';
  display: block;
  position: absolute;
  left: 0;
  width: 2px;
  height: 5px;
  background-color: var(--color-sub);
  transform: skewX(40deg);
}

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

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

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

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

.elevator__nav__breadcrumb .hs-breadcrumb-menu__item__anchor__icon,
.elevator__nav__breadcrumb .hs-breadcrumb-menu__item a.hs-breadcrumb-label__icon,
.elevator__nav__breadcrumb .hs-breadcrumb-menu .hs-breadcrumb-menu-item__anchor__icon,
.elevator__nav__breadcrumb .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__breadcrumb .hs-breadcrumb-menu__item__anchor__icon__arrow,
.elevator__nav__breadcrumb .hs-breadcrumb-menu__item a.hs-breadcrumb-label__icon__arrow,
.elevator__nav__breadcrumb .hs-breadcrumb-menu .hs-breadcrumb-menu-item__anchor__icon__arrow,
.elevator__nav__breadcrumb .hs-breadcrumb-menu .hs-breadcrumb-menu-item a.hs-breadcrumb-label__icon__arrow {
  fill: var(--color-point);
}

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

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

  フッター

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

footer {
  position: relative;
}

.footer {
  position: relative;
  overflow: hidden;
  padding-top: 92px;
}
@media screen and (min-width: 768px) {
  .footer {
    padding-top: 155px;
  }
}
@media screen and (min-width: 1050px) {
  .footer {
    padding-top: 173px;
  }
}

.footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-top-left-radius: 1000px 200px;
  border-top-right-radius: 1000px 200px;
  margin-left: -200px;
  margin-right: -200px;
  padding-left: 200px;
  padding-right: 200px;
  background: linear-gradient(-175deg, #FBFDFF 0, #E2F1FF 75%);
}
@media screen and (min-width: 768px) {
  .footer::before {
    border-top-left-radius: 2000px 300px;
    border-top-right-radius: 2000px 300px;
    background: linear-gradient(-170deg, #FBFDFF 0, #E2F1FF 75%);
  }
}
@media screen and (min-width: 1050px) {
  .footer::before {
    background: linear-gradient(-150deg, #FEFEFF 0,#E2F1FF 90%);
  }
}
@media screen and (min-width: 1450px) {
  .footer::before {
    border-top-left-radius: 3000px 300px;
    border-top-right-radius: 3000px 300px;
  }
}

.container.footer-container {
  position: relative;
}
@media screen and (min-width: 1050px) {
  .container.footer-container {
    max-width: 1390px;
  }
}

.footer__above {
  position: relative;
  margin-top: 60px;
}
@media screen and (min-width: 768px) {
  .footer__above {
    margin-top: 80px;
  }
}
@media screen and (min-width: 1050px) {
  .footer__above {
    margin-top: 103px;
  }
}

.footer__above__nav {
  padding-bottom: 30px;
}
@media screen and (min-width: 768px) {
  .footer__above__nav {
    padding-bottom: 70px;
  }
}
@media screen and (min-width: 1050px) {
  .footer__above__nav {
    padding-bottom: 176px;
  }
}

.footer__above__nav__columns {
  display: grid;
  grid-template-areas:
    "logo"
    "nav"
    "img";
}
@media screen and (min-width: 1050px) {
  .footer__above__nav__columns {
    grid-template-areas:
      "logo nav"
      "img nav";
    grid-template-columns: minmax(280px, 30.3%) 1fr;
    grid-template-rows: auto 1fr;
    gap: 0 11.2%;
  }
}

/* フッターロゴ */
.footer__above__nav__columns__column__item {
  grid-area: logo;
  display: grid;
  gap: 25px;
  height: fit-content;
}
@media screen and (min-width :768px) {
  .footer__above__nav__columns__column__item {
    grid-template-columns: auto auto;
    justify-content: space-between;
    gap: 118px;
  }
}
@media screen and (min-width :768px) {
  .footer__above__nav__columns__column__item {
    grid-template-columns: 1fr;
    gap: 26px;
  }
}

.footer__above__nav__logo {
  text-align: left;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

.footer__above__nav__logo__anchor,
.footer__above__nav__logo a {
  display: block;
}
.footer__above__nav__logo a {
  width: 260px;
}
@media screen and (min-width: 768px) {
  .footer__above__nav__logo a {
    width: 280px;
  }
}

.footer__above__nav__logo__anchor img,
.footer__above__nav__logo a img {
  width: 100% !important;
  vertical-align: bottom;
}


/* 画像スライドショーエリア */
.footer__above__nav__columns__column__img-slide-show {
  grid-area: img;
}


/* メインナビゲーションエリア */
.footer__above__nav__columns__column {
  grid-area: nav;
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  .footer__above__nav__columns__column {
    margin-top: 65px;
  }
}
@media screen and (min-width: 1050px) {
  .footer__above__nav__columns__column {
    margin-top: 0;
  }
}


/* コピーライト */
.footer__copyright {
  position: relative;
  background-color: var(--color-point);
}

.footer__copyright__text {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-top: 8px;
  padding-bottom: 7px;
  box-sizing: border-box;
  color: #ffffff;
  font-family: var(--font-en);
  font-size: 1rem;
  font-weight: var(--fw-normal-jp);
  line-height: 1.5;
  letter-spacing: .08em;
}
@media screen and (min-width :768px) {
  .footer__copyright__text {
    font-size: 1.2rem;
    padding-top: 7px;
    padding-bottom: 5px;
    max-width: initial;
  }
}
@media screen and (min-width: 1050px) {
  .footer__copyright__text {
    justify-content: flex-start;
    max-width: 1190px;
    margin-left: 0;
  }
}

/* ページトップ */
.footer__nav__page-top {
  display: block;
  right: 18px;
  bottom: 25px;
  box-sizing: border-box;
}
.footer__nav__page-top--fixed {
  position: fixed;
  z-index: 5;
}
.footer__nav__page-top--no-fixed {
  position: absolute;
}
@media screen and (min-width: 768px) {
  .footer__nav__page-top {
    bottom: 18px;
  }
}
@media screen and (min-width: 1050px) {
  .footer__nav__page-top {
    right: 29px;
    bottom: 26px;
  }
}


.footer__nav__page-top__anchor {
  display: block;
  position: relative;
  width: 55px;
  height: 40px;
  border-radius: 50%;
  transition: .3s;
}
@media screen and (min-width: 768px) {
  .footer__nav__page-top__anchor {
    width: 80px;
    height: 55px;
  }
}

.page-top__anchor__inner {
  display: flex;
  flex-direction: column;
  align-items: anchor-center;
  justify-content: center;
  gap: 1px;
  width: 100%;
  height: 100%;
  padding: 6px 10px 1px;
  box-sizing: border-box;
  border-radius: 50%;
  background: linear-gradient(40deg, rgba(24,97,160,.9) 20%, rgba(100,158,213.9));
  color: #ffffff;
  font-family: var(--font-en);
  font-size: 1.4rem;
  letter-spacing: .03em;
  line-height: 1.5;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .page-top__anchor__inner {
    gap: 3px;
    padding: 5px 20px;
    font-size: 1.6rem;
  }
}

.page-top__anchor__inner__icon {
  flex-shrink: 0;
  width: 10px;
  height: 10px;
  transition: .3s;
}

/* :focus & :hover */
.footer__nav__page-top__anchor:focus {
  color: #ffffff;
  background-color: var(--color-point);
}
.footer__nav__page-top__anchor:focus .page-top__anchor__inner__icon__path {
  fill: #ffffff;
}
@media screen and (min-width: 1050px) {
  .footer__nav__page-top__anchor:hover {
    color: #ffffff;
    background-color: var(--color-point);
  }
  .footer__nav__page-top__anchor:hover .page-top__anchor__inner__icon__path {
    fill: #ffffff;
  }
}

/* 追従時のスタイル */
.footer__nav__page-top.is-fixed {
  display: none;
}

.footer__nav__page-top.is-fixed {
  display: block;
  position: fixed;
  top: inherit;
  z-index: 5;
  bottom: 22px;
}
@media screen and (min-width: 768px) {
  .footer__nav__page-top.is-fixed {
    bottom: 20px;
  }
}
@media screen and (min-width: 1050px) {
  .footer__nav__page-top.is-fixed {
    bottom: 40px;
  }
}
/* ==========================================================================

  ヘッダー

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

.header {
  position: fixed;
  width: 100%;
  z-index: 99;
  background-color: #fff;
  box-shadow: 0 3px 12px rgba(65, 65, 65, 0.07);
  transition: .3s;
}
.header--no-nav {
  position: relative;
}
.container.header__container {
  padding-left: 20px;
  padding-right: 20px;
}
@media screen and (min-width: 768px) {
  .container.header__container {
    padding-left: 50px;
    padding-right: 50px;
  }
}
@media screen and (min-width: 1050px) {
  .container.header__container {
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media screen and (min-width: 1280px) {
  .container.header__container {
    padding-left: 30px;
    padding-right: 30px;
  }
}
@media screen and (min-width: 1380px) {
  .container.header__container {
    padding-left: 60px;
    padding-right: 60px;
  }
}

.header__columns {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  min-height: 60px;
}
@media screen and (min-width: 768px) {
  .header__columns {
    min-height: 102px;
  }
}
@media screen and (min-width: 1050px) {
  .header__columns {
    min-height: 100px;
  }
  .header--no-nav .header__columns {
    min-height: 100px;
  }
}
@media screen and (min-width: 1280px) {
  .header__columns {
    gap: 30px;
  }
}

@media screen and (min-width: 1050px) {
  .header__columns__column {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
  }
}

/* ロゴ画像 */
.header__columns__column:nth-child(1) {
  margin-top: 0;
}

.header__logo__inner--white {
  display: none;
}

.header__logo {
  position: relative;
  width: 130px;
  height: auto;
  transition: .3s;
  @media (min-width: 768px) {
    & {
      width: 210px;
    }
  }
  @media (min-width: 1050px) {
    & {
      width: 130px;
      opacity: 1;
      visibility: visible;
    }
    &.is-hidden {
      opacity: 0;
      visibility: hidden;
    }
  }
  @media (min-width: 1280px) {
    & {
      width: 160px;
    }
  }
  @media (min-width: 1380px) {
    & {
      width: 220px;
    }
  }
}

.header__main__logo {
  position: fixed;
  top: 20px;
  left: 20px;
  width: 162px;
  height: 33px;
  @media (min-width: 768px) {
    & {
      top: 35px;
      left: 50px;
      width: 250px;
      height: 51px;
    }
  }
  @media (min-width: 1050px) {
    & {
      top: 47px;
      left: 191px;
      width: 195px;
      height: 40px;
    }
  }
}

.header__logo a,
.header__main__logo a {
  display: block;
}
.header__logo a img,
.header__main__logo a img {
  max-width: 100%;
  vertical-align: bottom;
}

.header__main {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  padding-top: 0;
  padding-left: 20px;
  padding-right: 20px;
  background-color: transparent;
  pointer-events: none;
  transition: opacity .3s;
  pointer-events: auto;
  box-sizing: border-box;
}
@media screen and (min-width: 768px) {
  .header__main {
    padding-left: 50px;
    padding-right: 50px;
  }
}
@media screen and (min-width: 1050px) {
  .header__main {
    width: calc(100% - 70px);
    padding-left: 122px;
    padding-right: 80px;
    overflow: hidden;
  }
}
.header__main.is-active {
  opacity: 1;
  visibility: visible;
  position: fixed;
  top: 0;
  pointer-events: auto;
  z-index: 100;
}

.header__main::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(160deg, #F0F8FF, #E2F1FF);
}
@media screen and (min-width: 768px) {
  .header__main::before {
    background: linear-gradient(140deg, #F5FAFF, #E2F1FF);
  }
}
@media screen and (min-width: 1050px) {
  .header__main::before {
    transform: translateX(50px);
    background: linear-gradient(130deg, #FFFFFF, #E2F1FF);
    border-top-left-radius: 300px 1000px;
    border-bottom-left-radius: 300px 1000px;
    margin-top: -200px;
    margin-bottom: -200px;
    padding-top: 200px;
    padding-bottom: 200px;
    box-shadow: 0 3px 20px rgba(0,25,49,.2);
    transition: .3s;
  }
  .header__main.is-active::before {
    transform: translateX(0);
  }
  .header__main::after {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #002B3E;
    opacity: .45;
    z-index: -1;
  }
}

/* ハンバーガーナビ */
.header__hamburger {
  flex-shrink: 0;
  position: absolute;
  top: 10px;
  right: 20px;
  width: 60px;
  height: 40px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background-color: #ffffff;
  border: 1px solid var(--color-point);
  appearance: none;
  cursor: pointer;
  z-index: 101;
  transition: border .3s;
}
@media screen and (min-width: 768px) {
  .header__hamburger {
    top: 14px;
    right: 50px;
    width: 115px;
    height: 75px;
  }
}
@media screen and (min-width: 1050px) {
  .header__hamburger {
    top: 21px;
    right: 20px;
    width: 90px;
    height: 60px;
  }
}
@media screen and (min-width: 1280px) {
  .header__hamburger {
    right: 30px;
  }
}
@media screen and (min-width: 1380px) {
  .header__hamburger {
    right: 60px;
  }
}

.header__hamburger__inner {
  display: block;
  position: absolute;
  top: calc(50% - 6px);
  left: calc(50% - 7px);
}
@media screen and (min-width: 768px) {
  .header__hamburger__inner {
    top: calc(50% - 20px);
    left: calc(50% - 7px);
  }
}
@media screen and (min-width: 1050px) {
  .header__hamburger__inner {
    top: calc(50% - 16px);
    left: calc(50% - 5px);
  }
}
.header__hamburger__inner__line {
  display: block;
  position: absolute;
  left: 0;
  height: 1px;
  width: 15px;
  background-color: var(--color-point);
  transition: all .3s;
}
@media screen and (min-width: 1050px) {
  .header__hamburger__inner__line {
    width: 11px;
  }
}

.header__hamburger__inner__line:nth-child(1) {
  top: 0;
}
.header__hamburger__inner__line:nth-child(2) {
  top: 5px;
}
.header__hamburger__inner__line:nth-child(3) {
  top: 10px;
}
@media screen and (min-width: 1050px) {
  .header__hamburger__inner__line:nth-child(2) {
    top: 4px;
  }
  .header__hamburger__inner__line:nth-child(3) {
    top: 8px;
  }
}
.is-active .header__hamburger__inner__line:nth-child(1),
.is-active .header__hamburger__inner__line:nth-child(3) {
  width: 15px;
  left: 0px;
}
.is-active .header__hamburger__inner__line:nth-child(1) {
  top: 5px;
  transform: rotate(45deg);
}
.is-active .header__hamburger__inner__line:nth-child(2) {
  opacity: 0;
  transform: translateX(10px);
}
.is-active .header__hamburger__inner__line:nth-child(3) {
  top: 5px;
  transform: rotate(-45deg);
}
@media screen and (min-width: 1050px) {
  .is-active .header__hamburger__inner__line:nth-child(1),
  .is-active .header__hamburger__inner__line:nth-child(3) {
    width: 11px;
  }
  .is-active .header__hamburger__inner__line:nth-child(3) {
    top: 5px;
  }
}

.header__hamburger__text {
  display: none;
}
@media screen and (min-width: 768px) {
  .header__hamburger__text {
    display: block;
    position: absolute;
    top: 38px;
    left: calc(50% + 1px);
    transform: translateX(-50%);
    width: 100%;
    color: var(--color-point);
    font-family: var(--font-en);
    font-size: 1.8rem;
    line-height: 1.1;
    letter-spacing: .11em;
  }
}
@media screen and (min-width: 1050px) {
  .header__hamburger__text {
    top: 32px;
    font-size: 1.2rem;
  }
}


/* ハンバーガーメニュー用検索フォーム */
.header__hamburger__search {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0;
}
.header__hamburger__search--pc {
  display: none;
}
@media screen and (min-width: 1050px) {
  .header__hamburger__search--sp {
    display: none;
  }
  .header__hamburger__search--pc {
    display: flex;
    position: fixed;
    top: 54px;
    right: 194px;
  }
}

.header__hamburger__search--sp > div {
  width: 100%;
}

.header input.gsc-input {
  width: 100% !important;
  height: 35px !important;
  margin: 0 !important;
  padding: 6px 22px 3px !important;
  box-sizing: border-box;
  overflow: hidden;
  background: transparent !important;
  background-color: transparent;
  border: 1px solid var(--color-point) !important;
  border-radius: 18px 0 0 18px !important;
  color: var(--color-point);
  font-size: 1.6rem;
  font-weight: 500;
  line-height: var(--lh-normal-text);
  letter-spacing: var(--ls-root);
}
.header input.gsc-input::placeholder {
  color: var(--color-point);
  font-size: 1.6rem;
  font-weight; 500;
  line-height: var(--lh-normal-text);
  letter-spacing: var(--ls-root);
  opacity: .4;
}
@media screen and (min-width: 768px) {
  .header input.gsc-input {
    height: 50px !important;
    padding: 13px 25px 11px !important;
    border-radius: 26px 0 0 26px !important;
  }
}
@media screen and (min-width: 1050px) {
  .header input.gsc-input {
    width: 120px !important;
    height: 26px !important;
    padding: 4px 9px 2px !important;
    border-radius: 13px 0 0 13px !important;
  }
  .header input.gsc-input,
  .header input.gsc-input::placeholder {
    font-size: 1.2rem;
  }
}

.header .gsc-input-box {
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  overflow: hidden;
  border: none;
  background: none;
  background-color: transparent;
}

.header .gsib_a {
  height: fit-content;
  padding: 0;
}

.header td.gsc-input {
  padding-right: 0 !important;
}

.header td.gsib_b {
  position: absolute;
  top: 50%;
  right: 3px;
  transform: translateY(-50%);
}

.header .gsst_b {
  padding: 0;
}

.header .gscb_a {
  color: var(--color-point) !important;
  line-height: 26px;
}

.header .gsst_a {
  display: block;
  height: 25px;
  padding: 0;
}

.header .gsc-search-button-v2 {
  flex-shrink: 0;
  border: none;
  background-color: var(--color-point);
  width: 45px;
  height: 35px;
  margin-left: -1px;
  padding: 0;
  border-radius: 0 18px 18px 0;
  border: 1px solid var(--color-point);
  box-sizing: border-box;
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2215.998%22%20height%3D%2219.759%22%20viewBox%3D%220%200%2015.998%2019.759%22%3E%20%3Cpath%20d%3D%22M-3760.795%2C13184.866a7.8%2C7.8%2C0%2C0%2C1-3.389.771%2C7.819%2C7.819%2C0%2C0%2C1-7.815-7.819%2C7.818%2C7.818%2C0%2C0%2C1%2C7.815-7.818%2C7.819%2C7.819%2C0%2C0%2C1%2C7.819%2C7.818%2C7.8%2C7.8%2C0%2C0%2C1-2.957%2C6.124l3.321%2C4.833-1.43.983Zm-9.469-7.049a6.087%2C6.087%2C0%2C0%2C0%2C6.081%2C6.081%2C6.087%2C6.087%2C0%2C0%2C0%2C6.081-6.081%2C6.087%2C6.087%2C0%2C0%2C0-6.081-6.08A6.087%2C6.087%2C0%2C0%2C0-3770.264%2C13177.817Z%22%20transform%3D%22translate(3771.999%20-13169.999)%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E');
  background-size: 13px 16px;
  background-position: 43% 50%;
  background-repeat: no-repeat;
  cursor: pointer;
  transition: var(--transition-ptn01);
}
@media screen and (min-width: 768px) {
  .header .gsc-search-button-v2 {
    width: 70px;
    height: 50px;
    border-radius: 0 26px 26px 0;
    background-size: 16px 20px;
  }
}
@media screen and (min-width: 1050px) {
  .header .gsc-search-button-v2 {
    width: 31px;
    height: 26px;
    border-radius: 0 13px 13px 0;
    background-size: 9px 11px;
  }
  .header .gsc-search-button-v2:hover {
    background-color: var(--color-point);
    background-size: 11px 13px;
    background-position: 42% 46%;
    border-color: var(--color-point);
  }
}

.header .gsc-search-button-v2 svg {
  display: none;
}

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

  カラム

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

/* 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: 280px;
    max-width: 450px;
    margin: 0 auto;
    padding: 15px 65px 13px 30px;
    border: 1px solid var(--color-point);
    border-radius: 38px;
    color: var(--color-point);
    font-size: 1.8rem;
    font-weight: var(--fw-bold-jp);
    letter-spacing: var(--ls-root);
    line-height: var(--lh-heading);
    text-align: left;
    transition:
      background-color .3s,
      color .3s;
    @media (min-width: 768px) {
      & {
        min-width: 450px;
        padding: 15px 82px 12px 40px;
        border-radius: 40px;
        font-size: 2.1rem;
      }
    }
    /* :focus & :hover */
    &:focus-visible {
      background-color: var(--color-point);
      color: #fff;
    }
    @media (min-width: 1050px) {
      &:hover {
        background-color: var(--color-point);
        color: #fff;
      }
    }
  }
}

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

.entry-button__decoration-text {
  content: attr(data-entry);
  display: block;
  width: 100%;
  color: var(--color-point);
  font-family: var(--font-en);
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: var(--ls-root-en);
  line-height: 1.3;
  text-transform: uppercase;
  transition: color .5s;
  opacity: .4;
  /* hover & focus */
  a:focus-visible & {
    color: #fff;
  }
  @media (min-width: 1050px) {
    a:hover & {
      color: #fff;
    }
  }
}

/* link icon */
.entry-button .entry-button__icon {
  position: absolute;
  top: 50%;
  right: 30px;
  width: 30px;
  height: 18.5px;
  transform: translateY(-50%);
  @media (min-width: 768px) {
    & {
      right: 40px;
      width: 37px;
      height: 24px;
    }
  }

  /* hover & focus */
  a:focus-visible &::before {
    background-color: var(--color-sub);
  }
  @media (min-width: 1050px) {
    a:hover &::before {
      background-color: var(--color-sub);
    }
  }

  .link-icon__arrow {
    width: 8.9px;
    height: 7.8px;
    @media (min-width: 768px) {
      & {
        width: 12px;
        height: 11px;
      }
    }
  }
}

.entry-button .entry-button__icon__circle {
  fill: #ffffff;
}

.entry-button .entry-button__icon__path {
  fill: var(--color-point);
}

/* link icon : external link */
.entry-button .entry-button__icon.is-exlink {
  width: 20px;
  height: 20px;
  @media (min-width: 768px) {
    & {
      width: 18px;
      height: 18px;
    }
  }

  .link-icon__path {
    /* hover & focus */
    a:focus-visible & {
      fill: #fff;
    }
    @media (min-width: 1050px) {
      a:hover & {
        fill: #fff;
      }
    }
  }
}
/* ==========================================================================

    画像（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(45px + var(--leading-trim));
      /* --leading-trimの計算を.heading-2と揃えるために設定 */
      font-size: var(--fz-h2-desktop);
    }
  }
}

.heading-2 {
  margin-top: calc(60px + var(--leading-trim));
  margin-bottom: calc(25px + var(--leading-trim));
  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: calc(80px + var(--leading-trim));
      margin-bottom: calc(45px + var(--leading-trim));
      font-size: var(--fz-h2-desktop);
    }
  }
  &:first-child {
    margin-top: 0;
  }
  &:last-child {
    margin-bottom: 0;
  }
}

/*
  === 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__deco {
  box-sizing: border-box;
  display: block;
  position: relative;
  width: fit-content;
  margin-bottom: 2px;
  padding-left: 14px;
  color: var(--color-point);
  font-family: var(--font-en);
  font-size: 1.4rem;
  font-weight: var(--fw-normal-en);
  letter-spacing: var(--ls-root-en);
  line-height: 1.3;
  text-transform: capitalize;
  @media (min-width: 768px) {
    & {
      padding-left: 16px;
      font-size: 1.6rem;
    }
  }

  /* 装飾 */
  &::before {
    content: "";
    display: block;
    position: absolute;
    top: 4px;
    left: 0;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #1C5198;
    background-image: linear-gradient(221deg, #5F8DE3, #1C5198);
  }
  @media (min-width: 768px) {
    &::before {
      top: 5px;
    }
  }
}
/* 中央揃え */
.heading-2.text-center {
  display: flex;
  flex-direction: column;
  align-items: center;
  .heading-2__deco {
    padding-bottom: 14px;
    padding-left: 0;
    &::before {
      top: auto;
      bottom: 0;
      left: calc(50% - 4px);
    }
  }
}

/* 装飾テキストがない場合 */
.heading-2 .no-decoration-text {
  display: inline-block;
  position: relative;
  padding-left: 16px;

  /* 装飾 */
  &::before {
    content: "";
    display: block;
    position: absolute;
    top: 13px;
    left: 0;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #1C5198;
    background-image: linear-gradient(221deg, #5F8DE3, #1C5198);
  }
  @media (min-width: 768px) {
    &::before {
      top: 18px;
    }
  }
}
/* 中央揃え */
.heading-2.text-center {
  .no-decoration-text {
    padding-top: 16px;
    padding-left: 0;
    &::before {
      top: 0;
      left: calc(50% - 4px);
    }
  }
}

.heading-2--reverse {
  color: #ffffff;
  .heading-2__deco {
    color: #ffffff;
    &::before {
      background: #fff;
      background: linear-gradient(225deg, rgba(255, 255, 255, 0.34), #ffffff);
    }
  }
}

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

    見出し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 screen and (min-width: 768px) {
  .section-heading3 {
    margin-top: calc(55px + var(--leading-trim));
    margin-bottom: calc(30px + 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));
  font-size: var(--fz-h3-palmtop);
  font-weight: var(--fw-normal-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
}
@media screen and (min-width: 768px) {
  .heading-3 {
    margin-top: calc(55px + var(--leading-trim));
    margin-bottom: calc(30px + var(--leading-trim));
    font-size: var(--fz-h3-desktop);
  }
}
.heading-3:first-child {
  margin-top: 0;
}
.heading-3:last-child {
  margin-bottom: 0;
}

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

  & + * {
    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 screen and (min-width: 768px) {
  .section-heading4 {
    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 {
  margin-top: calc(30px + var(--leading-trim));
  margin-bottom: calc(20px + var(--leading-trim));
  font-size: var(--fz-h4-palmtop);
  font-weight: var(--fw-bold-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
}
@media screen and (min-width: 768px) {
  .heading-4 {
    margin-top: calc(45px + var(--leading-trim));
    margin-bottom: calc(25px + var(--leading-trim));
    font-size: var(--fz-h4-desktop);
  }
}
.heading-4:first-child {
  margin-top: 0;
}
.heading-4:last-child {
  margin-bottom: 0;
}

/*
  === child elements in modules
  モジュール内に配置する際のエレメントスタイルとは異なる場合のスタイル
*/
.heading-4.heading--child {
  margin-top: 25px;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .heading-4.heading--child {
    margin-top: 30px;
    margin-bottom: 25px;
  }
}
.heading-4.heading--child:first-child {
  margin-top: 0;
}
.heading-4.heading--child:last-child {
  margin-bottom: 0;
}
.heading-4.heading--child + * {
  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 screen and (min-width: 768px) {
  .section-heading5 {
    /* --leading-trimの計算を.heading-5と揃えるために設定 */
    font-size: var(--fz-h5-desktop);
  }
}

.heading-5 {
  margin-top: calc(30px + var(--leading-trim));
  margin-bottom: calc(20px + var(--leading-trim));
  font-size: var(--fz-h5-palmtop);
  font-weight: var(--fw-bold-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
}
@media screen and (min-width: 768px) {
  .heading-5 {
    font-size: var(--fz-h5-desktop);
  }
}
.heading-5:first-child {
  margin-top: 0;
}
.heading-5:last-child {
  margin-bottom: 0;
}

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

  /* アイコン */
  .link-icon {
    display: block;
    position: absolute;
    left: 0;
    width: 21px;
    height: 14px;
  }
}

/* 見出しレベル別　アイコン位置調整 */
.heading-2.heading-link {
  @media (min-width: 768px) {
    & {
      padding-left: 45px;
    }
  }
  .link-icon {
    top: 11px;
    @media (min-width: 768px) {
      & {
        width: 37px;
        height: 24px;
      }
    }
  }
  .link-icon__arrow {
    @media (min-width: 768px) {
      & {
        width: 12px;
        height: 11px;
      }
    }
  }
}

.heading-3.heading-link {
  @media (min-width: 768px) {
    & {
      padding-left: 38px;
    }
  }
  .link-icon {
    top: 7px;
    @media (min-width: 768px) {
      & {
        top: 8px;
        width: 29px;
        height: 19px;
      }
    }
  }
  .link-icon__arrow {
    @media (min-width: 768px) {
      & {
        width: 9px;
        height: 8.3px;
      }
    }
  }
}

.heading-4.heading-link {
  .link-icon {
    top: 4px;
    @media (min-width: 768px) {
      & {
        top: 8px;
      }
    }
  }
}

.heading-5.heading-link {
  .link-icon {
    top: 4px;
    @media (min-width: 768px) {
      & {
        top: 7px;
      }
    }
  }
}

/* link heading : PDF, external link */
.heading-2.heading-link:is(.is-pdf, .is-exlink) {
  padding-left: 27px;
}
:is(.heading-3, .heading-4, .heading-5).heading-link:is(.is-pdf, .is-exlink) {
  padding-left: 24px;
}
@media (min-width: 768px) {
  .heading-2.heading-link:is(.is-pdf, .is-exlink) {
    padding-left: 32px;
  }
  .heading-3.heading-link:is(.is-pdf, .is-exlink) {
    padding-left: 27px;
  }
}

/* link icon : PDF */
.heading-2.heading-link.is-pdf .link-icon {
  top: 8px;
  width: 17px;
  height: 17.44px;
}
:is(.heading-3, .heading-4, .heading-5).heading-link.is-pdf .link-icon {
  top: 5px;
  width: 16px;
  height: 16.41px;
}
.heading-4.heading-link.is-pdf .link-icon {
  top: 4px;
}
.heading-5.heading-link.is-pdf .link-icon {
  top: 3px;
}
@media (min-width: 768px) {
  .heading-2.heading-link.is-pdf .link-icon {
    top: 16px;
    width: 20px;
    height: 20.52px;
  }
  .heading-3.heading-link.is-pdf .link-icon {
    top: 11px;
    width: 17px;
    height: 17.44px;
  }
  .heading-4.heading-link.is-pdf .link-icon {
    top: 7px;
    width: 16px;
    height: 16.41px;
  }
  .heading-5.heading-link.is-pdf .link-icon {
    top: 5px;
  }
}

/* link icon : external link */
.heading-2.heading-link.is-exlink .link-icon {
  top: 9px;
  width: 16px;
  height: 16px;
}
:is(.heading-3, .heading-4, .heading-5).heading-link.is-exlink .link-icon {
  top: 7px;
  width: 14px;
  height: 14px;
}
:is(.heading-4, .heading-5).heading-link.is-exlink .link-icon {
  top: 5px;
}
@media (min-width: 768px) {
  .heading-2.heading-link.is-exlink .link-icon {
    top: 17px;
    width: 18px;
    height: 18px;
  }
  .heading-3.heading-link.is-exlink .link-icon {
    top: 11px;
    width: 16px;
    height: 16px;
  }
  .heading-4.heading-link.is-exlink .link-icon {
    top: 8px;
  }
  .heading-5.heading-link.is-exlink .link-icon {
    top: 7px;
  }
}
/* ==========================================================================

    リード文

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

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

.lead {
  font-size: 1.5rem;
  font-weight: var(--fw-bold-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;
}
/* ==========================================================================

  リンクボタン

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

.section-button {
  margin-top: 30px;
  margin-bottom: 30px;
}
@media (min-width: 768px) {
  .section-button {
    margin-top: 40px;
    margin-bottom: 40px;
  }
}

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

.link-button__anchor {
  box-sizing: border-box;
  display: inline-block;
  position: relative;
  min-width: 260px;
  padding: 17px 70px 15.5px 44px;
  background-color: transparent;
  border: 1px solid var(--color-point);
  border-radius: 60px;
  color: var(--color-main);
  font-family: var(--font-all);
  font-size: 1.6rem;
  line-height: var(--lh-button);
  letter-spacing: var(--ls-root);
  word-break: break-all;
  transition: color .3s, background-color .3s;
}
@media (min-width: 768px) {
  .link-button__anchor {
    padding: 19px 70px 18.5px 44px;
  }
}

/* :focus & :hover */
.link-button__anchor:focus-visible,
a:focus-visible .link-button__anchor {
  background-color: var(--color-point);
  color: #ffffff;
}
@media (min-width: 1050px) {
  .link-button__anchor:hover,
  :where(a:hover, .bl-hover) .link-button__anchor {
    background-color: var(--color-point);
    color: #ffffff;
  }
}

/* ボタンテキスト */
.link-button__anchor__inner {
  position: relative;
  z-index: 1;
}

/* ドットアイコン */
.link-button__anchor::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 30px;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  background-color: var(--color-sub);
  border-radius: 50%;
  transition: background-color .3s;
}
/* :focus & :hover */
.link-button__anchor:focus-visible::before {
  background-color: #ffffff;
}
@media (min-width: 1050px) {
  .link-button__anchor:hover::before,
  :where(a:hover, .bl-hover) .link-button__anchor::before {
    background-color: #ffffff;
  }
}

/* アローアイコン */
.link-button__anchor__icon {
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 30px;
  height: 19px;
  transform: translateY(-50%);
  @media (min-width: 768px) {
    & {
      width: 29px;
    }
  }

  /* アイコン背景 */
  &::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    background-color: var(--color-sub);
    border-radius: 50%;
    transition: background-color .3s;
  }
  /* :focus & :hover */
  .link-button__anchor:focus-visible &::before {
    background-color: #ffffff;
  }
  @media (min-width: 1050px) {
    .link-button__anchor:hover &::before,
    :where(.bl-hover, a:hover) &::before {
      background-color: #ffffff;
    }
  }

  .link-button__anchor:not(.is-pdf, .is-exlink) & .link-button__anchor__icon__inner {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 7px;
    height: 6.5px;
    transform: translate(-50%, -50%);
    transition: left .3s;
    @media (min-width: 768px) {
      & {
        width: 9px;
        height: 8.27px;
      }
    }
    /* :focus & :hover */
    .link-button__anchor:focus-visible & {
      left: calc(50% + 3px);
    }
    @media (min-width: 1050px) {
      .link-button__anchor:hover &,
      :where(.bl-hover, a:hover) & {
        left: calc(50% + 3px);
      }
    }
  }
}

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

/* PDFアイコン */
.link-button__anchor.is-pdf {
  .link-button__anchor__icon {
    width: 18px;
    height: 18.47px;
    @media (min-width: 768px) {
      & {
        width: 21px;
        height: 21.54px;
      }
    }
    /* hover & focus */

    &::before {
      content: none;
    }
  }

  .link-button__anchor__icon__inner__path {
    fill: var(--color-sub);
    /* hover & focus */
    .link-button__anchor.is-pdf:focus-visible & {
      fill: #ffffff;
    }
    @media (min-width: 1050px) {
      .link-button__anchor.is-pdf:hover &,
      :where(.bl-hover, a:hover) .is-pdf & {
        fill: #ffffff;
      }
    }
  }
}

/* 外部リンクアイコン */
.link-button__anchor.is-exlink {
  .link-button__anchor__icon {
    width: 16px;
    height: 16px;
    @media (min-width: 768px) {
      & {
        width: 18px;
        height: 18px;
      }
    }

    &::before {
      content: none;
    }
  }

  .link-button__anchor__icon__inner__path {
    fill: var(--color-sub);
    /* hover & focus */
    .link-button__anchor.is-exlink:focus-visible & {
      fill: #ffffff;
    }
    @media (min-width: 1050px) {
      .link-button__anchor.is-exlink:hover &,
      :where(.bl-hover, a:hover) .is-exlink & {
        fill: #ffffff;
      }
    }
  }
}

.link-button__anchor {
  .link-button__anchor__icon__inner__path--reverse {
    fill: #ffffff;
    .link-button__anchor:focus-visible & {
      fill: var(--color-point);
    }

    @media (min-width: 1050px) {
      .link-button__anchor.is-pdf:hover &,
      :where(.bl-hover, a:hover) .is-pdf & {
        fill: var(--color-point);
      }
    }
  }
}

/* icon reverse */
.link-button--reverse .link-button__anchor {
  border-color: #ffffff;
  color: #ffffff;
  &::before {
    background-color: #ffffff;
  }
}
/* デザイン反転時、arrowの下に置いて色を変更するための疑似要素 */
.link-button--reverse .link-button__anchor__icon::before {
  background-color: #ffffff;
}
.link-button--reverse .link-button__anchor__icon__inner__path {
  fill: var(--color-sub);
}
.link-button--reverse .link-button__anchor.is-pdf .link-button__anchor__icon__inner__path,
.link-button--reverse .link-button__anchor.is-exlink .link-button__anchor__icon__inner__path {
  fill: #ffffff;
}
.link-button--reverse .link-button__anchor .link-button__anchor__icon__inner__path--reverse {
  fill: var(--color-sub);
}
/* icon reverse hover style */
.link-button--reverse .link-button__anchor:focus-visible,
a:focus-visible .link-button--reverse .link-button__anchor {
  background-color: #ffffff;
  color: var(--color-point);
}
.link-button--reverse .link-button__anchor:focus-visible::before,
a:focus-visible .link-button--reverse .link-button__anchor::before {
  background-color: var(--color-point);
}
.link-button--reverse .link-button__anchor:focus-visible .link-button__anchor__icon::before,
a:focus-visible .link-button--reverse .link-button__anchor__icon::before {
  background-color: var(--color-sub);
}
.link-button--reverse .link-button__anchor:focus-visible .link-button__anchor__icon__inner__path,
a:focus-visible .link-button--reverse .link-button__anchor__icon__inner__path {
  fill: #ffffff;
}
.link-button--reverse .link-button__anchor:focus-visible .link-button__anchor__icon__inner__path--reverse {
  fill: var(--color-sub);
}
@media (min-width: 1050px) {
  .link-button--reverse .link-button__anchor:hover,
  :where(.bl-hover, a:hover) .link-button--reverse .link-button__anchor {
    background-color: #ffffff;
    color: var(--color-point);
  }
  .link-button--reverse .link-button__anchor:hover::before,
  :where(.bl-hover, a:hover) .link-button--reverse .link-button__anchor::before {
    background-color: var(--color-point);
  }
  .link-button--reverse .link-button__anchor:hover .link-button__anchor__icon::before,
  :where(.bl-hover, a:hover) .link-button--reverse .link-button__anchor__icon::before {
    background-color: var(--color-sub);
  }
  .link-button--reverse .link-button__anchor:hover .link-button__anchor__icon__inner__path,
  :where(.bl-hover, a:hover) .link-button--reverse .link-button__anchor__icon__inner__path {
    fill: #ffffff;
  }
  .link-button--reverse .link-button__anchor.is-pdf:hover .link-button__anchor__icon__inner__path,
  :where(.bl-hover, a:hover) .link-button--reverse .is-pdf .link-button__anchor__icon__inner__path,
  .link-button--reverse .link-button__anchor.is-exlink:hover .link-button__anchor__icon__inner__path,
  :where(.bl-hover, a:hover) .link-button--reverse .is-exlink .link-button__anchor__icon__inner__path {
    fill: var(--color-sub) !important;
  }
  .link-button--reverse .link-button__anchor.is-pdf:hover .link-button__anchor__icon__inner__path--reverse,
  :where(.bl-hover, a:hover) .link-button--reverse .is-pdf .link-button__anchor__icon__inner__path--reverse {
    fill: #ffffff;
  }
}

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

/* === MAX 3column list */
.section-button__list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 30px;
  margin-bottom: 30px;
  @media (min-width: 768px) {
    & {
      gap: 30px;
      margin-top: 40px;
      margin-bottom: 40px;
    }
  }

  .link-button {
    width: 260px;
    margin: 0;
  }
}

/* center */
.section-button__list.rich-button-center {
  justify-content: center;
}
@media (max-width: 767px) {
  .section-button__list.rich-button-center {
    flex-direction: column;
    align-items: center;
  }
}

/* MAX 3column list === */
/* ==========================================================================

  リンクアイコン

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

.link-icon {
  display: inline-block;
  position: relative;
  width: 21px;
  height: 14px;
}

.link-icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  background-color: var(--color-sub);
  border-radius: 50%;
  transition: background-color .3s;
}
/* :focus & :hover */
a:focus-visible .link-icon::before {
  background-color: var(--color-point);
}
@media (min-width: 1050px) {
  :is(a:hover, .bl-hover) .link-icon::before {
    background-color: var(--color-point);
  }
}

/* link icon : arrow svg */
.link-icon__arrow {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 7px;
  height: 6.5px;
  transform: translate(-50%, -50%);
  transition: left .3s;
}
/* :focus & :hover */
a:focus-visible .link-icon__arrow {
  left: calc(50% + 3px);
}
@media (min-width: 1050px) {
  :where(a:hover, .bl-hover) .link-icon__arrow {
    left: calc(50% + 3px);
  }
}

.link-icon__arrow__path {
  fill: #ffffff;
}

/* link icon : PDF */
.link-icon.is-pdf {
  width: 16px;
  height: 16.4px;
}
.link-icon.is-pdf .link-icon__path {
  fill: var(--color-sub);
  transition: fill .3s;
}
/* :focus & :hover */
a:focus-visible .link-icon.is-pdf .link-icon__path {
    fill: var(--color-point);
}
@media (min-width: 1050px) {
  :is(a:hover, .bl-hover) .link-icon.is-pdf .link-icon__path {
      fill: var(--color-point);
  }
}
.link-icon.is-pdf .link-icon__path--reverse {
  fill: #ffffff;
}

/* link icon : external link */
.link-icon.is-exlink {
  width: 14px;
  height: 14px;
}
.link-icon.is-exlink .link-icon__path {
  fill: var(--color-sub);
  transition: fill .3s;
}
/* :focus & :hover */
a:focus-visible .link-icon.is-exlink .link-icon__path {
  fill: var(--color-point);
}
@media (min-width: 1050px) {
  :is(a:hover, .bl-hover) .link-icon.is-exlink .link-icon__path {
    fill: var(--color-point);
  }
}

/* link style : reverse */
.link-icon.link-icon--reverse {
  &::before {
    background-color: var(--color-point);
  }

  .link-icon__arrow__path {
    fill: #ffffff;
  }
}

/* link icon : white color */
.link-icon.link-icon--white {
  &::before {
    background-color: #fff;
  }
  /* :focus & :hover */
  a:focus-visible &::before {
    background-color: var(--color-sub);
  }
  @media (min-width: 1050px) {
    :is(a:hover, .bl-hover) &::before {
      background-color: var(--color-sub);
    }
  }

  .link-icon__arrow__path {
    fill: var(--color-sub);
    /* :focus & :hover */
    a:focus-visible & {
      fill: #fff;
    }
    @media (min-width: 1050px) {
      :is(a:hover, .bl-hover) & {
        fill: #fff;
      }
    }
  }
}
/* ==========================================================================

  テキストボタン

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

.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-all);
  font-size: 1.6rem;
  letter-spacing: var(--ls-root);
  line-height: 1.4;
  &:not(:first-child) {
    margin-top: 12px;
    @media (min-width: 768px) {
      & {
        margin-top: 20px;
      }
    }
  }
  &:not(:last-child) {
    margin-bottom: 12px;
    @media (min-width: 768px) {
      & {
        margin-bottom: 20px;
      }
    }
  }
}

.link-text__anchor {
  display: inline-block;
  position: relative;
  padding-left: 29px;
  transition: color .3s;
  /* :focus & :hover */
  &:focus-visible,
  a:focus-visible & {
    color: var(--color-point);
  }
  @media (min-width: 1050px) {
    &:hover,
    :is(.bl-hover, a:not(.is-pdf, .is-exlink):hover) & {
      color: var(--color-point);
    }
  }
}

/* link icon */
.link-text__anchor__icon {
  display: block;
  position: absolute;
  top: 3px;
  left: 0;
  width: 21px;
  height: 14px;
  border-radius: 50%;

  .link-text__anchor:not(.is-pdf, .is-exlink) &::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    background-color: var(--color-sub);
    border-radius: 50%;
    transition: background-color .3s;
  }
  /* :focus & :hover */
  .link-text__anchor:not(.is-pdf, .is-exlink):focus-visible &::before {
    background-color: var(--color-point);
  }
  @media (min-width: 1050px) {
    .link-text__anchor:not(.is-pdf, .is-exlink):hover &::before,
    :is(.bl-hover, a:not(.is-pdf, .is-exlink):hover) &::before {
      background-color: var(--color-point);
    }
  }
}

.link-text__anchor__icon__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 7px;
  height: 6.5px;
  transform: translate(-50%, -50%);
  transition: left .3s;
  /* :focus & :hover */
  .link-text__anchor:not(.is-pdf, .is-exlink):focus-visible & {
    left: calc(50% + 3px);
  }
  @media (min-width: 1050px) {
    .link-text__anchor:not(.is-pdf, .is-exlink):hover &,
    :is(.bl-hover, a:not(.is-pdf, .is-exlink):hover) & {
      left: calc(50% + 3px);
    }
  }
}

.link-text__anchor__icon__inner__path {
  fill: #ffffff;
  transition: fill .3s;
}
.link-text__anchor__icon__inner__path--reverse {
  fill: #ffffff;
  transition: fill .3s;
}

.link-text__anchor__icon__inner__rect {
  fill: var(--color-sub);
  transition: fill .3s;
  /* hover & focus */
  .link-text__anchor:focus-visible & {
    fill: var(--color-point);
  }
  @media (min-width: 1050px) {
    .link-text__anchor:hover &,
    :is(.bl-hover, a:not(.is-pdf, .is-exlink):hover) & {
      fill: var(--color-point);
    }
  }
}

/* link icon : PDF */
.link-text__anchor.is-pdf {
  padding-left: 24px;
  .link-text__anchor__icon {
    width: 16px;
    height: 16.41px;
    border-radius: 0;
  }
  .link-text__anchor__icon__inner {
    width: 16px;
    height: 16.4px;
  }
  .link-text__anchor__icon__inner__path {
    fill: var(--color-sub);
    .link-text__anchor.is-pdf:focus-visible & {
      fill: var(--color-point);
    }
    @media (min-width: 1050px) {
      .link-text__anchor.is-pdf:hover &,
      :is(.bl-hover, a:hover) .is-pdf & {
        fill: var(--color-point);
      }
    }
  }
}

/* link icon : external link */
.link-text__anchor.is-exlink {
  padding-left: 22px;
  .link-text__anchor__icon {
    width: 14px;
    height: 14px;
    border-radius: 0;
  }
  .link-text__anchor__icon__inner {
    width: 14px;
    height: 14px;
  }
  .link-text__anchor__icon__inner__path {
    fill: var(--color-sub);
    .link-text__anchor.is-exlink:focus-visible & {
      fill: var(--color-point);
    }
    @media (min-width: 1050px) {
      .link-text__anchor.is-exlink:hover &,
      :is(.bl-hover, a:hover) .is-exlink & {
        fill: var(--color-point);
      }
    }
  }
}

/* icon reverse */
.link-text--reverse {

  .link-text__anchor {
    color: #ffffff;
    /* デザイン反転時、arrowの下に置いて色を変更するための疑似要素 */
    &:not(.is-pdf, .is-exlink) .link-text__anchor__icon::before {
      background-color: #ffffff;
    }
    /* hover & focus */
    &:focus-visible,
    a:focus-visible & {
      color: #ffffff;
    }
    @media (min-width: 1050px) {
      &:hover,
      :is(.bl-hover, a:not(.is-pdf, .is-exlink):hover) & {
        color: #ffffff;
      }
    }
  }

  .link-text__anchor__icon {
    /* hover & focus */
    .link-text__anchor:focus-visible &::before,
    a:focus-visible &::before {
      background-color: var(--color-sub);
    }
    @media (min-width: 1050px) {
      .link-text__anchor:hover &::before,
      :is(.bl-hover, a:not(.is-pdf, .is-exlink):hover) &::before {
        background-color: var(--color-sub);
      }
    }
  }

  .link-text__anchor__icon__inner__path {
    fill: var(--color-sub);

    .link-text__anchor.is-pdf &,
    .link-text__anchor.is-exlink & {
      fill: #ffffff;
    }
    /* hover & focus */
    .link-text__anchor:focus-visible &,
    a:focus-visible & {
      fill: #ffffff;
    }
    @media (min-width: 1050px) {
      .link-text__anchor:hover &,
      :is(.bl-hover, a:not(.is-pdf, .is-exlink):hover) & {
        fill: #ffffff;
      }
      .link-text__anchor.is-pdf:hover &,
      :is(.bl-hover, a:hover) .is-pdf &,
      .link-text__anchor.is-exlink:hover &,
      :is(.bl-hover, a:hover) .is-exlink & {
        fill: var(--color-sub);
      }
    }
  }

  .link-text__anchor__icon__inner__path--reverse {
    fill: var(--color-sub);
    /* hover & focus */
    .link-text__anchor:focus-visible & {
      fill: var(--color-sub);
    }
    @media (min-width: 1050px) {
      .link-text__anchor.is-pdf:hover &,
      :is(.bl-hover, a:not(.is-pdf, .is-exlink):hover) .is-pdf & {
        fill: #ffffff;
      }
    }
  }
}

/* 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 {
  color: var(--color-plane);
  font-size: var(--fz-root-palmtop);
  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 {
  margin-top: 70px;
  margin-bottom: 70px;
  /* 最初のセクション */
  &.dnd-section-color--first {
    margin-top: 60px;
  }
  /* 最後のセクション */
  &.dnd-section-color--last {
    margin-bottom: 80px;
  }
  @media (min-width: 768px) {
    & {
      margin-top: 100px;
      margin-bottom: 100px;
    }
    &.dnd-section-color--first {
      margin-top: 80px;
    }
    &.dnd-section-color--last {
      margin-bottom: 100px;
    }
  }

  /* 背景色ありセクション */
  &.dnd-section-color--bg {
    padding-top: 70px;
    padding-bottom: 70px;
    background-color: var(--color-bg);
    @media (min-width: 768px) {
      & {
        padding-top: 100px;
        padding-bottom: 100px;
      }
    }
  }
}

/* 最初のモジュール */
.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;
}
/* ==========================================================================

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

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

.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;
	}
}