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

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

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

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

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


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

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

/* Shippori Antique B1 - Regular */
@font-face {
  font-family: 'Shippori Antique B1';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('https://50427355.fs1.hubspotusercontent-na2.net/hubfs/50427355/raw_assets/public/Magicx_brand_2025/01_JP/assets/styles/vendors/fonts/ShipporiAntiqueB1/ShipporiAntiqueB1-Regular.ttf') format('truetype');
}

/* Zen Kaku Gothic New - Medium */
@font-face {
  font-family: 'Zen Kaku Gothic New';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('https://50427355.fs1.hubspotusercontent-na2.net/hubfs/50427355/raw_assets/public/Magicx_brand_2025/01_JP/assets/styles/vendors/fonts/ZenKakuGothicNew/ZenKakuGothicNew-Medium.ttf') format('truetype');
}

/* Zen Old Mincho - Bold */
@font-face {
  font-family: 'Zen Old Mincho';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('https://50427355.fs1.hubspotusercontent-na2.net/hubfs/50427355/raw_assets/public/Magicx_brand_2025/01_JP/assets/styles/vendors/fonts/ZenOldMincho/ZenOldMincho-Bold.ttf') format('truetype');
}


/* Poppins - Regular */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('https://50427355.fs1.hubspotusercontent-na2.net/hubfs/50427355/raw_assets/public/Magicx_brand_2025/01_JP/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://50427355.fs1.hubspotusercontent-na2.net/hubfs/50427355/raw_assets/public/Magicx_brand_2025/01_JP/assets/styles/vendors/fonts/Poppins/Poppins-Medium.ttf') format('truetype');
}

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

  サイト全体で共通の設定

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

:root {
  /* カラースキーム */
  --color-main: #00263D;
  --color-main-rgb: 0, 38, 61;
  --color-sub: linear-gradient(90deg, #00263D, #305B76);
  --color-point: #00324D;
  --color-point-2: linear-gradient(90deg, #002D54, #3C7693);
  --color-point-rgb: 0, 50, 77;
  --color-plane: #17303E;
  --color-plane-rgb: 23, 48, 62;
  --color-pale: #D8D4D1;
  --color-bg: #F8F3F0;
  --color-bg-2: #FDFAF8;
  /* カラースキーム：不透明度設定ありのペールカラー */
  --color-pale-light: rgba(216, 212, 209, .6);
  /* カラースキーム：フィルムカラー */
  --color-film: rgba(0, 38, 61, .4);
  --color-film-hover: rgba(0, 38, 61, .6);

  /* フォント：基本 */
  --font-default: 'Noto Sans JP', sans-serif;
  /* フォント：英字 */
  --font-en: 'Libre Baskerville', sans-serif;
  /* フォント：ボタン */
  --font-button: 'Poppins', 'Noto Sans JP', sans-serif;
  /* フォント：見出し */
  --font-title: 'Zen Old Mincho', 'Noto Sans JP', sans-serif;
  /* フォント：見出し装飾英語 */
  --font-title-deco: 'Poppins', 'Noto Sans JP', sans-serif;
  /* フォント：強調見出し */
  --font-special-title: 'Shippori Antique B1', 'Noto Sans JP', sans-serif;
  /* フォント：強調本文 */
  --font-special-text: 'Zen Kaku Gothic New', 'Noto Sans JP', sans-serif;

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

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

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

  /* 行間：見出し */
  --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;

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

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

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

  アニメーション

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

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

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

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

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

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

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

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

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

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

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

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

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

html {
  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 {
  background-color: var(--color-bg);
  font-size: 1.4rem;
  letter-spacing: var(--ls-root);
  line-height: 1;
}
body:before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #10181f;
  opacity: 0;
  visibility: hidden;
  z-index: 999;
  transition: .5s;
}
body.cover-on::before {
  opacity: 1;
  visibility: visible;
}

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

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

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

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

img {
  image-rendering: -webkit-optimize-contrast;
  vertical-align: top;
}

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

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

blockquote, q {
  quotes: none;
}

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

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

ol, ul {
  list-style: none;
}

iframe {
  vertical-align: top;
}

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

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

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

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

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

/* br */
.sp-br {
  display: block;
}
.tb-br {
  display: none;
}
.pc-br {
  display: none;
}
@media screen and (min-width: 768px) {
  .sp-br {
    display: none;
  }
  .tb-br {
    display: block;
  }
}
@media screen and (min-width: 1050px) {
  .tb-br {
    display: none;
  }
  .pc-br {
    display: block;
  }
}
/* ==========================================================================

  utility

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

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

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

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

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

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

.stick {
  margin: 0 !important;
}

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

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

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

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

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

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

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

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

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

.word {
  display: inline-block;
}

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

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

.hs_cos_wrapper_type_icon {
  display: none;
}

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

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

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

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

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

  ベースのスタイル

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

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

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

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

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

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


/* heading */
.natural h2 {
  margin-top: 60px;
  margin-bottom: 25px;
  font-family: var(--font-special-title);
  font-size: 2rem;
  letter-spacing: .05em;
  line-height: var(--lh-heading);
}
@media screen and (min-width: 768px) {
  .natural h2 {
    margin-top: 80px;
    margin-bottom: 45px;
    font-size: 2.5rem;
  }
}
.natural h2:first-child {
  margin-top: 0;
}
.natural h2:last-child {
  margin-bottom: 0;
}

.natural h3 {
  margin-top: 25px;
  margin-bottom: 20px;
  font-family: var(--font-special-title);
  font-size: 1.8rem;
  letter-spacing: .05em;
  line-height: var(--lh-heading);
}
@media screen and (min-width: 768px) {
  .natural h3 {
    margin-top: 55px;
    margin-bottom: 30px;
    font-size: 2.2rem;
  }
}
.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-family: var(--font-special-title);
  font-size: 1.7rem;
  letter-spacing: .05em;
  line-height: var(--lh-heading);
}
@media screen and (min-width: 768px) {
  .natural h4 {
    margin-top: 45px;
    margin-bottom: 25px;
    font-size: 1.8rem;
  }
}
.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-family: var(--font-special-title);
  font-size: 1.5rem;
  letter-spacing: .05em;
  line-height: var(--lh-heading);
}
@media screen and (min-width: 768px) {
  .natural h5 {
    font-size: 1.7rem;
  }
}
.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: 1.4rem;
  letter-spacing: var(--ls-root);
  line-height: var(--lh-paragraph);
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
@media screen and (min-width: 768px) {
  .natural p {
    font-size: 1.5rem;
  }
}
.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.2rem;
  line-height: 1.5;
  letter-spacing: var(--ls-root);
}
@media screen and (min-width:768px) {
  .natural figure figcaption,
  .natural caption {
    font-size: 1.4rem;
  }
}
.natural figure figcaption:first-child,
.natural caption:first-child {
  margin-top: 0
}

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

