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

/* Poppins - Light */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('https://46144360.fs1.hubspotusercontent-na2.net/hubfs/46144360/raw_assets/public/toyota-body/02_EN/assets/styles/vendors/fonts/Poppins/Poppins-Light.ttf') format('truetype');
}

/* Poppins - Regular */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('https://46144360.fs1.hubspotusercontent-na2.net/hubfs/46144360/raw_assets/public/toyota-body/02_EN/assets/styles/vendors/fonts/Poppins/Poppins-Regular.ttf') format('truetype');
}

/* Poppins - Medium */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('https://46144360.fs1.hubspotusercontent-na2.net/hubfs/46144360/raw_assets/public/toyota-body/02_EN/assets/styles/vendors/fonts/Poppins/Poppins-Medium.ttf') format('truetype');
}

/* Poppins - SemiBold */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('https://46144360.fs1.hubspotusercontent-na2.net/hubfs/46144360/raw_assets/public/toyota-body/02_EN/assets/styles/vendors/fonts/Poppins/Poppins-SemiBold.ttf') format('truetype');
}

/* Poppins - Bold */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('https://46144360.fs1.hubspotusercontent-na2.net/hubfs/46144360/raw_assets/public/toyota-body/02_EN/assets/styles/vendors/fonts/Poppins/Poppins-Bold.ttf') format('truetype');
}

/* Plus_Jakarta_Sans - Regular */
@font-face {
  font-family: 'PlusJakartaSans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('https://46144360.fs1.hubspotusercontent-na2.net/hubfs/46144360/raw_assets/public/toyota-body/02_EN/assets/styles/vendors/fonts/Plus_Jakarta_Sans/PlusJakartaSans-Regular.ttf') format('truetype');
}
/* Plus_Jakarta_Sans - Medium */
@font-face {
  font-family: 'PlusJakartaSans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('https://46144360.fs1.hubspotusercontent-na2.net/hubfs/46144360/raw_assets/public/toyota-body/02_EN/assets/styles/vendors/fonts/Plus_Jakarta_Sans/PlusJakartaSans-Medium.ttf') format('truetype');
}
/* Plus_Jakarta_Sans - SemiBold */
@font-face {
  font-family: 'PlusJakartaSans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('https://46144360.fs1.hubspotusercontent-na2.net/hubfs/46144360/raw_assets/public/toyota-body/02_EN/assets/styles/vendors/fonts/Plus_Jakarta_Sans/PlusJakartaSans-SemiBold.ttf') format('truetype');
}

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

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

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



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

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

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

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

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

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

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

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

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

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

html {
  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;
}

a:is(:hover, :focus){
  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;
}

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

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

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

/* リッチテキスト用スタイル */
/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

.natural {
  display: block;
  margin-top: 20px;
  margin-bottom: 20px;
  -webkit-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%;
}
@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: 100%;
  margin: 20px auto;
}
@media screen and (min-width:768px) {
  .natural figure {
    max-width: calc(100% - 100px);
    margin-top: 30px;
    margin-bottom: 30px;
  }
}
@media screen and (min-width:1050px) {
  .natural figure {
    max-width: 650px;
  }
}
.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: calc(100% - 100px);
  }
}
@media screen and (min-width: 1050px) {
  .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: 500;
  text-decoration: none;
  word-break: break-all;
  transition: .3s;
}
@media screen and (min-width: 1050px) {
  .natural a:not(.cta_button):not(.js-no-icon):is(:hover, :focus) {
    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;
  background: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMS45NjkiIGhlaWdodD0iMTEuOTY5IiB2aWV3Qm94PSIwIDAgMTEuOTY5IDExLjk2OSI+CiAgPHBhdGggaWQ9IuODkeOCuV82NDIxIiBkYXRhLW5hbWU9IuODkeOCuSA2NDIxIiBkPSJNLTc4OC41MjksMGgtNi4zNDJhLjUyOC41MjgsMCwwLDAtLjUyOC41MjlWMi4xNjdoLTMuODdhLjcuNywwLDAsMC0uNy43djguNGEuNy43LDAsMCwwLC43LjdoOC40YS43LjcsMCwwLDAsLjctLjdWNy40aDEuNjM4QS41MjguNTI4LDAsMCwwLTc4OCw2Ljg3MVYuNTI5QS41MjkuNTI5LDAsMCwwLTc4OC41MjksMFptLTIuNjM4LDEwLjk2OWgtNy44di03LjhoMy41N3YzLjdhLjUyNy41MjcsMCwwLDAsLjUyOC41MjhoMy43Wk0tNzg5LDYuNGgtNS40VjFoNS40WiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNzk5Ljk2OSkiIGZpbGw9IiM0MTQxNDEiLz4KPC9zdmc+Cg==") no-repeat center;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .natural a:not(.cta_button):not(.js-no-icon)[target="_blank"]::before {
    top: 6px;
    width: 10px;
    height: 10px;
  }
}

/* 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(--margin-offset-lineHeight));
  margin-bottom: calc(20px - var(--margin-offset-lineHeight));
  color: var(--color-plane);
  font-size: var(--fz-root-palmtop);
  font-weight: var(--fw-normal-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-paragraph);
}
@media screen and (min-width: 768px) {
  .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 {
  margin-top: 0;
}
.natural > ul li:last-child,
.natural > .hs_cos_wrapper_type_rich_text > ul 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 {
  list-style-type: decimal;
}

.natural ol li,
.natural > .hs_cos_wrapper_type_rich_text > ol li {
  display: list-item;
  margin-top: calc(20px - var(--margin-offset-lineHeight));
  margin-bottom: calc(20px - var(--margin-offset-lineHeight));
  font-size: var(--fz-root-palmtop);
  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);
  }
}
.natural > ol li:first-child,
.natural > .hs_cos_wrapper_type_rich_text > ol li:first-child {
  margin-top: 0;
}
.natural > ol li:last-child,
.natural > .hs_cos_wrapper_type_rich_text > ol li:last-child {
  margin-bottom: 0;
}

/* pre */
.natural pre {
  margin-top: 30px;
  margin-bottom: 30px;
  padding: 20px 20px 18px;
  border: 1px solid var(--color-pale);
  border-radius: 5px;
  font-size: var(--fz-root-palmtop);
  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.only-one-td table {
  min-width: initial;
}

.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 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;
}
@media screen and (min-width: 768px) {
  .natural table td {
    padding: 15px !important;
    font-size: var(--fz-root-desktop);
  }
}
.natural table tr:not(:first-child) td:first-child {
  background-color: #F2F2F5;
}
.natural table tr:first-of-type td {
  background-color: #E4E5E8;
  font-weight: var(--fw-bold-jp);
}

.natural table td:not(:last-child) {
  border-right: 1px solid var(--color-pale);
}

/* 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://46144360.fs1.hubspotusercontent-na2.net/hubfs/46144360/raw_assets/public/toyota-body/02_EN/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;
  }

  .only-one-td .js-table-scroll__icon {
    display: none;
  }
  .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;
  }
}

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

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

.elevator {
  padding-top: 10px;
}

.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(41,43,60,.6);
  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;
  top: calc(50% - 2px);
  left: 0;
  width: 2px;
  height: 4px;
  background-color: var(--color-point);
  transform: skewX(45deg);
}

.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% - 4px);
}

.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(45deg);
}

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

.elevator__nav__breadcrumb .hs-breadcrumb-menu__item__anchor:is(:hover, :focus),
.elevator__nav__breadcrumb .hs-breadcrumb-menu__item a.hs-breadcrumb-label:is(:hover, :focus),
.elevator__nav__breadcrumb .hs-breadcrumb-menu .hs-breadcrumb-menu-item__anchor:is(:hover, :focus),
.elevator__nav__breadcrumb .hs-breadcrumb-menu .hs-breadcrumb-menu-item a.hs-breadcrumb-label:is(:hover, :focus) {
  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 {
  color: var(--color-main);
  background-color: #ffffff;
}

.footer__above__nav__columns::before {
  content: "";
  position: absolute;
  aspect-ratio: 1 / 1;
  background-image:url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB3aWR0aD0iMTAxMi4xNjYiIGhlaWdodD0iMTAzMC4yOTUiIHZpZXdCb3g9IjAgMCAxMDEyLjE2NiAxMDMwLjI5NSI+CiAgPGRlZnM+CiAgICA8bGluZWFyR3JhZGllbnQgaWQ9ImxpbmVhci1ncmFkaWVudCIgeDE9IjAuMDIyIiB5MT0iMS4wMTYiIHgyPSIwLjUyOSIgeTI9IjAuMTY5IiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCI+CiAgICAgIDxzdG9wIG9mZnNldD0iMCIgc3RvcC1jb2xvcj0iI2ZkMTMxMyIvPgogICAgICA8c3RvcCBvZmZzZXQ9IjAuNTY3IiBzdG9wLWNvbG9yPSIjZjU0NTQ1IiBzdG9wLW9wYWNpdHk9IjAuNDUxIi8+CiAgICAgIDxzdG9wIG9mZnNldD0iMSIgc3RvcC1jb2xvcj0iI2ZmMGYwZiIgc3RvcC1vcGFjaXR5PSIwLjYiLz4KICAgIDwvbGluZWFyR3JhZGllbnQ+CiAgPC9kZWZzPgogIDxlbGxpcHNlIGlkPSLmpZXlhoblvaJfODkwNCIgZGF0YS1uYW1lPSLmpZXlhoblvaIgODkwNCIgY3g9IjEwNC4zODMiIGN5PSIxOTYuMjY4IiByeD0iMTA0LjM4MyIgcnk9IjE5Ni4yNjgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDQ1Ni4wOTggNzMxLjc1NCkgcm90YXRlKC0xMzkpIiBvcGFjaXR5PSIwLjEyMSIgZmlsbD0idXJsKCNsaW5lYXItZ3JhZGllbnQpIi8+Cjwvc3ZnPgo=');
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  filter: blur(18px);
  right: -66%;
  top: 46%;
  width: min(140%, 700px);
}
@media screen and (min-width: 768px) {
  .footer__above__nav__columns::before {
    filter: blur(40px);
    right: -37%;
    top: 45%;
    width: min(100%, 700px);
  }
}
@media screen and (min-width: 1050px) {
  .footer__above__nav__columns::before {
    right: -20%;
    top: -3%;
  }
}

.footer::after {
  content: "";
  position: absolute;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  filter: blur(30px);
  left: -32%;
  top: -10px;
  width: 101%;
  height: 180px;
  background-image:url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB3aWR0aD0iMTE5Mi4wMjkiIGhlaWdodD0iMTEwMi4xMTUiIHZpZXdCb3g9IjAgMCAxMTkyLjAyOSAxMTAyLjExNSI+CiAgPGRlZnM+CiAgICA8bGluZWFyR3JhZGllbnQgaWQ9ImxpbmVhci1ncmFkaWVudCIgeDE9IjAuNTA0IiB5MT0iMC43NTUiIHgyPSIwLjUyOSIgeTI9IjAuMTY5IiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCI+CiAgICAgIDxzdG9wIG9mZnNldD0iMCIgc3RvcC1jb2xvcj0iI2ZmZiIvPgogICAgICA8c3RvcCBvZmZzZXQ9IjAuNjMxIiBzdG9wLWNvbG9yPSIjZDJkZWZhIiBzdG9wLW9wYWNpdHk9IjAuNDUxIi8+CiAgICAgIDxzdG9wIG9mZnNldD0iMSIgc3RvcC1jb2xvcj0iIzRkNjFjMyIgc3RvcC1vcGFjaXR5PSIwLjEwMiIvPgogICAgPC9saW5lYXJHcmFkaWVudD4KICA8L2RlZnM+CiAgPGVsbGlwc2UgaWQ9IualleWGhuW9ol84ODczIiBkYXRhLW5hbWU9IualleWGhuW9oiA4ODczIiBjeD0iMTI2LjMzMyIgY3k9IjMwOS40IiByeD0iMTI2LjMzMyIgcnk9IjMwOS40IiB0cmFuc2Zvcm09Im1hdHJpeCgtMC41NzQsIDAuODE5LCAtMC44MTksIC0wLjU3NCwgOTIxLjkyMiwgNjI1LjAzNykiIG9wYWNpdHk9IjAuNDU5IiBmaWxsPSJ1cmwoI2xpbmVhci1ncmFkaWVudCkiLz4KPC9zdmc+Cg==');
}
@media screen and (min-width: 768px) {
  .footer::after {
    left: -42%;
    top: -2%;
    height: 279px;
  }
}
@media screen and (min-width: 1050px) {
  .footer::after {
    height: 291px;
    left: -53%;
    top: 0;
  }
}

.footer__above__nav {
  overflow: hidden;
}

.footer__above__nav__columns {
  background-color: #ffffff;
  position: relative;
}
@media screen and (min-width: 768px) {
  .footer__above__nav__columns {
    padding: 100px 50px 0px;
    margin: 0 auto;
  }
}
@media screen and (min-width: 1050px) {
  .footer__above__nav__columns {
    padding: 100px 80px 0px;
    max-width: 1250px;
    margin: 0 auto;
  }
}

/* フッターロゴ */

@media screen and (min-width: 1050px) {
  .footer__above__nav__columns__column__item {
    padding-right: 30px;
  }
}

.footer__above__nav__logo {
  text-align: left;
  padding: 0 0 30px;
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .footer__above__nav__logo {
    padding-left: 0;
    padding: 0 0 34px;
  }
}
@media screen and (min-width: 1050px) {
  .footer__above__nav__logo {
    padding: 0;
    margin-left: 0;
    padding: 0;
  }
}

.footer__above__nav__logo__anchor,
.footer__above__nav__logo a {
  display: block;
}

.footer__above__nav__logo__anchor img,
.footer__above__nav__logo a img {
  max-width: 160px;
  padding-right: 14px;
  vertical-align: bottom;
}
@media screen and (min-width: 768px) {
  .footer__above__nav__logo__anchor img,
  .footer__above__nav__logo a img {
    max-width: 170px;
    padding-right: 1px;
  }
}
@media screen and (min-width: 1050px) {
  .footer__above__nav__logo__anchor img,
  .footer__above__nav__logo a img {
  min-width: 100%;
  }
}

.footer__below {
  display: flex;
  flex-direction: column;
  padding: 10px 50px 50px;
  align-items: center;
  background-color: #ffffff;
}
@media screen and (min-width: 768px) {
  .footer__below {
    padding: 41px 0 47px;
    margin: 0 50px;
    border-top: solid 1px var(--color-pale);
  }
}
@media screen and (min-width: 1050px) {
  .footer__below {
    padding: 39px 50px;
    margin: 0 auto;
    max-width: 1250px;
    justify-content: space-between;
    flex-direction: initial;
    align-items: center;
  }
}

/* コピーライト */
.footer__below__copyright {
  padding: 25px 20px 0 20px;
  font-family: var(--font-en);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: .1em;
  line-height: 1.5;
  text-align: center;
  position: relative;
  max-width: 235px;
  background-color: var(--color-bg);
}
@media screen and (min-width: 768px) {
  .footer__below__copyright {
    padding-top: 20px;
    font-size: 1.4rem;
    line-height: 1.9;
    max-width: initial;
  }
}

@media screen and (min-width: 1050px) {
  .footer__below__copyright {
    padding-top: 0;
    padding-bottom: 0;
    margin-right: 25px;
    padding-left: 0;
    padding-right: 0;
    text-align: left;
  }
}

.footer__below__copyright__text {
  font-size: 1rem;
  color: var(--color-plane);
  font-weight: var(--fw-normal-jp);
  font-family: 'PlusJakartaSans', sans-serif;
  display: flex;
  letter-spacing: .02em;
  opacity: .6;
  justify-content: center;
  padding-top: 23px;
}
@media screen and (min-width :768px) {
  .footer__below__copyright__text {
    font-size: 1.1rem;
    width: max-content;
    padding: 0;
    max-width: initial;
    justify-content: inherit;
  }
}

/* ページトップ */
.page-top {
  display: none;
  position: fixed;
  bottom: 5px;
  right: 5px;
  z-index: 99;
}
@media screen and (min-width: 768px) {
  .page-top {
    bottom: 7px;
    right: 15px;
  }
}
@media screen and (min-width: 1050px) {
  .page-top {
    bottom: 30px;
    right: 17px;
  }
}

.page-top__anchor {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  text-align: center;
  font-family: ;
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: .03em;
  line-height: 1.5;
  color: #141622;
  border-radius: 70px;
}
@media screen and (min-width: 768px) {
  .page-top__anchor {
    width: 70px;
    height: 70px;
  }
}
.page-top__anchor__item::before {
  content: '';
  position: absolute;
  border: solid 1px var(--color-point);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 36px;
  height: 36px;
  background-color: #ffffff;
  border-radius: 70px;
  transition: width .3s, height .3s;
}
@media screen and (min-width: 768px) {
  .page-top__anchor__item::before {
    width: 48px;
    height: 48px;
  }
}
@media screen and (min-width: 1050px) {
  .page-top__anchor__item::before {
    width: 56px;
    height: 56px;
  }
}
@media screen and (min-width: 1050px) {
  .page-top__anchor:focus::before,
  .page-top__anchor:hover::before {
    width: 76px;
    height: 76px;
  }
}
.page-top__anchor__inner {
  display: none;
  position: absolute;
  margin-top: 20px;
  z-index: 1;
}
.page-top__anchor__icon {
  display: block;
  position: relative;
  width: 12px;
  height: 12px;
  background-image:url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNy40MTQiIGhlaWdodD0iMTcuNDE0IiB2aWV3Qm94PSIwIDAgMTcuNDE0IDE3LjQxNCI+CiAgPGcgaWQ9IuOCsOODq+ODvOODl180MDc4NCIgZGF0YS1uYW1lPSLjgrDjg6vjg7zjg5cgNDA3ODQiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAuNzA3IDEuNDExKSI+CiAgICA8cGF0aCBpZD0i44OR44K5XzExMDgxIiBkYXRhLW5hbWU9IuODkeOCuSAxMTA4MSIgZD0iTTAsOCw4LDBsOCw4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgwIDAuMDAzKSIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMTExOTg3IiBzdHJva2Utd2lkdGg9IjIiLz4KICAgIDxwYXRoIGlkPSLjg5HjgrlfMTEwODIiIGRhdGEtbmFtZT0i44OR44K5IDExMDgyIiBkPSJNMCwwVjE2IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSg4LjAwMSAwKSIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMTExOTg3IiBzdHJva2Utd2lkdGg9IjIiLz4KICA8L2c+Cjwvc3ZnPgo=');
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  z-index: 1;
  transition: transform .5s;
}
@media screen and (min-width: 768px) {
  .page-top__anchor__icon {
    width: 14px;
    height: 14px;
  }
}
@media screen and (min-width: 1050px) {
  .page-top__anchor__icon {
    width: 16px;
    height: 16px;
  }
  .page-top__anchor:hover .page-top__anchor__icon {
    transform: translateY(-3px);
  }
  .page-top__anchor:focus .page-top__anchor__icon {
    transform: translateY(-3px);
  }
}

@media screen and (min-width: 1050px) {
  .page-top__anchor__inner {
    display: block;
    margin-bottom: -65px;
  }
}

.page-top__anchor__inner__icon .page-top__anchor__inner__icon__path {
  fill: #ffffff;
}
/* ヘッダー */
.header {
  position: relative;
  width: 100%;
  z-index: 99;
  background-color: #fff;
  transition: .3s;
}
.header--no-nav {
  position: relative;
}
.container.header__container {
  padding-left: 14px;
  padding-right: 0;
}
@media screen and (min-width: 768px) {
  .container.header__container {
    padding-left: 25px;
  }
}
@media screen and (min-width: 1050px) {
  .container.header__container {
    padding-left: 35px;
  }
}
.header__columns {
  display: flex;
  align-items: center;
  min-height: 60px;
}
@media screen and (min-width: 768px) {
  .header__columns {
    min-height: 75px;
    justify-content: space-between;
  }
}
@media screen and (min-width: 1050px) {
  .header__columns {
    min-height: auto;
  }
  .header--no-nav .header__columns {
    min-height: 90px;
  }
}

