@charset "UTF-8";
/***********************************************************************************************
//
// Basic.scss
//
// @creation : 2022-12-10
// @update   : 2023-07-20
// @copyright: kadooka
//
**********************************************************************************************/
/* ----------------------------------------
プロジェクトをまたいで共通
---------------------------------------- */
:root {
  --viewport-max: 1600px;
  --viewport-min: 1024px;
  --size1: 0.8rem;
  --size: 0.8rem;
  --size2: calc(var(--size) * 2);
  --size3: calc(var(--size) * 3);
  --size4: calc(var(--size) * 4);
  --size5: calc(var(--size) * 5);
  --size6: calc(var(--size) * 6);
  --size7: calc(var(--size) * 7);
  --size8: calc(var(--size) * 8);
  --size9: calc(var(--size) * 9);
  --size10: calc(var(--size) * 10);
  --size11: calc(var(--size) * 11);
  --size12: calc(var(--size) * 12);
  --size13: calc(var(--size) * 13);
  --size14: calc(var(--size) * 14);
  --size15: calc(var(--size) * 15);
  --size16: calc(var(--size) * 16);
  --size17: calc(var(--size) * 17);
  --size18: calc(var(--size) * 18);
  --size19: calc(var(--size) * 19);
  --size20: calc(var(--size) * 20);
  --sizemax: 16rem;
  --round-xs: 4px;
  --round-s: 8px;
  --round-m: 16px;
  --round-l: 24px;
  --round-xl: 260px;
  --round-full: 100vmax;
  --fontsize11: 1.1rem;
  --fontsize12: 1.2rem;
  --fontsize13: 1.3rem;
  --fontsize14: clamp(1.3rem, 1.274rem + 0.11vw, 1.4rem);
  --fontsize15: clamp(1.3rem, 1.247rem + 0.22vw, 1.5rem);
  --fontsize16: clamp(1.3rem, 1.247rem + 0.22vw, 1.5rem);
  --fontsize17: clamp(1.5rem, 1.447rem + 0.22vw, 1.7rem);
  --fontsize18: clamp(1.5rem, 1.391rem + 0.55vw, 1.8rem);
  --fontsize24: clamp(1.5rem, 1.447rem + 0.22vw, 1.7rem);
  --fontsize-heading-m2: 1.8rem;
  --fontsize-heading-m: 1.7rem;
  --fontsize-heading-l: clamp(2.2rem, 2.027rem + 0.86vw, 3rem);
  --fontsize-dense13: clamp(1.2rem, 1.178rem + 0.11vw, 1.3rem);
  --fontsize-dense14: clamp(1.3rem, 1.278rem + 0.11vw, 1.4rem);
  --lineheight14: 1.4;
  --lineheight16: 1.6;
  --lineheight17: 1.7;
  --lineheight18: 1.8;
  --lineheight20: 2.0;
  --gap-main: 12.8rem;
  --gap-section-large: 6.4rem;
  --gap-section-medium: 4.8rem;
}

:root {
  --zindex-lv: 0;
  --zindex-lv1: 1;
  --zindex-lv2: calc(var(--zindex-lv1) * 10);
  --zindex-lv3: calc(var(--zindex-lv2) * 10);
  --zindex-lv4: calc(var(--zindex-lv3) * 10);
  --zindex-lv5: calc(var(--zindex-lv4) * 10);
  --zindex-lv6: calc(var(--zindex-lv5) * 10);
  --zindex-lv7: calc(var(--zindex-lv6) * 10);
  --zindex-lv8: calc(var(--zindex-lv7) * 10);
  --zindex-lv9: calc(var(--zindex-lv8) * 10);
  --zindex-lv10: calc(var(--zindex-lv9) * 10);
  --zindex-lv-max: 1000000000;
  --zindex-lv-limit: 2147483647;
}

:root {
  --color-line: #D6D6D6;
  --color-white: #FDFDFD;
  --color-pure-white: #ffffff;
  --color-pure-white-rgb: 255,255,255;
  --color-white-hov: #F2F2EF;
  --color-text1: #333333;
  --color-text2: #555555;
  --color-text3: #777777;
  --color-link: #d85c3f;
  --color-important: #DE0000;
  --color-important-rgb: 222,0,0;
  --color-theme: #3379E6;
  --color-sns-twitter: #222;
  --color-sns-facebook: #0866FF;
}

:root {
  --font-basic: "游ゴシック体", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "ヒラギノ角ゴ Pro", "メイリオ", "Meiryo", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "Helvetica", "Verdana", sans-serif;
  --font-en: "Roboto Condensed", sans-serif;
  --font-en2: "Roboto Condensed", sans-serif;
  --font-slogan: "DNPShuei4goStd-M";
}