.natural img {
  max-width: 100%;
  min-height: 10px;
  vertical-align: top;
  border-radius: 10px;
}
@media screen and (min-width: 768px) {
  .natural img {
    max-width: 650px;
  }
}
@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);
  text-decoration: none;
  word-break: break-all;
  transition: .3s;
}
/* :focus & :hover */
.natural a:not(.cta_button):not(.js-no-icon):focus {
  color: #73818B;
}
@media screen and (min-width: 1050px) {
  .natural a:not(.cta_button):not(.js-no-icon):hover {
    color: #73818B;
  }
}

/*
  external link
  ※.js-no-iconは_natural.jsで付与している
*/
.natural a:not(.cta_button):not(.js-no-icon)[target="_blank"] {
	padding-left: 15px;
}

.natural a:not(.cta_button):not(.js-no-icon)[target="_blank"]::before {
  content: "";
  position: absolute;
  top: 5px;
  left: 2px;
  width: 11px;
  height: 11px;
  mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMS45NjkiIGhlaWdodD0iMTEuOTY5IiB2aWV3Qm94PSIwIDAgMTEuOTY5IDExLjk2OSI+CiAgPHBhdGggaWQ9IuODkeOCuV82NDIxIiBkYXRhLW5hbWU9IuODkeOCuSA2NDIxIiBkPSJNLTc4OC41MjksMGgtNi4zNDJhLjUyOC41MjgsMCwwLDAtLjUyOC41MjlWMi4xNjdoLTMuODdhLjcuNywwLDAsMC0uNy43djguNGEuNy43LDAsMCwwLC43LjdoOC40YS43LjcsMCwwLDAsLjctLjdWNy40aDEuNjM4QS41MjguNTI4LDAsMCwwLTc4OCw2Ljg3MVYuNTI5QS41MjkuNTI5LDAsMCwwLTc4OC41MjksMFptLTIuNjM4LDEwLjk2OWgtNy44di03LjhoMy41N3YzLjdhLjUyNy41MjcsMCwwLDAsLjUyOC41MjhoMy43Wk0tNzg5LDYuNGgtNS40VjFoNS40WiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNzk5Ljk2OSkiIGZpbGw9IiM0MTQxNDEiLz4KPC9zdmc+Cg==");
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: cover;
  background-color: var(--color-plane);
  transition: background-color .3s;
}
/* :focus & :hover */
.natural a:not(.cta_button):not(.js-no-icon)[target="_blank"]:focus::before {
  background-color: var(--color-point);
}
@media screen and (min-width: 768px) {
  .natural a:not(.cta_button):not(.js-no-icon)[target="_blank"]::before {
    top: 6px;
  }
}
@media screen and (min-width: 1050px) {
  .natural a:not(.cta_button):not(.js-no-icon)[target="_blank"]:hover::before {
    background-color: var(--color-point);
  }
}

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

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

.natural > ul li,
.natural > .hs_cos_wrapper_type_rich_text > ul li {
  position: relative;
  margin-top: calc(20px + var(--leading-trim));
  margin-bottom: calc(20px + var(--leading-trim));
  color: var(--color-plane);
  font-size: 1.4rem;
  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: 1.5rem;
  }
}
.natural > ul li:first-child,
.natural > .hs_cos_wrapper_type_rich_text > ul li:first-child,
.natural > ol li:first-child,
.natural > .hs_cos_wrapper_type_rich_text > ol li:first-child {
  margin-top: 0;
}
.natural > ul li:last-child,
.natural > .hs_cos_wrapper_type_rich_text > ul li:last-child,
.natural > ol li:last-child,
.natural > .hs_cos_wrapper_type_rich_text > ol li:last-child, {
  margin-bottom: 0;
}

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

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

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

.natural ol li,
.natural > .hs_cos_wrapper_type_rich_text > ol li {
  display: list-item;
  margin-top: calc(20px + var(--leading-trim));
  margin-bottom: calc(20px + var(--leading-trim));
  font-size: 1.4rem;
  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: 1.5rem;
  }
}

/* pre */
.natural pre {
  margin-top: 30px;
  margin-bottom: 30px;
  padding: 20px 20px 18px;
  border: 1px solid var(--color-pale);
  border-radius: 5px;
  font-size: 1.4rem;
  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: 1.5rem;
  }
}
.natural pre:first-child {
  margin-top: 0;
}
.natural pre:last-child {
  margin-bottom: 0;
}

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

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

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

.natural table td {
  height: auto !important;
  padding-right: 20px !important;
  padding-left: 20px !important;
  color: var(--color-plane);
  font-size: 1.4rem;
  letter-spacing: var(--ls-root);
  line-height: var(--lh-paragraph);
  text-align: left;
  vertical-align: middle;
  border: 1px solid var(--color-pale);
}
@media screen and (min-width: 768px) {
  .natural table td {
    padding: 15px !important;
    font-size: 1.5rem;
  }
}