.header__columns__column:nth-child(1) {
  display: flex;
  align-items: center;
  width: 100%;
}
@media screen and (min-width: 1050px) {
  /* ロゴ画像 */
  .header__columns__column:nth-child(1) {
    width: auto;
  }
}

.header__logo__inner--white {
  display: none;
}
.header__logo,
.header__main__logo {
  position: relative;
  width: 140px;
  height: 20.5px;
}
.header__logo {
  margin-top: -5px;
}
.header__main__logo {
  margin: 17px 0 22px 13px;
}
@media screen and (min-width: 768px) {
  .header__logo,
  .header__main__logo {
    width: 160px;
    height: 27px;
  }
  .header__logo {
    margin-top: 0;
  }
  .header__main__logo {
    margin: 24px 0 24px 25px;
  }
}
@media screen and (min-width: 1050px) {
  .header__logo,
  .header__main__logo {
    width: 178px;
    height: 30.5px;
  }
  .header__main__logo {
    display: none;
  }
}
.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;
  left: 0;
  width: 100%;
  padding-top: 0;
  background-color: #fff;
  pointer-events: none;
  transition: opacity .3s;
  pointer-events: auto;
  box-sizing: border-box;
}
@media screen and (min-width: 768px) {
  .header__main {
    padding: 0;
  }
}
@media screen and (min-width: 1050px) {
  .header__main {
    opacity: 1;
    visibility: visible;
    position: static;
    padding: 0;
    background-color: #fff;
    pointer-events: auto;
  }
}

.header__main.is-active {
  opacity: 1;
  visibility: visible;
  position: fixed;
  top: 0;
  left: 0;
  pointer-events: auto;
  z-index: 100;
}

/* ハンバーガーナビ */
.header__hamburger {
  position: absolute;
  top: 0;
  right: 0;
  width: 60px;
  height: 60px;
  padding: 0;
  border: none;
  border-radius: 0;
  background-color: transparent;
  appearance: none;
  cursor: pointer;
  z-index: 101;
}
@media screen and (min-width: 768px) {
  .header__hamburger {
    width: 75px;
    height: 75px;
  }
}
@media screen and (min-width: 1050px) {
  .header__hamburger {
    display: none;
  }
}

.header__hamburger__inner {
  display: block;
  position: absolute;
  top: calc(50% - 6px);
  left: calc(50% - 8px);
}
@media screen and (min-width: 768px) {
  .header__hamburger__inner {
    left: calc(50% - 15px);
    top: calc(50% - 8px);
  }
  .is-active .header__hamburger__inner {
    left: calc(50% - 9px);
  }
}
.header__hamburger.is-active .header__hamburger__inner__line{
  background-color: var(--color-main);
}
.header__hamburger__inner__line {
  display: block;
  position: absolute;
  left: 0;
  height: 1px;
  width: 22px;
  background-color: var(--color-point);
  transition: all .3s;
}
@media screen and (min-width: 768px) {
  .header__hamburger__inner__line {
    width: 22px;
  }
}

.header__hamburger__inner__line:nth-child(1) {
  top: -2px;
}
.header__hamburger__inner__line:nth-child(2) {
  top: 5px;
}
@media screen and (min-width: 768px) {
  .header__hamburger__inner__line:nth-child(2) {
    top: 7px;
  }
}
.header__hamburger__inner__line:nth-child(3) {
  top: 12px;
}
@media screen and (min-width: 768px) {
  .header__hamburger__inner__line:nth-child(3) {
    top: 16px;
  }
}

.is-active .header__hamburger__inner__line:nth-child(1),
.is-active .header__hamburger__inner__line:nth-child(3) {
  width: 21px;
  left: -2px;
}
.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: 768px) {
  .is-active .header__hamburger__inner__line:nth-child(1),
  .is-active .header__hamburger__inner__line:nth-child(3) {
    width: 25px;
  }
  .is-active .header__hamburger__inner__line:nth-child(3) {
    top: 5px;
  }
}

/* サイト内検索 */
.header__search {
  color: #fff;
  border: 1px solid;
  border-bottom: none;
  border-top: none;
  border-color: var(--color-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: .3s;
  min-width: 47px;
  right: 57px;
  top: calc(50% - 13px);
  position: absolute;
  height: 24px;
}
.header__search__inner {
  width: 100%;
  height: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.header__search__inner::after {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNC41NjYiIGhlaWdodD0iMTQuNTY2IiB2aWV3Qm94PSIwIDAgMTQuNTY2IDE0LjU2NiI+PGcgZmlsbD0iIzExMTk4NyI+PHBhdGggZD0iTTYuNSAxLjZhNC45IDQuOSAwIDEgMCA0LjkgNC45IDQuOTA2IDQuOTA2IDAgMCAwLTQuOS00LjltMC0xLjZBNi41IDYuNSAwIDEgMSAwIDYuNSA2LjUgNi41IDAgMCAxIDYuNSAwIi8+PHBhdGggZD0ibTEzLjQzNCAxNC41NjYtMy0zIDEuMTMyLTEuMTMyIDMgM1oiLz48L2c+PC9zdmc+);
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  padding: 7.5px;
  height: 100%;
  display: inline-block;
}
@media screen and (min-width: 768px) {
  .header__search {
    min-width: 55px;
    right: 72px;
  }
  .header__search__inner::after {
    padding: 8.5px;
  }
}
@media screen and (min-width: 1050px) {
  .header__search {
    display: none;
  }
}

/* テンプレート独自のスタイル */
/* blog */

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

.content--blog-post {
  position: relative;
  overflow: hidden;
}

.content--blog-post::before {
  content: "";
  position: absolute;
  top: 0;
  left: -45px;
  width: 229px;
  height: 209px;
  background: radial-gradient(rgba(77,97,195,.1), rgba(210,222,250,.45),rgba(255,255,255,1));
  border-radius: 100%;
  filter: blur(4.4rem);
  opacity: .28;
  transform: rotate(55deg);
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .content--blog-post::before {
    top: -45px;
    left: -60px;
    width: 424px;
    height: 423px;
  }
}
@media screen and (min-width: 1050px) {
  .content--blog-post::before {
    left: -70px;
  }
}

.content--blog-post::after {
  content: "";
  position: absolute;
  top: 254px;
  right: -89px;
  width: 224px;
  height: 125px;
  background: radial-gradient(rgba(255,15,15,.8), rgba(245,69,69,.65),rgba(253,19,19,0));
  border-radius: 100%;
  filter: blur(4.4rem);
  opacity: .05;
  transform: rotate(220deg);
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .content--blog-post::after {
    top: 337px;
    right: -140px;
    width: 360px;
    height: 176px;
  }
}
@media screen and (min-width: 1050px) {
  .content--blog-post::after {
    top: 256px;
    right: -100px;
  }
}

/* container */
.container.blog-container,
.content--blog-listing .hero .container {
  max-width: calc(1130px + 20px * 2);
  @media screen and (min-width: 768px) {
    & {
      max-width: calc(1130px + 30px * 2);
    }
  }
  @media screen and (min-width: 1050px) {
    & {
      max-width: calc(1130px + 100px * 2);
    }
  }
}

/* blog contents area */
@media screen and (min-width: 1050px) {
  .blog-content {
    display: flex;
    margin-left: -35px;
    margin-right: -35px;
  }
}

.blog-content__main {
  width: 100%;
}
@media screen and (min-width: 1050px) {
  .blog-content__main {
    box-sizing: border-box;
    max-width: 820px;
    padding-left: 35px;
    padding-right: 35px;
  }
}


/* === article / 記事詳細 */
.content--blog-post .elevator {
  padding-top: 15px;
}
@media screen and (min-width: 768px) {
  .content--blog-post .elevator {
    padding-top: 20px;
  }
}

.content--blog-post {
  padding-bottom: 5px;
}

.section.section--blog-post {
  margin-top: 50px;
}
@media screen and (min-width: 768px) {
  .section.section--blog-post {
    margin-top: 70px;
  }
}

.blog-article__head__date {
  display: block;
  color: rgba(41,43,60,.5);
  font-family: var(--font-en);
  font-size: 1.3rem;
  font-weight: 500;
  letter-spacing: .05em;
  line-height: var(--lh-heading);
}
@media screen and (min-width: 768px) {
  .blog-article__head__date {
    font-size: 1.6rem;
  }
}

.blog-article__head__heading {
  margin-top: 6px;
  color: var(--color-main);
  font-size: 2.0rem;
  font-weight: 600;
  letter-spacing: var(--ls-root);
  line-height: 1.5em;
}
@media screen and (min-width: 768px) {
  .blog-article__head__heading {
    font-size: 2.8rem;
  }
}

.blog-article__head__category-list {
  margin-top: 15px;
  margin-right: -5px;
  margin-left: -5px;
  margin-bottom: -5px;
}
@media screen and (min-width: 768px) {
  .blog-article__head__category-list {
    margin-top: 20px;
  }
}

.blog-article__head__category-list__item {
  display: inline-block;
  min-width: 100px;
  margin: 5px;
}

.blog-article__head__category-list__item__anchor {
  display: block;
  background-color: var(--color-bg);
  color: rgba(41,43,60,.7);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: .05em;
  text-align: center;
  padding: 6px 15px 5px;
  border-radius: 12px;
  -webkit-transition: .3s;
  transition: .3s;
}
@media screen and (min-width: 768px) {
  .blog-article__head__category-list__item__anchor {
    padding: 7px 15px 6px;
    font-size: 1.3rem;
  }
}
@media screen and (min-width: 1050px) {
  .blog-article__head__category-list__item__anchor:is(:hover, :focus) {
    background-color: #E4E5E8;
    color: rgba(20,22,34,.7);
  }
}

.blog-article__head__thumbnail {
  margin: 25px -20px 45px;
}
@media screen and (min-width: 768px) {
  .blog-article__head__thumbnail {
    margin: 30px -50px 50px;
  }
}
@media screen and (min-width: 1050px) {
  .blog-article__head__thumbnail {
    margin-right: 0;
    margin-left: 0;
  }
}

.blog-article__head__thumbnail img {
  width: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  border-radius: 10px;
}

/* blog-article__body__content */
.blog-article__body__content.natural {
  padding-bottom: 0.6em; /* 最後のコンテンツが微妙に切れてしまうため対策 */
}

.blog-article__body__content h2,
.blog-article__body__summary__body h2 {
  margin-top: calc(45px - var(--margin-offset-lineHeight));
  margin-bottom: calc(25px - var(--margin-offset-lineHeight));
  padding: 12px 15px 10px;
  border-left: 3px solid var(--color-point);
  background-color: var(--color-bg);
  color: var(--color-plane);
  font-size: 2.0rem;
  font-weight: var(--fw-bold-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
}
@media screen and (min-width: 768px) {
  .blog-article__body__content h2,
  .blog-article__body__summary__body h2 {
    margin-top: calc(60px - var(--margin-offset-lineHeight));
    margin-bottom: calc(30px - var(--margin-offset-lineHeight));
    padding: 9px 20px;
    border-left: 4px solid var(--color-point);
    font-size: 2.5rem;
  }
}
.blog-article__body__content h2:first-child,
.blog-article__body__summary__body h2:first-child {
  margin-top: 0;
}
.blog-article__body__content h2:last-child,
.blog-article__body__summary__body h2:last-child {
  margin-bottom: 0;
}

.blog-article__body__content h3,
.blog-article__body__summary__body h3 {
  position: relative;
  margin-top: calc(35px - var(--margin-offset-lineHeight));
  margin-bottom: calc(25px - var(--margin-offset-lineHeight));
  padding: 1px 11px 1px;
  color: var(--color-plane);
  font-size: 1.8rem;
  font-weight: var(--fw-bold-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
  border-left: 2px solid var(--color-point);
}
@media screen and (min-width: 768px) {
  .blog-article__body__content h3,
  .blog-article__body__summary__body h3 {
    padding: 1px 13px 1px;
    margin-top: calc(45px - var(--margin-offset-lineHeight));
    margin-bottom: calc(30px - var(--margin-offset-lineHeight));
    font-size: 2.2rem;
    border-left: 3px solid var(--color-point);
  }
}
.blog-article__body__content h3:first-child,
.blog-article__body__summary__body h3:first-child {
  margin-top: 0;
}
.blog-article__body__content h3:last-child,
.blog-article__body__summary__body h3:last-child {
  margin-bottom: 0;
}

.blog-article__body__content h3::before,
.blog-article__body__summary__body h3::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - var(--lh-heading)) * .5em);
}
.blog-article__body__content h4,
.blog-article__body__summary__body h4 {
  margin-top: calc(35px - var(--margin-offset-lineHeight));
  margin-bottom: calc(20px - var(--margin-offset-lineHeight));
  color: var(--color-plane);
  font-size: 1.7rem;
  font-weight: var(--fw-bold-jp);
  letter-spacing: .15em;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .blog-article__body__content h4,
  .blog-article__body__summary__body h4 {
    margin-top: calc(40px - var(--margin-offset-lineHeight));
    margin-bottom: calc(25px - var(--margin-offset-lineHeight));
    font-size: 1.8rem;
  }
}
.blog-article__body__content h4:first-child,
.blog-article__body__summary__body h4:first-child {
  margin-top: 0;
}
.blog-article__body__content h4:last-child,
.blog-article__body__summary__body h4:last-child {
  margin-bottom: 0;
}

.blog-article__body__content h4::before,
.blog-article__body__summary__body h4::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - var(--lh-heading)) * .5em);
}
.blog-article__body__content h4::after,
.blog-article__body__summary__body h4::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - var(--lh-heading)) * .5em);
}


.blog-article__body__content p,
.blog-article__body__summary__body p {
  margin-top: calc(35px - var(--margin-offset-lineHeight));
  margin-bottom: calc(20px - var(--margin-offset-lineHeight));
  color: var(--color-plane);
  font-size: 1.5rem;
  letter-spacing: var(--ls-root);
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .blog-article__body__content p,
  .blog-article__body__summary__body p {
    margin-top: calc(40px - var(--margin-offset-lineHeight));
    margin-bottom: calc(25px - var(--margin-offset-lineHeight));
    font-size: 1.6rem;
  }
}
.blog-article__body__content p:first-child,
.blog-article__body__summary__body p:first-child {
  margin-top: 0;
}
.blog-article__body__content p:last-child,
.blog-article__body__summary__body p:last-child {
  margin-bottom: 0;
}

.blog-article__body__content p::before,
.blog-article__body__summary__body p::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - var(--lh-heading)) * .5em);
}
.blog-article__body__content p::after,
.blog-article__body__summary__body p::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - var(--lh-heading)) * .5em);
}


.blog-article__body__content strong,
.blog-article__body__summary__body strong {
  font-weight: var(--fw-bold-jp);
}

.blog-article__body__content em,
.blog-article__body__summary__body em {
  font-style: italic;
}

.blog-article__body__content img,
.blog-article__body__summary__body img {
  display: block;
  width: 100%;
  max-width: 100%;
  margin: 20px auto;
  border-radius: 10px;
}
@media screen and (min-width: 768px) {
  .blog-article__body__content img,
  .blog-article__body__summary__body img {
    max-width: 650px !important;
    margin-top: 30px;
    margin-bottom: 30px;
  }
}
.blog-article__body__content img:first-child,
.blog-article__body__summary__body img:first-child {
  margin-top: 0;
}
.blog-article__body__content img:last-child,
.blog-article__body__summary__body img:last-child {
  margin-bottom: 0;
}

/* まとめ */
.blog-article__body__summary {
  margin-top: 45px;
  border: 1px solid var(--color-pale);
  border-radius: 5px;
}
@media screen and (min-width: 768px) {
  .blog-article__body__summary {
    margin-top: 60px;
  }
}

.blog-article__body__summary__head {
  padding: 11px 20px 10px;
  border-radius: 5px 5px 0 0;
  background-color: var(--color-bg);
}
@media screen and (min-width: 768px) {
  .blog-article__body__summary__head {
    padding: 14px 30px;
  }
}

.blog-article__body__summary__head__heading {
  color: var(--color-plane);
  font-size: 1.8rem;
  font-weight: 600;
  letter-spacing: var(--ls-root);
}
@media screen and (min-width: 768px) {
  .blog-article__body__summary__head__heading {
    font-size: 2.0rem;
  }
}

.blog-article__body__summary__body {
  padding: 17px 20px;
}
@media screen and (min-width: 768px) {
  .blog-article__body__summary__body {
    padding: 27px 30px;
  }
}

/* cta */
.blog-article__body__cta {
  margin-top: 45px;
  margin-bottom: 45px;
}
@media screen and (min-width: 768px) {
  .blog-article__body__cta {
    margin-top: 60px;
    margin-bottom: 60px;
  }
}
.blog-article__body__cta:first-child {
  margin-top: 0;
}
.blog-article__body__cta:last-child {
  margin-bottom: 45px;
}

.blog-article__body__cta .container {
  max-width: 100%;
  padding-right: inherit;
  padding-left: inherit;
}

.natural .blog-article__body__cta a {
  border-bottom: none;
}
.natural .blog-article__body__cta a[target="_blank"] {
  padding-left: 50px;
  border-bottom: none;
}
@media screen and (max-width: 767px) {
  .natural .blog-article__body__cta a[target="_blank"] {
    padding-left: 20px;
  }
}
.natural .blog-article__body__cta a[target="_blank"]::before {
  content: none;
}

.blog-article__body__cta .cta-text-wrap {
  padding-bottom: 0;
}
.blog-article__body__cta .cta-text-wrap::before {
  content: none;
}

.blog-article__body__cta__anchor {
  display: block;
}

.blog-article__body__cta__content img {
  width: 100%;
  max-width: 100%;
  margin-right: auto;
  margin-left: auto;
  vertical-align: middle;
  border-radius: 10px;
}

/* 前の記事 / 次の記事 */
.blog-article__foot {
  margin-top: 45px;
  padding-top: 15px;
  border-top: 1px solid var(--color-pale);
}
@media screen and (min-width: 768px) {
  .blog-article__foot {
    margin-top: 60px;
    padding-top: 20px;
  }
}

@media screen and (min-width: 768px) {
  .blog-article__foot__nav__list {
    display: flex;
    margin-right: -30px;
    margin-left: -30px;
  }
  .blog-article__foot__nav__list__item {
    width: 50%;
    padding-left: 30px;
    padding-right: 30px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
}

.blog-article__foot__nav__list__item--prev {
  margin-right: auto;
}
.blog-article__foot__nav__list__item--next {
  margin-top: 20px;
  margin-left: auto;
  padding-top: 20px;
  border-top: 1px dotted var(--color-pale);
}
@media screen and (min-width: 768px) {
  .blog-article__foot__nav__list__item--next {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
    border-left: 1px dotted var(--color-pale);
  }
}

.blog-article__foot__nav__list__item--prev .blog-article__foot__nav__list__item__heading {
  text-align: left;
}
.blog-article__foot__nav__list__item--next .blog-article__foot__nav__list__item__heading {
  text-align: left;
}
@media screen and (min-width: 768px) {
  .blog-article__foot__nav__list__item--next .blog-article__foot__nav__list__item__heading {
    text-align: right;
  }
}

.blog-article__foot__nav__list__item__heading {
  color: var(--color-plane);
  font-size: 1.6rem;
  font-weight: 600;
  letter-spacing: var(--ls-root);
}
@media screen and (min-width: 768px) {
  .blog-article__foot__nav__list__item__heading {
    display: block;
    font-size: 1.7rem;
  }
}
.blog-article__foot__nav__list__item__block {
  display: flex;
  align-items: flex-start;
  margin-top: 15px;
}

.blog-article__foot__nav__list__item__block__image {
  width: 100%;
  max-width: 110px;
  aspect-ratio: 16/9;
}
@media screen and (min-width: 768px) {
  .blog-article__foot__nav__list__item__block__image {
    max-width: 120px;
  }
}
.blog-article__foot__nav__list__item__block__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 5px;
}