:root {
  --ease: ease;
  --linear: linear;
  --easeIn: ease-in;
  --easeOut: ease-out;
  --easeInOut: ease-in-out;
  --easeSnap: cubic-bezier(0, 1, 0.5, 1);
  --easeOutCubic: cubic-bezier(0.215, 0.61, 0.355, 1);
  --easeInOutCubic: cubic-bezier(0.645, 0.045, 0.355, 1);
  --easeInCirc: cubic-bezier(0.6, 0.04, 0.98, 0.335);
  --easeOutCirc: cubic-bezier(0.075, 0.82, 0.165, 1);
  --easeInOutCirc: cubic-bezier(0.785, 0.135, 0.15, 0.86);
  --easeInExpo: cubic-bezier(0.95, 0.05, 0.795, 0.035);
  --easeOutExpo: cubic-bezier(0.19, 1, 0.22, 1);
  --easeInOutExpo: cubic-bezier(1, 0, 0, 1);
  --easeInQuad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
  --easeOutQuad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --easeInOutQuad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
  --easeInQuart: cubic-bezier(0.895, 0.03, 0.685, 0.22);
  --easeOutQuart: cubic-bezier(0.165, 0.84, 0.44, 1);
  --easeInOutQuart: cubic-bezier(0.77, 0, 0.175, 1);
  --easeInQuint: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  --easeOutQuint: cubic-bezier(0.23, 1, 0.32, 1);
  --easeInOutQuint: cubic-bezier(0.86, 0, 0.07, 1);
  --easeInSine: cubic-bezier(0.47, 0, 0.745, 0.715);
  --easeOutSine: cubic-bezier(0.39, 0.575, 0.565, 1);
  --easeInOutSine: cubic-bezier(0.445, 0.05, 0.55, 0.95);
  --easeInBack: cubic-bezier(0.6, -0.28, 0.735, 0.045);
  --easeOutBack: cubic-bezier(0.175, 0.885, 0.32, 1.275);
  --easeInOutBack: cubic-bezier(0.68, -0.55, 0.265, 1.55);
  --easeFloating: cubic-bezier(0.77, 0, 0.175, 1);
  --easeOrg: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

@-webkit-keyframes arrow-anim {
  0% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  29% {
    opacity: 0;
    -webkit-transform: translateX(10px);
            transform: translateX(10px);
  }
  30% {
    -webkit-transform: translateX(-10px);
            transform: translateX(-10px);
  }
  60% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes arrow-anim {
  0% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  29% {
    opacity: 0;
    -webkit-transform: translateX(10px);
            transform: translateX(10px);
  }
  30% {
    -webkit-transform: translateX(-10px);
            transform: translateX(-10px);
  }
  60% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@-webkit-keyframes arrow-anim__reverse {
  0% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  29% {
    opacity: 0;
    -webkit-transform: translateX(-10px);
            transform: translateX(-10px);
  }
  30% {
    -webkit-transform: translateX(10px);
            transform: translateX(10px);
  }
  60% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes arrow-anim__reverse {
  0% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  29% {
    opacity: 0;
    -webkit-transform: translateX(-10px);
            transform: translateX(-10px);
  }
  30% {
    -webkit-transform: translateX(10px);
            transform: translateX(10px);
  }
  60% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@layer reset {
  /* ==============================================================================================
  CSS RESET
  ============================================================================================== */
  * {
    min-height: 0;
    margin: 0;
    padding: 0;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    vertical-align: baseline;
  }
  html {
    font-size: 62.5%;
    -ms-scroll-chaining: none;
        overscroll-behavior: none;
  }
  html,
  body {
    height: 100%;
  }
  body {
    display: block;
    line-height: 1;
    color: var(--color-black2);
    text-align: left;
    width: 100%;
    background: var(--color-pure-white);
    margin: 0;
    padding: 0;
    position: relative;
    text-rendering: optimizelegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: none;
       -moz-text-size-adjust: none;
        -ms-text-size-adjust: none;
            text-size-adjust: none;
    -webkit-font-feature-settings: "palt" on;
            font-feature-settings: "palt" on;
    word-wrap: break-word;
    overflow-wrap: break-word;
    font-family: var(--font-basic);
    font-weight: normal;
    background: #f7f5ee;
  }
  :lang(en) main {
    font-family: var(--font-en);
    text-align: left;
    letter-spacing: 0;
  }
  body.fixed {
    position: fixed;
    width: 100%;
    height: 100%;
  }
  summary {
    cursor: pointer;
  }
  article,
  aside,
  dialog,
  figure,
  footer,
  header,
  hgroup,
  menu,
  nav,
  section,
  main {
    display: block;
  }
  audio,
  canvas,
  progress,
  video {
    display: inline-block;
    *display: inline;
    *zoom: 1;
    vertical-align: baseline;
  }
  audio:not([controls]) {
    display: none;
    height: 0;
  }
  [hidden] {
    display: none;
  }
  template {
    display: none;
  }
  address {
    font-style: normal;
  }
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    font-weight: normal;
    line-height: 100%;
    margin: 0;
    padding: 0;
  }
  strong,
  b {
    font-weight: 600;
  }
  object {
    pointer-events: none;
  }
  img {
    border: none;
    vertical-align: bottom;
  }
  audio:not([controls]) {
    display: none;
    height: 0;
  }
  svg {
    fill: currentcolor;
    vertical-align: bottom;
  }
  svg:not(:root) {
    overflow: hidden;
  }
  a {
    color: inherit;
    cursor: pointer;
  }
  a:hover {
    text-decoration: none;
  }
  .l-main a:not(.c-button) {
    color: var(--color-link);
  }
  a[href^="#"]:not([class], [target=_blank], [href$=".pdf"], [href$=".docx"], [href$=".doc"], [href$=".xls"], [href$=".xlsx"], [href$=".tsv"]) {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0.5em;
  }
  a[href^="#"]:not([class], [target=_blank], [href$=".pdf"], [href$=".docx"], [href$=".doc"], [href$=".xls"], [href$=".xlsx"], [href$=".tsv"])::before {
    content: "";
    background: currentColor;
    display: inline-block;
    inline-size: 0.8em;
    block-size: 0.8em;
    -webkit-mask-image: url("/assets/image/common/icon-arrow.svg");
            mask-image: url("/assets/image/common/icon-arrow.svg");
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-position: center;
            mask-position: center;
    -webkit-mask-size: contain;
            mask-size: contain;
    opacity: 0.5;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
  }
  a[href^="#"]:not([class], [target=_blank], [href$=".pdf"], [href$=".docx"], [href$=".doc"], [href$=".xls"], [href$=".xlsx"], [href$=".tsv"]):hover::before {
    opacity: 1;
    translate: 0.3em 0;
  }
  @media (hover: hover) and (pointer: fine) {
    a[href^="tel:"] {
      color: currentColor;
      text-decoration: none;
      pointer-events: none;
      cursor: default;
    }
  }
  a.u-link-currentcolor {
    color: currentColor;
  }
  a[target=_blank], a[href$=".pdf"], a[href$=".docx"], a[href$=".doc"], a[href$=".xls"], a[href$=".xlsx"], a[href$=".tsv"] {
    vertical-align: middle;
    position: relative;
    margin-right: 1.5em;
  }
  a[target=_blank]:has(img):hover, a[href$=".pdf"]:has(img):hover, a[href$=".docx"]:has(img):hover, a[href$=".doc"]:has(img):hover, a[href$=".xls"]:has(img):hover, a[href$=".xlsx"]:has(img):hover, a[href$=".tsv"]:has(img):hover {
    opacity: 0.8;
  }
  .l-nav a[target=_blank], .l-nav a[href$=".pdf"], .l-nav a[href$=".docx"], .l-nav a[href$=".doc"], .l-nav a[href$=".xls"], .l-nav a[href$=".xlsx"], .l-nav a[href$=".tsv"] {
    margin: 0;
  }
  a[target=_blank]:has(img)::after, a[target=_blank]:has(.c-entry-title)::after, .l-nav a[target=_blank]::after, a[href$=".pdf"]:has(img)::after, a[href$=".pdf"]:has(.c-entry-title)::after, .l-nav a[href$=".pdf"]::after, a[href$=".docx"]:has(img)::after, a[href$=".docx"]:has(.c-entry-title)::after, .l-nav a[href$=".docx"]::after, a[href$=".doc"]:has(img)::after, a[href$=".doc"]:has(.c-entry-title)::after, .l-nav a[href$=".doc"]::after, a[href$=".xls"]:has(img)::after, a[href$=".xls"]:has(.c-entry-title)::after, .l-nav a[href$=".xls"]::after, a[href$=".xlsx"]:has(img)::after, a[href$=".xlsx"]:has(.c-entry-title)::after, .l-nav a[href$=".xlsx"]::after, a[href$=".tsv"]:has(img)::after, a[href$=".tsv"]:has(.c-entry-title)::after, .l-nav a[href$=".tsv"]::after {
    display: none;
  }
  header a[target=_blank], a[target=_blank].u-link-under, header a[href$=".pdf"], a[href$=".pdf"].u-link-under, header a[href$=".docx"], a[href$=".docx"].u-link-under, header a[href$=".doc"], a[href$=".doc"].u-link-under, header a[href$=".xls"], a[href$=".xls"].u-link-under, header a[href$=".xlsx"], a[href$=".xlsx"].u-link-under, header a[href$=".tsv"], a[href$=".tsv"].u-link-under {
    -webkit-padding-end: 0;
            padding-inline-end: 0;
    margin-right: 0;
  }
  a[target=_blank].u-link-under, a[href$=".pdf"].u-link-under, a[href$=".docx"].u-link-under, a[href$=".doc"].u-link-under, a[href$=".xls"].u-link-under, a[href$=".xlsx"].u-link-under, a[href$=".tsv"].u-link-under {
    text-decoration: none;
  }
  a[target=_blank].u-link-under:hover, a[href$=".pdf"].u-link-under:hover, a[href$=".docx"].u-link-under:hover, a[href$=".doc"].u-link-under:hover, a[href$=".xls"].u-link-under:hover, a[href$=".xlsx"].u-link-under:hover, a[href$=".tsv"].u-link-under:hover {
    text-decoration: underline;
  }
  a[target=_blank]::after, a[href$=".pdf"]::after, a[href$=".docx"]::after, a[href$=".doc"]::after, a[href$=".xls"]::after, a[href$=".xlsx"]::after, a[href$=".tsv"]::after {
    content: "";
    inline-size: 0.8em;
    vertical-align: middle;
    aspect-ratio: 1/1;
    position: relative;
    display: inline-block;
    background: currentColor;
    position: absolute;
    bottom: calc(0.5lh - 0.5333333333em);
    padding-left: 0.5em;
  }
  header a[target=_blank]::after, a[target=_blank].u-link-under::after, header a[href$=".pdf"]::after, a[href$=".pdf"].u-link-under::after, header a[href$=".docx"]::after, a[href$=".docx"].u-link-under::after, header a[href$=".doc"]::after, a[href$=".doc"].u-link-under::after, header a[href$=".xls"]::after, a[href$=".xls"].u-link-under::after, header a[href$=".xlsx"]::after, a[href$=".xlsx"].u-link-under::after, header a[href$=".tsv"]::after, a[href$=".tsv"].u-link-under::after {
    display: none;
  }
  a[target=_blank]::after, a[href$=".pdf"]::after, a[href$=".docx"]::after, a[href$=".doc"]::after, a[href$=".xls"]::after, a[href$=".xlsx"]::after, a[href$=".tsv"]::after {
    -webkit-mask-image: url("/assets/image/common/icon/icon_dl.svg");
            mask-image: url("/assets/image/common/icon/icon_dl.svg");
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-position: center;
            mask-position: center;
    -webkit-mask-size: contain;
            mask-size: contain;
  }
  a[target=_blank]::after {
    -webkit-mask-image: url("/assets/image/common/icon/icon_blank.svg");
            mask-image: url("/assets/image/common/icon/icon_blank.svg");
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-position: center;
            mask-position: center;
    -webkit-mask-size: contain;
            mask-size: contain;
  }
  a * {
    cursor: pointer;
  }
  a,
  input,
  select,
  textarea,
  button,
  a object,
  a img,
  button span,
  a .c-button,
  .u-hvr {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
  :is(ol, ul) li {
    list-style: none;
  }
  img {
    max-width: 100%;
  }
  figure {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.8rem;
  }
  figure figcaption {
    font-size: clamp(1.1rem, 1.0736842105rem + 0.1122807018vw, 1.2rem);
    line-height: var(--lineheight16);
    color: var(--color-black4);
  }
  input[type=text],
  input[type=tel],
  input[type=email],
  input[type=number],
  textarea {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  input[type=text]:focus,
  input[type=tel]:focus,
  input[type=email]:focus,
  input[type=number]:focus,
  input[type=checkbox]:focus,
  textarea:focus,
  label:focus,
  select {
    outline: 0;
  }
  select::-ms-expand {
    display: none;
  }
  :-moz-placeholder-shown {
    color: var(--color-placeholder);
  }
  :-ms-input-placeholder {
    color: var(--color-placeholder);
  }
  :placeholder-shown {
    color: var(--color-placeholder);
  }
  ::-webkit-input-placeholder {
    color: var(--color-placeholder);
  }
  ::-moz-placeholder {
    color: var(--color-placeholder);
  }
  :-ms-input-placeholder {
    color: var(--color-placeholder);
  }
  ::-ms-input-placeholder {
    color: var(--color-placeholder);
  }
  ::placeholder {
    color: var(--color-placeholder);
  }
  :input-placeholder {
    color: var(--color-placeholder);
  }
  :placeholder {
    color: var(--color-placeholder);
  }
  ::-webkit-input-placeholder {
    color: var(--color-placeholder);
  }
  ::-moz-placeholder {
    color: var(--color-placeholder);
  }
  :-ms-input-placeholder {
    color: var(--color-placeholder);
  }
  ::-ms-input-placeholder {
    color: var(--color-placeholder);
  }
  ::placeholder {
    color: var(--color-placeholder);
  }
  ::input-placeholder {
    color: var(--color-placeholder);
  }
  iframe {
    width: 100%;
    height: 100%;
    border: none;
    outline: none;
    aspect-ratio: 16/9;
  }
  ruby {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.7rem;
    border: none;
    white-space: nowrap;
    vertical-align: text-bottom;
    text-align: center;
    line-height: 100%;
  }
  ruby rt {
    display: table-header-group;
    font-size: 50%;
    text-align: center;
    line-height: 100%;
  }
  ruby ruby rt {
    display: table-footer-group;
    font-size: 50%;
    line-height: 100%;
  }
  ruby rp {
    display: none;
  }
  dl dt {
    font-weight: bold;
  }
  body > span {
    position: fixed;
    width: 0;
    height: 0;
    overflow: hidden;
    left: 0;
  }
  select {
    width: 100%;
    -webkit-appearance: none;
       -moz-appearance: none;
            appearance: none;
    border-radius: 2px;
    font-size: 1.4rem;
    background: var(--color-pure-white);
    border: none;
    border: 1px solid #dbdbdb;
    padding: 0 1.5rem;
    outline: none;
    -webkit-box-shadow: none;
            box-shadow: none;
  }
  @media screen and (max-width: 768px) {
    select {
      background: #eee;
    }
  }
  hr {
    inline-size: 100%;
    block-size: 1px;
    background: url(/assets/image/common/line_dot_x.gif) repeat-x left bottom;
    border: none;
    -webkit-box-shadow: none;
            box-shadow: none;
    opacity: 0.4;
  }
}
/* ----------------------------------------
プロジェクト要素
---------------------------------------- */
@layer layout {
  /* ==============================================================================================
  メインフレーム：ヘッダー
  ============================================================================================== */
  .l-header {
    inline-size: 100%;
    text-align: center;
    padding-block: 10rem;
  }
  @media screen and (max-width: 768px) {
    .l-header {
      padding-block: 4rem;
    }
  }
  .l-header-logo {
    inline-size: 35rem;
    margin-inline: auto;
  }
  .l-header-logo img {
    inline-size: 100%;
    block-size: auto;
  }
  .l-header-logo img:hover {
    opacity: 0.5;
  }
  @media screen and (max-width: 768px) {
    .l-header-logo {
      inline-size: 20rem;
    }
  }
}
@layer layout {
  /* ==============================================================================================
  メインフレーム：フッター
  ============================================================================================== */
  .l-breadcrumb {
    font-size: 1.2rem;
    line-height: 1.4;
    border-top: #d9d9d9 solid 1px;
    border-bottom: #d9d9d9 solid 1px;
    padding: 1.5em 0;
  }
  @media screen and (max-width: 768px) {
    .l-breadcrumb {
      font-size: 1rem;
      padding: 1.4em 0;
    }
  }
  .l-breadcrumb__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .l-breadcrumb__list li:after {
    content: ">";
    display: inline-block;
    color: #999999;
    padding: 0 0.8em;
  }
  @media screen and (max-width: 768px) {
    .l-breadcrumb__list li:after {
      padding: 0 0.4em;
    }
  }
  .l-breadcrumb__list li:last-child:after {
    display: none;
  }
  .l-breadcrumb__list li > a {
    text-decoration: none;
    color: #777777;
  }
  .l-breadcrumb__list li > a:hover {
    text-decoration: underline;
  }
  .l-info {
    background: #eae8df;
    padding-block: 5rem;
  }
  @media screen and (max-width: 768px) {
    .l-info {
      padding-block: 3.2rem;
    }
  }
  .l-info-box {
    background: #fff;
    padding: 5rem;
    text-align: center;
  }
  @media screen and (max-width: 768px) {
    .l-info-box {
      padding: 1.6rem;
    }
  }
  .l-info-box__label {
    font-size: 1.8rem;
    line-height: 1.6;
    color: var(--color-text2);
  }
  @media screen and (max-width: 768px) {
    .l-info-box__label {
      font-size: 1.2rem;
      line-height: 1.4;
    }
  }
  .l-info-box__tel {
    font-family: var(--font-en);
    font-size: 4.8rem;
    color: var(--color-link);
    letter-spacing: 0.05rem;
    padding-block: 0.5em;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0.8rem;
  }
  @media screen and (max-width: 768px) {
    .l-info-box__tel {
      font-size: 2.8rem;
      padding-block: 0.4em;
      gap: 0.4rem;
    }
  }
  .l-info-box__tel::before {
    content: "";
    inline-size: 3.8rem;
    block-size: 4.2rem;
    background: url(/assets/image/common/icon_phone.svg) no-repeat left top/cover;
    display: block;
  }
  @media screen and (max-width: 768px) {
    .l-info-box__tel::before {
      inline-size: 1.9rem;
      block-size: 2.1rem;
    }
  }
  .l-info-box__notice {
    color: var(--color-text2);
    font-size: 1.8rem;
    line-height: 1.6;
  }
  @media screen and (max-width: 768px) {
    .l-info-box__notice {
      font-size: 1.2rem;
    }
  }
  .l-footer {
    text-align: center;
    color: var(--color-pure-white);
    background-color: #000;
    padding-block: 10rem;
  }
  @media screen and (max-width: 768px) {
    .l-footer {
      padding-block: 4rem;
    }
  }
  .l-footer__logo {
    inline-size: 22.7rem;
    margin-inline: auto;
  }
  @media screen and (max-width: 768px) {
    .l-footer__logo {
      inline-size: 14rem;
    }
  }
  .l-footer__logo > a {
    display: block;
    margin: 0 auto;
  }
  .l-footer__logo > a:hover {
    opacity: 0.5;
  }
  .l-footer__profile {
    color: #d1d1d1;
    font-size: 1.4rem;
    letter-spacing: 5%;
    line-height: 2.2;
    padding-top: 4rem;
  }
  @media screen and (max-width: 768px) {
    .l-footer__profile {
      font-size: 1.2rem;
      letter-spacing: 0;
      line-height: 1.8;
      padding-top: 2.4rem;
    }
  }
  .l-footer__profile > dt > small {
    font-size: 1rem;
  }
  @media screen and (max-width: 768px) {
    .l-footer__profile > dt > small {
      display: block;
      padding-bottom: 1em;
    }
  }
  .l-footer__profile > dd > address {
    display: inline-block;
  }
  @media screen and (max-width: 768px) {
    .l-footer__profile > dd > address {
      display: block;
    }
  }
  .l-footer__profile a {
    color: #d1d1d1;
    text-decoration: underline;
  }
  .l-footer__profile a:hover {
    text-decoration: none;
  }
  .l-footer__copyright {
    font-family: var(--font-en2);
    color: #6f6f6f;
    font-size: 1.4rem;
    letter-spacing: 5%;
    line-height: 2.2;
    text-transform: uppercase;
    padding-top: 3rem;
  }
  @media screen and (max-width: 768px) {
    .l-footer__copyright {
      font-size: 1.2rem;
      letter-spacing: 0;
      padding-top: 1.6rem;
    }
  }
}
@layer layout {
  /* ==============================================================================================
  メインフレーム：メインコンテンツ
  ============================================================================================== */
  .l-main {
    inline-size: 100%;
    min-inline-size: var(--viewport-min);
    overflow: hidden;
    position: relative;
    padding-bottom: 8rem;
  }
  .l-main.is-home {
    padding-top: 8rem;
  }
  @media screen and (max-width: 768px) {
    .l-main {
      min-width: inherit;
      min-width: auto;
      padding-bottom: 4rem;
    }
  }
  /* c-content
  -----------------------------------------------------------------*/
  .c-content {
    width: 100%;
    min-width: 1024px;
    overflow: hidden;
    position: relative;
  }
  @media screen and (max-width: 768px) {
    .c-content {
      min-width: inherit;
      min-width: auto;
    }
  }
  /* c-content__large
  -----------------------------------------------------------------*/
  .c-content__large {
    width: 100%;
    max-width: 1680px;
    min-width: 980px;
    margin: 0 auto;
    position: relative;
  }
  @media screen and (max-width: 768px) {
    .c-content__large {
      width: auto;
      margin: 0 20px;
      max-width: inherit;
      max-width: auto;
      min-width: inherit;
      min-width: auto;
    }
  }
  /* c-content__medium
  -----------------------------------------------------------------*/
  .c-content__medium {
    width: 75%;
    max-width: 1280px;
    min-width: 980px;
    margin: 0 auto;
    position: relative;
  }
  @media screen and (max-width: 768px) {
    .c-content__medium {
      width: auto;
      margin: 0 20px;
      max-width: inherit;
      max-width: auto;
      min-width: inherit;
      min-width: auto;
    }
  }
  .c-content__xmedium {
    width: 87.5%;
    margin: 0 auto;
    position: relative;
  }
  @media screen and (max-width: 768px) {
    .c-content__xmedium {
      width: auto;
      margin: 0 20px;
      max-width: inherit;
      max-width: auto;
      min-width: inherit;
      min-width: auto;
    }
  }
  /* c-content__small
  -----------------------------------------------------------------*/
  .c-content__small {
    width: 75%;
    max-width: 768px;
    margin: 0 auto;
    position: relative;
  }
  @media screen and (max-width: 768px) {
    .c-content__small {
      width: auto;
      margin: 0 20px;
      max-width: inherit;
      max-width: auto;
      min-width: inherit;
      min-width: auto;
    }
  }
  /* c-content__half
  -----------------------------------------------------------------*/
  .c-content__half {
    width: 60%;
    max-width: 600px;
    min-width: 440px;
    margin: 0 auto;
    position: relative;
  }
  @media screen and (max-width: 768px) {
    .c-content__half {
      width: auto;
      margin: 0 20px;
      max-width: inherit;
      max-width: auto;
      min-width: inherit;
      min-width: auto;
    }
  }
}
@layer layout {
  /* pagetop
  -----------------------------------------------------------------*/
  .l-pagetop {
    position: fixed;
    right: 0;
    bottom: 0;
    z-index: 9999;
    -webkit-transition: all 0.3s var(--easeInOutSine);
    transition: all 0.3s var(--easeInOutSine);
  }
  @media screen and (max-width: 768px) {
    .l-pagetop {
      bottom: -40px;
    }
  }
  .l-pagetop.is-scrolling {
    bottom: 0px;
  }
  .l-pagetop__link {
    display: block;
    background: #202020;
  }
  .l-pagetop__link:hover {
    background: #393939;
  }
  .l-pagetop__link__inner {
    display: -ms-grid;
    display: grid;
    place-content: center;
    width: 7.4rem;
    aspect-ratio: 1/1;
    position: relative;
  }
  @media screen and (max-width: 768px) {
    .l-pagetop__link__inner {
      width: 40px;
      height: 40px;
    }
  }
  .l-pagetop__link__inner img {
    inline-size: 1.2rem;
    aspect-ratio: 1/0.9;
  }
  a:hover .l-pagetop__link__inner img {
    translate: 0 -5px;
  }
  @media screen and (max-width: 768px) {
    .l-pagetop__link__inner:after {
      background-size: 4px 6px;
      background-size: 0.4rem 0.6rem;
    }
  }
}
/* ==============================================================================================
コンポーネント
============================================================================================== */
/* ----------------------------------------
グランドコンポーネント
---------------------------------------- */
/***********************************************************************************************
//
// カラムレイアウトクラス
// _column.scss
//
// 均等配置されたレイアウトのみ含まれます。
// （2:4など等幅でないレイアウトは「layout.scss」に記述）
// 
// [仕様]
// ■カラム値
// 「$max-column」を変更することで最大カラムの調整が可能
// ■gap値
// gap値は初期設定をベースに自動生成
// 一部ユニークな値や、倍数外の数値を含むため
// 値のリストを$gapsとして当てはめる形式をとっている。
// 
// @creation : 2022-12-10
// @update   : 2024-11-05
// @copyright: kadooka
//
**********************************************************************************************/
.c-column {
  display: -ms-grid;
  display: grid;
  container-type: inline-size;
}
.c-column.-vertical {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.c-column.-align-center {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.c-column.-col-free {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.c-column.-col-free.-space-bw {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-clear {
    display: block;
  }
  .c-column.-medium-vertical {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-clear {
    display: block;
  }
  .c-column.-small-vertical {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.c-column.-col2 {
  -ms-grid-columns: (1fr)[2];
  grid-template-columns: repeat(2, 1fr);
}
.c-column.-col3 {
  -ms-grid-columns: (1fr)[3];
  grid-template-columns: repeat(3, 1fr);
}
.c-column.-col4 {
  -ms-grid-columns: (1fr)[4];
  grid-template-columns: repeat(4, 1fr);
}
.c-column.-col5 {
  -ms-grid-columns: (1fr)[5];
  grid-template-columns: repeat(5, 1fr);
}
.c-column.-col6 {
  -ms-grid-columns: (1fr)[6];
  grid-template-columns: repeat(6, 1fr);
}
.c-column.-col7 {
  -ms-grid-columns: (1fr)[7];
  grid-template-columns: repeat(7, 1fr);
}
.c-column.-col8 {
  -ms-grid-columns: (1fr)[8];
  grid-template-columns: repeat(8, 1fr);
}
.c-column.-col9 {
  -ms-grid-columns: (1fr)[9];
  grid-template-columns: repeat(9, 1fr);
}
.c-column.-col10 {
  -ms-grid-columns: (1fr)[10];
  grid-template-columns: repeat(10, 1fr);
}
@media screen and (max-width: 768px) {
  .c-column.-small-col2 {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-col3 {
    -ms-grid-columns: (1fr)[3];
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-col4 {
    -ms-grid-columns: (1fr)[4];
    grid-template-columns: repeat(4, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-col5 {
    -ms-grid-columns: (1fr)[5];
    grid-template-columns: repeat(5, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-col6 {
    -ms-grid-columns: (1fr)[6];
    grid-template-columns: repeat(6, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-col7 {
    -ms-grid-columns: (1fr)[7];
    grid-template-columns: repeat(7, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-col8 {
    -ms-grid-columns: (1fr)[8];
    grid-template-columns: repeat(8, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-col9 {
    -ms-grid-columns: (1fr)[9];
    grid-template-columns: repeat(9, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-col10 {
    -ms-grid-columns: (1fr)[10];
    grid-template-columns: repeat(10, 1fr);
  }
}
.c-column.-gap8 {
  gap: 0.8rem;
}
.c-column.-row-gap8 {
  row-gap: 0.8rem;
}
.c-column.-gap12 {
  gap: 1.2rem;
}
.c-column.-row-gap12 {
  row-gap: 1.2rem;
}
.c-column.-gap16 {
  gap: 1.6rem;
}
.c-column.-row-gap16 {
  row-gap: 1.6rem;
}
.c-column.-gap24 {
  gap: 2.4rem;
}
.c-column.-row-gap24 {
  row-gap: 2.4rem;
}
.c-column.-gap32 {
  gap: 3.2rem;
}
.c-column.-row-gap32 {
  row-gap: 3.2rem;
}
.c-column.-gap40 {
  gap: 4rem;
}
.c-column.-row-gap40 {
  row-gap: 4rem;
}
.c-column.-gap48 {
  gap: 4.8rem;
}
.c-column.-row-gap48 {
  row-gap: 4.8rem;
}
.c-column.-gap56 {
  gap: 5.6rem;
}
.c-column.-row-gap56 {
  row-gap: 5.6rem;
}
.c-column.-gap64 {
  gap: 6.4rem;
}
.c-column.-row-gap64 {
  row-gap: 6.4rem;
}
.c-column.-gap80 {
  gap: 8rem;
}
.c-column.-row-gap80 {
  row-gap: 8rem;
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-gap8 {
    gap: 0.8rem;
  }
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-gap12 {
    gap: 1.2rem;
  }
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-gap16 {
    gap: 1.6rem;
  }
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-gap24 {
    gap: 2.4rem;
  }
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-gap32 {
    gap: 3.2rem;
  }
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-gap40 {
    gap: 4rem;
  }
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-gap48 {
    gap: 4.8rem;
  }
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-gap56 {
    gap: 5.6rem;
  }
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-gap64 {
    gap: 6.4rem;
  }
}
@media screen and (max-width: 1364px) {
  .c-column.-medium-gap80 {
    gap: 8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-gap8 {
    gap: 0.8rem;
  }
  .c-column.-small-row-gap8 {
    row-gap: 0.8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-gap12 {
    gap: 1.2rem;
  }
  .c-column.-small-row-gap12 {
    row-gap: 1.2rem;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-gap16 {
    gap: 1.6rem;
  }
  .c-column.-small-row-gap16 {
    row-gap: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-gap24 {
    gap: 2.4rem;
  }
  .c-column.-small-row-gap24 {
    row-gap: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-gap32 {
    gap: 3.2rem;
  }
  .c-column.-small-row-gap32 {
    row-gap: 3.2rem;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-gap40 {
    gap: 4rem;
  }
  .c-column.-small-row-gap40 {
    row-gap: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-gap48 {
    gap: 4.8rem;
  }
  .c-column.-small-row-gap48 {
    row-gap: 4.8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-gap56 {
    gap: 5.6rem;
  }
  .c-column.-small-row-gap56 {
    row-gap: 5.6rem;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-gap64 {
    gap: 6.4rem;
  }
  .c-column.-small-row-gap64 {
    row-gap: 6.4rem;
  }
}
@media screen and (max-width: 768px) {
  .c-column.-small-gap80 {
    gap: 8rem;
  }
  .c-column.-small-row-gap80 {
    row-gap: 8rem;
  }
}
.c-column__block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: var(--size4);
}

/* ==============================================================================================
カラムレイアウト
gap数値は自動生成も検討中
不要数値を生成してしまう恐れがあるため一旦手動で記述
============================================================================================== */
.c-float {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.c-float.-vertical {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 768px) {
  .c-float.-small-clear {
    display: block;
  }
  .c-float.-small-vertical {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.c-float.-gap12 {
  gap: 1.2rem;
}
.c-float.-gap16 {
  gap: var(--size2);
}
.c-float.-gap24 {
  gap: var(--size3);
}
.c-float.-gap32 {
  gap: var(--size4);
}
.c-float.-gap40 {
  gap: var(--size5);
}
.c-float.-gap48 {
  gap: var(--size6);
}
.c-float.-gap56 {
  gap: var(--size7);
}
.c-float.-gap64 {
  gap: var(--size8);
}
@media screen and (max-width: 768px) {
  .c-float.-small-gap4 {
    gap: 0.4rem;
  }
  .c-float.-small-gap8 {
    gap: 0.8rem;
  }
  .c-float.-small-gap12 {
    gap: 1.2rem;
  }
  .c-float.-small-gap16 {
    gap: var(--size2);
  }
  .c-float.-small-gap24 {
    gap: var(--size3);
  }
  .c-float.-small-gap32 {
    gap: var(--size4);
  }
  .c-float.-small-gap40 {
    gap: var(--size5);
  }
  .c-float.-small-gap48 {
    gap: var(--size6);
  }
  .c-float.-small-gap56 {
    gap: var(--size7);
  }
  .c-float.-small-gap64 {
    gap: var(--size8);
  }
}
.c-float.-row-gap12 {
  gap: 1.2rem;
}
.c-float.-row-gap16 {
  gap: var(--size2);
}
.c-float.-row-gap24 {
  gap: var(--size3);
}
.c-float.-row-gap32 {
  gap: var(--size4);
}
.c-float.-row-gap40 {
  gap: var(--size5);
}
.c-float.-row-gap48 {
  gap: var(--size6);
}
.c-float.-row-gap56 {
  gap: var(--size7);
}
@media screen and (max-width: 768px) {
  .c-float.-small-row-gap16 {
    gap: var(--size2);
  }
  .c-float.-small-row-gap24 {
    gap: var(--size3);
  }
  .c-float.-small-row-gap32 {
    gap: var(--size4);
  }
  .c-float.-small-row-gap40 {
    gap: var(--size5);
  }
  .c-float.-small-row-gap48 {
    gap: var(--size6);
  }
  .c-float.-small-row-gap56 {
    gap: var(--size7);
  }
}
.c-float__block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: var(--size4);
}

/* ----------------------------------------
汎用コンポーネント
---------------------------------------- */
@layer component {
  /* ==============================================================================================
  リスト
  萬松閣敷島から流用
  ============================================================================================== */
  .c-list {
    list-style-type: none;
    text-align: left;
  }
  .c-list li {
    list-style-type: none;
    padding-left: 1.5em;
    position: relative;
  }
  .c-list li:after {
    content: "";
    display: block;
    width: 0.6rem;
    height: 0.6rem;
    background: #111;
    border-radius: 50%;
    position: absolute;
    left: 0.3em;
    top: 0.5em;
    top: calc(0.9em - 0.3rem);
  }
}
@layer component {
  /* ==============================================================================================
  テーブル

  読み上げやスクリーンリーダブルな構造を目指すため、
  都合上DLタグは使用せず、Tableタグで完結させる。
  https://zenn.dev/kagan/articles/html-dl-vs-ul-vs-table

  萬象閣敷島の現行サイトから流用しつつ改修を行っている。

  ============================================================================================== */
  .c-table, .c-table--min {
    width: 100%;
    line-height: 2;
    vertical-align: middle;
    border-top: #d9d9d9 solid 1px;
  }
  @media screen and (max-width: 768px) {
    .c-table, .c-table--min {
      line-height: 1.6;
    }
  }
  .c-table th, .c-table--min th,
  .c-table td,
  .c-table--min td {
    font-weight: normal;
    color: var(--color-text3);
    text-align: left;
    vertical-align: top;
    padding: 1.3em 0;
    border-bottom: #d9d9d9 solid 1px;
  }
  @media screen and (max-width: 768px) {
    .c-table th, .c-table--min th,
    .c-table td,
    .c-table--min td {
      padding: 1em 0;
    }
  }
  .c-table th, .c-table--min th {
    width: 25%;
  }
  @media screen and (max-width: 768px) {
    .c-table th, .c-table--min th {
      width: 30%;
    }
  }
  .c-table td, .c-table--min td {
    padding-left: 0;
  }
  .c-table--top {
    vertical-align: top;
  }
  .c-table--top th,
  .c-table--top td {
    vertical-align: top;
  }
  .c-table--middle {
    vertical-align: middle;
  }
  .c-table--middle th,
  .c-table--middle td {
    vertical-align: middle;
  }
  .c-table .is-strong, .c-table--min .is-strong {
    color: var(--color-link);
  }
  .c-table .is-caption, .c-table--min .is-caption {
    display: inline-block;
    text-indent: -1em;
    padding-left: 1em;
  }
  .c-table .is-small, .c-table--min .is-small {
    padding-top: 19px;
    font-size: 13px;
    line-height: 1.53 !important;
  }
  .c-table--min th,
  .c-table--min td {
    font-weight: normal;
    color: var(--color-text3);
    text-align: left;
    vertical-align: top;
    padding: 0.34em 0;
    border-bottom: #d9d9d9 solid 1px;
  }
  @media screen and (max-width: 768px) {
    .c-table--min th,
    .c-table--min td {
      padding: 1em 0;
    }
  }
}
/* ----------------------------------------
コンポーネント
---------------------------------------- */
@layer component {
  .c-txt {
    font-size: 1.6rem;
    line-height: 2.2;
  }
  @media screen and (max-width: 768px) {
    .c-txt {
      font-size: 1.2rem;
      line-height: 1.8;
    }
  }
  .c-txt--small {
    font-size: 1.4rem;
    line-height: 1.8;
  }
  @media screen and (max-width: 768px) {
    .c-txt--small {
      font-size: 1.2rem;
    }
  }
  .c-txt--xsmall {
    font-size: 1.2rem;
    line-height: 1.8;
    color: var(--color-text3);
  }
  @media screen and (max-width: 768px) {
    .c-txt--xsmall {
      font-size: 1rem;
    }
  }
  .c-caption {
    font-size: 1rem;
    line-height: 1.8;
    display: block;
    color: var(--color-text3);
    padding-top: 5px;
  }
  .c-txt--tel {
    color: var(--color-link);
    margin-bottom: 16px;
    font-size: 4.8rem;
  }
  @media screen and (max-width: 768px) {
    .c-txt--tel {
      margin-bottom: 10px;
      font-size: 2.4rem;
    }
  }
  .c-txt--large {
    font-size: 1.8rem;
  }
  @media screen and (max-width: 768px) {
    .c-txt--large {
      font-size: 1.2rem;
    }
  }
}
/* ==============================================================================================
コンポーネント（未整理）
============================================================================================== */
@layer component {
  .c-hero {
    block-size: 46rem;
    display: -ms-grid;
    display: grid;
    place-content: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    position: relative;
  }
  @media screen and (max-width: 768px) {
    .c-hero {
      block-size: 28rem;
    }
  }
  .c-hero::after {
    content: "";
    inline-size: 100%;
    block-size: 100%;
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    background: rgba(0, 0, 0, 0.2);
  }
  .t-spa-001 .c-hero {
    background-image: url(/001/image/title_bg.jpg);
  }
  .t-spa-002 .c-hero {
    background-image: url(/002/image/title_bg.jpg);
  }
  .t-spa-003 .c-hero {
    background-image: url(/003/image/title_bg.jpg);
  }
  .t-spa-004 .c-hero {
    background-image: url(/004/image/title_bg.jpg);
  }
  .t-spa-005 .c-hero {
    background-image: url(/005/image/title_bg.jpg);
  }
  .t-spa-006 .c-hero {
    background-image: url(/006/image/title_bg.jpg);
  }
  .t-spa-007 .c-hero {
    background-image: url(/007/image/title_bg.jpg);
  }
  .t-spa-008 .c-hero {
    background-image: url(/008/image/title_bg.jpg);
  }
  .c-hero-title {
    position: relative;
    z-index: 5;
    color: var(--color-pure-white);
    font-weight: bold;
    font-size: 3.6rem;
    line-height: 1.9;
    text-align: center;
    letter-spacing: 0.4rem;
  }
  @media screen and (max-width: 768px) {
    .c-hero-title {
      font-size: 2.8rem;
      line-height: 1.6;
    }
  }
  .c-hero-title span {
    font-size: 2rem;
    display: block;
  }
  @media screen and (max-width: 768px) {
    .c-hero-title span {
      font-size: 1.6rem;
    }
  }
  .c-section {
    width: 75%;
    max-width: 1280px;
    min-width: 980px;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 4rem;
    margin-top: 12.8rem;
    margin-inline: auto;
  }
  .c-section.-full {
    width: 100%;
    max-width: 100%;
  }
  @media screen and (max-width: 768px) {
    .c-section.-full {
      margin-inline: 0;
    }
  }
  @media screen and (max-width: 768px) {
    .c-section {
      gap: 2.4rem;
      margin-top: 4rem;
      width: auto;
      margin-inline: 2rem;
      max-width: inherit;
      max-width: auto;
      min-width: inherit;
      min-width: auto;
    }
  }
  .c-heading {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  @media screen and (max-width: 768px) {
    .c-heading {
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      gap: 0.6rem;
    }
  }
  .c-heading__en {
    text-transform: uppercase;
    font-weight: 300;
    font-family: var(--font-en);
    font-size: 3.6rem;
    letter-spacing: 0.5rem;
  }
  @media screen and (max-width: 768px) {
    .c-heading__en {
      font-size: 2.4rem;
    }
  }
  .c-heading__en:after {
    content: "";
    display: inline-block;
    inline-size: 1px;
    block-size: 0.75em;
    background-color: #bfbfbf;
    -webkit-transform: skew(-30deg);
            transform: skew(-30deg);
    margin: 0 0.5em;
  }
  @media screen and (max-width: 768px) {
    .c-heading__en:after {
      display: none;
    }
  }
  .c-heading__jp {
    font-size: 1.6rem;
    color: var(--color-text2);
  }
  @media screen and (max-width: 768px) {
    .c-heading__jp {
      font-size: 1.2rem;
    }
  }
  .t-card-column {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .c-spa-column {
    border-bottom: 1px solid #d9d9d9;
    border-left: 1px solid #d9d9d9;
    block-size: -webkit-fit-content;
    block-size: -moz-fit-content;
    block-size: fit-content;
  }
  .c-spa {
    inline-size: 33.3333333333%;
    display: block;
    background: var(--color-pure-white);
    border: 1px solid #d9d9d9;
    block-size: auto;
  }
  .c-spa.is-current {
    -webkit-filter: saturate(0%);
            filter: saturate(0%);
    opacity: 0.4;
  }
  .c-column.-col4 .c-spa {
    inline-size: 100%;
    border-bottom: none;
    border-left: none;
  }
  @media screen and (max-width: 768px) {
    .c-spa {
      inline-size: 100%;
    }
  }
  .c-spa + .c-spa {
    border-left: none;
  }
  @media screen and (max-width: 768px) {
    .c-spa + .c-spa {
      border-left: 1px solid #d9d9d9;
      margin-top: 1.6rem;
    }
    .c-column.-col4 .c-spa + .c-spa {
      margin-top: 0;
    }
  }
  .c-spa a {
    display: block;
    text-decoration: none;
    color: var(--color-text2);
  }
  .c-spa__media {
    aspect-ratio: 3/1.8;
  }
  .c-spa__media img {
    inline-size: 100%;
    block-size: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .c-spa__body {
    padding: 2.2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1.2rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  @media screen and (max-width: 768px) {
    .c-spa__body {
      padding: 1.8rem;
      gap: 0.8rem;
    }
  }
  .c-spa__num {
    font-size: 1.4rem;
  }
  @media screen and (max-width: 768px) {
    .c-spa__num {
      font-size: 1.2rem;
    }
  }
  .c-spa__name {
    font-size: 1.6rem;
    color: var(--color-link);
    text-decoration: underline;
  }
  @media screen and (max-width: 768px) {
    .c-spa__name {
      font-size: 1.4rem;
    }
  }
  a:hover .c-spa__name {
    text-decoration: none;
  }
  .c-spa__notice small {
    font-size: 1.2rem;
  }
  @media screen and (max-width: 768px) {
    .c-spa__notice small {
      font-size: 1rem;
    }
  }
}
@layer utility {
  /* ==============================================================================================
  ユーティリティ：余白
  ============================================================================================== */
  .u-mt0 {
    margin-top: 0;
  }
  @media screen and (max-width: 768px) {
    .u-mt0-small {
      margin-top: 0;
    }
  }
  .u-mb0 {
    margin-bottom: 0;
  }
  @media screen and (max-width: 768px) {
    .u-mb0-small {
      margin-bottom: 0;
    }
  }
  .u-pt0 {
    padding-top: 0;
  }
  @media screen and (max-width: 768px) {
    .u-pt0-small {
      padding-top: 0;
    }
  }
  .u-pb0 {
    padding-bottom: 0;
  }
  @media screen and (max-width: 768px) {
    .u-pb0-small {
      padding-bottom: 0;
    }
  }
  .u-pl0 {
    padding-left: 0;
  }
  @media screen and (max-width: 768px) {
    .u-pl0-small {
      padding-left: 0;
    }
  }
  .u-pr0 {
    padding-right: 0;
  }
  @media screen and (max-width: 768px) {
    .u-pr0-small {
      padding-right: 0;
    }
  }
  .u-mt4 {
    margin-top: 0.4rem;
  }
  @media screen and (max-width: 768px) {
    .u-mt4-small {
      margin-top: 0.4rem;
    }
  }
  .u-mb4 {
    margin-bottom: 0.4rem;
  }
  @media screen and (max-width: 768px) {
    .u-mb4-small {
      margin-bottom: 0.4rem;
    }
  }
  .u-pt4 {
    padding-top: 0.4rem;
  }
  @media screen and (max-width: 768px) {
    .u-pt4-small {
      padding-top: 0.4rem;
    }
  }
  .u-pb4 {
    padding-bottom: 0.4rem;
  }
  @media screen and (max-width: 768px) {
    .u-pb4-small {
      padding-bottom: 0.4rem;
    }
  }
  .u-pl4 {
    padding-left: 0.4rem;
  }
  @media screen and (max-width: 768px) {
    .u-pl4-small {
      padding-left: 0.4rem;
    }
  }
  .u-pr4 {
    padding-right: 0.4rem;
  }
  @media screen and (max-width: 768px) {
    .u-pr4-small {
      padding-right: 0.4rem;
    }
  }
  .u-mt8 {
    margin-top: var(--size);
  }
  @media screen and (max-width: 768px) {
    .u-mt8-small {
      margin-top: var(--size);
    }
  }
  .u-mb8 {
    margin-bottom: var(--size);
  }
  @media screen and (max-width: 768px) {
    .u-mb8-small {
      margin-bottom: var(--size);
    }
  }
  .u-pt8 {
    padding-top: var(--size);
  }
  @media screen and (max-width: 768px) {
    .u-pt8-small {
      padding-top: var(--size);
    }
  }
  .u-pb8 {
    padding-bottom: var(--size);
  }
  @media screen and (max-width: 768px) {
    .u-pb8-small {
      padding-bottom: var(--size);
    }
  }
  .u-pl8 {
    padding-left: var(--size);
  }
  @media screen and (max-width: 768px) {
    .u-pl8-small {
      padding-left: var(--size);
    }
  }
  .u-pr8 {
    padding-right: var(--size);
  }
  @media screen and (max-width: 768px) {
    .u-pr8-small {
      padding-right: var(--size);
    }
  }
  .u-mt16 {
    margin-top: var(--size2);
  }
  @media screen and (max-width: 768px) {
    .u-mt16-small {
      margin-top: var(--size2);
    }
  }
  .u-mb16 {
    margin-bottom: var(--size2);
  }
  @media screen and (max-width: 768px) {
    .u-mb16-small {
      margin-bottom: var(--size2);
    }
  }
  .u-pt16 {
    padding-top: var(--size2);
  }
  @media screen and (max-width: 768px) {
    .u-pt16-small {
      padding-top: var(--size2);
    }
  }
  .u-pb16 {
    padding-bottom: var(--size2);
  }
  @media screen and (max-width: 768px) {
    .u-pb16-small {
      padding-bottom: var(--size2);
    }
  }
  .u-pl16 {
    padding-left: var(--size2);
  }
  @media screen and (max-width: 768px) {
    .u-pl16-small {
      padding-left: var(--size2);
    }
  }
  .u-pr16 {
    padding-right: var(--size2);
  }
  @media screen and (max-width: 768px) {
    .u-pr16-small {
      padding-right: var(--size2);
    }
  }
  .u-mt20 {
    margin-top: 2rem;
  }
  @media screen and (max-width: 768px) {
    .u-mt20-small {
      margin-top: 2rem;
    }
  }
  .u-mb20 {
    margin-bottom: 2rem;
  }
  @media screen and (max-width: 768px) {
    .u-mb20-small {
      margin-bottom: 2rem;
    }
  }
  .u-pt20 {
    padding-top: 2rem;
  }
  @media screen and (max-width: 768px) {
    .u-pt20-small {
      padding-top: 2rem;
    }
  }
  .u-pb20 {
    padding-bottom: 2rem;
  }
  @media screen and (max-width: 768px) {
    .u-pb20-small {
      padding-bottom: 2rem;
    }
  }
  .u-pl20 {
    padding-left: 2rem;
  }
  @media screen and (max-width: 768px) {
    .u-pl20-small {
      padding-left: 2rem;
    }
  }
  .u-pr20 {
    padding-right: 2rem;
  }
  @media screen and (max-width: 768px) {
    .u-pr20-small {
      padding-right: 2rem;
    }
  }
  .u-mt24 {
    margin-top: var(--size3);
  }
  @media screen and (max-width: 768px) {
    .u-mt24-small {
      margin-top: var(--size3);
    }
  }
  .u-mb24 {
    margin-bottom: var(--size3);
  }
  @media screen and (max-width: 768px) {
    .u-mb24-small {
      margin-bottom: var(--size3);
    }
  }
  .u-pt24 {
    padding-top: var(--size3);
  }
  @media screen and (max-width: 768px) {
    .u-pt24-small {
      padding-top: var(--size3);
    }
  }
  .u-pb24 {
    padding-bottom: var(--size3);
  }
  @media screen and (max-width: 768px) {
    .u-pb24-small {
      padding-bottom: var(--size3);
    }
  }
  .u-pl24 {
    padding-left: var(--size3);
  }
  @media screen and (max-width: 768px) {
    .u-pl24-small {
      padding-left: var(--size3);
    }
  }
  .u-pr24 {
    padding-right: var(--size3);
  }
  @media screen and (max-width: 768px) {
    .u-pr24-small {
      padding-right: var(--size3);
    }
  }
  .u-mt32 {
    margin-top: var(--size4);
  }
  @media screen and (max-width: 768px) {
    .u-mt32-small {
      margin-top: var(--size4);
    }
  }
  .u-mb32 {
    margin-bottom: var(--size4);
  }
  @media screen and (max-width: 768px) {
    .u-mb32-small {
      margin-bottom: var(--size4);
    }
  }
  .u-pt32 {
    padding-top: var(--size4);
  }
  @media screen and (max-width: 768px) {
    .u-pt32-small {
      padding-top: var(--size4);
    }
  }
  .u-pb32 {
    padding-bottom: var(--size4);
  }
  @media screen and (max-width: 768px) {
    .u-pb32-small {
      padding-bottom: var(--size4);
    }
  }
  .u-pl32 {
    padding-left: var(--size4);
  }
  @media screen and (max-width: 768px) {
    .u-pl32-small {
      padding-left: var(--size4);
    }
  }
  .u-pr32 {
    padding-right: var(--size4);
  }
  @media screen and (max-width: 768px) {
    .u-pr32-small {
      padding-right: var(--size4);
    }
  }
  .u-mt40 {
    margin-top: var(--size5);
  }
  @media screen and (max-width: 768px) {
    .u-mt40-small {
      margin-top: var(--size5);
    }
  }
  .u-mb40 {
    margin-bottom: var(--size5);
  }
  @media screen and (max-width: 768px) {
    .u-mb40-small {
      margin-bottom: var(--size5);
    }
  }
  .u-pt40 {
    padding-top: var(--size5);
  }
  @media screen and (max-width: 768px) {
    .u-pt40-small {
      padding-top: var(--size5);
    }
  }
  .u-pb40 {
    padding-bottom: var(--size5);
  }
  @media screen and (max-width: 768px) {
    .u-pb40-small {
      padding-bottom: var(--size5);
    }
  }
  .u-pl40 {
    padding-left: var(--size5);
  }
  @media screen and (max-width: 768px) {
    .u-pl40-small {
      padding-left: var(--size5);
    }
  }
  .u-pr40 {
    padding-right: var(--size5);
  }
  @media screen and (max-width: 768px) {
    .u-pr40-small {
      padding-right: var(--size5);
    }
  }
  .u-mt48 {
    margin-top: var(--size6);
  }
  @media screen and (max-width: 768px) {
    .u-mt48-small {
      margin-top: var(--size6);
    }
  }
  .u-mb48 {
    margin-bottom: var(--size6);
  }
  @media screen and (max-width: 768px) {
    .u-mb48-small {
      margin-bottom: var(--size6);
    }
  }
  .u-pt48 {
    padding-top: var(--size6);
  }
  @media screen and (max-width: 768px) {
    .u-pt48-small {
      padding-top: var(--size6);
    }
  }
  .u-pb48 {
    padding-bottom: var(--size6);
  }
  @media screen and (max-width: 768px) {
    .u-pb48-small {
      padding-bottom: var(--size6);
    }
  }
  .u-pl48 {
    padding-left: var(--size6);
  }
  @media screen and (max-width: 768px) {
    .u-pl48-small {
      padding-left: var(--size6);
    }
  }
  .u-pr48 {
    padding-right: var(--size6);
  }
  @media screen and (max-width: 768px) {
    .u-pr48-small {
      padding-right: var(--size6);
    }
  }
  .u-mt56 {
    margin-top: var(--size7);
  }
  @media screen and (max-width: 768px) {
    .u-mt56-small {
      margin-top: var(--size7);
    }
  }
  .u-mb56 {
    margin-bottom: var(--size7);
  }
  @media screen and (max-width: 768px) {
    .u-mb56-small {
      margin-bottom: var(--size7);
    }
  }
  .u-pt56 {
    padding-top: var(--size7);
  }
  @media screen and (max-width: 768px) {
    .u-pt56-small {
      padding-top: var(--size7);
    }
  }
  .u-pb56 {
    padding-bottom: var(--size7);
  }
  @media screen and (max-width: 768px) {
    .u-pb56-small {
      padding-bottom: var(--size7);
    }
  }
  .u-pl56 {
    padding-left: var(--size7);
  }
  @media screen and (max-width: 768px) {
    .u-pl56-small {
      padding-left: var(--size7);
    }
  }
  .u-pr56 {
    padding-right: var(--size7);
  }
  @media screen and (max-width: 768px) {
    .u-pr56-small {
      padding-right: var(--size7);
    }
  }
  .u-mt64 {
    margin-top: var(--size8);
  }
  @media screen and (max-width: 768px) {
    .u-mt64-small {
      margin-top: var(--size8);
    }
  }
  .u-mb64 {
    margin-bottom: var(--size8);
  }
  @media screen and (max-width: 768px) {
    .u-mb64-small {
      margin-bottom: var(--size8);
    }
  }
  .u-pt64 {
    padding-top: var(--size8);
  }
  @media screen and (max-width: 768px) {
    .u-pt64-small {
      padding-top: var(--size8);
    }
  }
  .u-pb64 {
    padding-bottom: var(--size8);
  }
  @media screen and (max-width: 768px) {
    .u-pb64-small {
      padding-bottom: var(--size8);
    }
  }
  .u-pl64 {
    padding-left: var(--size8);
  }
  @media screen and (max-width: 768px) {
    .u-pl64-small {
      padding-left: var(--size8);
    }
  }
  .u-pr64 {
    padding-right: var(--size8);
  }
  @media screen and (max-width: 768px) {
    .u-pr64-small {
      padding-right: var(--size8);
    }
  }
}
@layer utility {
  /* ==============================================================================================
  ユーティリティ：位置
  ============================================================================================== */
  .u-sticky {
    position: sticky;
  }
  @media screen and (max-width: 768px) {
    .u-sticky {
      position: static;
    }
  }
  .u-fixed {
    position: fixed;
  }
}
@layer utility {
  /* ==============================================================================================
  ユーティリティ：デバイス間での表示非表示
  ============================================================================================== */
  @media screen and (max-width: 639px) {
    .u-hidden-small {
      display: none;
    }
  }
  .u-visible-small {
    display: none;
  }
  @media screen and (max-width: 639px) {
    .u-visible-small {
      display: block;
    }
  }
}
@layer utility {
  /* ==============================================================================================
  ユーティリティ：アライン
  ============================================================================================== */
  .u-align-left {
    text-align: left;
  }
  .u-align-right {
    text-align: right;
  }
  .u-align-top {
    vertical-align: top;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .u-align-top th, .u-align-top td {
    vertical-align: top;
  }
  .u-align-middle {
    vertical-align: middle;
  }
  .u-align-middle th, .u-align-middle td {
    vertical-align: middle;
  }
  .u-align-middle {
    vertical-align: middle;
  }
  .u-align-center {
    text-align: center;
  }
  .u-align-center th, .u-align-center td {
    text-align: center;
  }
}
@layer utility {
  /* ==============================================================================================
  ユーティリティ：ブロック
  ============================================================================================== */
  .u-ib {
    display: inline-block;
  }
}
@layer utility {
  /* ==============================================================================================
  ユーティリティ：テキスト上下の余白をトリミング
  ============================================================================================== */
  :root {
    --leading-trim: calc((1em - 1lh) / 2);
  }
  :lang(en) {
    --leading-trim: calc((1cap - 1lh) / 2);
  }
  .u-text-trim::before, .u-text-trim::after {
    content: "";
    display: block;
    inline-size: 0;
    block-size: 1px;
  }
  .u-text-trim::before {
    -webkit-margin-after: var(--leading-trim);
            margin-block-end: var(--leading-trim);
  }
  .u-text-trim::after {
    -webkit-margin-before: var(--leading-trim);
            margin-block-start: var(--leading-trim);
  }
}
@layer utility {
  /* ==============================================================================================
  ユーティリティ：罫線
  ============================================================================================== */
  .u-aspect-32 {
    aspect-ratio: 3/2;
  }
  .u-aspect-32 img {
    inline-size: 100%;
    block-size: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .u-aspect-43 {
    aspect-ratio: 4/3;
  }
  .u-aspect-43 img {
    inline-size: 100%;
    block-size: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .u-aspect-169 {
    aspect-ratio: 16/9;
  }
  .u-aspect-169 img {
    inline-size: 100%;
    block-size: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .u-aspect-square {
    aspect-ratio: 1/1;
  }
  .u-aspect-square img {
    inline-size: 100%;
    block-size: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .u-aspect-gold {
    aspect-ratio: 1.618/1;
  }
  .u-aspect-gold img {
    inline-size: 100%;
    block-size: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .u-aspect-silver {
    aspect-ratio: 1.414/1;
  }
  .u-aspect-silver img {
    inline-size: 100%;
    block-size: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.u-txtw {
  word-break: keep-all;
}

.u-font-red {
  color: #c51212;
}

/**
* slick-1.6.0
*/
/* slick.css */
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
}

.slick-track:before,
.slick-track:after {
  display: table;
  content: "";
}

.slick-track:after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px;
}

[dir=rtl] .slick-slide {
  float: right;
}

.slick-slide img {
  display: block;
}

.slick-slide.slick-loading img {
  display: none;
}

.slick-slide.dragging img {
  pointer-events: none;
}

.slick-initialized .slick-slide {
  display: block;
}

.slick-loading .slick-slide {
  visibility: hidden;
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

/* slick-theme.css */
/* Slider */
/* Icons */
@font-face {}
/* Arrows */
.slick-prev,
.slick-next {
  font-size: 0;
  line-height: 0;
  position: absolute;
  top: 50%;
  display: block;
  width: 20px;
  height: 20px;
  padding: 0;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  cursor: pointer;
  color: transparent;
  border: none;
  outline: none;
  background: transparent;
}

.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  color: transparent;
  outline: none;
  background: transparent;
}

.slick-prev:hover:before,
.slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before {
  opacity: 1;
}

.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: 0;
}

.slick-prev:before,
.slick-next:before {
  font-family: "slick";
  font-size: 20px;
  line-height: 1;
  opacity: 1;
  color: white;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
  left: -25px;
}

[dir=rtl] .slick-prev {
  right: -25px;
  left: auto;
}

.slick-prev:before {
  content: "←";
}

[dir=rtl] .slick-prev:before {
  content: "→";
}

.slick-next {
  right: -25px;
}

[dir=rtl] .slick-next {
  right: auto;
  left: -25px;
}

.slick-next:before {
  content: "→";
}

[dir=rtl] .slick-next:before {
  content: "←";
}

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px;
}

.slick-dots {
  position: absolute;
  bottom: -25px;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}

.slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}

.slick-dots li button:hover,
.slick-dots li button:focus {
  outline: none;
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
  opacity: 1;
}

.slick-dots li button:before {
  font-family: "slick";
  font-size: 6px;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  content: "•";
  text-align: center;
  opacity: 0.25;
  color: black;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button:before {
  opacity: 0.75;
  color: black;
}

/* slick - speedchannel skin / p-topics__slider */
.p-topics__slider__nav .slider .slick-slide {
  margin: 0;
}

.p-topics__slider__main .slider .slick-slide img {
  width: 100%;
}

.p-topics__slider__nav .slider .slick-slide img {
  width: 100%;
  width: calc(100% - 10px);
  margin-left: 5px;
}

@media (max-width: 767px) {
  .p-topics__slider .slick-dots li button:before {
    background: #ffffff;
  }
}
@media (max-width: 767px) {
  .p-topics__slider .slick-dotted.slick-slider {
    margin-bottom: 25px;
  }
  .p-topics__slider .slick-dots {
    bottom: -25px;
  }
  .p-topics__slider .slick-list {
    border: #ffffff solid 2px;
  }
}
/* slick - speedchannel skin / common */
.slick-slide:focus,
.slick-slide a:focus {
  outline: none;
}

.p-slider {
  margin-top: 8rem;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
@media screen and (max-width: 768px) {
  .p-slider {
    margin-top: 0;
    padding-top: 4rem;
  }
}
.p-slider.slick-initialized {
  opacity: 1;
}

.p-slider.c-content__small {
  max-width: 908px;
}
@media screen and (max-width: 768px) {
  .p-slider.c-content__small {
    margin: 0 30px;
  }
}

.p-slider .slick-list {
  overflow: visible !important;
}

.p-slider .slideCell span {
  display: block;
  margin: 0 20px;
}
@media screen and (max-width: 768px) {
  .p-slider .slideCell span {
    margin: 0 10px;
  }
}

.p-slider .slideCell img {
  display: block;
  width: 100%;
  height: auto;
}

.p-fade-top {
  opacity: 0;
  -webkit-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
@media screen and (max-width: 768px) {
  .p-fade-top {
    margin-top: 0;
  }
}
.p-fade-top.slick-initialized {
  opacity: 1;
}

.p-fade-top .slick-list {
  overflow: visible !important;
}

.p-fade-top .slideCell span {
  display: block;
}
.p-fade-top .slideCell img {
  display: block;
  width: 100%;
}

.slick-list {
  opacity: 0;
}
.slick-initialized .slick-list {
  opacity: 1;
}

.slick-dotted.slick-slider {
  margin-bottom: 50px;
}

@media (max-width: 767px) {
  .slick-dotted.slick-slider {
    margin-bottom: 80px;
  }
}
.slick-dots {
  position: absolute;
  bottom: -40px;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}
.p-fade-top .slick-dots {
  bottom: 30px;
}
@media screen and (max-width: 768px) {
  .p-fade-top .slick-dots {
    bottom: 15px;
  }
}

@media (max-width: 767px) {
  .slick-dots {
    bottom: -30px;
  }
}
.slick-dots li {
  position: relative;
  display: inline-block;
  width: 1rem;
  height: 1rem;
  margin: 0 15px;
  padding: 0;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .slick-dots li {
    margin: 0 7px;
  }
}
.p-fade-top .slick-dots li {
  margin: 0 5px;
}
@media screen and (max-width: 768px) {
  .p-fade-top .slick-dots li {
    margin: 0 3px;
  }
}

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 1rem;
  height: 1rem;
  padding: 0;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}

@media (max-width: 767px) {
  .slick-dots li button {
    width: 8px;
    height: 8px;
  }
}
.slick-dots li button:hover,
.slick-dots li button:focus {
  outline: none;
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
  opacity: 1;
}

.slick-dots li button:before {
  line-height: 0;
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  text-align: center;
  opacity: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  display: block;
  width: 1rem;
  height: 1rem;
  background: #d0d0d0;
  border-radius: 50%;
}
.p-fade-top .slick-dots li button:before {
  width: 0.8rem;
  height: 0.8rem;
  background: #777777;
}
@media screen and (max-width: 768px) {
  .p-fade-top .slick-dots li button:before {
    width: 0.7rem;
    height: 0.7rem;
  }
}

@media (max-width: 767px) {
  .slick-dots li button:before {
    width: 8px;
    height: 8px;
  }
}
.slick-dots li.slick-active button:before {
  background: #d85c3f;
}
.p-fade-top .slick-dots li.slick-active button:before {
  background: #fdfdfd;
}

/* ef-shadow
-----------------------------------------------------------------*/
.ef-txt-roll {
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
a:hover .ef-txt-roll {
  translate: 0 -100%;
}
.ef-txt-roll__base {
  position: relative;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  translate: 0 -40%;
}
a:hover .ef-txt-roll__base {
  opacity: 0;
}
.ef-txt-roll__hidden {
  position: absolute;
  top: 0;
  left: 0;
  translate: 0 100%;
  opacity: 0;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
a:hover .ef-txt-roll__hidden {
  opacity: 1;
}

.p-caution {
  background: rgba(0, 0, 0, 0.03);
  padding: 6.4rem 4.8rem;
}
@media screen and (max-width: 768px) {
  .p-caution {
    padding: 3.2rem 2rem;
  }
}
.p-caution .c-txt {
  text-align: center;
  font-size: 1.5rem;
  line-height: 1.75;
}
@media screen and (max-width: 768px) {
  .p-caution .c-txt {
    text-align: left;
    font-size: 1.3rem;
  }
}
.p-caution .c-txt + .c-txt {
  margin-top: 0.8em;
}

.c-section-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4rem;
}