/* 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://50427355.fs1.hubspotusercontent-na2.net/hubfs/50427355/raw_assets/public/Magicx_brand_2025/01_JP/assets/images/common/ico_blockquote.svg) no-repeat;
  background-size: contain;
}
.natural blockquote::before {
  top: 16px;
  left: 16px;
}
.natural blockquote::after {
  top: 16px;
  right: 16px;
  transform: rotate(180deg);
}
@media screen and (min-width: 768px) {
  .natural blockquote::before,
  .natural blockquote::after {
    position: absolute;
    width: 25.87px;
    height: 18.16px;
  }
  .natural blockquote::before {
    left: 20px;
  }
  .natural blockquote::after {
    right: 20px;
    transform: rotate(180deg);
  }
}

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


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

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

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

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

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

  パンくず

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

.elevator {
  padding-top: 15px;
  background-color: var(--color-bg);
}
@media screen and (min-width: 768px) {
  .elevator {
    padding-top: 20px;
  }
}

.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.1rem;
  letter-spacing: .1em;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .elevator__nav__breadcrumb .hs-breadcrumb-menu {
    font-size: 1.2rem;
  }
}

.elevator__nav__breadcrumb .hs-breadcrumb-menu__item,
.elevator__nav__breadcrumb .hs-breadcrumb-menu .hs-breadcrumb-menu-item {
  float: none;
  padding: 0;
  color: rgba(0,38,61,.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: 10px;
  padding-left: 16px;
}
@media screen and (min-width: 768px) {
  .elevator__nav__breadcrumb .hs-breadcrumb-menu__item:not(:first-child),
  .elevator__nav__breadcrumb .hs-breadcrumb-menu .hs-breadcrumb-menu-item:not(:first-child) {
    margin-left: 15px;
    padding-left: 21px;
  }
}

.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 {
  content: '';
  display: block;
  position: absolute;
  top: calc(50% - 3px);
  left: 0;
  width: 6px;
  height: 6px;
  background-color: var(--color-main);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

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

.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-main);
  transition: all .3s;
}

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

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

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

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

  フッター

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

footer {
  position: relative;
  background-color: #ffffff;
}

.footer {
  overflow: hidden;
  color: #ffffff;
  padding: 90px 25px 15px;
}
.footer.footer--no-nav {
  padding: 22px 0 21px;
}
@media screen and (min-width: 768px) {
  .footer {
    padding: 96px 30px 20px 50px;
  }
  .footer.footer--no-nav {
    padding: 23px 0 23px;
  }
}
@media screen and (min-width: 1050px) {
  .footer {
    padding: 45px 30px 23px 50px;
  }
}

.footer--no-nav .container {
  padding-left: 25px;
  padding-right: 25px;
}
@media screen and (min-width: 768px) {
  .footer--no-nav .container {
    padding-left: 50px;
   padding-right: 30px;
  }
}

.footer--no-nav__wrap {
  display: grid;
  grid-template-columns: 1fr 48px;
  gap: 21px;
}
@media screen and (min-width: 768px) {
  .footer--no-nav__wrap {
    align-items: center;
  }
}

.footer__above__nav__columns {
  display: grid;
  grid-template-areas:
    "logo page-top"
    "text text";
  grid-template-columns: 1fr 48px;
  align-items: center;
  justify-content: space-between;
  background-color: #ffffff;
}

@media screen and (min-width: 1050px) {
  .footer__above__nav__columns {
    align-items: flex-start;
    grid-template-areas:
      "logo logo logo"
      "copy text-data page-top";
    grid-template-columns: 1fr max-content 48px;
    gap: 21px;
  }
}

@media screen and (min-width: 768px) {
  .footer__above__nav__columns__column--text {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: flex-start;
    gap: 30px;
    margin-top: 15px;
  }
}
@media screen and (min-width: 1050px) {
  .footer__above__nav__columns__column--text {
    display: contents;
  }
}

@media screen and (min-width: 768px) {
  .footer--no-nav__contents {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 0 30px;
  }
}

/* フッターロゴ */
.footer__above__nav__columns__column--logo {
  grid-area: logo;
}

@media screen and (min-width: 1050px) {
  .footer__above__nav__columns__column__item {
    margin-bottom: 9px;
  }
}

.footer__above__nav__logo {
  text-align: left;
  width: 105px;
  height: 32px;
}
.footer--no-nav .footer__above__nav__logo {
  margin-top: 7px;
}
@media screen and (min-width: 768px) {
  .footer__above__nav__logo {
    width: 120px;
    height: 36px;
  }
}
@media screen and (min-width: 1050px) {
  .footer__above__nav__logo {
    width: 133px;
    height: 40px;
  }
}

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

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

.footer__below {
  display: flex;
  flex-direction: column-reverse;
  padding: 40px 50px;
  align-items: center;
  background-color: var(--color-main);
}
@media screen and (min-width: 1050px) {
  .footer__below {
    padding: 30px 80px 30px;
    border-top: none;
    justify-content: space-between;
    flex-direction: initial;
    align-items: center;
    background-color: var(--color-film);
  }
}

/* コピーライト上テキスト */
.footer__above__nav__columns__column--text {
  grid-area: text;
}

.footer__below__text {
  margin-top: 17px;
}
@media screen and (min-width: 768px) {
  .footer__below__text {
    margin-top: 0;
  }
}
@media screen and (min-width: 1050px) {
  .footer__below__text {
    grid-area: text-data;
    margin-top: 3px;
  }
}

.footer__below__text .natural p {
  margin-top: 0;
  margin-bottom: 0;
  font-family: var(--font-title-deco);
  font-size: 1rem;
}
.footer__below__text .natural p:not(:last-child) {
  margin-bottom: 3px;
}
@media screen and (min-width: 768px) {
  .footer__below__text .natural p {
    text-align: right;
  }
}

.footer__below__text .natural a:not(.cta_button):not(.js-no-icon) {
  opacity: 1;
  transition: opacity .3s;
}
.footer__below__text .natural a,
.footer__below__text .natural a:not(.cta_button):not(.js-no-icon)[target=_blank] {
  padding-left: 0;
  border-bottom: 1px solid rgba(23,48,62,.25) !important;
}
@media screen and (min-width: 768px) {
  .footer__below__text .natural a:not(.cta_button):not(.js-no-icon):focus,
  .footer__below__text .natural a:not(.cta_button):not(.js-no-icon):hover {
    color: var(--color-plane);
    opacity: .7;
  }
}
.footer__below__text .natural a:not(.cta_button):not(.js-no-icon)[target=_blank]:before {
  display: none;
}


/* コピーライト */
.footer__below__copyright {
  position: relative;
  max-width: 225px;
  margin-top: 10px;
  font-family: var(--font-title-deco);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: .1em;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .footer__below__copyright {
    max-width: 205px;
    margin-top: 0;
    font-size: 1.4rem;
    line-height: 1.9;
  }
}

@media screen and (min-width: 1050px) {
  .footer__below__copyright {
    grid-area: copy;
  }
  .footer--no-nav .footer__below__copyright {
    grid-area: auto;
    text-align: left;
    max-width: none;
    margin-top: 6px;
  }
}

.footer__below__copyright__text {
  display: flex;
  color: var(--color-plane);
  font-family: var(--font-title-deco);
  font-size: 1rem;
  font-weight: var(--fw-normal-jp);
  line-height: 1.5;
  letter-spacing: .1em;
  opacity: .5;
}
@media screen and (min-width: 768px) {
  .footer__below__copyright__text {
    font-size: .9rem;
  }
}

/* ページトップ */
.footer__above__nav__columns__column--page-top {
  grid-area: page-top;
}
.footer--no-nav .footer__above__nav__columns__column--page-top {
  grid-area: auto;
}

.footer__nav__page-top {
  display: block;
}