.blog-article__foot__nav__list__item__block__heading {
  width: 100%;
  margin-left: 15px;
  font-size: 1.3rem;
  font-weight: 500;
  letter-spacing: var(--ls-root);
  line-height: var(--lh-blog);
  color: var(--color-plane);
  transition: color .3s;
}
@media screen and (min-width: 768px) {
  .blog-article__foot__nav__list__item__block__heading {
    max-width: 210px;
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 1050px) {
  a:is(:hover, :focus) .blog-article__foot__nav__list__item__block__heading {
    color: rgba(20, 22, 34, .6);
  }
}

.blog-article__foot__back {
  margin-top: 60px;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .blog-article__foot__back {
    margin-top: 80px;
  }
}

.blog-article__foot__back__anchor {
  position: relative;
  padding-left: 38px;
  color: var(--color-plane);
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: var(--ls-root);
  line-height: 1.4;
  transition: color .3s;
}

.blog-article__foot__back__anchor__icon {
  display: block;
  position: absolute;
  top: calc(50% - 14px);
  left: 0;
  width: 28px;
  height: 28px;
  transform: rotate(180deg);
}
.blog-article__foot__back__anchor__icon__circle__bg {
  fill: transparent;
  transition: fill .3s;
}
.blog-article__foot__back__anchor__icon__circle__border,
.blog-article__foot__back__anchor__icon__circle__arrow {
  fill: var(--color-main);
  transition: fill .3s;
}
@media screen and (min-width: 1050px) {
  .blog-article__foot__back__anchor:is(:hover, :focus) {
    color: var(--color-point);
  }
  .blog-article__foot__back__anchor:is(:hover, :focus) .blog-article__foot__back__anchor__icon__circle__bg {
    fill: var(--color-point);
  }
  .blog-article__foot__back__anchor:is(:hover, :focus) .blog-article__foot__back__anchor__icon__circle__border {
    fill: transparent;
  }
  .blog-article__foot__back__anchor:is(:hover, :focus) .blog-article__foot__back__anchor__icon__circle__arrow {
    fill: #fff;
  }
}
/* article / 記事詳細 === */


/* === article / 記事一覧 */

/* blog listing hero */
.hero--blog-listing .hero__image {
  background-image: url(https://46144360.fs1.hubspotusercontent-na2.net/hubfs/46144360/raw_assets/public/toyota-body/02_EN/assets/images/common/hero.jpg);
}
@media only screen and (max-width: 767px) {
  .hero--blog-listing .hero__image {
    background-position: 50% 50%;
  }
}

@media screen and (min-width: 768px) {
  .blog-content__main__article-list {
    display: flex;
    flex-wrap: wrap;
    margin-right: -20px;
    margin-left: -20px;
  }
}

@media screen and (min-width: 768px) {
  .blog-content__main__article-list__item {
    box-sizing: border-box;
    width: 50%;
    padding-right: 20px;
    padding-left: 20px;
  }
}
.blog-content__main__article-list__item:nth-child(n+2) {
  margin-top: 40px;
}
@media screen and (min-width: 768px) {
  .blog-content__main__article-list__item:nth-child(n+2) {
    margin-top: 0;
  }
}
@media screen and (min-width: 768px) {
  .blog-content__main__article-list__item:nth-child(n+3) {
    margin-top: 40px;
  }
}

.blog-content__main__article-list__item__block {
  display: block;
}

/* blog list item head */
.blog-content__main__article-list__item__block__image {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
  aspect-ratio: 71 / 40;
  border-radius: 10px;
}
.blog-content__main__article-list__item__block__image__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(1);
  width: 100%;
  height: 100%;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  transition: .3s;
}
@media screen and (min-width: 1050px) {
  .blog-content__main__article-list__item__block a:is(:hover, :focus) .blog-content__main__article-list__item__block__image__inner {
    transform: translate(-50%, -50%) scale(1.05);
  }
}

.blog-content__main__article-list__item__block__date {
  display: block;
  margin-top: 15px;
  color: rgba(41,43,60,.5);
  font-family: var(--font-en);
  font-size: 1.3rem;
  font-weight: var(--fw-normal-en);
  letter-spacing: .05em;
  transition: color .3s;
}
@media screen and (min-width: 768px) {
  .blog-content__main__article-list__item__block__date {
    margin-top: 17px;
    font-size: 1.4rem;
  }
}

/* blog list item body */
.blog-content__main__article-list__item__block__title {
  display: block;
  margin-top: 5px;
  color: var(--color-main);
  font-size: 1.7rem;
  font-weight: var(--fw-bold-jp);
  letter-spacing: var(--ls-root);
  line-height: var(--lh-blog);
  transition: color .3s;
}
@media screen and (min-width: 768px) {
  .blog-content__main__article-list__item__block__title {
    margin-top: 10px;
    font-size: 1.8rem;
  }
}
@media screen and (min-width: 1050px) {
  .blog-content__main__article-list__item__block a:is(:hover, :focus) .blog-content__main__article-list__item__block__title {
    color: rgba(20,22,34,.6);
  }
}

.blog-content__main__article-list__item__block__category-list {
  margin: 13px -5px -5px;
}
.blog-content__main__article-list__item__block__category-list__item {
  display: inline-block;
  min-width: 100px;
  margin: 5px;
}
.blog-content__main__article-list__item__block__category-list__item__anchor {
  display: block;
  padding: 5px 15px 6px;
  text-align: center;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: .05em;
  border-radius: 12px;
  background-color: var(--color-bg);
  color: rgba(41,43,60,.7);
  transition: .3s;
}
@media screen and (min-width: 1050px) {
  .blog-content__main__article-list__item__block__category-list__item__anchor:is(:hover, :focus) {
    background-color: #E4E5E8;
    color: rgba(20,22,34,.7);
  }
}

.blog-content__main__pager {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 50px;
}
@media screen and (min-width: 768px) {
  .blog-content__main__pager {
    margin-top: 75px;
  }
}

.blog-content__main__pager__item:not(:first-child) {
  margin-left: 15px;
}

.blog-content__main__pager__item__anchor {
  display: block;
  font-size: 1.7rem;
  font-weight: 500;
  font-family: var(--font-en);
  letter-spacing: .1em;
  color: var(--color-plane);
  padding-left: 5px;
  padding-right: 5px;
  -webkit-transition: color .3s;
  transition: color .3s;
}
@media screen and (min-width: 768px) {
  .blog-content__main__pager__item__anchor {
    font-size: 1.8rem;
  }
}
/* :focus & :hover */
@media screen and (min-width: 1050px) {
  .blog-content__main__pager__item__anchor:is(:hover, :focus) {
    color: rgba(20,22,34,.7);
  }
}
.blog-content__main__pager__item.is-current .blog-content__main__pager__item__anchor {
  color: rgba(20, 22, 34, .5);
}

.blog-content__main__pager__item__anchor__icon {
  display: block;
  width: 24px;
  height: 24px;
}
@media screen and (min-width: 768px) {
  .blog-content__main__pager__item__anchor__icon {
    width: 28px;
    height: 28px;
  }
}

.blog-content__main__pager__item__anchor--prev,
.blog-content__main__pager__item__anchor--next {
  position: relative;
}
.blog-content__main__pager__item__anchor--prev::before,
.blog-content__main__pager__item__anchor--next::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  background: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI2IiBoZWlnaHQ9IjgiIHZpZXdCb3g9IjAgMCA2IDgiPgogIDxwYXRoIGlkPSJhcnJvdyIgZD0iTTAsOCw0LDQsMCwwSDJMNiw0LDIsOFoiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDYgOCkgcm90YXRlKDE4MCkiIGZpbGw9IiNmZmYiLz4KPC9zdmc+Cg==');
  width: 6px;
  height: 8px;
  transition: background .3s;
}
.blog-content__main__pager__item__anchor--next::before {
  transform: translate(-50%,-50%) rotate(180deg);
}

.blog-content__main__pager__item__anchor__icon__circle {
  fill: var(--color-point);
  transition: fill .3s;
}
@media screen and (min-width: 1050px) {
  :is(a:hover, a:focus) .blog-content__main__pager__item__anchor__icon__circle {
    fill: var(--color-sub);
  }
}

/* blog list side menu */
.blog-content__aside {
  width: 100%;
  margin-top: 60px;
}
@media screen and (min-width: 1050px) {
  .blog-content__aside {
    box-sizing: border-box;
    max-width: 380px;
    margin-top: 0;
    padding-right: 35px;
    padding-left: 35px;
  }
}

.blog-content__aside__magazine {
  max-width: 450px;
  margin-left: auto;
  margin-right: auto;
}

/* blog list side menu */
.blog-content__aside {
  width: 100%;
  margin-top: 60px;
}
@media screen and (min-width: 768px) {
  .blog-content__aside {
    margin-top: 80px;
  }
}
@media screen and (min-width: 1050px) {
  .blog-content__aside {
    box-sizing: border-box;
    max-width: 380px;
    margin-top: 0;
    padding-right: 35px;
    padding-left: 35px;
  }
}

.blog-content__aside__magazine {
  max-width: 450px;
  margin-left: auto;
  margin-right: auto;
}

.blog-content__aside__magazine a {
  display: grid;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  min-height: 134px;
  padding: 22px 20px 18px;
  background-color: var(--color-bg);
  transition: opacity .3s;
}
@media screen and (min-width: 768px) {
  .blog-content__aside__magazine a {
    min-height: 180px;
  }
}
@media screen and (min-width: 1050px) {
  .blog-content__aside__magazine a {
    min-height: 124px;
  }
}
/* :focus & :hover */
@media screen and (min-width: 1050px) {
  .blog-content__aside__magazine a:is(:hover, :focus) {
    opacity: .6;
  }
}

.blog-content__aside__magazine__inner {
  display: block;
  color: #05A235;
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: .1em;
  line-height: 1.5;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .blog-content__aside__magazine__inner {
    font-size: 2.4rem;
  }
}

/* side menu heading */
.blog-content__aside__heading {
  position: relative;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-pale);
  color: var(--color-plane);
  font-weight: 600;
  font-size: 1.8rem;
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
}

.blog-content__aside__heading {
  margin-top: 40px;
}

.blog-content__aside__heading::before {
  content: "";
  background-color: var(--color-point);
  height: 1px;
  width: 75px;
  bottom: -1px;
  left: 0;
  position: absolute;
}
.blog-content__aside__heading.blog-content__aside__heading--recent::before {
  background-color: var(--color-sub);
}
@media screen and (min-width: 1050px) {
  .blog-content__aside__heading.blog-content__aside__heading--popular {
    margin-top: 0;
  }
}

.blog-content__aside__article-list {
  margin-top: 12px;
}
@media screen and (min-width: 768px) {
  .blog-content__aside__article-list {
    margin-top: 17px;
  }
}

.blog-content__aside__article-list__item:not(:first-child) {
  margin-top: 11px;
  padding-top: 12px;
  border-top: 1px dotted var(--color-pale);
}

.blog-content__aside__article-list__item:last-child {
  padding-bottom: 11px;
  border-bottom: 1px dotted var(--color-pale);
}
@media screen and (min-width: 768px) {
  .blog-content__aside__article-list__item:not(:first-child) {
    margin-top: 19px;
    padding-top: 17px;
  }
  .blog-content__aside__article-list__item:last-child {
    padding-bottom: 19px;
  }
}
@media screen and (min-width: 1050px) {
  .blog-content__aside__article-list__item:not(:first-child) {
    margin-top: 15px;
  }
  .blog-content__aside__article-list__item:last-child {
    padding-bottom: 15px;
  }
}

.blog-content__aside__article-list__item__block {
  display: flex;
}

.blog-content__aside__article-list__item__block__head {
  width: 100%;
  max-width: 100px;
}

.blog-content__aside__article-list__item__block__head__image {
  position: relative;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 5px;
}

.blog-content__aside__article-list__item__block__head__image::before {
  content: "";
  display: block;
  padding-bottom: 56%;
}

.blog-content__aside__article-list__item__block__head__date {
  display: block;
  margin-top: 10px;
  color: rgba(41,43,60,.5);
  font-family: var(--font-en);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: .05em;
  transition: color .3s;
}
@media screen and (min-width: 768px) {
  .blog-content__aside__article-list__item__block__head__date {
    font-size: 1.3rem;
  }
}

.blog-content__aside__article-list__item__block__body {
  width: 100%;
  margin-left: 15px;
}
@media screen and (min-width: 1050px) {
  .blog-content__aside__article-list__item__block__body {
    max-width: 195px;
  }
}

.blog-content__aside__article-list__item__block__body__title {
  color: var(--color-plane);
  font-size: 1.3rem;
  font-weight: 500;
  letter-spacing: var(--ls-root);
  line-height: var(--lh-blog);
  transition: color .3s;
}
@media screen and (min-width: 768px) {
  .blog-content__aside__article-list__item__block__body__title {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 1050px) {
  :is(a:hover, a:focus) .blog-content__aside__article-list__item__block__body__title {
    color: rgba(20,22,34,.6);
  }
}
/* article / 記事一覧 === */
/* lp */

/* === Offset HubSpot default style */

/* 複数カラム時（MAX:3カラム） */
.lp-form form :is(.form-columns-2, .form-columns-3) .hs-form-field {
  float: none;
  width: 100%;
}

/* .input */
.lp-form form .hs-form-field > .input {
  margin-right: 0;
}
.lp-form form .hs-form-field > .input .hs-input:not(input[type="checkbox"], input[type="radio"]) {
  float: none;
  width: 100% !important;
}
.lp-form form .hs-form-field.hs-fieldtype-booleancheckbox .input input[type="checkbox"] {
  float: none;
}
.lp-form form .legal-consent-container .hs-form-booleancheckbox-display input {
  float: none;
}
@media screen and (min-width: 768px) {
  .lp-form form .legal-consent-container .hs-form-booleancheckbox-display input {
    margin-top: 6px;
  }
}
/* 電話番号＋国別コード時のSP表示 */
@media (max-device-width: 480px) and (min-device-width: 320px), (max-width: 400px) {
  .lp-form form > .hs-phone > .input > .hs-fieldtype-intl-phone.hs-input > select.hs-input {
    width: 100% !important;
  }
  .lp-form form > .hs-phone > .input > .hs-fieldtype-intl-phone.hs-input > input.hs-input {
    width: 100% !important;
  }
}

/* Offset HubSpot default style === */


/* === Original form style */

main.content--lp {
  padding-bottom: 80px;
}
@media screen and (min-width: 768px) {
  main.content--lp {
    padding-bottom: 120px;
  }
}

/* === variables */
.lp-form {
  --select-max-width: 350px; /* select要素の最大幅 */
  --line-margin-top: 40px; /* 行のmargin-top */
  --line-margin-top-sp: 30px; /* 行のmargin-top(SP) */
  --input-error-color: #CB0303; /* エラーテキストの文字色 */
}

/* === wrapper */
.content--lp .dnd-section-color {
  margin-bottom: 60px;
  padding-bottom: 0;
}
@media screen and (min-width: 768px) {
  .content--lp .dnd-section-color {
    margin-bottom: 80px;
    padding-bottom: 0;
  }
}

.lp-form {
  margin-top: 60px;
}
@media screen and (min-width: 768px) {
  .lp-form {
    margin-top: 80px;
  }
}

/* === form parts */
/* form fieldset (フォームの行) */
.lp-form form fieldset {
  max-width: none;
}
.lp-form form fieldset:not(:first-child) {
  margin-top: var(--line-margin-top-sp);
}
@media screen and (min-width: 768px) {
  .lp-form form fieldset:not(:first-child) {
    margin-top: var(--line-margin-top);
  }
}

/* form column */
.lp-form form .hs-form-field:not(:first-child),
.lp-form form .hs-dependent-field {
  margin-top: var(--line-margin-top-sp);
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field:not(:first-child),
  .lp-form form .hs-dependent-field {
    margin-top: var(--line-margin-top);
  }
  /* 「1つのチェックボックス」フィールド以外 */
  .lp-form form .hs-form-field:not(.hs-fieldtype-booleancheckbox) {
    display: grid;
    grid-template-columns: 205px 1fr;
    column-gap: 40px;
  }
}

/* form field label */
/* 「1つのチェックボックス」フィールド以外 */
.lp-form form label {
  cursor: pointer;
}

.lp-form form .hs-form-field:not(.hs-fieldtype-booleancheckbox) > label {
  box-sizing: border-box;
  display: block;
  grid-row-start: 1;
  grid-row-end: 10;
  height: fit-content;
  padding-left: 12px;
  border-left: 3px solid var(--color-point);
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: .05em;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .lp-form form .hs-form-field:not(.hs-fieldtype-booleancheckbox) > label {
    font-size: 1.3rem;
  }
}

/* contact property : require */
.lp-form form .hs-form-field label .hs-form-required {
  color: var(--input-error-color);
}

/* help text */
.lp-form form .hs-form-field .hs-field-desc {
  width: auto;
  margin-top: 5px;
  color: var(--color-plane);
  font-size: 1.3rem;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field .hs-field-desc {
    position: relative;
    margin-top: -4px;
    margin-bottom: 5px;
    font-size: 1.6rem;
  }
}


/* === from input  */

/* form input : parent div element */
/* 「1つのチェックボックス」フィールド以外 */
.lp-form form .hs-form-field:not(.hs-fieldtype-booleancheckbox) > .input {
  display: block;
  margin-top: 15px;
}
/* ヘルプテキストの入力がある場合 */
.lp-form form .hs-form-field .hs-field-desc[style="display: block;"] + .input {
  margin-top: 4px;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field:not(.hs-fieldtype-booleancheckbox) > .input {
    margin-top: 0;
  }
}

/* form input : parts [basic] */
.lp-form form .hs-form-field .input :is(input[type="text"], input[type="tel"], input[type="email"], input[type="number"], textarea) {
  box-sizing: border-box;
  width: 100% !important;
  padding: 12px 14px 11px;
  border: 1px solid var(--color-pale);
  border-radius: 5px;
  background: none transparent;
  color: var(--color-plane);;
  font-size: 1.3rem;
  letter-spacing: .05em;
  vertical-align: middle;
  appearance: none;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field .input :is(input[type="text"], input[type="tel"], input[type="email"], input[type="number"], textarea) {
    padding: 15px 14px 14px;
    font-size: 1.6rem;
  }
}
/* checkbox, radio button */
@media screen and (max-width: 767px) {
  .lp-form form .hs-form-field .input :is(input[type="checkbox"], input[type="radio"]) {
    position: relative;
    top: 2px;
  }
}
/* placeholder */
.lp-form form .hs-form-field .input :is(input[type="text"], input[type="tel"], input[type="email"], input[type="number"], textarea)::placeholder {
  color: var(--color-plane);
  opacity: .6;
}

/* contact property : parts [basic] on error */
.lp-form form .hs-form-field .input :is(input[type="text"], input[type="tel"], input[type="email"], input[type="number"], textarea).error {
  border-color: var(--input-error-color);
}

/* form input : form parts [number] */
.lp-form form .hs-form-field .input[type="number"] {
  max-width: var(--select-max-width);
}

/* form input : form parts [file] */
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field:not(.hs-fieldtype-booleancheckbox) > .input:has(input[type="file"]) {
    margin-top: 5px;
  }
}

/* form input : parts [radio button] */
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field.hs-fieldtype-radio .input .inputs-list {
    display: flex;
    flex-wrap: wrap;
  }

  .lp-form form .hs-form-field.hs-fieldtype-radio .input .inputs-list .hs-form-radio {
    display: inline-block;
  }

  .lp-form form .hs-form-field.hs-fieldtype-radio .input .inputs-list .hs-form-radio:not(:last-child) {
    margin-right: 25px;
  }
}

.lp-form form .hs-form-field.hs-fieldtype-radio .input .inputs-list .hs-form-radio label span {
  padding-left: 10px;
  color: var(--color-plane);
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: .05em;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .lp-form form .hs-form-field.hs-fieldtype-radio .input .inputs-list .hs-form-radio label span {
    font-size: 1.3rem;
  }
}

/* form input : parts [checkbox] */
.lp-form form .hs-form-field .input .hs-form-checkbox:not(:first-child) {
  margin-top: 10px;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field .input .hs-form-checkbox:not(:first-child) {
    margin-top: 20px;
  }
}

.lp-form form .hs-form-field .input .hs-form-checkbox span {
  display: inline-flex;
  width: calc(100% - 25px);
  padding-left: 5px;
  color: var(--color-plane);
  font-size: 1.3rem;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field .input .hs-form-checkbox span {
    font-size: 1.6rem;
    letter-spacing: .05em;
    line-height: 1.5;
  }
}