.footer__nav__page-top__anchor {
  display: block;
  position: relative;
  width: 48px;
  height: 48px;
  padding: 22px 5px 15px 5px;
  box-sizing: border-box;
  color: #ffffff;
  font-family: var(--font-button);
  font-size: .8rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: .15em;
  text-align: center;
  background-color: rgba(60,118,147,1);
  border-radius: 24px;
  border: none;
  cursor: pointer;
  transition: .3s;
}
/* :focus & :hover */
.footer__nav__page-top__anchor:focus {
  background-color: rgba(60,118,147,.85);
}
@media screen and (min-width: 1050px) {
  .footer__nav__page-top__anchor:hover {
    background-color: rgba(60,118,147,.85);
  }
}

.footer__nav__page-top__anchor::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 50%;
  transform: translateX(-50%);
  width: 5px;
  height: 7px;
  background-color: #ffffff;
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
}
/* ==========================================================================

  ヘッダー

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

.header {
  position: absolute;
  width: 100%;
  background-color: transparent;
  z-index: 99;
  transition: .3s;
}
.header.header--no-nav {
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (min-width: 1050px) {
  .header {
    position: fixed;
  }
}

.container.header__container {
  padding-left: 30px;
  padding-right: 20px;
}
@media screen and (min-width: 768px) {
  .container.header__container {
    padding-left: 50px;
    padding-right: 30px;
  }
}
@media screen and (min-width: 1050px) {
  .container.header__container {
    padding-left: 40px;
  }
}
.header__columns {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
}
@media screen and (min-width: 768px) {
  .header__columns {
    justify-content: space-between;
  }
}

.header__columns__column:nth-child(1) {
  display: flex;
  align-items: center;
  width: 100%;
}

.header__logo__inner--default,
.header__logo__inner--white {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: opacity .3s;
}

.header__logo__inner--default.active,
.header__logo__inner--white.active {
  opacity: 1;
}

.header__logo,
.header__main__logo {
  position: relative;
  width: 90px;
  height: 27px;
  margin-top: 35px;
}
.header__logo {
  transition: ease-in-out .7s;
}
.header__main__logo {
  margin-left: 30px;
}
@media screen and (min-width: 768px) {
  .header__logo,
  .header__main__logo {
    margin-top: 40px;
  }
  .header__main__logo {
    margin-left: 50px;
  }
}
@media screen and (min-width: 1050px) {
  .header__logo {
    width: 130px;
    height: 40px;
    margin-top: 30px;
  }
  .header__main__logo {
    width: 340px;
    height: 101px;
    margin-top: 0;
    margin-left: auto;
    margin-right: auto;
  }
}
.header__logo a,
.header__main__logo a {
  display: block;
}
.header__logo a img,
.header__main__logo a img {
  width: 130px !important;
  max-width: 100%;
  vertical-align: bottom;
}
@media screen and (min-width: 1050px) {
  .header__main__logo a img {
    width: 340px !important;
  }
}

.header__main {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  padding-top: 0;
  background-size: cover;
  background-position: center bottom;
  background-repeat: no-repeat;
  pointer-events: none;
  transition: opacity .3s;
  pointer-events: auto;
  box-sizing: border-box;
}
@media screen and (min-width: 768px) {
  .header__main {
    padding: 0;
  }
}

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

@media screen and (min-width: 1050px) {
  .header__main__wrap {
    display: grid;
    grid-template-columns: 1fr 600px;
    align-items: center;
    max-width: 1450px;
    height: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ハンバーガーナビ */
.header__hamburger {
  position: fixed;
  top: 0;
  right: 20px;
  width: 50px;
  height: 50px;
  margin-top: 20px;
  padding: 0;
  box-sizing: border-box;
  border-radius: 50%;
  border: 1px solid #ffffff;
  background-color: transparent;
  appearance: none;
  cursor: pointer;
  z-index: 101;
  transition: border .3s;
}
.header__hamburger.color {
  border: 1px solid var(--color-plane);
}
.header__hamburger.color.is-active {
  border: 1px solid #ffffff;
}
@media screen and (min-width: 768px) {
  .header__hamburger {
    right: 30px;
    width: 53px;
    height: 53px;
    margin-top: 30px;
  }
}

.header__hamburger__inner {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
}

.header__hamburger__inner__text {
  display: block;
  position: absolute;
  top: 14px;
  left: calc(50% + 1px);
  transform: translateX(-50%);
  color: #ffffff;
  font-size: .8rem;
  line-height: 1.5;
  letter-spacing: .15em;
  white-space: nowrap;
  transition: color .3s;
}
.header__hamburger.color .header__hamburger__inner__text {
  color: var(--color-main);
}
.header__hamburger.color.is-active .header__hamburger__inner__text {
  color: #ffffff;
}
@media screen and (min-width: 768px) {
  .header__hamburger__inner__text {
    top: 14px;
    font-size: .7rem;
    font-weight: var(--fw-bold-en);
    letter-spacing: .3em;
  }
}

.header__hamburger__inner__line {
  display: block;
  position: absolute;
  right: 12px;
  height: 1px;
  background-color: #fff;
  transition: all .3s;
}
.header__hamburger.color .header__hamburger__inner__line {
  background-color: var(--color-main);
}
.header__hamburger.color.is-active .header__hamburger__inner__line {
  background-color: #fff;
}
@media screen and (min-width: 768px) {
  .header__hamburger__inner__line {
    right: 13px;
  }
}

.header__hamburger__inner__line:nth-child(1) {
  top: 29px;
  width: 26px;
}
.header__hamburger__inner__line:nth-child(2) {
  top: 34px;
  width: 16px;
}
@media screen and (min-width: 768px) {
  .header__hamburger__inner__line:nth-child(1) {
    width: 27px;
  }
  .header__hamburger__inner__line:nth-child(2) {
    width: 18px;
  }
}

.is-active .header__hamburger__inner__line:nth-child(1),
.is-active .header__hamburger__inner__line:nth-child(2) {
  width: 20px;
  right: auto;
  left: 14px;
}
.is-active .header__hamburger__inner__line:nth-child(1) {
  top: 32px;
  transform: rotate(20deg);
}
.is-active .header__hamburger__inner__line:nth-child(2) {
  top: 32px;
  transform: rotate(-20deg);
}
@media screen and (min-width: 768px) {
  .is-active .header__hamburger__inner__line:nth-child(1),
  .is-active .header__hamburger__inner__line:nth-child(2) {
    left: 16.5px;
    width: 18px;
  }
}

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

  カラム

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

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

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

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

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

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

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

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

/* 1:2カラム */

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

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

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

  コンテナ

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

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

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

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

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

  エントリーボタン

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