/* form input : boolean checkbox (1つのチェックボックス、個人情報チェックボックス) */
.lp-form form .hs-form-field.hs-fieldtype-booleancheckbox .hs-form-booleancheckbox  > label {
  display: flex;
  align-items: flex-start;
}

.lp-form form .hs-form-field.hs-fieldtype-booleancheckbox .input label > span {
  display: inline;
  margin-left: 0;
  padding-left: 5px;
  color: var(--color-plane);
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: .05em;
  line-height: var(--lh-normal-text);
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field.hs-fieldtype-booleancheckbox .input label > span {
    font-size: 1.6rem;
    padding-left: 8px;
  }
}
/* 出現条件不明だが一応残す */
.lp-form form .hs-form-field.hs-fieldtype-booleancheckbox .input label > span .aInput {
  text-decoration: underline;
}

/* contact property : form parts (textarea) */
.lp-form form .hs-form-field .input textarea {
  min-height: 120px;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field .input textarea {
    min-height: 200px;
  }
}

/* form input : form parts [select] */
.lp-form form .hs-form-field.hs-fieldtype-select .input {
  position: relative;
  max-width: var(--select-max-width);
}

.lp-form form .hs-form-field.hs-fieldtype-select > .input::before {
  content: '';
  position: absolute;
  top: 18px;
  right: 15px;
  width: 10px;
  height: 6px;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMCA2Ij48ZGVmcz48c3R5bGU+LmNscy0xe2ZpbGw6IzBmMGYwZjt9PC9zdHlsZT48L2RlZnM+PGcgaWQ9IuODrOOCpOODpOODvF8yIiBkYXRhLW5hbWU9IuODrOOCpOODpOODvCAyIj48ZyBpZD0i44Os44Kk44Ok44O8XzEtMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMSI+PHBhdGggaWQ9IuWQiOS9k18xNCIgZGF0YS1uYW1lPSLlkIjkvZMgMTQiIGNsYXNzPSJjbHMtMSIgZD0iTTUsNGw1LTRWMkw1LDZaTTAsMlYwTDUsNFY2WiIvPjwvZz48L2c+PC9zdmc+");
  background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field.hs-fieldtype-select > .input::before {
    top: 23px;
    right: 20px;
  }
}

.lp-form form .hs-form-field.hs-fieldtype-select > .input select {
  display: block;
  box-sizing: border-box;
  width: 100%;
  max-height: 40px;
  padding: 11px 30px 11px 14px;
  border: 1px solid var(--color-pale);
  border-radius: 5px;
  color: var(--color-plane);
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: .05em;
  line-height: 1.5;
  appearance: none;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field.hs-fieldtype-select > .input select {
    max-height: 50px;
    padding: 12px 40px 14px 14px;
    font-size: 1.6rem;
    font-weight: 400;
  }
}

/* form input : form parts [select] (電話番号の国別コードドロップダウン) */
.lp-form form .hs-form-field .hs-fieldtype-intl-phone {
  position: relative;
  max-width: 515px;
}
@media screen and (min-width: 1050px) {
  .lp-form form .hs-form-field .hs-fieldtype-intl-phone {
    max-width: none;
  }
}

.lp-form form .hs-form-field .hs-fieldtype-intl-phone::before {
  content: '';
  position: absolute;
  top: 18px;
  left: calc(100% - 30px);
  z-index: 1;
  width: 10px;
  height: 6px;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMCA2Ij48ZGVmcz48c3R5bGU+LmNscy0xe2ZpbGw6IzBmMGYwZjt9PC9zdHlsZT48L2RlZnM+PGcgaWQ9IuODrOOCpOODpOODvF8yIiBkYXRhLW5hbWU9IuODrOOCpOODpOODvCAyIj48ZyBpZD0i44Os44Kk44Ok44O8XzEtMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMSI+PHBhdGggaWQ9IuWQiOS9k18xNCIgZGF0YS1uYW1lPSLlkIjkvZMgMTQiIGNsYXNzPSJjbHMtMSIgZD0iTTUsNGw1LTRWMkw1LDZaTTAsMlYwTDUsNFY2WiIvPjwvZz48L2c+PC9zdmc+");
  background-repeat: no-repeat;
}
@media screen and (min-width: 1050px) {
  .lp-form form .hs-form-field .hs-fieldtype-intl-phone::before {
    left: calc(515px - 30px);
  }
}

.lp-form form .hs-form-field .hs-fieldtype-intl-phone select {
  display: block;
  box-sizing: border-box;
  position: relative;
  width: 100%;
  max-width: 515px;
  max-height: 40px;
  margin-bottom: 13px;
  padding: 8px 30px 11px 14px;
  border: 1px solid var(--color-pale);
  border-radius: 5px;
  color: var(--color-plane);
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: .05em;
  line-height: 1.5;
  appearance: none;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-form-field .hs-fieldtype-intl-phone select {
    max-height: 40px;
    margin-bottom: 15px;
    padding: 9px 40px 5px 15px;
    font-size: 1.5rem;
  }
}

/* from input (parent div) === */


/* error message */
.lp-form form .hs-error-msgs {
  width: 100%;
  margin-top: 5px;
  color: var(--input-error-color);
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: .05em;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .lp-form form .hs-error-msgs {
    font-size: 1.3rem;
  }
}

/* === date picker (カレンダー) */

/* 本体 */
.lp-form form .hs-form-field.hs-fieldtype-date .input .hs-dateinput .fn-date-picker.pika-single {
  border: 1px solid var(--color-pale);
}
/* 月/年 部分 */
.lp-form form .fn-date-picker .pika-label {
  color: var(--color-plane);
  font-size: 1.5rem;
  font-weight: 400;
}
/* 前月/翌月ボタン */
.lp-form form .fn-date-picker .pika-next,
.lp-form form .fn-date-picker .pika-prev {
  position: absolute;
  background-size: inherit;
  opacity: 1;
  transition: .3s;
}
/* 前月 */
.lp-form form .fn-date-picker .pika-prev {
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%226%22%20height%3D%2212%22%20viewBox%3D%220%200%206%2012%22%3E%20%3Cpath%20d%3D%22M6%2C0l6%2C6H0Z%22%20transform%3D%22translate(0%2012)%20rotate(-90)%22%20fill%3D%22%23111987%22%2F%3E%3C%2Fsvg%3E');
  left: 0;
  top: 0;
}
/* 翌月 */
.lp-form form .fn-date-picker .pika-next {
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%226%22%20height%3D%2212%22%20viewBox%3D%220%200%206%2012%22%3E%20%3Cpath%20d%3D%22M6%2C0l6%2C6H0Z%22%20transform%3D%22translate(6)%20rotate(90)%22%20fill%3D%22%23111987%22%2F%3E%3C%2Fsvg%3E');
  right: 0;
  top: 0;
}
/* 曜日 */
.lp-form form .fn-date-picker .pika-table th {
  color: var(--color-plane);
  font-size: 1.2rem;
  font-weight: 500;
}
.lp-form form .fn-date-picker .pika-table th abbr {
  text-decoration: none;
  cursor: inherit;
}
/* 日ボタン */
.lp-form form .fn-date-picker .pika-button {
  border-radius: 2px;
  background-color: var(--color-bg);
  color: var(--color-plane);
  font-size: 1.3rem;
  font-weight: 500;
}
@media screen and (min-width: 1050px) {
  .lp-form form .fn-date-picker .pika-button:is(:hover, :focus) {
    background: #909090 !important;
  }
}
/* 今日の日付 */
.lp-form form .fn-date-picker .is-today .pika-button {
  color: var(--color-point);
}
/* 選択した日付 */
.lp-form form .fn-date-picker .is-selected .pika-button {
  background: var(--color-point);
  box-shadow: none;
  color: #fff;
}

/* date picker (カレンダー) === */


/* === データのプライバシーと同意 */
.lp-form form .legal-consent-container {
  margin-top: var(--line-margin-top-sp);
}
@media screen and (min-width: 768px) {
  .lp-form form .legal-consent-container {
    margin-top: var(--line-margin-top);
  }
}

/* コミュニケーション同意/プライバシー/処理同意 テキスト */
.lp-form form .legal-consent-container .hs-richtext {
  color: var(--color-plane);
  font-size: 1.3rem;
  letter-spacing: .05em;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .lp-form form .legal-consent-container .hs-richtext {
    font-size: 1.4rem;
  }
}
.lp-form form .legal-consent-container .hs-richtext:not(:first-child) {
  margin-top: 20px;
}
.lp-form form .legal-consent-container .hs-richtext:not(:last-child) {
  margin-bottom: 20px;
}
/* プライバシー/処理同意 テキストが存在する場合の余白 */
.lp-form form .legal-consent-container div:has(.hs-dependent-field) + .hs-richtext {
  margin-top: 30px;
}
@media screen and (min-width: 768px) {
  .lp-form form .legal-consent-container div:has(.hs-dependent-field) + .hs-richtext {
    margin-top: 40px;
  }
}

/* line-height分の余白を相殺 */
.lp-form form .legal-consent-container .hs-richtext::before {
  content: '';
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - 2) * .5em);
}
.lp-form form .legal-consent-container .hs-richtext::after {
  content: '';
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - 2) * .5em);
}

/* strong */
.lp-form form .legal-consent-container .hs-richtext strong {
  font-weight: 700;
}

/* link */
.lp-form form .legal-consent-container .hs-richtext a {
  display: inline;
  position: relative;
  border-bottom: 1px solid #E8D815;
  text-decoration: none;
  transition: color .3s;
}
@media screen and (min-width: 1050px) {
  .lp-form form .legal-consent-container .hs-richtext a:is(:hover, :focus) {
    color: var(--color-point);
  }
}
/* 外部リンク */
.lp-form form .legal-consent-container .hs-richtext a[target="_blank"] {
  padding-left: 15px;
}
@media screen and (min-width: 768px) {
  .lp-form form .legal-consent-container .hs-richtext a[target="_blank"] {
    padding-left: 20px;
  }
}
/* 外部リンクアイコン */
.lp-form form .legal-consent-container .hs-richtext a[target="_blank"]::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 12px;
  height: 12px;
  margin-top: -6px;
  background: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMS45NjkiIGhlaWdodD0iMTEuOTY5IiB2aWV3Qm94PSIwIDAgMTEuOTY5IDExLjk2OSI+CiAgPHBhdGggaWQ9IuODkeOCuV82NDIxIiBkYXRhLW5hbWU9IuODkeOCuSA2NDIxIiBkPSJNLTc4OC41MjksMGgtNi4zNDJhLjUyOC41MjgsMCwwLDAtLjUyOC41MjlWMi4xNjdoLTMuODdhLjcuNywwLDAsMC0uNy43djguNGEuNy43LDAsMCwwLC43LjdoOC40YS43LjcsMCwwLDAsLjctLjdWNy40aDEuNjM4QS41MjguNTI4LDAsMCwwLTc4OCw2Ljg3MVYuNTI5QS41MjkuNTI5LDAsMCwwLTc4OC41MjksMFptLTIuNjM4LDEwLjk2OWgtNy44di03LjhoMy41N3YzLjdhLjUyNy41MjcsMCwwLDAsLjUyOC41MjhoMy43Wk0tNzg5LDYuNGgtNS40VjFoNS40WiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNzk5Ljk2OSkiIGZpbGw9IiM0MTQxNDEiLz4KPC9zdmc+Cg==") no-repeat center;
  background-size: cover;
}

/* 個人情報の取扱について同意する チェックボックス部分 */
.lp-form form .legal-consent-container .field.hs-form-field {
  margin-bottom: 0;
}

/* error massage */
.lp-form .legal-consent-container .hs-error-msgs label {
  color: var(--input-error-color);
}

/* データのプライバシーと同意 === */


/* === reCAPTCHA */
.lp-form form .hs-form-field.hs_recaptcha {
  display: block;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
/* reCAPTCHA === */


/* === submit button */

.lp-form form .hs-submit {
  position: relative;
  max-width: 245px;
  margin: 30px 60px 0;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-submit {
    margin-top: 40px;
    margin-right: auto;
    margin-left: auto;
  }
}


/* arrow icon */
.lp-form form .hs-submit .actions {
  position: relative;
  overflow: hidden;
  background-color: var(--color-point);
  border-radius: 30px;
}
.lp-form form .hs-submit .actions::after {
  content: "";
  display: block;
  position: absolute;
  right: 20px;
  top: calc(50% - 2px);
  transform: translateY(-50%);
  width: 15px;
  height: 15px;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMi40OCIgaGVpZ2h0PSIxMi40OCIgdmlld0JveD0iMCAwIDEyLjQ4IDEyLjQ4Ij48ZyBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS13aWR0aD0iMS41IiBkYXRhLW5hbWU9IuOCsOODq+ODvOODlyA0MDcwNCI+PHBhdGggZD0iTS43NSA0LjY2aDcuMDd2Ny4wNzIiIGRhdGEtbmFtZT0i44OR44K5IDExMDgxIi8+PHBhdGggZD0iTTcuODIzIDQuNjYuNzUyIDExLjczMyIgZGF0YS1uYW1lPSLjg5HjgrkgMTEwODIiLz48L2c+PC9zdmc+);
  background-repeat: no-repeat;
  background-size: contain;
  transition: opacity .7s;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-submit .actions::after {
    opacity: 0;
  }
}

@media screen and (min-width: 1050px) {
  .lp-form form .hs-submit .actions:hover::after {
    opacity: 1;
  }
}
.lp-form form .hs-submit .actions::before {
  content: "";
  background-color: #fff;
  top: 50%;
  transition: transform .7s,background-color .6s ease-in;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-submit .actions::before {
    background-color: #ffffff;
    border-radius: 50%;
    height: 6px;
    isolation: isolate;
    overflow: hidden;
    position: absolute;
    right: 25px;
    top: 50%;
    transform: translateY(-50%);
    transition: all .5s;
    width: 6px;
  }
}
@media screen and (min-width: 1050px) {
  .lp-form form .hs-submit .actions:hover::before {
    background-color: var(--color-sub);
    transform: scale(150);
    transition: transform 1.2s,background-color .8s ease-out;
  }
}


.lp-form form .hs-submit .actions input {
  appearance: none;
  box-sizing: border-box;
  display: block;
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 19px 30px 18px;
  border: none;
  background: transparent;
  border-radius: 30px;
  color: #fff;
  font-family: var(--font-button);
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: .05em;
  line-height: var(--lh-button);
  text-align: left;
  word-break: break-all;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .lp-form form .hs-submit .actions input {
    font-size: 1.6rem;
  }
}

.lp-form form .hs-submit .actions .hs-button__icon {
  display: none;
}

/* submit button === */

/* Original form style === */



.lp-form form .checkbox-title {
  display: inline-block;
  float: left;
  width: 100%;
  padding-top: 9px;
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: .05em;
  line-height: 2em;
  border-top: 1px solid var(--color-main);
}
@media screen and (min-width: 768px) {
  .lp-form form .checkbox-title {
    font-size: 1.6rem;
    width: 200px;
  }
}

.hs_error_rollup {
  margin-top: 30px;
  color: var(--input-error-color);
  font-size: 1.3rem;
}
@media screen and (min-width: 768px) {
  .hs_error_rollup {
    font-size: 1.5rem;
  }
}
/* news */

.header--has-shadow {
  box-shadow: rgba(65, 65, 65, 0.07) 0px 3px 12px !important;
}

.content--news-post {
  position: relative;
  overflow: hidden;
}

.content--news-post::before {
  content: "";
  position: absolute;
  top: 0;
  left: -45px;
  width: 229px;
  height: 209px;
  background: radial-gradient(rgba(77,97,195,.1), rgba(210,222,250,.45),rgba(255,255,255,1));
  border-radius: 100%;
  filter: blur(4.4rem);
  opacity: .28;
  transform: rotate(55deg);
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .content--news-post::before {
    top: -45px;
    left: -60px;
    width: 424px;
    height: 423px;
  }
}
@media screen and (min-width: 1050px) {
  .content--news-post::before {
    left: -70px;
  }
}

.content--news-post::after {
  content: "";
  position: absolute;
  top: 254px;
  right: -89px;
  width: 224px;
  height: 125px;
  background: radial-gradient(rgba(255,15,15,.8), rgba(245,69,69,.65),rgba(253,19,19,0));
  border-radius: 100%;
  filter: blur(4.4rem);
  opacity: .05;
  transform: rotate(220deg);
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .content--news-post::after {
    top: 337px;
    right: -140px;
    width: 360px;
    height: 176px;
  }
}
@media screen and (min-width: 1050px) {
  .content--news-post::after {
    top: 256px;
    right: -100px;
  }
}

.content--news-post {
  padding-bottom: 5px;
}

@media screen and (max-width: 767px) {
  .section.section--news-post {
    margin-top: 45px;
  }
}


/* === article / 記事詳細 */
.content--news-post .elevator {
  padding-top: 15px;
}
@media screen and (min-width: 768px) {
  .content--news-post .elevator {
    padding-top: 20px;
  }
}

.news-article__head__date {
  display: block;
  color: rgba(41,43,60,.5);
  font-size: 1.2rem;
  letter-spacing: .05em;
  line-height: 1.5em;
  font-weight: 500;
}

@media screen and (min-width: 768px) {
  .news-article__head__date {
    font-size: 1.6rem;
  }
}

.news-article__head__heading {
  color: var(--color-main);
  font-size: 2.0rem;
  letter-spacing: .05em;
  line-height: 1.5em;
  font-weight: 600;
  margin-top: 6px;
}

@media screen and (min-width: 768px) {
  .news-article__head__heading {
    font-size: 3.0rem;
  }
}

.news-article__head__category-list {
  margin-top: 20px;
}

@media screen and (min-width: 768px) {
  .news-article__head__category-list {
    margin-top: 25px;
  }
}

.news-article__head__category-list__item {
  display: inline-block;
  min-width: 100px;
  margin-right: 6px;
}

.news-article__head__category-list__item:not(:first-child) {
  margin-top: 0;
}