.entry-button.rich-button-center {
  text-align: center;
}
.entry-button a {
  display: block;
  box-sizing: border-box;
  position: relative;
  min-width: inherit;
  max-width: 450px;
  margin: 0 auto;
  padding: 15px 59px 11px 24px;
  background-color: var(--color-point);
  color: #ffffff;
  font-family: var(--font-special-title);
  font-size: 1.8rem;
  letter-spacing: .08em;
  line-height: 2;
  text-align: left;
  transition: .5s;
}
@media screen and (min-width: 768px) {
  .entry-button a {
    display: inline-block;
    min-width: 450px;
    padding: 15px 95px 9px 25px;
    font-size: 2rem;
  }
}

.entry-button .link-button__anchor::before {
  background: var(--color-point-2);
}
.entry-button .link-button__anchor::after {
  background: var(--color-sub);
}

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

.entry-button__decoration-text {
  content: attr(data-entry);
  display: block;
  width: 100%;
  font-family: var(--font-title-deco);
  font-size: 1.3rem;
  letter-spacing: .08em;
  line-height: 1;
  text-transform: uppercase;
  transition: .5s;
  opacity: .7;
}
@media screen and (min-width: 768px) {
  .entry-button__decoration-text {
    font-size: 1.4rem;
  }
}

/* link icon */
.entry-button .entry-button__icon {
  position: absolute;
  top: 50%;
  right: 22px;
  width: 24px;
  height: 24px;
  transform: translateY(-50%);
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .entry-button .entry-button__icon {
    right: 25px;
    width: 28px;
    height: 28px;
  }
}
.link-button__anchor__icon.link-button__anchor__icon--entry.link-button__anchor__icon--default {
  left: auto;
  right: 30px;
  width: 28px;
  height: 5px;
  transition; .3s;
}
@media screen and (min-width: 768px) {
  .link-button__anchor__icon.link-button__anchor__icon--entry.link-button__anchor__icon--default {
    width: 32px;
    height: 6px;
  }
}
@media screen and (min-width: 1050px) {
  .entry-button a:focus .link-button__anchor__icon.link-button__anchor__icon--entry.link-button__anchor__icon--default,
  .entry-button a:hover .link-button__anchor__icon.link-button__anchor__icon--entry.link-button__anchor__icon--default {
    right: 27px;
    width: 35px;
  }
}

.link-button__anchor__icon.link-button__anchor__icon--entry.link-button__anchor__icon--default::before {
  width: 10px;
  height: 5px;
}
@media screen and (min-width: 768px) {
  .link-button__anchor__icon.link-button__anchor__icon--entry.link-button__anchor__icon--default::before {
    width: 12px;
    height: 6px;
  }
}

.link-button__anchor__icon.link-button__anchor__icon--entry.link-button__anchor__icon--default::after {
  width: 16px;
  height: 1px;
}
@media screen and (min-width: 768px) {
  .link-button__anchor__icon.link-button__anchor__icon--entry.link-button__anchor__icon--default::after {
    width: 18px;
  }
}
@media screen and (min-width: 1050px) {
  .entry-button a:focus .link-button__anchor__icon.link-button__anchor__icon--entry.link-button__anchor__icon--default::after,
  .entry-button a:hover .link-button__anchor__icon.link-button__anchor__icon--entry.link-button__anchor__icon--default::after {
    width: 21px;
  }
}
/* link icon : external link */
.entry-button .entry-button__icon.is-exlink {
  width: 20px;
  height: 20px;
}
@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）

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

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

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

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

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

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

  見出し1

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

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

    見出し2

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

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

.heading-2 {
  margin-top: calc(60px + var(--leading-trim));
  margin-bottom: calc(25px + var(--leading-trim));
  font-family: var(--font-special-title);
  font-size: var(--fz-h2-palmtop);
  font-weight: var(--fw-bold-jp);
  letter-spacing: .05em;
  line-height: var(--lh-heading);
}
@media screen and (min-width: 768px) {
  .heading-2 {
    margin-top: calc(80px + var(--leading-trim));
    margin-bottom: calc(45px + var(--leading-trim));
    font-size: var(--fz-h2-desktop);
  }
}
.heading-2:first-child {
  margin-top: 0;
}
.heading-2:last-child {
  margin-bottom: 0;
}

/*
  === 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-title-deco);
  font-size: var(--fz-h2-decoration-palmtop);
  font-weight: 500;
  letter-spacing: .05em;
  line-height: var(--lh-heading);
}
@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;
}

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

    見出し3

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

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

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

/*
  === child elements in modules
  モジュール内に配置する際のエレメントスタイルとは異なる場合のスタイル
*/
.heading-3.heading--child {
  margin-top: 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 === */
/* ==========================================================================

    見出し4

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

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

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

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

    見出し5

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

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

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

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

  見出しリンク

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

.section-heading-link {
  margin-top: 20px;
  margin-bottom: 30px;
}
@media 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,
.heading-link a {
  color: var(--color-main);
  transition: color .3s;
}
.heading-link a {
  display: inline-block;
  text-decoration: none;
}
/* :focus & :hover */
a:focus .heading-link,
.heading-link a:focus {
  color: rgba(0,38,61,.85);
}
@media screen and (min-width: 1050px) {
  a:hover .heading-link,
  .bl-hover .heading-link a,
  .heading-link a:hover {
    color: rgba(0,38,61,.85);
  }
}

.heading-link .link-icon {
  display: block;
  position: absolute;
  left: 0;
}
/* 見出しレベル別　アイコン位置調整 */
.heading-2.heading-link .link-icon {
  top: 8px;
  width: 22px;
  height: 22px;
}
.heading-3.heading-link .link-icon {
  top: 2px;
  width: 24px;
  height: 24px;
}
.heading-4.heading-link .link-icon {
  top: 4px;
  width: 18px;
  height: 18px;
}
.heading-5.heading-link .link-icon {
  top: 2px;
  width: 18px;
  height: 18px;
}
@media screen and (min-width: 768px) {
  .heading-2.heading-link .link-icon {
    top: 12px;
    width: 30px;
    height: 30px;
  }
  .heading-3.heading-link .link-icon {
    top: 6px;
    width: 26px;
    height: 26px;
  }
  .heading-4.heading-link .link-icon {
    top: 4px;
    width: 22px;
    height: 22px;
  }
  .heading-5.heading-link .link-icon {
    top: 3px;
    width: 22px;
    height: 22px;
  }
}

.heading-2.heading-link .link-icon__arrow,
.heading-3.heading-link .link-icon__arrow {
  top: 8.5px;
  left: 1px;
  width: 17.5px;
  height: 5px;
}
.heading-4.heading-link .link-icon__arrow,
.heading-5.heading-link .link-icon__arrow {
  top: 6.5px;
  left: 1px;
  width: 13px;
  height: 4px;
}
@media screen and (min-width: 768px) {
  .heading-2.heading-link .link-icon__arrow {
    top: 11.5px;
    left: 2px;
    width: 22px;
    height: 6px;
  }
  .heading-3.heading-link .link-icon__arrow {
    top: 9.5px;
    width: 21px;
    height: 6px;
  }
  .heading-4.heading-link .link-icon__arrow,
  .heading-5.heading-link .link-icon__arrow {
    top: 8.5px;
    width: 17.5px;
    height: 5px;
  }
}
@media screen and (min-width: 1050px) {
  a:focus .heading-2.heading-link .link-icon__arrow,
  .heading-2.heading-link a:focus .link-icon__arrow,
  a:hover .heading-2.heading-link .link-icon__arrow,
  .bl-hover .heading-2.heading-link a .link-icon__arrow,
  .heading-2.heading-link a:hover .link-icon__arrow {
    width: 25px;
  }
  a:focus .heading-3.heading-link .link-icon__arrow,
  .heading-3.heading-link a:focus .link-icon__arrow,
  a:hover .heading-3.heading-link .link-icon__arrow,
  .bl-hover .heading-3.heading-link a .link-icon__arrow,
  .heading-3.heading-link a:hover .link-icon__arrow {
    width: 23px;
  }
  a:focus .heading-4.heading-link .link-icon__arrow,
  .heading-4.heading-link a:focus .link-icon__arrow,
  a:hover .heading-4.heading-link .link-icon__arrow,
  .bl-hover .heading-4.heading-link a .link-icon__arrow,
  .heading-4.heading-link a:hover .link-icon__arrow,
  a:focus .heading-5.heading-link .link-icon__arrow,
  .heading-5.heading-link a:focus .link-icon__arrow,
  a:hover .heading-5.heading-link .link-icon__arrow,
  .bl-hover .heading-5.heading-link a .link-icon__arrow,
  .heading-5.heading-link a:hover .link-icon__arrow {
    width: 19.5px;
  }
}

.heading-2.heading-link .link-icon__arrow::before,
.heading-3.heading-link .link-icon__arrow::before {
  width: 8px;
  height: 5px;
}
.heading-4.heading-link .link-icon__arrow::before,
.heading-5.heading-link .link-icon__arrow::before {
  width: 6px;
  height: 4px;
}
@media screen and (min-width: 768px) {
  .heading-2.heading-link .link-icon__arrow::before,
  .heading-3.heading-link .link-icon__arrow::before {
    width: 10px;
    height: 6px;
  }
  .heading-4.heading-link .link-icon__arrow::before,
  .heading-5.heading-link .link-icon__arrow::before {
    width: 8px;
    height: 5px;
  }
}

.heading-2.heading-link .link-icon__arrow::after,
.heading-3.heading-link .link-icon__arrow::after {
  width: 8px;
  height: 1px;
}
.heading-4.heading-link .link-icon__arrow::after,
.heading-5.heading-link .link-icon__arrow::after {
  width: 6px;
  height: 1px;
}
@media screen and (min-width: 768px) {
  .heading-2.heading-link .link-icon__arrow::after {
    width: 10px;
    height: 2px;
  }
  .heading-3.heading-link .link-icon__arrow::after {
    width: 9px;
    height: 2px;
  }
  .heading-4.heading-link .link-icon__arrow::after,
  .heading-5.heading-link .link-icon__arrow::after {
    width: 8px;
  }
}
@media screen and (min-width: 1050px) {
  a:focus .heading-2.heading-link .link-icon__arrow::after,
  .heading-2.heading-link a:focus .link-icon__arrow::after,
  a:hover .heading-2.heading-link .link-icon__arrow::after,
  .bl-hover .heading-2.heading-link a .link-icon__arrow::after,
  .heading-2.heading-link a:hover .link-icon__arrow::after {
    width: 13px;
  }
  a:focus .heading-3.heading-link .link-icon__arrow::after,
  .heading-3.heading-link a:focus .link-icon__arrow::after,
  a:hover .heading-3.heading-link .link-icon__arrow::after,
  .bl-hover .heading-3.heading-link a .link-icon__arrow::after,
  .heading-3.heading-link a:hover .link-icon__arrow::after {
    width: 11px;
  }
  a:focus .heading-4.heading-link .link-icon__arrow::after,
  .heading-4.heading-link a:focus .link-icon__arrow::after,
  a:hover .heading-4.heading-link .link-icon__arrow::after,
  .bl-hover .heading-4.heading-link a .link-icon__arrow::after,
  .heading-4.heading-link a:hover .link-icon__arrow::after,
  a:focus .heading-5.heading-link .link-icon__arrow::after,
  .heading-5.heading-link a:focus .link-icon__arrow::after,
  a:hover .heading-5.heading-link .link-icon__arrow::after,
  .bl-hover .heading-5.heading-link a .link-icon__arrow::after,
  .heading-5.heading-link a:hover .link-icon__arrow::after {
    width: 10px;
  }
}


/* 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;
    width: 16px;
    height: 16.41px;
  }
  .heading-5.heading-link.is-pdf .link-icon {
    top: 5px;
  }
}

/* link icon : external link */
.heading-2.heading-link.is-exlink .link-icon {
  top: 9px;
  width: 16px;
  height: 16px;
}
:is(.heading-3, .heading-4, .heading-5).heading-link.is-exlink .link-icon {
  top: 7px;
  width: 14px;
  height: 14px;
}
:is(.heading-4, .heading-5).heading-link.is-exlink .link-icon {
  top: 5px;
}
@media 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: 40px;
  margin-bottom: 40px;
}
@media screen and (min-width: 768px) {
  .section-lead {
    margin-top: 55px;
    margin-bottom: 55px;
  }
}

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

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

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

  リンクボタン

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

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

.link-button {
  width: fit-content;
  max-width: 100%;
}
.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: 7px 20px 6px 30px;
  border-radius: 5px;
  color: #ffffff;
  font-family: var(--font-button);
  font-size: 1.2rem;
  line-height: var(--lh-button);
  letter-spacing: var(--ls-root-en);
  word-break: break-all;
}
@media screen and (min-width: 768px) {
  .link-button__anchor {
    padding: 7px 25px 6.5px 39px;
    font-size: 1.5rem;
  }
}

.link-button__anchor::before,
.link-button__anchor::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 5px;
  transition: opacity .3s;
}
.link-button__anchor::before {
  background: var(--color-sub);
}
.link-button__anchor::after {
  background-color: var(--color-main);
  opacity: 1;
}