.news-article__head__category-list__item__anchor {
  display: block;
  background-color: var(--color-bg);
  color: rgba(41,43,60,.7);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: .05em;
  text-align: center;
  padding: 6px 15px 5px;
  border-radius: 12px;
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (min-width: 768px) {
  .news-article__head__category-list__item__anchor {
    padding: 7px 15px 6px;
    font-size: 1.3rem;
  }
}
@media screen and (min-width: 1050px) {
  .news-article__head__category-list__item__anchor:is(:hover, :focus) {
    background-color: #E4E5E8;
    color: rgba(20,22,34,.7);
  }
}

.news-article__head__thumbnail {
  margin-top: 25px;
  margin-bottom: 50px;
  margin-right: -20px;
  margin-left: -20px;
}

@media screen and (min-width: 768px) {
  .news-article__head__thumbnail {
    margin-left: 0;
    margin-right: 0;
    margin-top: 30px;
  }
}

.news-article__head__thumbnail img {
  max-width: 100%;
  width: 100%;
  vertical-align: middle;
  border-radius: 10px;
}

.news-article__body {
  margin-top: 60px !important;
}

/* news-article__body__content */
.news-article__body__content.natural {
  padding-bottom: 0.6em; /* 最後のコンテンツが微妙に切れてしまうため対策 */
}

.news-article__body__content h2, .news-article__body__summary__body h2 {
  font-size: 2.0rem;
  letter-spacing: .15em;
  line-height: 1.5em;
  font-weight: var(--fw-bold-jp);
  color: var(--color-plane);
  background-color: var(--color-bg);
  border-left: 3px solid var(--color-point);
  padding: 12px 15px 10px;
}

@media screen and (min-width: 768px) {
  .news-article__body__content h2, .news-article__body__summary__body h2 {
    font-size: 2.5rem;
    border-left: 4px solid var(--color-point);
    padding: 9px 20px;
  }
}

.news-article__body__content h2:not(:first-child), .news-article__body__summary__body h2:not(:first-child) {
  margin-top: 50px;
}

@media screen and (min-width: 768px) {
  .news-article__body__content h2:not(:first-child), .news-article__body__summary__body h2:not(:first-child) {
    margin-top: 60px;
  }
}

.news-article__body__content h2:not(:last-child), .news-article__body__summary__body h2:not(:last-child) {
  margin-bottom: 25px;
}

@media screen and (min-width: 768px) {
  .news-article__body__content h2:not(:last-child), .news-article__body__summary__body h2:not(:last-child) {
    margin-bottom: 30px;
  }
}

.news-article__body__content h3, .news-article__body__summary__body h3 {
  font-size: 1.8rem;
  letter-spacing: .15em;
  line-height: 1.36;
  font-weight: var(--fw-bold-jp);
  color: var(--color-plane);
  position: relative;
  margin-top: -.5em;
  padding: 0 10px;
  border-left: 2px solid var(--color-point);
}

@media screen and (min-width: 768px) {
  .news-article__body__content h3, .news-article__body__summary__body h3 {
    padding: 1px 13px 1px;
    font-size: 2.0rem;
    border-left: 3px solid var(--color-point);
  }
}

.news-article__body__content h3:not(:first-child), .news-article__body__summary__body h3:not(:first-child) {
  margin-top: 35px;
}

@media screen and (min-width: 768px) {
  .news-article__body__content h3:not(:first-child), .news-article__body__summary__body h3:not(:first-child) {
    margin-top: 40px;
  }
}

.news-article__body__content h3:not(:last-child), .news-article__body__summary__body h3:not(:last-child) {
  margin-bottom: 20px;
}

@media screen and (min-width: 768px) {
  .news-article__body__content h3:not(:last-child), .news-article__body__summary__body h3:not(:last-child) {
    margin-bottom: 25px;
  }
}

.news-article__body__content h4, .news-article__body__summary__body h4 {
  font-size: 1.7rem;
  letter-spacing: .15em;
  line-height: 1.5em;
  font-weight: var(--fw-bold-jp);
  color: var(--color-plane);
  margin-top: -.5em;
  margin-bottom: -.5em;
}
@media screen and (min-width: 768px) {
  .news-article__body__content h4, .news-article__body__summary__body h4 {
    font-size: 1.8rem;
  }
}

.news-article__body__content h4::before, .news-article__body__summary__body h4::before {
  content: '';
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - 1.5) * .5em);
}

.news-article__body__content h4::after, .news-article__body__summary__body h4::after {
  content: '';
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - 1.5) * .5em);
}

.news-article__body__content h4:not(:first-child), .news-article__body__summary__body h4:not(:first-child) {
  margin-top: 35px;
}

@media screen and (min-width: 768px) {
  .news-article__body__content h4:not(:first-child), .news-article__body__summary__body h4:not(:first-child) {
    margin-top: 40px;
  }
}

.news-article__body__content h4:not(:last-child), .news-article__body__summary__body h4:not(:last-child) {
  margin-bottom: 20px;
}

@media screen and (min-width: 768px) {
  .news-article__body__content h4:not(:last-child), .news-article__body__summary__body h4:not(:last-child) {
    margin-bottom: 25px;
  }
}

.news-article__body__content p, .news-article__body__summary__body p {
  font-size: 1.5rem;
  letter-spacing: var(--ls-root);
  line-height: 2;
  color: var(--color-plane);
  margin-top: -.5em;
  margin-bottom: -.5em;
}

.news-article__body__content p::before, .news-article__body__summary__body p::before {
  content: '';
  display: block;
  width: 0;
  height: 0;
  margin-top: calc((1 - 2) * .5em);
}

.news-article__body__content p::after, .news-article__body__summary__body p::after {
  content: '';
  display: block;
  width: 0;
  height: 0;
  margin-bottom: calc((1 - 2) * .5em);
}

@media screen and (min-width: 768px) {
  .news-article__body__content p, .news-article__body__summary__body p {
    font-size: 1.6rem;
  }
}

.news-article__body__content p:not(:first-child), .news-article__body__summary__body p:not(:first-child) {
  margin-top: 20px;
}

.news-article__body__content p:not(:last-child), .news-article__body__summary__body p:not(:last-child) {
  margin-bottom: 20px;
}

@media screen and (min-width: 768px) {
  .news-article__body__content p:not(:last-child), .news-article__body__summary__body p:not(:last-child) {
    margin-bottom: 30px;
  }
}

.news-article__body__content img, .news-article__body__summary__body img {
  display: block;
  max-width: 100%;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  border-radius: 10px;
}
@media screen and (min-width: 768px) {
  .news-article__body__content img, .news-article__body__summary__body img {
    max-width: calc(100% - 100px) !important;
  }
}
@media screen and (min-width: 1050px) {
  .news-article__body__content img, .news-article__body__summary__body img {
    max-width: 650px !important;
  }
}

.news-article__body__content img:not(:first-child), .news-article__body__summary__body img:not(:first-child) {
  margin-top: 35px;
}

@media screen and (min-width: 768px) {
  .news-article__body__content img:not(:first-child), .news-article__body__summary__body img:not(:first-child) {
    margin-top: 40px;
  }
}

.news-article__body__content img:not(:last-child), .news-article__body__summary__body img:not(:last-child) {
  margin-bottom: 35px;
}

@media screen and (min-width: 768px) {
  .news-article__body__content img:not(:last-child), .news-article__body__summary__body img:not(:last-child) {
    margin-bottom: 40px;
  }
}

.news-article__body__summary {
  margin-top: 50px;
  border: 1px solid var(--color-pale);
  border-radius: 5px;
}

@media screen and (min-width: 768px) {
  .news-article__body__summary {
    margin-top: 60px;
  }
}

.news-article__body__summary__head {
  background-color: #F1F1ED;
  border-radius: 5px 5px 0 0;
  padding: 11px 20px 10px;
}

@media screen and (min-width: 768px) {
  .news-article__body__summary__head {
    padding: 14px 30px;
  }
}

.news-article__body__summary__head__heading {
  font-size: 1.8rem;
  letter-spacing: .2em;
  font-weight: 700;
  color: var(--color-plane);
}

@media screen and (min-width: 768px) {
  .news-article__body__summary__head__heading {
    font-size: 2.2rem;
  }
}

.news-article__body__summary__body {
  padding: 20px;
}

@media screen and (min-width: 768px) {
  .news-article__body__summary__body {
    padding: 30px;
  }
}

.news-article__body__cta__anchor {
  display: block;
}

.news-article__body__cta__content img {
  max-width: 100%;
  width: 100%;
  vertical-align: middle;
  margin-left: auto;
  margin-right: auto;
  border-radius: 10px;
}

.news-article__body__cta:not(:first-child) {
  margin-top: 60px;
}

@media screen and (min-width: 768px) {
  .news-article__body__cta:not(:first-child) {
    margin-top: 80px;
  }
}

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

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

.news-article__foot {
  margin-top: 60px;
  padding-top: 25px;
  border-top: 1px solid var(--color-pale);
}

@media screen and (min-width: 768px) {
  .news-article__foot {
    margin-top: 80px;
  }
}

@media screen and (min-width: 768px) {
  .news-article__foot__nav__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-left: -30px;
    margin-right: -30px;
  }
}

@media screen and (min-width: 768px) {
  .news-article__foot__nav__list__item {
    width: 50%;
    padding-left: 30px;
    padding-right: 30px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
}

.news-article__foot__nav__list__item--prev {
  margin-right: auto;
}

.news-article__foot__nav__list__item--next {
  margin-left: auto;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px dotted var(--color-pale);
}

@media screen and (min-width: 768px) {
  .news-article__foot__nav__list__item--next {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
    border-left: 1px dotted var(--color-pale);
  }
}

.news-article__foot__nav__list__item--next .news-article__foot__nav__list__item__heading {
  text-align: right;
}

.news-article__foot__nav__list__item__heading {
  color: var(--color-plane);
  font-size: 1.6rem;
  letter-spacing: .2em;
  font-weight: 700;
}

.news-article__foot__nav__list__item__block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 15px;
}

.news-article__foot__nav__list__item__block__image {
  width: 100%;
  max-width: 110px;
}

@media screen and (min-width: 768px) {
  .news-article__foot__nav__list__item__block__image {
    max-width: 120px;
  }
}

.news-article__foot__nav__list__item__block__image img {
  max-width: 100%;
  width: 100%;
  vertical-align: middle;
  border-radius: 5px;
}

.news-article__foot__nav__list__item__block__heading {
  width: 100%;
  margin-left: 15px;
  font-size: 1.4rem;
  letter-spacing: .15em;
  line-height: 1.6em;
  font-weight: 500;
  -webkit-transition: color .3s;
  transition: color .3s;
}

@media screen and (min-width: 768px) {
  .news-article__foot__nav__list__item__block__heading {
    max-width: 210px;
  }
}

a:is(:hover, :focus) .news-article__foot__nav__list__item__block__heading {
  color: var(--color-main);
}

.news-article__foot__back {
  margin-top: 60px;
  text-align: center;
}

@media screen and (min-width: 768px) {
  .news-article__foot__back {
    margin-top: 80px;
  }
}

.news-article__foot__back__anchor {
  color: var(--color-plane);
  font-size: 1.6rem;
  letter-spacing: .15em;
  line-height: 1.4em;
  font-weight: 500;
  position: relative;
  padding-left: 38px;
  -webkit-transition: color .3s;
  transition: color .3s;
}

.news-article__foot__back__anchor__icon {
  display: block;
  position: absolute;
  top: calc(50% - 14px);
  left: 0;
  width: 28px;
  height: 28px;
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}

.news-article__foot__back__anchor__icon__circle {
  fill: var(--color-plane);
  -webkit-transition: fill .3s;
  transition: fill .3s;
}

a:is(:hover, :focus) .news-article__foot__back__anchor__icon__circle {
  fill: var(--color-main);
}

.news-article__foot__back__anchor:is(:hover, :focus) {
  color: var(--color-main);
}
/* article / 記事詳細 === */


/* === archive / 記事一覧 */

.news-archive__menu {
  display: grid;
  grid-template-columns: 98px 1fr;
  align-items: center;
  margin-bottom: 15px;
}
@media screen and (min-width:768px) {
  .news-archive__menu {
    grid-template-columns: 143px 1fr;
    margin-bottom: 40px;
  }
}

.news-archive__menu__tab {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
}

.news-archive__menu__tab__item {
  position: relative;
  width: fit-content;
  padding: 2px 9px;
  color: rgba(20,22,34,.7);
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.5;
  border-radius: 18px;
  border: 1px solid #D2D4D9;
  background-color: #ffffff;
  cursor: pointer;
}
.news-archive__menu__tab__item.is-active {
  padding-left: 19px;
  background-color: var(--color-point);
  color: #ffffff;
  border: 1px solid var(--color-point);
}
.news-archive__menu__tab__item.is-active::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
  width: 4px;
  height: 4px;
  border-radius: 4px;
  background-color: #ffffff;
}
@media screen and (min-width:768px) {
  .news-archive__menu__tab__item {
    padding: 4px 16px;
    font-size: 1.6rem;
  }
  .news-archive__menu__tab__item.is-active {
    padding-left: 29px;
  }
  .news-archive__menu__tab__item.is-active::before {
    left: 18px;
    width: 5px;
    height: 5px;
  }
}

.news-archive__menu__list {
  display: none;
  flex-wrap: wrap;
  align-items: center;
  gap: 15px 20px;
  min-height: 62px;
  box-sizing: border-box;
  padding-top: 5px;
  padding-bottom: 5px;
  padding-left: 22px;
  border-left: 1px solid #D2D4D9;
}
.news-archive__menu__list.is-active {
  display: flex;
}
@media screen and (min-width:768px) {
  .news-archive__menu__list {
    gap: 17px 32px;
    min-height: 80px;
    padding-top: 7px;
    padding-bottom: 7px;
    padding-left: 40px;
  }
}

.news-archive__menu__list__item__anchor {
  display: block;
  position: relative;
}

.news-archive__menu__list__item__anchor__inner {
  display: block;
  position: relative;
  box-sizing: border-box;
  color: var(--color-main);
  font-size: 1.3rem;
  line-height: 1.5;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .news-archive__menu__list__item__anchor__inner {
    font-size: 1.6rem;
  }
}
/* :focus & :hover */
@media screen and (min-width: 1050px) {
  .news-archive__menu__list__item__anchor:is(:hover, :focus) .news-archive__menu__list__item__anchor__inner {
    font-weight: 500;
  }
}
/* active */
.news-archive__menu__list__item__anchor.is-active .news-archive__menu__list__item__anchor__inner {
  position: relative;
}
.news-archive__menu__list__item__anchor.is-active .news-archive__menu__list__item__anchor__inner::before {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: var(--color-point);
}

.news-archive__content__list__item {
  border-bottom: 1px dotted var(--color-pale);
}

.news-archive__content__list__item__anchor {
  display: block;
  position: relative;
  padding-top: 22px;
  padding-bottom: 24px;
  padding-right: 40px;
  transition: background-color .3s;
}

@media screen and (min-width: 768px) {
  .news-archive__content__list__item__anchor {
    padding-top: 30px;
    padding-bottom: 30px;
    padding-right: 45px;
  }
}
@media screen and (min-width: 1050px) {
  .news-archive__content__list__item__anchor {
    padding-right: 50px;
  }
}

.news-archive__content__list__item__anchor .link-icon-circle {
  right: 50%;
  top: 50%;
  background-color: transparent;
}
@media screen and (min-width: 1050px) {
  .news-archive__content__list__item__anchor .link-icon-circle {
    background-color: var(--color-point);
  }
  .news-archive__content__list__item__content__body__text:focus .link-icon-circle,
  .news-archive__content__list__item__content__body__text:hover .link-icon-circle {
    height: 32px;
    width: 32px;
    background-color: var(--color-sub);
  }
}

.news-archive__content__list__item__anchor .link-button__anchor__icon {
  right: 0;
}
.news-archive__content__list__item__anchor .link-button__anchor__icon:before {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  width: 12px;
  height: 12px;
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2211.062%22%20height%3D%2211.063%22%20viewBox%3D%220%200%2011.062%2011.063%22%3E%20%3Cpath%20d%3D%22M3582.608%2C6954.273v-8.192l-3.721%2C3.719-1.061-1.061%2C5.531-5.529%2C5.531%2C5.529-1.061%2C1.061-3.718-3.716v8.189Z%22%20transform%3D%22translate(-3577.826%20-6943.21)%22%20fill%3D%22%23111987%22%2F%3E%3C%2Fsvg%3E');
}
@media screen and (min-width: 768px) {
  .news-archive__content__list__item__anchor .link-button__anchor__icon {
    top: 50%;
  }
  .news-archive__content__list__item__anchor .link-button__anchor__icon:before {
    display: block;
    width: 13px;
    height: 13px;
  }
}
@media screen and (min-width: 1050px) {
  .news-archive__content__list__item__anchor .link-button__anchor__icon {
    right: 5px;
  }
  .news-archive__content__list__item__anchor .link-button__anchor__icon:before {
    background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2211.062%22%20height%3D%2211.063%22%20viewBox%3D%220%200%2011.062%2011.063%22%3E%20%3Cpath%20d%3D%22M3582.608%2C6954.273v-8.192l-3.721%2C3.719-1.061-1.061%2C5.531-5.529%2C5.531%2C5.529-1.061%2C1.061-3.718-3.716v8.189Z%22%20transform%3D%22translate(-3577.826%20-6943.21)%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E');
  }
}

@media screen and (min-width: 768px) {
  .news-archive__content__list__item__content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
}

/* .news-archive__content__list__item__content__head */
@media screen and (min-width: 768px) {
  .news-archive__content__list__item__content__head {
    display: flex;
    align-items: center;
  }
}

.news-archive__content__list__item__content__head__date {
  color: rgba(41,43,60,.5);
  font-family: var(--font-en);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: .05em;
}
@media screen and (min-width: 768px) {
  .news-archive__content__list__item__content__head__date {
    font-size: 1.5rem;
  }
}

.news-archive__content__list__item__content__head__category-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}
@media screen and (min-width: 768px) {
  .news-archive__content__list__item__content__head__category-list {
    gap: 15px;
    margin-top: 0;
    margin-left: 20px;
  }
}

.news-archive__content__list__item__content__head__category-list__item__anchor {
  display: inline-block;
  box-sizing: border-box;
  min-width: 100px;
  padding: 5px 15px;
  border-radius: 16px;
  background-color: var(--color-bg);
  color: rgba(41,43,60,.7);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: .05em;
  text-align: center;
  transition: .3s;
}
@media screen and (min-width: 768px) {
  .news-archive__content__list__item__content__head__category-list__item__anchor {
    font-size: 1.3rem;
  }
}
@media screen and (min-width: 1050px) {
  .news-archive__content__list__item__content__head__category-list__item__anchor:is(:hover, :focus) {
    background-color: #E4E5E8;
    color: rgba(20,22,34,.7);
  }
}

.news-archive__content__list__item__content__body {
  margin-top: 10px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .news-archive__content__list__item__content__body {
    margin-top: 15px;
  }
}

.news-archive__content__list__item__content__body__text {
  display: inline-block;
  width: 100%;
}

.news-archive__content__list__item__content__body__text__inner {
  margin-right: 2px;
}
.news-archive__content__list__item__content__body__text__icon {
  display: inline-block;
  margin-bottom: -1px;
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
}
.news-archive__content__list__item__content__body__text__icon--external {
  width: 12px;
  height: 12px;
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2215%22%20height%3D%2215%22%20viewBox%3D%220%200%2015%2015%22%3E%20%3Cpath%20d%3D%22M-785.632%2C0h-7.948a.662.662%2C0%2C0%2C0-.662.663V2.716h-4.85a.877.877%2C0%2C0%2C0-.877.877v10.53a.878.878%2C0%2C0%2C0%2C.877.877h10.53a.877.877%2C0%2C0%2C0%2C.877-.877V9.273h2.053a.662.662%2C0%2C0%2C0%2C.663-.662V.663A.663.663%2C0%2C0%2C0-785.632%2C0Zm-3.306%2C13.747h-9.778V3.969h4.474V8.611a.661.661%2C0%2C0%2C0%2C.662.662h4.642Zm2.716-5.727h-6.766V1.253h6.766Z%22%20transform%3D%22translate(799.969)%22%20fill%3D%22%23111987%22%2F%3E%3C%2Fsvg%3E');
}
.news-archive__content__list__item__content__body__text__icon--pdf {
  width: 14px;
  height: 14px;
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2216%22%20height%3D%2216.414%22%20viewBox%3D%220%200%2016%2016.414%22%3E%20%3Cdefs%3E%20%3CclipPath%20id%3D%22clip-path%22%3E%20%3Crect%20width%3D%2216%22%20height%3D%2216.414%22%20fill%3D%22none%22%2F%3E%20%3C%2FclipPath%3E%20%3C%2Fdefs%3E%20%3Cg%20clip-path%3D%22url(%23clip-path)%22%3E%20%3Cpath%20d%3D%22M10.907%2C16.414H2.321a.621.621%2C0%2C0%2C1-.621-.621V.621A.621.621%2C0%2C0%2C1%2C2.321%2C0H14.734a.622.622%2C0%2C0%2C1%2C.621.621V11.967a.625.625%2C0%2C0%2C1-.182.439l-3.828%2C3.828a.621.621%2C0%2C0%2C1-.439.181M2.941%2C15.172h7.708l3.465-3.463V1.241H2.941Z%22%20transform%3D%22translate(0.645%20-0.001)%22%20fill%3D%22%23111987%22%2F%3E%20%3Crect%20width%3D%2213.567%22%20height%3D%227.454%22%20transform%3D%22translate(0%202.826)%22%20fill%3D%22%23111987%22%2F%3E%20%3Cpath%20d%3D%22M1.325%2C7.278V3.318H2.732a1.932%2C1.932%2C0%2C0%2C1%2C.77.138.984.984%2C0%2C0%2C1%2C.477.414%2C1.453%2C1.453%2C0%2C0%2C1%2C.163.724%2C1.523%2C1.523%2C0%2C0%2C1-.161.738.987.987%2C0%2C0%2C1-.473.429A1.827%2C1.827%2C0%2C0%2C1%2C2.75%2C5.9h-.7V7.278ZM2.049%2C5.3h.617a.81.81%2C0%2C0%2C0%2C.552-.167A.672.672%2C0%2C0%2C0%2C3.4%2C4.609a.66.66%2C0%2C0%2C0-.189-.521.85.85%2C0%2C0%2C0-.57-.164H2.049Z%22%20transform%3D%22translate(0.503%201.258)%22%20fill%3D%22%23fff%22%2F%3E%20%3Cpath%20d%3D%22M3.933%2C7.278V3.318H5.414a2.093%2C2.093%2C0%2C0%2C1%2C1.007.236%2C1.719%2C1.719%2C0%2C0%2C1%2C.69.679A2.121%2C2.121%2C0%2C0%2C1%2C7.362%2C5.3a2.121%2C2.121%2C0%2C0%2C1-.251%2C1.065%2C1.727%2C1.727%2C0%2C0%2C1-.69.679%2C2.093%2C2.093%2C0%2C0%2C1-1.007.236Zm.724-.646h.759a1.189%2C1.189%2C0%2C0%2C0%2C.641-.161%2C1%2C1%2C0%2C0%2C0%2C.388-.461%2C2.016%2C2.016%2C0%2C0%2C0%2C0-1.426%2C1%2C1%2C0%2C0%2C0-.388-.461%2C1.189%2C1.189%2C0%2C0%2C0-.641-.161H4.657Z%22%20transform%3D%22translate(1.492%201.258)%22%20fill%3D%22%23fff%22%2F%3E%20%3Cpath%20d%3D%22M6.967%2C7.277V3.319H9.4v.708H7.69v.843H9.014v.7H7.69V7.277Z%22%20transform%3D%22translate(2.643%201.258)%22%20fill%3D%22%23fff%22%2F%3E%20%3Cpath%20d%3D%22M9.166%2C12.673H7.925V8.847a.622.622%2C0%2C0%2C1%2C.621-.622h3.828V9.468H9.166Z%22%20transform%3D%22translate(3.006%203.119)%22%20fill%3D%22%23111987%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
}
@media screen and (min-width: 768px) {
  .news-archive__content__list__item__content__body__text__icon--external {
    width: 15px;
    height: 15px;
  }
  .news-archive__content__list__item__content__body__text__icon--pdf {
    width: 16px;
    height: 16px;
  }
}

.news-archive__pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 25px;
  margin-top: 50px;
}

@media screen and (min-width: 768px) {
  .news-archive__pager {
    margin-top: 75px;
  }
}

.news-archive__pager__item__anchor {
  display: block;
  color: var(--color-plane);
  font-family: var(--font-en);
  font-size: 1.7rem;
  font-weight: 500;
  letter-spacing: .1em;
  transition: color .3s;
}
@media screen and (min-width: 768px) {
  .news-archive__pager__item__anchor {
    font-size: 1.8rem;
  }
}
/* :focus & :hover */
@media screen and (min-width: 1050px) {
  .news-archive__pager__item__anchor:is(:hover, :focus) {
    color: rgba(20,22,34,.7);
  }
}
/* 現在閲覧中のページ */
.news-archive__pager__item.is-current .news-archive__pager__item__anchor {
  color: rgba(20, 22, 34, .5);
}

/* pagenation icon */
.news-archive__pager__item__anchor__icon {
  display: block;
  width: 24px;
  height: 24px;
}
@media screen and (min-width: 768px) {
  .news-archive__pager__item__anchor__icon {
    width: 28px;
    height: 28px;
  }
}

.news-archive__pager__item__anchor--prev,
.news-archive__pager__item__anchor--next {
  position: relative;
}
.news-archive__pager__item__anchor--prev::before,
.news-archive__pager__item__anchor--next::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  background: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI2IiBoZWlnaHQ9IjgiIHZpZXdCb3g9IjAgMCA2IDgiPgogIDxwYXRoIGlkPSJhcnJvdyIgZD0iTTAsOCw0LDQsMCwwSDJMNiw0LDIsOFoiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDYgOCkgcm90YXRlKDE4MCkiIGZpbGw9IiNmZmYiLz4KPC9zdmc+Cg==');
  width: 6px;
  height: 8px;
  transition: background .3s;
}
.news-archive__pager__item__anchor--next::before {
  transform: translate(-50%,-50%) rotate(180deg);
}

.news-archive__pager__item__anchor__icon__circle {
  fill: var(--color-point);
  transition: fill .3s;
}
@media screen and (min-width: 1050px) {
  a:is(:hover, :focus) .news-archive__pager__item__anchor__icon__circle {
    fill: var(--color-sub);
  }
}
/* archive / 記事一覧 === */

/* モーダルのスタイル */
.post-image-modal {
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  z-index: 1000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(0,0,0,0.6);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s, visibility 0.5s;
}

/* モーダル */
.post-image-modal__content {
  display: flex;
  flex-direction: column;
  align-items: end;
  justify-content: center;
  position: relative;
  width: fit-content;
  max-width: calc(100% - 40px);
  height: 100%;
  max-height: calc(100% - 140px);
}
@media screen and (min-width: 768px) {
  .post-image-modal__content {
    max-width: calc(100% - 100px);
  }
}
@media screen and (min-width: 1050px) {
  .post-image-modal__content {
    max-width: calc(100% - 200px);
  }
}
@media screen and (min-width: 1250px) {
  .post-image-modal__content {
    max-width: 1050px;
  }
}

#post-image-modal__item {
  max-width: 100%;
  max-height: 100%;
  width: 100%;
  height: auto;
  object-fit: contain;
}

#post-image-modal__close {
  color: #ffffff;
  font-size: 20px;
  font-weight: bold;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  #post-image-modal__close {
    font-size: 30px;
  }
}
.container.home__container {
  max-width: 1450px;
  padding-left: 20px;
  padding-right: 20px;
}

.main-content {
  overflow: hidden;
}

@media screen and (min-width: 768px) and (max-width: 1049px) {
  .home-body .link-button__anchor__icon:before {
    display: block;
  }
  .home-body .link-icon-circle {
    display: none;
  }
  .home-body .link-text__anchor_icon::before {
    display: block;
  }
}

/* フィードイン */

.fade-in-item {
  opacity: 0;
  transform: translateY(25px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
  visibility: hidden;
}

.fade-in-item.is-visible {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
}
/* site-search */


.site-search-search-box-container {
  margin-bottom: 55px;
}
@media screen and (min-width: 768px) {
  .site-search-search-box-container {
    margin-bottom: 65px;
  }
}

.gn_search_site-search .gn_search_searchBox_query_wrap {
  width: 100%;
}
.gn_search_site-search .gn_search_searchBox_items {
  display: flex;
  align-items: center;
  position: relative;
}

.gn_search_site-search .gn_search_searchBox_query_input {
  background-color: #f2f2f5;
  border: none;
  border-radius: 8px;
  height: 50px;
  font-family: var(--font-en);
  font-size: 1.4rem;
  padding-right: 0;
  padding-left: 20px;
  width: calc(100% - 20px);
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .gn_search_searchBox_query_input {
    height: 56px;
  }
}

.gn_search_site-search .gn_search_searchBox_query_input::placeholder {
  font-family: var(--font-en);
  font-size: 1.4rem;
  color: var(--color-plane);
  opacity: .5;
}
.gn_search_site-search .gn_search_searchBox_query_input::-webkit-search-cancel-button {
  -webkit-appearance: none;
  display: none;
}

.gn_search_site-search .gn_search_searchBox_submit {
  position: absolute;
  right: 10px;
  background: var(--color-point);
  color: #fff;
  border: none;
  border-radius: 35px;
  width: 36px;
  height: 36px;
  cursor: pointer;
  font-family: var(--font-en);
  padding: 0;
  transition: .3s;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .gn_search_searchBox_submit {
    width: 101px;
  }
}
.gn_search_site-search .gn_search_searchBox_submit:is(:hover,:focus) {
  background: var(--color-sub);
}
.gn_search_site-search .gn_search_searchBox_submit::before {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNC41MyIgaGVpZ2h0PSIxNC41MyIgdmlld0JveD0iMCAwIDE0LjUzIDE0LjUzIj48cGF0aCBkPSJNNiwxLjVBNC41LDQuNSwwLDEsMCwxMC41LDYsNC41MDUsNC41MDUsMCwwLDAsNiwxLjVNNiwwQTYsNiwwLDEsMSwwLDYsNiw2LDAsMCwxLDYsMFoiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMy40Nyw0LjUzbC00LTRMLjUzLS41M2w0LDRaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxMCAxMCkiIGZpbGw9IiNmZmYiLz48L3N2Zz4=);
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  padding: 7px;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .gn_search_searchBox_submit::before {
    margin-right: 4px;
  }
}
.gn_search_site-search .gn_search_searchBox_submit span {
  display: none;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .gn_search_searchBox_submit span {
    display: inline-block;
  }
}

.gn_search_site-search .search-results ._cp_component ._searchstatusfull {
  border-bottom: 1px solid var(--color-plane);
  font-family: var(--font-en);
  font-size: 1.3rem;
  font-weight: 500;
  letter-spacing: .1em;
  padding-bottom: 17px;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .search-results ._cp_component ._searchstatusfull {
    font-size: 1.5rem;
    padding-bottom: 15px;
    margin-bottom: 30px;
  }
}
.gn_search_site-search .search-results ._cp_component ._searchstatusfull ._countstart,
.gn_search_site-search .search-results ._cp_component ._searchstatusfull ._countend,
.gn_search_site-search .search-results ._cp_component ._searchstatusfull ._totalhits,
.gn_search_site-search .search-results ._cp_component ._searchstatusfull ._keyword {
  font-size: 1.8rem;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .search-results ._cp_component ._searchstatusfull ._countstart,
  .gn_search_site-search .search-results ._cp_component ._searchstatusfull ._countend,
  .gn_search_site-search .search-results ._cp_component ._searchstatusfull ._totalhits,
  .gn_search_site-search .search-results ._cp_component ._searchstatusfull ._keyword {
    font-size: 2.0rem;
  }
}

.gn_search_searchBox_query_wrap .poplink.pcia {
  width: 100%;
  font-size: 1.3rem;
}
@media screen and (min-width: 768px) {
  .gn_search_searchBox_query_wrap .poplink.pcia {
    width: calc(100% - 111px);
  }
}
.gn_search_searchBox_query_wrap .poplink.pcia .poplink_suggest {
  display: flex;
  flex-wrap: wrap;
  background-color: #fff;
  border: 1px solid var(--color-pale);
  border-radius: 8px;
  margin-top: 5px;
  padding: 15px 25px;
}
.gn_search_searchBox_query_wrap .poplink.pcia .poplink_suggest .word {
  width: 100%;
  color: var(--color-main);
  border-top: 1px solid #e0e0e0;
  padding: 12px 0;
  cursor: pointer;
}
.gn_search_searchBox_query_wrap .poplink.pcia .poplink_suggest .word.highlighted {
  color: var(--color-pale);
  background-color: #fff;
}

.gn_search_searchBox_query_wrap .poplink.pcia .poplink_suggest .word:hover {
  color: var(--color-pale);
  background-color: #fff;
}

.gn_search_searchBox_query_wrap .poplink.pcia .poplink_suggest .word:first-child {
  border-top: none;
}