/* :focus & :hover */
.link-button__anchor:focus::after,
a:focus .link-button__anchor::after {
  opacity: 0;
}
@media screen and (min-width: 1050px) {
  .link-button__anchor:hover::after,
  :where(a:hover, .bl-hover) .link-button__anchor::after {
    opacity: 0;
  }
}

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

/* link icon */
.link-button__anchor__icon {
  display: block;
  position: absolute;
  top: 50%;
  left: 15px;
  width: 24px;
  height: 24px;
  transform: translateY(-50%);
  z-index: 1;
}
.link-button__anchor__icon.link-button__anchor__icon--default {
  top: calc(50% - 1px);
  left: 2px;
  transform: translateY(-50%);
  width: 18px;
  height: 4px;
  z-index: 1;
  transition: .3s;
}
@media screen and (min-width: 768px) {
  .link-button__anchor__icon {
    left: 18px;
    width: 28px;
    height: 28px;
  }
  .link-button__anchor__icon.link-button__anchor__icon--default {
    left: 4px;
    width: 23px;
    height: 5px;
  }
}
@media screen and (min-width: 1050px) {
  .link-button__anchor:focus .link-button__anchor__icon.link-button__anchor__icon--default,
  a:focus .link-button__anchor .link-button__anchor__icon.link-button__anchor__icon--default,
  .link-button__anchor:hover .link-button__anchor__icon.link-button__anchor__icon--default,
  :where(a:hover, .bl-hover) .link-button__anchor__icon.link-button__anchor__icon--default {
    width: 25px;
  }
}

.link-button__anchor__icon--default::before,
.link-button__anchor__icon--default::after {
  content: "";
  display: block;
  position: absolute;
  background-color: #ffffff;
}
.link-button__anchor__icon--default::before {
  top: 0;
  right: 0;
  width: 7px;
  height: 4px;
  clip-path: polygon(0% 100%, 0% 0%, 100% 100%);
}
@media screen and (min-width: 768px) {
  .link-button__anchor__icon--default::before {
    width: 9px;
    height: 5px;
  }
}
.link-button__anchor__icon--default::after {
  bottom: 0;
  left: 0;
  width: 9px;
  height: 1px;
  transition: .3s;
}
@media screen and (min-width: 768px) {
  .link-button__anchor__icon--default::after {
    width: 12px;
  }
}
@media screen and (min-width: 1050px) {
  .link-button__anchor:focus .link-button__anchor__icon--default::after,
  a:focus .link-button__anchor .link-button__anchor__icon--default::after,
  .link-button__anchor:hover .link-button__anchor__icon--default::after,
  :where(a:hover, .bl-hover) .link-button__anchor__icon--default::after {
    width: 14px;
  }
}

.link-button__anchor__icon svg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
}
.link-button__anchor__icon__path {
  fill: #ffffff;
  transition: fill .3s;
}
.link-button__anchor__icon__path--reverse {
  fill: var(--color-main);
  transition: fill .3s;
}


/* link icon : PDF */
.link-button__anchor.is-pdf .link-button__anchor__icon {
  left: 14px;
  width: 13px;
  height: 13.34px;
}
@media screen and (min-width: 768px) {
  .link-button__anchor.is-pdf .link-button__anchor__icon {
    left: 17px;
    width: 14px;
    height: 14.36px;
  }
}
/* link icon : external link */
.link-button__anchor.is-exlink .link-button__anchor__icon {
  width: 11px;
  height: 11px;
}
@media screen and (min-width: 768px) {
  .link-button__anchor.is-exlink .link-button__anchor__icon {
    width: 12px;
    height: 12px;
  }
}

/* icon reverse */
.link-button--reverse .link-button__anchor {
  color: var(--color-main);
}

.link-button--reverse .link-button__anchor::before {
  background: linear-gradient(70deg, rgba(255,255,255,.6), rgba(255,255,255,1));
}
.link-button--reverse .link-button__anchor::after {
  background-color: #FFFFFF;
}

/* デザイン反転時、arrowの下に置いて色を変更するための疑似要素 */
.link-button--reverse .link-button__anchor__icon::before,
.link-button--reverse .link-button__anchor__icon::after {
  background-color: var(--color-main);
}
.link-button--reverse .link-button__anchor__icon__path {
  fill: var(--color-main);
}
.link-button--reverse .link-button__anchor__icon__path--reverse {
  fill: #ffffff;
}
/* icon reverse hover style */

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

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

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

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

  リンクアイコン

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

.link-icon {
  display: inline-block;
  position: relative;
  width: 18px;
  height: 18px;
}
.link-icon--default {
  border-radius: 5px;
}