.gn_search_site-search .search-results ._cp_component ._item {
  margin: 0 0 20px 0;
  padding: 0 0 37px 0;
  border-bottom: 1px solid var(--color-pale);
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .search-results ._cp_component ._item {
    margin: 0 0 30px 0;
    padding: 0 0 30px 0;
  }
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap {
  width: 100%;
  display: flex;
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup1 {
  display: block;
  padding: 0;
  margin-bottom: 0;
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup1 ._thumbnail {
  min-width: 110px;
  min-height: 83px;
  padding: 0;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup1 ._thumbnail {
    width: 202px;
    height: 152px;
  }
}

.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup1 ._thumbnail a img {
  vertical-align: top;
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 {
  color: var(--color-main);
  display: block;
  padding-right: 0;
  padding-left: 10px;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 {
    padding-left: 30px;
  }
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._title {
  font-size: 1.4rem;
  padding-left: 0;
  padding-right: 0;
  padding-bottom: 13px;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._title {
    font-size: 1.7rem;
    padding-bottom: 17px;
  }
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._snippet {
  font-size: 1.3rem;
  padding-left: 0;
  padding-right: 0;
  padding-bottom: 17px;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._snippet {
    font-size: 1.4rem;
    padding-bottom: 22px;
  }
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._snippet em {
  background-color: rgba(255,222,226,.5);;
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._link {
  font-size: 1.3rem;
  line-height: 1.5;
  padding-left: 0;
  padding-right: 0;
  padding-top: 29px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._link {
    padding-top: 0;
    padding-left: 69px;
  }
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._link a::before {
  content: "URL";
  color: #fff;
  margin-right: 10px;
  padding: 0 15px;
  border-radius: 10px;
  background-color: var(--color-plane);
  font-size: 1.3rem;
  max-height: 22px;
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._link a::before {
    content: "URL";
    color: #fff;
    margin-right: 10px;
    padding: 0 15px;
    border-radius: 10px;
    background-color: var(--color-plane);
    font-size: 1.3rem;
    max-height: 22px;
    position: absolute;
    left: 0;
  }
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._link a:hover {
  color: var(--color-point);
  text-decoration: none;
  cursor: pointer;
}
.gn_search_site-search .search-results ._cp_component ._item ._wrap ._layoutgroup2 ._link a:hover::before{
  background-color: var(--color-point);
}

.gn_search_site-search .search-results ._cp_component ._pagenator {
  padding: 0;
  margin-top: 15px;
  margin-bottom: 156px;
  margin-left: 0;
  margin-right: 0;
  font-size: 1.8rem;
}
@media screen and (min-width: 768px) {
  .gn_search_site-search .search-results ._cp_component ._pagenator {
    padding: 0;
    margin-top: 20px;
    margin-bottom: 215px;
    margin-left: 0;
    margin-right: 0;
    font-size: 1.8rem;
  }
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav {
  flex: none;
  margin: 0 .25rem;
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav a {
  padding: .5rem 1.2rem;
  color: var(--color-plane)
  height: 100%;
  display: inline-block;
  text-decoration: none;
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._page {
  padding: 0;
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._page._current {
  padding: .5rem 1.2rem;
  color: var(--color-film);
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._first,
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._prev,
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._next {
  margin: 0 .25rem;
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._first a,
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._prev a,
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._next a {
  border: none;
  height: 28px;
  vertical-align: middle;
  width: 28px;
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._first ._disable,
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._prev ._disable,
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._next ._disable {
  display: none;
}

.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._first {
  position: relative;
  display: none;
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._first ._button::before {
  content: "";
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA1MTIgNTEyIj48IS0tISBGb250IEF3ZXNvbWUgUHJvIDYuNC4yIGJ5IEBmb250YXdlc29tZSAtIGh0dHBzOi8vZm9udGF3ZXNvbWUuY29tIExpY2Vuc2UgLSBodHRwczovL2ZvbnRhd2Vzb21lLmNvbS9saWNlbnNlIChDb21tZXJjaWFsIExpY2Vuc2UpIENvcHlyaWdodCAyMDIzIEZvbnRpY29ucywgSW5jLiAtLT48cGF0aCBkPSJNNDEuNCAyMzMuNGMtMTIuNSAxMi41LTEyLjUgMzIuOCAwIDQ1LjNsMTYwIDE2MGMxMi41IDEyLjUgMzIuOCAxMi41IDQ1LjMgMHMxMi41LTMyLjggMC00NS4zTDEwOS4zIDI1NiAyNDYuNiAxMTguNmMxMi41LTEyLjUgMTIuNS0zMi44IDAtNDUuM3MtMzIuOC0xMi41LTQ1LjMgMGwtMTYwIDE2MHptMzUyLTE2MGwtMTYwIDE2MGMtMTIuNSAxMi41LTEyLjUgMzIuOCAwIDQ1LjNsMTYwIDE2MGMxMi41IDEyLjUgMzIuOCAxMi41IDQ1LjMgMHMxMi41LTMyLjggMC00NS4zTDMwMS4zIDI1NiA0MzguNiAxMTguNmMxMi41LTEyLjUgMTIuNS0zMi44IDAtNDUuM3MtMzIuOC0xMi41LTQ1LjMgMHoiLz48L3N2Zz4=);
  width: 9.5px;
  height: 10px;
  display: inline-block;
  background-repeat: no-repeat;
  position: absolute;
  left: calc(50% - 5.5px);
  top: calc(50% - 4.5px);
}

.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._prev {
  position: relative;
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._prev ._button::before {
  content: "";
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI1LjU5IiBoZWlnaHQ9IjkuMDYiIHZpZXdCb3g9IjAgMCA1LjU5IDkuMDYiPjxwYXRoIGQ9Ik03LjQ3LDQuNTI5LDQsMS4wNi41Myw0LjUyOS0uNTMsMy40NjgsNC0xLjA2LDguNTMsMy40NjhaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxLjA2IDguNTMpIHJvdGF0ZSgtOTApIiBmaWxsPSIjZmZmIi8+PC9zdmc+);
  width: 28px;
  height: 28px;
  display: inline-block;
  background-repeat: no-repeat;
  position: absolute;
  left: calc(50% - 3.5px);
  top: calc(50% - 4.5px);
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._next {
  position: relative;
}
.gn_search_site-search .search-results ._cp_component ._pagenator ._nav._next ._button::before {
  content: "";
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI1LjU5IiBoZWlnaHQ9IjkuMDYiIHZpZXdCb3g9IjAgMCA1LjU5IDkuMDYiPjxwYXRoIGQ9Ik03LjQ3LDQuNTI5LDQsMS4wNi41Myw0LjUyOS0uNTMsMy40NjgsNC0xLjA2LDguNTMsMy40NjhaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSg0LjUyOSAwLjUzKSByb3RhdGUoOTApIiBmaWxsPSIjZmZmIi8+PC9zdmc+);
  width: 28px;
  height: 28px;
  display: inline-block;
  background-repeat: no-repeat;
  position: absolute;
  left: calc(50% - 2.5px);
  top: calc(50% - 4.5px);
}

.gn_search_site-search .search-results ._cp_component ._pagenator ._nav ._button:active {
  transform: none;
  box-shadow: none;
}

.gn_search_site-search .search-results ._cp_component ._pagenator ._nav ._button {
  background-color: var(--color-point);
  border-radius: 50%;
  padding: 0;
}

/* サイト全体で共通のエレメント */
/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

/* カラム */

/* 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: flex;
    flex-wrap: wrap;
    margin-right: calc(var(--column-margin-horizon) * -1);
    margin-left: calc(var(--column-margin-horizon) * -1);
  }
}

/* [.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;
    padding-right: var(--column-margin-horizon);
    padding-left: var(--column-margin-horizon);
  }
}

/* 1カラム */
@media screen and (min-width: 768px) {
  .columns--one > .columns__column:nth-child(n+2) {
    margin-top: var(--column-margin-top);
  }
}

/* 2カラム */
@media screen and (min-width:768px) {
  .columns--two > .columns__column {
    width: 50%
  }
  .columns--two > .columns__column:nth-child(n+3){
    margin-top: var(--column-margin-top);
  }
}

/* 3カラム */
@media screen and (min-width:768px) {
  .columns--three > .columns__column {
    width: 50%;
  }
  .columns--three > .columns__column:nth-child(n+3) {
    margin-top: var(--column-margin-top);
  }
}
@media screen and (min-width:1050px) {
  .columns.columns--three {
    margin-right: calc(var(--column-margin-horizon)* -1);
    margin-left: calc(var(--column-margin-horizon)* -1);
  }
  .columns.columns--three:has(.columns__column__inner--bg) {
    margin-right: calc(var(--column-margin-horizon-narrow)* -1);
    margin-left: calc(var(--column-margin-horizon-narrow)* -1);
  }
  .columns.columns--three > .columns__column {
    width: calc(100% / 3);
    padding-right: var(--column-margin-horizon);
    padding-left: var(--column-margin-horizon);
  }
  .columns.columns--three > .columns__column:has(.columns__column__inner--bg) {
    padding-right: var(--column-margin-horizon-narrow);
    padding-left: var(--column-margin-horizon-narrow);
  }
  .columns--three > .columns__column:nth-child(3) {
    margin-top: 0;
  }
}

/* 4カラム */
@media screen and (min-width:768px) {
  .columns.columns--four {
    margin-right: calc(var(--column-margin-horizon) * -1);
    margin-left: calc(var(--column-margin-horizon) * -1);
  }
  .columns--four > .columns__column {
    width: 50%;
    padding-right: var(--column-margin-horizon);
    padding-left: var(--column-margin-horizon);
  }
  .columns--four > .columns__column:nth-child(n+3) {
    margin-top: var(--column-margin-top);
  }
}
@media screen and (min-width:1050px) {
  .columns.columns--four {
    margin-right: calc(var(--column-margin-horizon-narrow) * -1);
    margin-left: calc(var(--column-margin-horizon-narrow) * -1);
  }
  .columns.columns--four > .columns__column {
    width: calc(100% / 4);
    padding-right: var(--column-margin-horizon-narrow);
    padding-left: var(--column-margin-horizon-narrow);
  }
  .columns--four > .columns__column:is(:nth-child(3), :nth-child(4)) {
    margin-top: 0;
  }
}

/* 1:2カラム */
@media screen and (min-width:768px) {
  .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

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

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

.entry-button.rich-button-center {
  text-align: center;
}
.entry-button a {
  display: block;
  box-sizing: border-box;
  position: relative;
  min-width: inherit;
  max-width: 450px;
  margin: 0 auto;
  padding: 19px 59px 18px 24px;
  background-color: var(--color-point);
  color: #ffffff;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: var(--ls-root);
  line-height: 1.5;
  text-align: left;
  transition: .5s;
  border-radius: 40px;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .entry-button a {
    display: inline-block;
    min-width: 450px;
    font-weight: 600;
    padding: 20px 70px 18px 36px;
    font-size: 2rem;
  }
}
@media screen and (min-width: 1050px) {
  .entry-button .link-icon-circle {
    transition: transform .7s, background-color .6s ease-in;
  }
  .entry-button a:is(:hover, :focus) .link-icon-circle {
    background-color: var(--color-sub);
    transform: scale(150);
    transition: transform 1.2s, background-color .8s ease-out;
  }
  .entry-button a:is(:hover, :focus):has(.is-exlink) {
    background-color: var(--color-sub);
  }

}

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

.entry-button .link-button__anchor__icon::before {
  right: 12px;
  top: 3px;
}

.entry-button__text {
  position: relative;
}

.entry-button__decoration-text {
  content: attr(data-entry);
  display: block;
  width: 100%;
  font-family: var(--font-en);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: var(--ls-root);
  line-height: 1;
  transition: .5s;
  opacity: .5;
}

/* link icon */
.entry-button .link-icon-circle {
  position: absolute;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
  background-color: #ffffff;
}
@media screen and (min-width: 768px) {
  .entry-button .link-icon-circle {
    right: 20px;
  }
}
.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;
  position: absolute;
  right: 30px;
  top: 36%;
}
@media screen and (min-width: 768px) {
  .entry-button .entry-button__icon.is-exlink {
    width: 22px;
    height: 22px;
  }
}
.entry-button .entry-button__icon.is-exlink .entry-button__icon__path {
  fill: #ffffff;
}
/* ==========================================================================

    figure

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

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

.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;
  border-radius: 10px;
}
@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;
  }
}
/* 見出し */

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

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

.section-heading2 {
  margin-top: 60px;
  margin-bottom: 25px;
}
@media screen and (min-width: 768px) {
  .section-heading2 {
    margin-top: 80px;
    margin-bottom: 45px;
  }
}

.heading-2 {
  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);
  color: var(--color-point);
}
@media screen and (min-width: 768px) {
  .heading-2 {
    margin-top: 80px;
    margin-bottom: 45px;
    font-size: var(--fz-h2-desktop);
  }
}
.heading-2:first-child {
  margin-top: 0;
}
.heading-2:last-child {
  margin-bottom: 0;
}

/* 上下margin相殺 */
.heading-2::before,
.heading-2::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.heading-2::before {
  margin-top: calc((1 - var(--lh-heading)) * .5em);
}
.heading-2::after {
  margin-bottom: calc((1 - var(--lh-heading)) * .5em);
}

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

.heading-2__deco {
  display: block;
  margin-bottom: 1px;
  color: var(--color-main);
  font-family: var(--font-en);
  font-size: var(--fz-h2-decoration-palmtop);
  font-weight: 600;
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
  opacity: .3;
}
@media screen and (min-width: 768px) {
  .heading-2__deco {
    margin-bottom: 6px;
    font-size: var(--fz-h2-decoration-desktop);
  }
}

.heading-2--reverse {
  color: #ffffff;
}
.heading-2--reverse .heading-2__deco {
  color: #ffffff;
  opacity: 1;
}
.heading-2--reverse .heading-2__inner::after {
  border-color: #ffffff;
}

.heading-2__inner::after {
  content: "";
  border-bottom: solid 2px var(--color-sub);
  display: block;
  width: 22px;
  padding-top: 13px;
}
@media screen and (min-width: 768px) {
  .heading-2__inner::after {
    border-bottom: solid 3px var(--color-sub);
    width: 24px;
    padding-top: 14px;
  }
}

.text-center .heading-2__inner::after {
  margin: 0 auto;
}

.text-right .heading-2__inner::after {
  margin-left: auto;
  margin-right: 0;
}
/* h3 */

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

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

.heading-3 {
  margin-top: 40px;
  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) {
  .heading-3 {
    margin-top: 55px;
    margin-bottom: 30px;
    font-size: var(--fz-h3-desktop);
  }
}
.heading-3:first-child {
  margin-top: 0;
}
.heading-3:last-child {
  margin-bottom: 0;
}

/* 上下margin相殺 */
.heading-3::before,
.heading-3::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.heading-3::before {
  margin-top: calc((1 - var(--lh-heading)) * .5em);
}

.heading-3::after {
  margin-bottom: calc((1 - var(--lh-heading)) * .5em);
}

/* heading-3装飾 */
.heading-3__inner {
  position: relative;
  display: inline-block;
  padding-left: 30px;
}
@media screen and (min-width: 768px) {
  .heading-3__inner {
    padding-left: 45px;
  }
}

.heading-3__inner::before {
  content: "";
  top: 11px;
  position: absolute;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 20px;
  background-color: var(--color-sub);
}
@media screen and (min-width: 768px) {
  .heading-3__inner::before {
    width: 15px;
    height: 15px;
    top: 12px;
  }
}

.heading-3__inner::after {
  content: "";
  margin-bottom: calc((1 - var(--lh-heading)) * .5em);
  top: 12px;
  position: absolute;
  left: 14px;
  width: 6px;
  height: 6px;
  border-radius: 20px;
  background-color: var(--color-point);
}
@media screen and (min-width: 768px) {
  .heading-3__inner::after {
    width: 9px;
    height: 9px;
    left: 22px;
    top: 16px;
  }
}

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

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

.section-heading4 {
  margin-top: 30px;
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .section-heading4 {
    margin-top: 45px;
    margin-bottom: 25px;
  }
}

.heading-4 {
  margin-top: 30px;
  margin-bottom: 20px;
  color: var(--color-main);
  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: 45px;
    margin-bottom: 25px;
    font-size: var(--fz-h4-desktop);
  }
}
.heading-4:first-child {
  margin-top: 0;
}
.heading-4:last-child {
  margin-bottom: 0;
}

/* 上下margin相殺 */
.heading-4::before,
.heading-4::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.heading-4::before {
  margin-top: calc((1 - var(--lh-heading)) * .5em);
}
.heading-4::after {
  margin-bottom: calc((1 - var(--lh-heading)) * .5em);
}


/*
  === 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 === */
/* h5 */

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

.section-heading5 {
  margin-top: 30px;
  margin-bottom: 20px;
}

.heading-5 {
  margin-top: 30px;
  margin-bottom: 20px;
  color: var(--color-main);
  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;
}

/* 上下margin相殺 */
.heading-5::before,
.heading-5::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.heading-5::before {
  margin-top: calc((1 - var(--lh-heading)) * .5em);
}
.heading-5::after {
  margin-bottom: calc((1 - var(--lh-heading)) * .5em);
}

/*
  === 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 === */
/* ==========================================================================

  heading link

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

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

.heading-link {
  position: relative;
}
.heading-link:not(:first-child) {
  margin-top: 20px;
}
.heading-link:not(:last-child) {
  margin-bottom: 20px;
}
@media screen and (min-width: 768px) {
  .heading-link:not(:first-child) {
    margin-top: 30px;
  }
  .heading-link:not(:last-child) {
    margin-bottom: 30px;
  }
}
/* 見出しレベル別　アイコン位置調整 */
.heading-2.heading-link,
.heading-3.heading-link {
  padding-left: 34px;
}
.heading-4.heading-link,
.heading-5.heading-link {
  padding-left: 30px;
}
@media screen and (min-width: 768px) {
  .heading-2.heading-link {
    padding-left: 43px;
  }
  .heading-3.heading-link {
    padding-left: 38px;
  }
  .heading-4.heading-link,
  .heading-5.heading-link {
    padding-left: 34px;
  }
}

.heading-link a {
  color: var(--color-main);
  display: inline-block;
  text-decoration: none;
  transition: color .5s;
}
@media screen and (min-width: 1050px) {
  .heading-link a:is(:hover, :focus) .link-icon {
    background-color: var(--color-sub);
  }
  .heading-link a .link-icon:before{
    content: none;
  }
}

.heading-link .link-icon {
  display: block;
  position: absolute;
  left: 0;
  border-radius: 20px;
  background-color: var(--color-point);
  transition: background-color .3s;
}

.link-icon__arrow {
  position: absolute;
  top: 7px;
  right: 7px;
}
/* 見出しレベル別　アイコン位置調整 */
.heading-2.heading-link .link-icon {
  top: 6px;
  width: 24px;
  height: 24px;
}
.heading-2 .link-icon__arrow {
  top: 11px;
  right: 7px;
  width: 10px;
  height: 10px;
}
.heading-3.heading-link .link-icon {
  top: 2px;
  width: 24px;
  height: 24px;
}
.heading-3 .link-icon__arrow {
  left: 55%;
  top: 11px;
  width: 9px;
  height: 9px;
}
.heading-4.heading-link .link-icon {
  top: 2px;
  width: 20px;
  height: 20px;
}
.heading-4 .link-icon__arrow {
  right: 5px;
  top: 9px;
  width: 8px;
  height: 8px;
}
.heading-5.heading-link .link-icon {
  top: 1px;
  width: 20px;
  height: 20px;
}
.heading-5 .link-icon__arrow {
  height: 7px;
  right: 5px;
  top: 9px;
  width: 7px;
}
@media screen and (min-width: 768px) {
  .heading-2.heading-link .link-icon {
    top: 11px;
    width: 32px;
    height: 32px;
  }
  .heading-2 .link-icon__arrow {
    top: 47%;
    left: 54%;
    width: 15px;
    height: 14px;
  }
  .heading-3.heading-link .link-icon {
    top: 13%;
    width: 28px;
    height: 28px;
  }
  .heading-3 .link-icon__arrow {
    left: 54%;
    top: .54em;
    width: 13px;
    height: 12px;
  }
  .heading-4.heading-link .link-icon {
    top: 3px;
    width: 24px;
    height: 24px;
  }
  .heading-4 .link-icon__arrow {
    right: 5px;
    top: 11px;
    height: 11px;
    width: 12px;
  }
  .heading-5.heading-link .link-icon {
    top: 1px;
    width: 24px;
    height: 24px;
  }
  .heading-5 .link-icon__arrow {
    right: 5px;
    top: 11px;
    height: 11px;
    width: 12px;
  }
}

/* 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 screen and (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 screen and (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;
  }
  .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 screen and (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: 75px;
  margin-bottom: 55px;
}
@media screen and (min-width: 768px) {
  .section-lead {
    margin-top: 55px;
  }
}

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

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

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

    link

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

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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


/* 文中リンク */
.link {
  display: inline-block;
  position: relative;
  color: var(--color-plane);
  text-decoration: none;
  word-break: break-all;
  transition: .5s;
}
.link:is(:hover, :focus) {
  color: var(--color-point);
  text-decoration: none;
}
.link::after {
  content: "";
  position: absolute;
  bottom: 2px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: var(--color-point);
  transition: .5s;
}
.link:is(:hover, :focus)::after {
  background-color: var(--color-point);
}

/* 外部リンクアイコン付き文中リンク */
.link--window {
  padding-left: 20px;
}
.link--window::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 12px;
  height: 12px;
  margin-top: -6px;
  background: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMS45NjkiIGhlaWdodD0iMTEuOTY5IiB2aWV3Qm94PSIwIDAgMTEuOTY5IDExLjk2OSI+CiAgPHBhdGggaWQ9IuODkeOCuV82NDIxIiBkYXRhLW5hbWU9IuODkeOCuSA2NDIxIiBkPSJNLTc4OC41MjksMGgtNi4zNDJhLjUyOC41MjgsMCwwLDAtLjUyOC41MjlWMi4xNjdoLTMuODdhLjcuNywwLDAsMC0uNy43djguNGEuNy43LDAsMCwwLC43LjdoOC40YS43LjcsMCwwLDAsLjctLjdWNy40aDEuNjM4QS41MjguNTI4LDAsMCwwLTc4OCw2Ljg3MVYuNTI5QS41MjkuNTI5LDAsMCwwLTc4OC41MjksMFptLTIuNjM4LDEwLjk2OWgtNy44di03LjhoMy41N3YzLjdhLjUyNy41MjcsMCwwLDAsLjUyOC41MjhoMy43Wk0tNzg5LDYuNGgtNS40VjFoNS40WiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNzk5Ljk2OSkiIGZpbGw9IiM0MTQxNDEiLz4KPC9zdmc+Cg==") no-repeat center;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
/* ==========================================================================

  リンクボタン

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

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

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

.link-button__anchor {
  box-sizing: border-box;
  display: block;
  position: relative;
  padding: 15px 45px 13px 29px;
  border: none;
  color: #ffffff;
  font-family: var(--font-button);
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: var(--ls-root);
  word-break: break-all;
  transition: color .4s;
  border-radius: 31px;
  background-color: var(--color-point);
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .link-button__anchor {
    padding: 19px 45px 17px 30px;
    font-size: 1.6rem;
  }
}

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

/* link icon */
.link-button__anchor__icon {
  display: block;
  position: absolute;
  top: 50%;
  right: 10px;
  width: 24px;
  height: 24px;
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .link-button__anchor__icon {
    width: 28px;
    height: 28px;
    top: 53%;
  }
}
.link-button__anchor__icon svg {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: -5px;
  right: 9px;
  padding: 5px;
}
@media screen and (min-width: 768px) {
  .link-button__anchor__icon svg {
    right: 19px;
  }
}

.link-button__anchor__icon::before {
  content: "";
  display: block;
  height: 15px;
  background-image:url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMi40OCIgaGVpZ2h0PSIxMi40OCIgdmlld0JveD0iMCAwIDEyLjQ4IDEyLjQ4Ij4KICA8ZyBpZD0i44Kw44Or44O844OXXzQwNzA0IiBkYXRhLW5hbWU9IuOCsOODq+ODvOODlyA0MDcwNCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNC4yODYgMS4xMjQpIHJvdGF0ZSg0NSkiPgogICAgPHBhdGggaWQ9IuODkeOCuV8xMTA4MSIgZGF0YS1uYW1lPSLjg5HjgrkgMTEwODEiIGQ9Ik0wLDUsNSwwbDUsNSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAwLjAwMikiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIxLjUiLz4KICAgIDxwYXRoIGlkPSLjg5HjgrlfMTEwODIiIGRhdGEtbmFtZT0i44OR44K5IDExMDgyIiBkPSJNMCwwVjEwIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSg1LjAwMikiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIxLjUiLz4KICA8L2c+Cjwvc3ZnPgo=');
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  right: 5px;
  top: 4px;
  transition: opacity .7s;
  width: 15px;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .link-button__anchor__icon::before {
    right: 7px;
    top: 3px;
  }
}
@media screen and (min-width: 1050px) {
  .link-button__anchor__icon::before {
    right: 6px;
    top: 4px;
  }
}
@media screen and (min-width: 1050px) {
  .link-button__anchor__icon::before {
    opacity: 0;
  }
  a:hover .link-button__anchor__icon::before {
    opacity: 1;
  }
  a:focus-visible .link-button__anchor__icon::before {
    opacity: 1;
  }
}

@media screen and (min-width: 768px) and (max-width: 1049px) {
  .link-button__anchor__icon:before {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .link-icon-circle {
    border-radius: 50%;
    height: 8px;
    isolation: isolate;
    overflow: hidden;
    position: absolute;
    right: 18px;
    top: 35%;
    transform: translate(50%, -50%);
    transition: all .5s;
    width: 8px;
    background-color: var(--color-point);
  }
}



.link-button__anchor .link-icon-circle::before {
  display: none;
}

.link-button__anchor__icon__path {
  fill: #ffffff;
  transition: fill .3s;
}
.link-button__anchor__icon__path--reverse {
  fill: var(--color-main);
  transition: fill .3s;
}
.link-button--reverse .link-button__anchor__icon__path {
  fill: var(--color-point);
  transition: fill .6s;
}
.link-button__anchor .link-icon-circle {
  background-color: #ffffff;
  top: 50%;
  transition: transform .7s ,background-color .6s ease-in;
}

.link-button__anchor.is-exlink .link-icon-circle {
  right: -35px;
  top: 6px;
}
.is-exlink.link-button__anchor .link-button__anchor__icon::before {
  top: -5px;
}
@media screen and (min-width: 768px) {
  .is-exlink.link-button__anchor .link-button__anchor__icon::before {
    top: -2px;
  }
}

@media screen and (min-width: 1050px) {
  .link-button__anchor.is-exlink {
    transition: .6s;
  }
  .link-button__anchor.is-exlink:is(:hover, :focus) {
    background-color: var(--color-sub);
  }
  .home_recruit .link-button__anchor.is-exlink:is(:hover, :focus) {
    background-color: #ffffff;
  }
  .bl-hover .link-button__anchor.is-exlink {
    background-color: var(--color-sub);
  }
  .bl-hover .link-button__anchor__icon.is-exlink .link-button__anchor__icon__path {
    fill: #fff;
  }
}

@media screen and (min-width: 1050px) {
  .is-exlink.link-button__anchor .link-button__anchor__icon::before {
    top: -4px;
  }
  .link-button__anchor:is(:hover, :focus) .link-button__anchor__icon::before {
    opacity: 1;
  }
  .link-button__anchor:is(:hover, :focus) .link-icon-circle {
    transform: scale(150);
    background-color: var(--color-sub);
    transition: transform 1.2s ,background-color .8s ease-out;
  }
  .link-button__anchor:is(:hover, :focus) .link-button__anchor__icon__path--reverse,
  :is(a:hover, a:focus, .bl-hover) .link-button__anchor__icon__path--reverse {
    fill: var(--color-sub);
  }
}

/* link icon : PDF */
.link-button__anchor.is-pdf .link-button__anchor__icon {
  width: 18px;
  height: 18.47px;
}
@media screen and (min-width: 768px) {
  .link-button__anchor.is-pdf .link-button__anchor__icon {
    width: 21px;
    height: 21.54px;
  }
}

.link-button__anchor.is-pdf .link-button__anchor__icon::before {
  content: none;
}

@media screen and (min-width: 1050px) {
  .link-button__anchor.is-pdf {
    transition: background-color .5s;
  }
  .link-button__anchor.is-pdf:hover {
    background-color: var(--color-sub);
  }
}

/* link icon : external link */
.link-button__anchor.is-exlink .link-button__anchor__icon {
  width: 16px;
  height: 16px;
}
@media screen and (min-width: 768px) {
  .link-button__anchor.is-exlink .link-button__anchor__icon {
    width: 22px;
    height: 22px;
  }
}

.link-button__anchor.is-exlink .link-button__anchor__icon.home_recruit_button {
  display: none;
}

.link-button__anchor__icon.is-exlink::before {
  content: none;
}

/* icon reverse */
.link-button--reverse .link-button__anchor {
  border: none;
  color: var(--color-point);
  background-color: #ffffff;
  transition: color .6s , background-color .7s ;
}
.link-button--reverse .link-button__anchor::before {
  background-color: #ffffff;
}
.link-button--reverse .link-button__anchor .link-icon-circle {
  background-color: var(--color-point);
  transition: transform .7s, background-color .7s ease-in;
}

.link-button--reverse .link-button__anchor__icon::before {
  height: 14px;
  background-image:url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNC42MDEiIGhlaWdodD0iMTQuNjAyIiB2aWV3Qm94PSIwIDAgMTQuNjAxIDE0LjYwMiI+CiAgPGcgaWQ9IuOCsOODq+ODvOODl180MTQ0MiIgZGF0YS1uYW1lPSLjgrDjg6vjg7zjg5cgNDE0NDIiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDQuOTkzIDEuMTI0KSByb3RhdGUoNDUpIj4KICAgIDxwYXRoIGlkPSLjg5HjgrlfMTEwODEiIGRhdGEtbmFtZT0i44OR44K5IDExMDgxIiBkPSJNMCw2LDYsMGw2LDYiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAgMC4wMDIpIiBmaWxsPSJub25lIiBzdHJva2U9IiMxMTE5ODciIHN0cm9rZS13aWR0aD0iMS41Ii8+CiAgICA8cGF0aCBpZD0i44OR44K5XzExMDgyIiBkYXRhLW5hbWU9IuODkeOCuSAxMTA4MiIgZD0iTTAsMFYxMiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNi4wMDIpIiBmaWxsPSJub25lIiBzdHJva2U9IiMxMTE5ODciIHN0cm9rZS13aWR0aD0iMS41Ii8+CiAgPC9nPgo8L3N2Zz4K');
}
@media screen and (min-width: 1050px) {
  .link-button--reverse .link-button__anchor__icon::before {
    background-image:url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMi40OCIgaGVpZ2h0PSIxMi40OCIgdmlld0JveD0iMCAwIDEyLjQ4IDEyLjQ4Ij4KICA8ZyBpZD0i44Kw44Or44O844OXXzQwNzA0IiBkYXRhLW5hbWU9IuOCsOODq+ODvOODlyA0MDcwNCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNC4yODYgMS4xMjQpIHJvdGF0ZSg0NSkiPgogICAgPHBhdGggaWQ9IuODkeOCuV8xMTA4MSIgZGF0YS1uYW1lPSLjg5HjgrkgMTEwODEiIGQ9Ik0wLDUsNSwwbDUsNSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAwLjAwMikiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIxLjUiLz4KICAgIDxwYXRoIGlkPSLjg5HjgrlfMTEwODIiIGRhdGEtbmFtZT0i44OR44K5IDExMDgyIiBkPSJNMCwwVjEwIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSg1LjAwMikiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIxLjUiLz4KICA8L2c+Cjwvc3ZnPgo=');
  }
}



/* icon reverse hover style */
@media screen and (min-width: 1050px) {
  .link-button--reverse .link-button__anchor:is(:hover, :focus),
  :is(a:hover, a:focus, .bl-hover) .link-button--reverse .link-button__anchor {
    color: #ffffff;
  }
  .link-button--reverse .link-button__anchor:is(:hover, :focus) .link-icon-circle {
    background-color: var(--color-sub);
    transition: transform 1.5s, background-color .3s ease-out;
  }
  .link-button--reverse .link-button__anchor:is(:hover, :focus) .link-button__anchor__icon.is-exlink .link-button__anchor__icon__path {
    fill: #ffffff;
  }
  .bl-hover .link-button__anchor .link-icon-circle {
    transform: scale(200);
    background-color: var(--color-sub);
  }
  .bl-hover .link-button__anchor__icon::before {
    opacity: 1;
  }
}

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

/* === MAX 3column list */
.section-button__list {
  display: flex;
  flex-wrap: wrap;
  margin-top: 30px;
  margin-bottom: 30px;
}
.section-button__list .link-button {
  width: 280px;
  margin-top: 0;
}
@media screen and (min-width: 768px) {
  .section-button__list {
    margin-top: 40px;
    margin-bottom: 40px;
  }
  .section-button__list .link-button:not(:last-child) {
    margin-right: 40px;
  }
}
@media screen and (min-width: 1050px) {
  .section-button__list .link-button:not(:last-child) {
    margin-bottom: 0;
  }
}

/* center */
.section-button__list.rich-button-center {
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .section-button__list.rich-button-center {
    flex-direction: column;
    align-items: center;
  }
}
@media screen and (min-width: 768px) {
  .section-button__list.rich-button-center .link-button {
    margin-right: 20px;
    margin-left: 20px;
  }
}

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

  link icon

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

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

.link-icon {
  display: inline-block;
  position: relative;
  width: 24px;
  height: 24px;
}
@media screen and (min-width: 768px) {
  .link-icon {
    width: 28px;
    height: 28px;
  }
}

/* link icon : arrow background circle */
.link-icon:not(.is-pdf, .is-exlink)::before {
  content: "";
  box-sizing: border-box;
  display: block;
  width: 100%;
  height: 100%;
  border: 1px solid var(--color-point);
  border-radius: 50%;
  transition: border .5s, background-color .5s;
}
@media screen and (min-width: 1050px) {
  :is(a:hover, a:focus, .bl-hover) .link-icon::before {
    border: 1px solid var(--color-point);
    background-color: var(--color-point);
  }
}

/* link icon : arrow svg */
.link-icon__arrow {
  position: absolute;
  top: 47%;
  left: 54%;
  width: 8px;
  height: 8px;
  transform: translate(-50%, -50%);
}
@media screen and (min-width: 768px) {
  .link-icon__arrow {
    width: 9px;
    height: 9px;
    top: 45%;
    left: 54%;
  }
}
@media screen and (min-width: 1050px) {
  .link-icon__arrow {
    left: 55%;
  }
}
/* link icon : arrow path */
.link-icon__arrow__path {
  transition: background-color .5s;
}
@media screen and (min-width: 1050px) {
  :is(a:hover, a:focus, .bl-hover) .link-icon__arrow__path {
    fill: #ffffff;
  }
  .bl-hover .heading-link .link-icon {
    background-color: var(--color-sub);
  }
}

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

/* link icon : external link */
.link-icon.is-exlink {
  width: 14px;
  height: 14px;
  background-color: transparent;
  border-radius: 0;
}
.link-icon.is-exlink .link-icon__path {
  fill: var(--color-point);
  transition: fill .3s;
}
@media screen and (min-width: 1050px) {
  .bl-hover .heading-link .link-icon.is-exlink .link-icon__path,
  .heading-link a:is(:hover, :focus) .link-icon.is-exlink .link-icon__path {
    fill: var(--color-sub);
  }
  .bl-hover .heading-link .link-icon.is-exlink,
  .heading-link a:is(:hover, :focus) .link-icon.is-exlink {
    background-color: transparent;
  }
}

/* link style : reverse */
.link-icon.link-icon--reverse::before {
  background-color: var(--color-point);
}
.link-icon.link-icon--reverse .link-icon__arrow__path {
  fill: #ffffff;
}

/* link icon : white color */
.link-icon.link-icon--white::before {
  border-color: #ffffff;
}

.link-icon.link-icon--white {
  background-color: #ffffff;
  border-radius: 50%;
}

.heading-link a:is(:hover,:focus) .link-icon.link-icon--white {
  background-color: #ffffff;
}

:is(a:hover,a:focus,.bl-hover) .link-icon.link-icon--white::before {
  background-color: #ffffff;
  border-color: #ffffff;
}
/* ==========================================================================

  テキストボタン

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

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

.link-text {
  font-family: var(--font-button);
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: var(--ls-root);
  line-height: var(--lh-heading);
}
.link-text:not(:first-child) {
  margin-top: 12px;
}
@media screen and (min-width: 768px) {
  .link-text:not(:first-child) {
    margin-top: 20px;
  }
}
.link-text:not(:last-child) {
  margin-bottom: 12px;
}
@media screen and (min-width: 768px) {
  .link-text:not(:last-child) {
    margin-bottom: 20px;
  }
  .link-text {
    font-size: 1.6rem;
  }
}

.link-text__anchor {
  padding-right: 25px; /* 位置調整用の変数 */
  display: inline-block;
  position: relative;
  padding-left: var(--icon-margin);
  transition: color .3s;
}
.link-text__anchor::before {
  content: "";
  position: absolute;
  left: var(--icon-margin);
  bottom: 0;
  width: calc(100% - var(--icon-margin));
  height: 1px;
  background-color: var(--color-point);
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform var(--transition-ptn01);
}
.link-text__anchor .link-icon-circle::before {
  right: 5px;
  top: 0px;
}
@media screen and (min-width: 768px) {
  .link-text__anchor .link-icon-circle::before{
    height: 18px;
    width: 18px;
    right: -5px;
  }
}
@media screen and (min-width: 1050px) {
  .link-text__anchor .link-icon-circle::before{
    height: 12px;
    width: 12px;
    right: 8px;
    top: 8px;
  }
}

@media screen and (min-width: 1050px) {
  .link-text__anchor .link-icon-circle {
    right: 0px;
    top: 50%;
  }
  .link-text a:is(:hover,:focus) .link-icon-circle {
    width: 38px;
    height: 38px;
    background-color: var(--color-sub);
    transform: translate(50%, -50%);
  }
  .bl-hover .link-text a .link-icon-circle {
    width: 38px;
    height: 38px;
    background-color: var(--color-sub);
    transform: translate(50%, -50%);
  }
  .bl-hover .link-text__anchor_icon::before {
    opacity: 1;
  }
  .bl-hover .link-text.link-text--reverse .link-text__anchor .link-icon-circle {
    background-color: var(--color-sub);
    width: 38px;
    height: 38px;
    transform: translate(50%, -50%);
  }
  .bl-hover .link-text.link-text--reverse .link-text__anchor .link-text__anchor_icon::before {
    opacity: 1;
  }
}

/* link icon */
.link-text__anchor__icon {
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 6px;
  height: 8px;
  transform: translateY(-50%);
}
.link-text__anchor__icon__path {
  fill: var(--color-point);
  transition: fill .3s;
}
@media screen and (min-width: 1050px) {
  .link-text__anchor:is(:hover, :focus) .link-text__anchor__icon__path,
  :is(a:hover, a:focus, .bl-hover) .link-text__anchor__icon__path {
    fill: var(--color-sub);
  }
}
.link-text__anchor__icon__path--reverse {
  fill: #ffffff;
}

.link-text__anchor_icon {
  display: block;
  height: 24px;
  position: absolute;
  right: 0;
  top: 32%;
  transform: translateY(-50%);
  width: 24px;
}
@media screen and (min-width: 768px) {
  .link-text__anchor_icon{
    height: 28px;
    width: 28px;
    top: 44%;
  }
}
@media screen and (min-width: 1050px) {
  .link-text__anchor_icon{
    top: 50%;
  }
}

.link-text__anchor_icon::before {
  content: "";
  display: block;
  height: 15px;
  background-image:url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNC42MDEiIGhlaWdodD0iMTQuNjAyIiB2aWV3Qm94PSIwIDAgMTQuNjAxIDE0LjYwMiI+CiAgPGcgaWQ9IuOCsOODq+ODvOODl180MTYzMCIgZGF0YS1uYW1lPSLjgrDjg6vjg7zjg5cgNDE2MzAiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNzAuNDk1IC05MzgzLjg5NCkiPgogICAgPGcgaWQ9IuOCsOODq+ODvOODl180MTU4MyIgZGF0YS1uYW1lPSLjgrDjg6vjg7zjg5cgNDE1ODMiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDI3NS40ODggOTM4NS4wMTgpIHJvdGF0ZSg0NSkiPgogICAgICA8cGF0aCBpZD0i44OR44K5XzExMDgxIiBkYXRhLW5hbWU9IuODkeOCuSAxMTA4MSIgZD0iTTAsNiw2LDBsNiw2IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgwIDAuMDAyKSIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMTExOTg3IiBzdHJva2Utd2lkdGg9IjEuNSIvPgogICAgICA8cGF0aCBpZD0i44OR44K5XzExMDgyIiBkYXRhLW5hbWU9IuODkeOCuSAxMTA4MiIgZD0iTTAsMFYxMiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNi4wMDIpIiBmaWxsPSJub25lIiBzdHJva2U9IiMxMTE5ODciIHN0cm9rZS13aWR0aD0iMS41Ii8+CiAgICA8L2c+CiAgPC9nPgo8L3N2Zz4K');
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  right: 5px;
  top: 6px;
  transition: opacity var(--transition-ptn01);
  width: 15px;
  z-index: 1;
}
@media screen and (min-width: 1050px) {
  .link-text__anchor_icon::before {
    background-image:url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMi40OCIgaGVpZ2h0PSIxMi40OCIgdmlld0JveD0iMCAwIDEyLjQ4IDEyLjQ4Ij4KICA8ZyBpZD0i44Kw44Or44O844OXXzQwNzA0IiBkYXRhLW5hbWU9IuOCsOODq+ODvOODlyA0MDcwNCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNC4yODYgMS4xMjQpIHJvdGF0ZSg0NSkiPgogICAgPHBhdGggaWQ9IuODkeOCuV8xMTA4MSIgZGF0YS1uYW1lPSLjg5HjgrkgMTEwODEiIGQ9Ik0wLDUsNSwwbDUsNSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAwLjAwMikiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIxLjUiLz4KICAgIDxwYXRoIGlkPSLjg5HjgrlfMTEwODIiIGRhdGEtbmFtZT0i44OR44K5IDExMDgyIiBkPSJNMCwwVjEwIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSg1LjAwMikiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIxLjUiLz4KICA8L2c+Cjwvc3ZnPgo=');
    right: -7px;
    top: 7px;
  }
}
@media screen and (min-width: 1050px) {
  .link-text__anchor_icon::before {
    opacity: 0;
    right: -9px;
    top: 5px;
  }
  a:hover .link-text__anchor_icon::before {
    opacity: 1;
  }
  a:focus .link-text__anchor_icon::before {
    opacity: 1;
  }
}

@media screen and (min-width: 768px) and (max-width: 1049px) {
  .link-text__anchor_icon::before {
    display: none;
  }
  .link-text__anchor_icon .link-icon-circle {
    top: 56%;
    right: 7px;
  }
}



/* link icon : PDF */
.link-text__anchor.is-pdf {
  --icon-margin: 26px; /* 位置調整用の変数 */
  padding-left: var(--icon-margin);
}
.link-text__anchor.is-pdf::before {
  left: var(--icon-margin);
  width: calc(100% - var(--icon-margin));
}
.link-text__anchor.is-pdf .link-text__anchor__icon {
  width: 16px;
  height: 16.4px;
}
/* link icon : external link */
.link-text__anchor.is-exlink {
  --icon-margin: 26px; /* 位置調整用の変数 */

  padding-left: var(--icon-margin);
}
.link-text__anchor.is-exlink::before {
  left: var(--icon-margin);
  width: calc(100% - var(--icon-margin));
}
.link-text__anchor.is-exlink .link-text__anchor__icon {
  left: 2px;
  width: 14px;
  height: 14px;
}

/* reverse style */
.link-text.link-text--reverse .link-text__anchor {
  color: #ffffff;
}
.link-text.link-text--reverse .link-text__anchor::before {
  background-color: #ffffff;
}
.link-text.link-text--reverse .link-text__anchor__icon__path {
  fill: #ffffff;
}
.link-text.link-text--reverse .link-text__anchor .link-icon-circle {
  background-color: #ffffff;
}
@media screen and (min-width: 1050px) {
  .link-text.link-text--reverse a:is(:hover, :focus) .link-icon-circle {
    background-color: var(--color-sub);
    width: 30px;
    height: 30px;
    transform: translate(50%, -50%);
  }
}

.link-text--reverse .link-text__anchor_icon::before {
  background-image:url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMi40OCIgaGVpZ2h0PSIxMi40OCIgdmlld0JveD0iMCAwIDEyLjQ4IDEyLjQ4Ij4KICA8ZyBpZD0i44Kw44Or44O844OXXzQwNzA0IiBkYXRhLW5hbWU9IuOCsOODq+ODvOODlyA0MDcwNCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNC4yODYgMS4xMjQpIHJvdGF0ZSg0NSkiPgogICAgPHBhdGggaWQ9IuODkeOCuV8xMTA4MSIgZGF0YS1uYW1lPSLjg5HjgrkgMTEwODEiIGQ9Ik0wLDUsNSwwbDUsNSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCAwLjAwMikiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIxLjUiLz4KICAgIDxwYXRoIGlkPSLjg5HjgrlfMTEwODIiIGRhdGEtbmFtZT0i44OR44K5IDExMDgyIiBkPSJNMCwwVjEwIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSg1LjAwMikiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIxLjUiLz4KICA8L2c+Cjwvc3ZnPgo=');
}

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

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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

/* variables */
.section-paragraph,
.paragraph {
  --p-margin: 20px;
}

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

/* 上下margin相殺 */
.paragraph::before,
.paragraph::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.paragraph::before {
  margin-top: calc((1 - var(--lh-paragraph)) * .5em);
}
.paragraph::after {
  margin-bottom: calc((1 - var(--lh-paragraph)) * .5em);
}

/* adjust margin-top when "heading + paragraph" */
.heading-2 + .paragraph::before,
.heading-3 + .paragraph::before,
.heading-4 + .paragraph::before,
.heading-5 + .paragraph::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-top: calc(((1 - var(--lh-paragraph)) * .5em) * 2);
}

.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: 768px) {
  .section {
    margin-top: 80px;
    margin-bottom: 100px;
  }
}
@media screen and (min-width: 1050px) {
  .section {
    margin-bottom: 120px;
  }
}

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

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

.dnd-section-color {
  padding-top: 60px;
  padding-bottom: 80px;
}
@media screen and (min-width: 768px) {
  .dnd-section-color {
    padding-bottom: 100px;
    padding-top: 80px;
  }
}
@media screen and (min-width: 1050px) {
  .dnd-section-color {
    padding-bottom: 120px;
  }
}
/* 最初のモジュール */
.dnd-section-color .hs_cos_wrapper_type_module--first>div {
  margin-top: 0;
}
/* 最後のモジュール */
.dnd-section-color .hs_cos_wrapper_type_module--last>div {
  margin-bottom: 0;
}

.dnd-section-color--bg {
  background-color: var(--color-bg);
}
/* ==========================================================================

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

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

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

    view

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

/* サイト全体で共通の設定 */
/* --------------------------------------------------

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #141622;
  --color-main-rgb: 20, 22, 34;
  --color-sub: #D70028;
  --color-point: #111987;
  --color-point-rgb: 17, 25, 135;
  --color-plane: #292B3C;
  --color-plane-rgb: 41, 43, 60;
  --color-pale: #D2D4D9;
  --color-bg: #F2F2F5;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(210, 212, 217, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(20, 22, 34, .4);
  --color-film-hover: rgba(20, 22, 34, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Poppins', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;

  /* 文字サイズ：基本 */
  --fz-root-desktop: 1.6rem;
  --fz-root-palmtop: 1.3rem;
  /* 文字サイズ：見出し(desktop) */
  --fz-h2-desktop: 3.2rem;
  --fz-h2-decoration-desktop: 1.4rem;
  --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.1rem;
  --fz-h3-palmtop: 1.8rem;
  --fz-h4-palmtop: 1.6rem;
  --fz-h5-palmtop: 1.5rem;

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

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

  /* 行間：見出し */
  --lh-heading: 1.5;
  /* 行間：段落(p) */
  --lh-paragraph: 2;
  /* 行間：通常テキスト */
  --lh-normal-text: 1.5;
  /* 行間：ボタン */
  --lh-button: 1.5;
  /* 行間：ブログテンプレート */
  --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;

  /* 上下のmarginからline-height分を相殺する (calc()と併用) */
  --margin-offset-lineHeight: (( (1em * var(--lh-paragraph)) - 1em ) / 2);

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


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