.link-icon::before,
.link-icon::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 5px;
}
.link-icon::before {
  background: linear-gradient(92deg,#00263D, #305B76);
}
.link-icon::after {
  background-color: var(--color-main);
  opacity: 1;
  transition: .3s;
}
a:focus .link-icon::after {
  opacity: 0;
}
@media screen and (min-width: 1050px) {
  :where(a:hover, .bl-hover) .link-icon::after {
    opacity: 0;
  }
}

.link-icon__arrow {
  display: block;
  position: absolute;
  top: 6px;
  left: 1px;
  width: 13px;
  height: 4px;
  z-index: 1;
  transition: .3s;
}
@media screen and (min-width: 1050px) {
  a:focus .link-icon__arrow {
    width: 15px;
  }
  :where(a:hover, .bl-hover) .link-icon__arrow {
    width: 15px;
  }
}

.link-icon__arrow::before,
.link-icon__arrow::after {
  content: "";
  display: block;
  position: absolute;
  background-color: #ffffff;
}
.link-icon__arrow::before {
  top: 0;
  right: 0;
  width: 6px;
  height: 4px;
  clip-path: polygon(0% 100%, 0% 0%, 100% 100%);
}
.link-icon__arrow::after {
  left: 0;
  bottom: 0;
  width: 6px;
  height: 1px;
  transition: .3s;
}
@media screen and (min-width: 1050px) {
  .link-text__anchor:focus .link-icon__arrow::after,
  a:focus .link-text__anchor .link-icon__arrow::after {
    width: 8px;
  }
  .link-text__anchor:hover .link-icon__arrow::after,
  :where(a:hover, .bl-hover) .link-icon__arrow::after {
    width: 8px;
  }
}

/* link icon : PDF */
.link-icon.is-pdf {
  width: 16px;
  height: 16.4px;
}
.link-icon.is-pdf .link-icon__path {
  fill: var(--color-main);
  transition: fill .3s;
}
.link-icon.is-pdf .link-icon__path--reverse {
  fill: #ffffff;
}

/* link icon : external link */
.link-icon.is-exlink {
  width: 14px;
  height: 14px;
}
.link-icon.is-exlink .link-icon__path {
  fill: var(--color-main);
  transition: fill .3s;
}

/* link style : reverse */
.link-icon.link-icon--reverse::before {
  background: linear-gradient(45deg, rgba(255,255,255,.6), rgba(255,255,255,1));
}
.link-icon.link-icon--reverse::after{
  background-color: #ffffff;
}
.link-icon.link-icon--reverse .link-icon__arrow::before,
.link-icon.link-icon--reverse .link-icon__arrow::after {
  background-color: var(--color-main);
}

.link-icon.link-icon--reverse .link-icon__path {
  fill: #ffffff;
}
.link-icon.link-icon--reverse .link-icon__path--reverse {
  fill: var(--color-main);
}

/* link icon : white color */
.link-icon.link-icon--white::before {
  border-color: #ffffff;
}
.link-icon.link-icon--white .link-icon__arrow__path {
  fill: #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-title-deco);
  font-size: 1.2rem;
  letter-spacing: var(--ls-button);
  line-height: var(--lh-button);
}
.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__anchor {
  display: inline-block;
  position: relative;
  padding-right: 25px;
  transition: color .3s;
}
/* :focus & :hover */
.link-text__anchor:focus,
a:focus .link-text__anchor {
  color: rgba(0,38,61,.75);
}
@media screen and (min-width: 1050px) {
  .link-text__anchor:hover,
  :where(a:hover, .bl-hover) .link-text__anchor {
    color: rgba(0,38,61,.75);
  }
}

/* link icon */
.link-text__anchor__icon {
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  width: 17px;
  height: 17px;
  transform: translateY(-50%);
}
.link-text__anchor__icon--default {
  border-radius: 5px;
}

.link-text__anchor__icon::before,
.link-text__anchor__icon::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 5px;
}
.link-text__anchor__icon::before {
  background: linear-gradient(92deg,#00263D, #305B76);
}
.link-text__anchor__icon::after{
  background-color: var(—color-main);
  opacity: 1;
  transition: .3s;
}

@media screen and (min-width: 1050px) {
  .link-text__anchor:hover .link-text__anchor__icon::after,
  :where(a:hover, .bl-hover) .link-text__anchor__icon::after {
    opacity: 0;
  }
}

.link-text__anchor__icon__arrow {
  display: block;
  position: absolute;
  top: 6px;
  left: 1px;
  width: 13px;
  height: 4px;
  z-index: 1;
  transition: .3s;
}
.link-text__anchor:focus .link-text__anchor__icon__arrow,
a:focus .link-text__anchor .link-text__anchor__icon__arrow {
  width: 15px;
}
@media screen and (min-width: 1050px) {
  .link-text__anchor:hover .link-text__anchor__icon__arrow,
  :where(a:hover, .bl-hover) .link-text__anchor__icon__arrow {
    width: 15px;
  }
}

.link-text__anchor__icon__arrow::before,
.link-text__anchor__icon__arrow::after {
  content: "";
  display: block;
  position: absolute;
  background-color: #ffffff;
}
.link-text__anchor__icon__arrow::before {
  top: 0;
  right: 0;
  width: 6px;
  height: 4px;
  clip-path: polygon(0% 100%, 0% 0%, 100% 100%);
}
.link-text__anchor__icon__arrow::after {
  left: 0;
  bottom: 0;
  width: 6px;
  height: 1px;
  transition: .3s;
}
.link-text__anchor:focus .link-text__anchor__icon__arrow::after,
a:focus .link-text__anchor .link-text__anchor__icon__arrow::after {
  width: 8px;
}
@media screen and (min-width: 1050px) {
  .link-text__anchor:hover .link-text__anchor__icon__arrow::after,
  :where(a:hover, .bl-hover) .link-text__anchor__icon__arrow::after {
    width: 8px;
  }
}

.link-text__anchor__icon__path {
  fill: var(--color-main);
  transition: fill .3s;
}
/* :focus & :hover */
.link-text__anchor__icon__path--reverse {
  fill: #ffffff;
}

/* link icon : PDF */
.link-text__anchor.is-pdf {
  padding-right: 23px;
}

.link-text__anchor.is-pdf .link-text__anchor__icon {
  width: 15px;
  height: 15.4px;
  border-radius: 0;
}
.link-text__anchor.is-pdf .link-text__anchor__icon::before,
.link-text__anchor.is-pdf .link-text__anchor__icon::after {
  content: none;
}


/* link icon : external link */
.link-text__anchor.is-exlink {
  padding-right: 20px;
}

.link-text__anchor.is-exlink .link-text__anchor__icon {
  width: 12px;
  height: 12px;
  border-radius: 0;
}
.link-text__anchor.is-exlink .link-text__anchor__icon::before,
.link-text__anchor.is-exlink .link-text__anchor__icon::after {
  content: none;
}


/* reverse style */
.link-text.link-text--reverse .link-text__anchor {
  color: #ffffff;
}
.link-text.link-text--reverse .link-text__anchor:focus,
a:focus .link-text.link-text--reverse .link-text__anchor {
  color: rgba(255,255,255,.75);
}
@media screen and (min-width: 1050px) {
  .link-text.link-text--reverse .link-text__anchor:hover,
  :where(a:hover, .bl-hover) .link-text.link-text--reverse .link-text__anchor {
    color: rgba(255,255,255,.75);
  }
}

.link-text.link-text--reverse .link-text__anchor__icon::before {
  background: linear-gradient(45deg, rgba(255,255,255,.6), rgba(255,255,255,1));
}
.link-text.link-text--reverse .link-text__anchor__icon::after{
  background-color: #ffffff;
}
.link-text.link-text--reverse .link-text__anchor__icon__arrow::before,
.link-text.link-text--reverse .link-text__anchor__icon__arrow::after {
  background-color: var(--color-main);
}

.link-text.link-text--reverse .link-text__anchor__icon__path {
  fill: #ffffff;
}
.link-text.link-text--reverse .link-text__anchor__icon__path--reverse {
  fill: var(--color-main);
}

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

  段落

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

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

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

.paragraph {
  margin-top: calc(1px * var(--leading-trim));
  margin-bottom: calc(1px * var(--leading-trim));
  color: var(--color-plane);
  font-size: var(--fz-root-palmtop);
  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);
}

/* adjust margin-top when "heading + paragraph" */
.heading-2 + .paragraph,
.heading-3 + .paragraph,
.heading-4 + .paragraph,
.heading-5 + .paragraph {
  margin-top: calc(var(--leading-trim) * 2);
}

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

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

  セクション

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

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

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

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

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

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

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

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

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

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

    view

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

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

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

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

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