@charset "UTF-8";
@import url("https://cdn.jsdelivr.net/npm/yakuhanjp@4.1.1/dist/css/yakuhanjp.css");
@import url("https://fonts.googleapis.com/css2?family=Asap+Condensed:wght@400;500&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Zen+Kaku+Gothic+New:wght@400;500&display=swap");
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%;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

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

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}

q, blockquote {
  quotes: none;
}
q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none;
}

a img {
  border: none;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}

/****************************************

          $breakpoint

@include maxs($breakpoint-sp) {}

*****************************************/
/****************************************

          GENERAL SETTING
          
*****************************************/
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%;
  vertical-align: baseline;
  box-sizing: border-box;
}

html {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

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

caption, th, td {
  text-align: left;
  font-weight: 400;
  vertical-align: middle;
}

q, blockquote {
  quotes: none;
}

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

a {
  text-decoration: none;
}

a img {
  border: none;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}

/****************************************

          SWIPER
          
*****************************************/
/**
 * Swiper 8.4.7
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2023 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: January 30, 2023
 */
@font-face {
  font-family: swiper-icons;
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA");
  font-weight: 400;
  font-style: normal;
}
:root {
  --swiper-theme-color: #007aff;
}

.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
}

.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
}

.swiper-android .swiper-slide, .swiper-wrapper {
  transform: translate3d(0, 0, 0);
}

.swiper-pointer-events {
  touch-action: pan-y;
}

.swiper-pointer-events.swiper-vertical {
  touch-action: pan-x;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

.swiper-autoheight, .swiper-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform,height;
}

.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-3d, .swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}

.swiper-3d .swiper-cube-shadow, .swiper-3d .swiper-slide, .swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top, .swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15);
}

.swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}

.swiper-vertical.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}

.swiper-centered > .swiper-wrapper::before {
  content: '';
  flex-shrink: 0;
  order: 9999;
}

.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after);
}

.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}

.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always;
}

.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
}

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
  height: 1px;
  width: var(--swiper-virtual-size);
}

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
  width: 1px;
  height: var(--swiper-virtual-size);
}

:root {
  --swiper-navigation-size: 44px;
}

.swiper-button-next, .swiper-button-prev {
  position: absolute;
  top: 50%;
  width: calc(var(--swiper-navigation-size)/ 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - (var(--swiper-navigation-size)/ 2));
  z-index: 10;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
}

.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
  opacity: .35;
  cursor: auto;
  pointer-events: none;
}

.swiper-button-next.swiper-button-hidden, .swiper-button-prev.swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none;
}

.swiper-navigation-disabled .swiper-button-next, .swiper-navigation-disabled .swiper-button-prev {
  display: none !important;
}

.swiper-button-next:after, .swiper-button-prev:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  font-variant: initial;
  line-height: 1;
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
  left: 10px;
  right: auto;
}

.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
  content: 'prev';
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
}

.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
  content: 'next';
}

.swiper-button-lock {
  display: none;
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  transition: .3s opacity;
  transform: translate3d(0, 0, 0);
  z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-pagination-disabled > .swiper-pagination, .swiper-pagination.swiper-pagination-disabled {
  display: none !important;
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: 10px;
  left: 0;
  width: 100%;
}

.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transform: scale(0.33);
  position: relative;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}

.swiper-pagination-bullet {
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  display: inline-block;
  border-radius: 50%;
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
}

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet:only-child {
  display: none !important;
}

.swiper-pagination-bullet-active {
  opacity: var(--swiper-pagination-bullet-opacity, 1);
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-pagination-vertical.swiper-pagination-bullets, .swiper-vertical > .swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  transform: translate3d(0, -50%, 0);
}

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  display: block;
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: .2s transform,.2s top;
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: .2s transform,.2s left;
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: .2s transform,.2s right;
}

.swiper-pagination-progressbar {
  background: rgba(0, 0, 0, 0.25);
  position: absolute;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}

.swiper-horizontal > .swiper-pagination-progressbar, .swiper-pagination-progressbar.swiper-pagination-horizontal, .swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite, .swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: 4px;
  left: 0;
  top: 0;
}

.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-vertical, .swiper-vertical > .swiper-pagination-progressbar {
  width: 4px;
  height: 100%;
  left: 0;
  top: 0;
}

.swiper-pagination-lock {
  display: none;
}

.swiper-scrollbar {
  border-radius: 10px;
  position: relative;
  -ms-touch-action: none;
  background: rgba(0, 0, 0, 0.1);
}

.swiper-scrollbar-disabled > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-disabled {
  display: none !important;
}

.swiper-horizontal > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-horizontal {
  position: absolute;
  left: 1%;
  bottom: 3px;
  z-index: 50;
  height: 5px;
  width: 98%;
}

.swiper-scrollbar.swiper-scrollbar-vertical, .swiper-vertical > .swiper-scrollbar {
  position: absolute;
  right: 3px;
  top: 1%;
  z-index: 50;
  width: 5px;
  height: 98%;
}

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 10px;
  left: 0;
  top: 0;
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-zoom-container {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.swiper-zoom-container > canvas, .swiper-zoom-container > img, .swiper-zoom-container > svg {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.swiper-slide-zoomed {
  cursor: move;
}

.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}

.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader, .swiper:not(.swiper-watch-progress) .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear;
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.swiper .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000;
}

.swiper-free-mode > .swiper-wrapper {
  transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-grid > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-grid-column > .swiper-wrapper {
  flex-wrap: wrap;
  flex-direction: column;
}

.swiper-fade.swiper-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}

.swiper-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}

.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-fade .swiper-slide-active, .swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube {
  overflow: visible;
}

.swiper-cube .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
}

.swiper-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-cube.swiper-rtl .swiper-slide {
  transform-origin: 100% 0;
}

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-next, .swiper-cube .swiper-slide-next + .swiper-slide, .swiper-cube .swiper-slide-prev {
  pointer-events: auto;
  visibility: visible;
}

.swiper-cube .swiper-slide-shadow-bottom, .swiper-cube .swiper-slide-shadow-left, .swiper-cube .swiper-slide-shadow-right, .swiper-cube .swiper-slide-shadow-top {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  opacity: .6;
  z-index: 0;
}

.swiper-cube .swiper-cube-shadow:before {
  content: '';
  background: #000;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  filter: blur(50px);
}

.swiper-flip {
  overflow: visible;
}

.swiper-flip .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
}

.swiper-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-flip .swiper-slide-active, .swiper-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-flip .swiper-slide-shadow-bottom, .swiper-flip .swiper-slide-shadow-left, .swiper-flip .swiper-slide-shadow-right, .swiper-flip .swiper-slide-shadow-top {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-creative .swiper-slide {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  overflow: hidden;
  transition-property: transform,opacity,height;
}

.swiper-cards {
  overflow: visible;
}

.swiper-cards .swiper-slide {
  transform-origin: center bottom;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  overflow: hidden;
}

/****************************************

          font
          
*****************************************/
/****************************************

          COLOR
          
*****************************************/
:root {
  --bk: #212836;
  --wt: #ffffff;
  --key--extra-dark: #35387d;
  --key--dark: #35387d;
  --key: #35387d;
  --key--lite: #35387d;
  --key--extra-lite: #35387d;
  --green: #56c597;
}

/****************************************

          COMMON
          
*****************************************/
.lenis.lenis-smooth {
  scroll-behavior: auto !important;
}

.lenis.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}

.lenis.lenis-stopped {
  overflow: hidden;
}

.lenis.lenis-smooth iframe {
  pointer-events: none;
}

.lenis.lenis-smooth .wp-block-embed iframe {
  pointer-events: auto;
}

html {
  box-sizing: border-box;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

body {
  color: #000000;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-M", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 500;
  line-height: 1.8;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-kerning: auto;
  font-feature-settings: "palt" 1;
  text-rendering: optimizeLegibility;
  text-size-adjust: 100%;
  overflow-wrap: break-word;
  word-break: break-word;
  scroll-behavior: auto;
  min-height: 100vh;
  isolation: isolate;
  text-decoration-skip-ink: auto;
}
@media screen and (min-width: 768px) {
  body {
    /*--- PC TAB ---*/
    background: url(../img/bg.png) center center/cover fixed no-repeat #eaf5f9;
  }
}
@media screen and (max-width: 768px) {
  body {
    /*--- SP ---*/
  }
  body::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    background: url(../img/bg.png) center center/cover;
    z-index: -1;
    pointer-events: none;
  }
}
body::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  background: url(../img/bg_tile.png) center center fixed repeat;
  background-size: 25px 25px;
  z-index: -2;
  pointer-events: none;
  opacity: .05;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

#main {
  opacity: 0;
  top: 20px;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  #main {
    /*--- PC TAB ---*/
    padding-top: 170px;
  }
}
@media screen and (max-width: 768px) {
  #main {
    /*--- SP ---*/
    padding-top: 33vw;
  }
}

.header_bg {
  width: 100%;
  overflow: hidden;
}
.header_bg::before, .header_bg::after {
  content: "";
  display: block;
  position: fixed;
  top: 0;
  z-index: 1;
  pointer-events: none;
  -moz-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -moz-transition: -moz-transform 0.8s ease;
  -o-transition: -o-transform 0.8s ease;
  -webkit-transition: -webkit-transform 0.8s ease;
  transition: transform 0.8s ease;
}
@media screen and (min-width: 768px) {
  .header_bg::before, .header_bg::after {
    /*--- PC TAB ---*/
    width: 400px;
    height: 275px;
  }
  .scroll2 .header_bg::before, .scroll2 .header_bg::after {
    -moz-transform: translate(0, -100px);
    -ms-transform: translate(0, -100px);
    -webkit-transform: translate(0, -100px);
    transform: translate(0, -100px);
  }
}
@media screen and (max-width: 768px) {
  .header_bg::before, .header_bg::after {
    /*--- SP ---*/
    width: 40vw;
    height: 30vw;
  }
  .scroll2 .header_bg::before, .scroll2 .header_bg::after {
    -moz-transform: translate(0, -5vw);
    -ms-transform: translate(0, -5vw);
    -webkit-transform: translate(0, -5vw);
    transform: translate(0, -5vw);
  }
}
.header_bg::before {
  background: url(../img/bg_header_l.png) left top/contain no-repeat;
  left: 0;
}
.header_bg::after {
  background: url(../img/bg_header_r.png) right top/contain no-repeat;
  right: 0;
}

/*============================
base
============================*/
a {
  color: inherit;
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }

  .sp {
    display: block;
  }
}
.pc,
.sp {
  aria-hidden: true;
}

strong {
  font-weight: 700;
}

small,
sup,
sub {
  font-size: 80%;
}

sup,
sub {
  position: relative;
}

sup {
  vertical-align: super;
  top: -0.1em;
}

sub {
  vertical-align: sub;
  bottom: -0.1em;
}

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

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

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

.text-justify {
  text-align: justify;
}

/*===================================
= extend指定：@extend %base;
===================================*/
/*===================================
= vwでのサイズ指定：vw(16)
===================================*/
:root {
  --vw-base: 375;
  /* pxをvwに換算したカスタムプロパティ　例）var(--vw-24) */
  --vw-16: calc(100vw / var(--vw-base) * 16);
  --vw-24: calc(100vw / var(--vw-base) * 24);
  --vw-32: calc(100vw / var(--vw-base) * 32);
}

/****************************************

          FORM RESET
          
*****************************************/
input {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
  padding: 0;
  margin: 0;
}

input::-webkit-search-decoration {
  display: none;
}

input::focus {
  outline: none;
  border: none;
}

::selection {
  background-color: #eeede5;
  text-shadow: none;
  -moz-transition: color 0.2s ease, background-color 0.2s ease;
  -o-transition: color 0.2s ease, background-color 0.2s ease;
  -webkit-transition: color 0.2s ease, background-color 0.2s ease;
  transition: color 0.2s ease, background-color 0.2s ease;
}

/****************************************

          HEADER
          
*****************************************/
#header-logo.header-logo {
  position: fixed;
  height: auto;
  text-align: center;
  z-index: 990;
  -moz-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -moz-transition: width 0.4s ease, -moz-transform 0.4s ease, margin-left 0.4s ease;
  -o-transition: width 0.4s ease, -o-transform 0.4s ease, margin-left 0.4s ease;
  -webkit-transition: width 0.4s ease, -webkit-transform 0.4s ease, margin-left 0.4s ease;
  transition: width 0.4s ease, transform 0.4s ease, margin-left 0.4s ease;
}
@media screen and (min-width: 768px) {
  #header-logo.header-logo {
    /*--- PC TAB ---*/
    width: 370px;
    top: 20px;
    left: 50%;
    margin-left: -185px;
  }
}
@media screen and (max-width: 768px) {
  #header-logo.header-logo {
    /*--- SP ---*/
    width: 80vw;
    top: 3vw;
    left: 50%;
    margin-left: -40vw;
  }
}
@media screen and (min-width: 768px) {
  .scroll2 #header-logo.header-logo {
    /*--- PC TAB ---*/
    width: 300px;
    margin-left: -150px;
    -moz-transform: translate(0, -32px);
    -ms-transform: translate(0, -32px);
    -webkit-transform: translate(0, -32px);
    transform: translate(0, -32px);
  }
}
@media screen and (max-width: 768px) {
  .scroll2 #header-logo.header-logo {
    /*--- SP ---*/
    width: 65vw;
    margin-left: -32.5vw;
    -moz-transform: translate(0, -7vw);
    -ms-transform: translate(0, -7vw);
    -webkit-transform: translate(0, -7vw);
    transform: translate(0, -7vw);
  }
}
#header-logo.header-logo span.copy {
  font-weight: 600;
  color: var(--key);
  opacity: 1;
  -moz-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -moz-transition: opacity 0.4s ease, -moz-transform 0.4s ease;
  -o-transition: opacity 0.4s ease, -o-transform 0.4s ease;
  -webkit-transition: opacity 0.4s ease, -webkit-transform 0.4s ease;
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.scroll2 #header-logo.header-logo span.copy {
  opacity: 0;
  -moz-transform: translate(0, -10px);
  -ms-transform: translate(0, -10px);
  -webkit-transform: translate(0, -10px);
  transform: translate(0, -10px);
}
@media screen and (min-width: 768px) {
  #header-logo.header-logo span.copy {
    /*--- PC TAB ---*/
    font-size: 11px;
  }
}
@media screen and (max-width: 768px) {
  #header-logo.header-logo span.copy {
    /*--- SP ---*/
    font-size: 10px;
  }
}
#header-logo.header-logo img.logo-image {
  display: block;
  -moz-transition: width 0.4s ease;
  -o-transition: width 0.4s ease;
  -webkit-transition: width 0.4s ease;
  transition: width 0.4s ease;
  -moz-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}
@media screen and (min-width: 768px) {
  #header-logo.header-logo img.logo-image {
    /*--- PC TAB ---*/
    margin: 15px 0 0;
  }
}
@media screen and (max-width: 768px) {
  #header-logo.header-logo img.logo-image {
    /*--- SP ---*/
    margin: 2vw 0 0;
  }
}
@media screen and (min-width: 768px) {
  #header-logo.header-logo a {
    transition: opacity .4s ease;
  }
  #header-logo.header-logo a:hover {
    opacity: .5;
  }
}

a.btn-about {
  color: #35387D;
  position: fixed;
  top: 25px;
  left: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
  width: 160px;
  height: 50px;
  font-size: 13px;
  font-weight: 500;
  border-radius: 9999px;
  background-color: var(--wt);
  box-shadow: 1px 2px 2px rgba(53, 56, 125, 0.07);
  border: none;
  cursor: pointer;
  z-index: 10;
  opacity: 0;
  -moz-transition: opacity 0.4s ease, background-color 0.4s ease, color 0.4s ease;
  -o-transition: opacity 0.4s ease, background-color 0.4s ease, color 0.4s ease;
  -webkit-transition: opacity 0.4s ease, background-color 0.4s ease, color 0.4s ease;
  transition: opacity 0.4s ease, background-color 0.4s ease, color 0.4s ease;
}
body.transition a.btn-about {
  opacity: 0;
}
body.loaded a.btn-about {
  opacity: 1;
}
@media screen and (min-width: 768px) {
  a.btn-about {
    transition: all .4s ease;
  }
  a.btn-about:hover {
    background-color: var(--key);
    color: var(--wt);
  }
}
@media screen and (max-width: 768px) {
  a.btn-about {
    /*--- SP ---*/
    display: none;
  }
}
a.btn-about i {
  font-size: 20px;
  margin-right: 10px;
  margin-left: 0;
}

ol.breadcrumb {
  position: fixed;
  top: 25px;
  left: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  max-width: 400px;
  height: 50px;
  padding: 10px 20px;
  border-radius: 60px;
  font-size: 11px;
  background-color: var(--wt);
  box-shadow: 1px 2px 2px rgba(53, 56, 125, 0.07);
  overflow: hidden;
  z-index: 8;
  opacity: 0;
  -moz-transition: opacity 0.4s ease, background-color 0.4s ease, color 0.4s ease;
  -o-transition: opacity 0.4s ease, background-color 0.4s ease, color 0.4s ease;
  -webkit-transition: opacity 0.4s ease, background-color 0.4s ease, color 0.4s ease;
  transition: opacity 0.4s ease, background-color 0.4s ease, color 0.4s ease;
}
body.transition ol.breadcrumb {
  opacity: 0;
}
body.loaded ol.breadcrumb {
  opacity: 1;
}
@media screen and (max-width: 768px) {
  ol.breadcrumb {
    /*--- SP ---*/
    display: none;
  }
}
ol.breadcrumb li {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
ol.breadcrumb li + li::before {
  display: inline-block;
  content: "/";
  margin: 0 5px;
  color: #d2d4f6;
}
ol.breadcrumb li a {
  display: inline-block;
  max-width: 200px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--key);
  -moz-transition: color 0.4s ease;
  -o-transition: color 0.4s ease;
  -webkit-transition: color 0.4s ease;
  transition: color 0.4s ease;
}
ol.breadcrumb li a i {
  font-size: 20px;
  margin-right: 10px;
  margin-left: 0;
}
@media screen and (min-width: 768px) {
  ol.breadcrumb li a:hover {
    color: #000;
  }
}

svg path#clip-path-feature, svg path#clip-path-article {
  transform: scale(0.00084, 0.00127);
}

/*============================
drawer-btn
============================*/
div.btn-search {
  color: #35387D;
  position: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
  width: 160px;
  height: 50px;
  font-size: 13px;
  font-weight: 500;
  border-radius: 9999px;
  background-color: var(--wt);
  border: none;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all .4s ease;
}
div.btn-search i.ico-search {
  display: block;
  width: 18px;
  height: 18px;
  margin-right: 10px;
}
@media screen and (max-width: 768px) {
  div.btn-search i.ico-search {
    margin-right: 10px;
  }
}
div.btn-search i.ico-search svg {
  display: block;
  width: 100%;
  height: auto;
}
div.btn-search i.ico-search path {
  fill: var(--key);
  transition: all .4s ease;
}
div.btn-search.active {
  color: #FFF;
  background-color: var(--key);
  border: 1px solid #FFF;
}
div.btn-search.active svg path {
  fill: var(--wt);
}
@media screen and (min-width: 768px) {
  div.btn-search {
    /*--- PC TAB ---*/
    top: 25px;
    right: 85px;
    transition: all .4s ease;
    box-shadow: 1px 2px 2px rgba(53, 56, 125, 0.07);
  }
  div.btn-search:hover {
    background-color: var(--key);
    color: var(--wt);
  }
  div.btn-search:hover svg path {
    fill: var(--wt);
  }
}
@media screen and (max-width: 768px) {
  div.btn-search {
    bottom: 15px;
    right: 75px;
    box-shadow: 0px 1px 3px rgba(53, 56, 125, 0.07);
  }
}

/*============================
drawer-btn
============================*/
div.btn-drawer {
  position: fixed;
  z-index: 1000;
  width: 50px;
  height: 50px;
  border-radius: 9999px;
  border: 1px solid transparent;
  background-color: var(--wt);
  border: none;
  cursor: pointer;
  transition: all .4s ease;
}
@media screen and (min-width: 768px) {
  div.btn-drawer {
    /*--- PC TAB ---*/
    top: 25px;
    right: 20px;
    box-shadow: 1px 2px 2px rgba(53, 56, 125, 0.07);
  }
  div.btn-drawer:hover {
    background-color: var(--key);
  }
  div.btn-drawer:hover span {
    background-color: var(--wt);
  }
}
@media screen and (max-width: 768px) {
  div.btn-drawer {
    /*--- SP ---*/
    bottom: 15px;
    right: 15px;
    box-shadow: 0px 1px 3px rgba(53, 56, 125, 0.07);
  }
}
div.btn-drawer.active {
  background-color: var(--key);
  border: 1px solid #FFF;
}
div.btn-drawer.active span {
  background-color: var(--wt);
}
div.btn-drawer.active span.line1 {
  top: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
}
div.btn-drawer.active span.line2 {
  opacity: 0;
}
div.btn-drawer.active span.line3 {
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
}
div.btn-drawer span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 16px;
  height: 2px;
  background-color: var(--key);
  transition: all .2s ease;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  overflow: hidden;
}
div.btn-drawer span.line1 {
  top: calc(50% + 6px);
}
div.btn-drawer span.line3 {
  top: calc(50% - 6px);
}

/*============================
drawer-menu
============================*/
/* 全画面ドロワーメニューのスタイル */
div.search-menu,
div.drawer-menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  /* 半透明の背景 */
  color: #fff;
  opacity: 0;
  /* 非表示 */
  visibility: hidden;
  /* 初期状態で非表示 */
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: 999;
}
div.search-menu .nav-inner,
div.drawer-menu .nav-inner {
  position: fixed;
  top: 0;
  right: 0;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  text-align: left;
  z-index: 2;
  mask-image: url(../img/bg_nav.png);
  mask-position: top left;
  mask-repeat: no-repeat;
  mask-size: cover;
  background-color: #35387D;
  -moz-transform: translate(10px, 0);
  -ms-transform: translate(10px, 0);
  -webkit-transform: translate(10px, 0);
  transform: translate(10px, 0);
  -moz-transition: -moz-transform 0.4s ease;
  -o-transition: -o-transform 0.4s ease;
  -webkit-transition: -webkit-transform 0.4s ease;
  transition: transform 0.4s ease;
}
@media screen and (min-width: 768px) {
  div.search-menu .nav-inner,
  div.drawer-menu .nav-inner {
    /*--- PC TAB ---*/
    width: 400px;
    padding: 50px 50px 50px 80px;
  }
}
@media screen and (max-width: 768px) {
  div.search-menu .nav-inner,
  div.drawer-menu .nav-inner {
    /*--- SP ---*/
    width: 90vw;
    padding: 10vw 8vw 10vw 15vw;
  }
}
div.search-menu .nav-inner .nav-drawer ul.main-nav,
div.drawer-menu .nav-inner .nav-drawer ul.main-nav {
  position: relative;
}
div.search-menu .nav-inner .nav-drawer ul.main-nav::before,
div.drawer-menu .nav-inner .nav-drawer ul.main-nav::before {
  content: "CONTENTS";
  display: block;
  position: absolute;
  top: -30px;
  left: 12px;
  color: #FFF;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-size: 10px;
  letter-spacing: .1em;
  opacity: .7;
  -moz-transition: opacity 0.4s ease, -moz-transform 0.4s ease;
  -o-transition: opacity 0.4s ease, -o-transform 0.4s ease;
  -webkit-transition: opacity 0.4s ease, -webkit-transform 0.4s ease;
  transition: opacity 0.4s ease, transform 0.4s ease;
}
div.search-menu .nav-inner .nav-drawer ul.main-nav li,
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li {
  text-align: left;
  opacity: 0;
  position: relative;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -moz-transform: translate(10px, 0);
  -ms-transform: translate(10px, 0);
  -webkit-transform: translate(10px, 0);
  transform: translate(10px, 0);
  -moz-transition: opacity 0.4s ease, -moz-transform 0.4s ease;
  -o-transition: opacity 0.4s ease, -o-transform 0.4s ease;
  -webkit-transition: opacity 0.4s ease, -webkit-transform 0.4s ease;
  transition: opacity 0.4s ease, transform 0.4s ease;
}
div.search-menu .nav-inner .nav-drawer ul.main-nav li a,
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li a {
  color: #FFF;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
  letter-spacing: .05em;
  padding: 10px 10px;
  opacity: 1;
  -moz-transition: opacity 0.4s ease;
  -o-transition: opacity 0.4s ease;
  -webkit-transition: opacity 0.4s ease;
  transition: opacity 0.4s ease;
}
@media screen and (min-width: 768px) {
  div.search-menu .nav-inner .nav-drawer ul.main-nav li a,
  div.drawer-menu .nav-inner .nav-drawer ul.main-nav li a {
    /*--- PC TAB ---*/
    font-size: 18px;
  }
}
@media screen and (max-width: 768px) {
  div.search-menu .nav-inner .nav-drawer ul.main-nav li a,
  div.drawer-menu .nav-inner .nav-drawer ul.main-nav li a {
    /*--- SP ---*/
    font-size: 4vw;
  }
}
div.search-menu .nav-inner .nav-drawer ul.main-nav li a:hover,
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li a:hover {
  opacity: .7;
}
div.search-menu .nav-inner .nav-drawer ul.main-nav li:hover::before,
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li:hover::before {
  opacity: .7;
  left: -8px;
}
div.search-menu .nav-inner .nav-drawer ul.main-nav li::before,
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li::before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  position: absolute;
  top: 50%;
  left: -5px;
  background-color: #FFF;
  border-radius: 9999px;
  opacity: 0;
  margin-top: -4px;
  -moz-transition: opacity 0.4s ease, left 0.4s ease;
  -o-transition: opacity 0.4s ease, left 0.4s ease;
  -webkit-transition: opacity 0.4s ease, left 0.4s ease;
  transition: opacity 0.4s ease, left 0.4s ease;
}
body.home div.search-menu .nav-inner .nav-drawer ul.main-nav li.home::before, body.single-article div.search-menu .nav-inner .nav-drawer ul.main-nav li.article::before, body.post-type-archive-article div.search-menu .nav-inner .nav-drawer ul.main-nav li.article::before, body.tax-article-category div.search-menu .nav-inner .nav-drawer ul.main-nav li.article::before, body.single-feature div.search-menu .nav-inner .nav-drawer ul.main-nav li.feature::before, body.post-type-archive-feature div.search-menu .nav-inner .nav-drawer ul.main-nav li.feature::before, body.about div.search-menu .nav-inner .nav-drawer ul.main-nav li.about::before, body.home
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li.home::before, body.single-article
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li.article::before, body.post-type-archive-article
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li.article::before, body.tax-article-category
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li.article::before, body.single-feature
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li.feature::before, body.post-type-archive-feature
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li.feature::before, body.about
div.drawer-menu .nav-inner .nav-drawer ul.main-nav li.about::before {
  opacity: 1;
  left: -8px;
}
div.search-menu .nav-search form div,
div.drawer-menu .nav-search form div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  border-radius: 9999px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  font-size: 15px;
  -moz-transition: color 0.4s ease, border 0.4s ease, background-color 0.25s ease;
  -o-transition: color 0.4s ease, border 0.4s ease, background-color 0.25s ease;
  -webkit-transition: color 0.4s ease, border 0.4s ease, background-color 0.25s ease;
  transition: color 0.4s ease, border 0.4s ease, background-color 0.25s ease;
}
div.search-menu .nav-search form div:hover,
div.drawer-menu .nav-search form div:hover {
  border: 1px solid white;
}
div.search-menu .nav-search form div:hover button,
div.drawer-menu .nav-search form div:hover button {
  opacity: 1;
}
div.search-menu .nav-search form div input[type="text"],
div.drawer-menu .nav-search form div input[type="text"] {
  width: calc( 100% - 60px );
  color: #FFF;
  text-align: left;
  outline: none;
  padding: 15px 20px;
  background-color: transparent;
  -moz-transition: border 0.4s ease, background-color 0.4s ease;
  -o-transition: border 0.4s ease, background-color 0.4s ease;
  -webkit-transition: border 0.4s ease, background-color 0.4s ease;
  transition: border 0.4s ease, background-color 0.4s ease;
}
div.search-menu .nav-search form div input[type="text"]::placeholder,
div.drawer-menu .nav-search form div input[type="text"]::placeholder {
  color: rgba(255, 255, 255, 0.3);
}
div.search-menu .nav-search form div button,
div.drawer-menu .nav-search form div button {
  width: 52px;
  color: #FFF;
  text-align: left;
  outline: none;
  border: none;
  outline: none;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  background-color: transparent;
  opacity: .2;
  cursor: pointer;
  -moz-transition: opacity 0.4s ease, border 0.4s ease, background-color 0.4s ease;
  -o-transition: opacity 0.4s ease, border 0.4s ease, background-color 0.4s ease;
  -webkit-transition: opacity 0.4s ease, border 0.4s ease, background-color 0.4s ease;
  transition: opacity 0.4s ease, border 0.4s ease, background-color 0.4s ease;
}
div.search-menu .nav-search form div button svg,
div.drawer-menu .nav-search form div button svg {
  fill: #FFF;
  width: 18px;
  height: 18px;
  opacity: 1;
  -moz-transition: opacity 0.4s ease;
  -o-transition: opacity 0.4s ease;
  -webkit-transition: opacity 0.4s ease;
  transition: opacity 0.4s ease;
}
div.search-menu .nav-search form div button:hover svg,
div.drawer-menu .nav-search form div button:hover svg {
  opacity: .5;
}
div.search-menu .nav-search .category-list,
div.drawer-menu .nav-search .category-list {
  margin: 30px 0 0;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
div.search-menu .nav-search .category-list li,
div.drawer-menu .nav-search .category-list li {
  margin: 2px 4px 2px 0;
  letter-spacing: .08em;
}
div.search-menu .nav-search .category-list li a,
div.drawer-menu .nav-search .category-list li a {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  color: #FFF;
  background-color: transparent;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-size: 12px;
  font-weight: 400;
  border-radius: 9999px;
  line-height: 1;
  padding: 8px 12px;
  width: fit-content;
  border: 1px solid rgba(255, 255, 255, 0.2);
  -moz-transition: color 0.4s ease, border 0.4s ease, background-color 0.25s ease;
  -o-transition: color 0.4s ease, border 0.4s ease, background-color 0.25s ease;
  -webkit-transition: color 0.4s ease, border 0.4s ease, background-color 0.25s ease;
  transition: color 0.4s ease, border 0.4s ease, background-color 0.25s ease;
}
div.search-menu .nav-search .category-list li a:hover,
div.drawer-menu .nav-search .category-list li a:hover {
  color: #35387D;
  border: 1px solid white;
  background-color: #FFF;
}
div.search-menu.active .nav-inner .nav-drawer ul.main-nav::before,
div.drawer-menu.active .nav-inner .nav-drawer ul.main-nav::before {
  opacity: .7;
  -moz-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
  -moz-transition: opacity 0.4s ease 0.05s, -moz-transform 0.4s ease 0.05s;
  -o-transition: opacity 0.4s ease 0.05s, -o-transform 0.4s ease 0.05s;
  -webkit-transition: opacity 0.4s ease, -webkit-transform 0.4s ease;
  -webkit-transition-delay: 0.05s, 0.05s;
  transition: opacity 0.4s ease 0.05s, transform 0.4s ease 0.05s;
}
div.search-menu.active .nav-inner .nav-drawer ul.main-nav li,
div.drawer-menu.active .nav-inner .nav-drawer ul.main-nav li {
  opacity: 1;
  -moz-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}
div.search-menu.active .nav-inner .nav-drawer ul.main-nav li:first-child,
div.drawer-menu.active .nav-inner .nav-drawer ul.main-nav li:first-child {
  -moz-transition: opacity 0.4s ease 0.1s, -moz-transform 0.4s ease 0.1s;
  -o-transition: opacity 0.4s ease 0.1s, -o-transform 0.4s ease 0.1s;
  -webkit-transition: opacity 0.4s ease, -webkit-transform 0.4s ease;
  -webkit-transition-delay: 0.1s, 0.1s;
  transition: opacity 0.4s ease 0.1s, transform 0.4s ease 0.1s;
}
div.search-menu.active .nav-inner .nav-drawer ul.main-nav li:nth-child(2),
div.drawer-menu.active .nav-inner .nav-drawer ul.main-nav li:nth-child(2) {
  -moz-transition: opacity 0.4s ease 0.15s, -moz-transform 0.4s ease 0.15s;
  -o-transition: opacity 0.4s ease 0.15s, -o-transform 0.4s ease 0.15s;
  -webkit-transition: opacity 0.4s ease, -webkit-transform 0.4s ease;
  -webkit-transition-delay: 0.15s, 0.15s;
  transition: opacity 0.4s ease 0.15s, transform 0.4s ease 0.15s;
}
div.search-menu.active .nav-inner .nav-drawer ul.main-nav li:nth-child(3),
div.drawer-menu.active .nav-inner .nav-drawer ul.main-nav li:nth-child(3) {
  -moz-transition: opacity 0.4s ease 0.2s, -moz-transform 0.4s ease 0.2s;
  -o-transition: opacity 0.4s ease 0.2s, -o-transform 0.4s ease 0.2s;
  -webkit-transition: opacity 0.4s ease, -webkit-transform 0.4s ease;
  -webkit-transition-delay: 0.2s, 0.2s;
  transition: opacity 0.4s ease 0.2s, transform 0.4s ease 0.2s;
}
div.search-menu.active .nav-inner .nav-drawer ul.main-nav li:nth-child(4),
div.drawer-menu.active .nav-inner .nav-drawer ul.main-nav li:nth-child(4) {
  -moz-transition: opacity 0.4s ease 0.25s, -moz-transform 0.4s ease 0.25s;
  -o-transition: opacity 0.4s ease 0.25s, -o-transform 0.4s ease 0.25s;
  -webkit-transition: opacity 0.4s ease, -webkit-transform 0.4s ease;
  -webkit-transition-delay: 0.25s, 0.25s;
  transition: opacity 0.4s ease 0.25s, transform 0.4s ease 0.25s;
}
div.search-menu.active .nav-inner .nav-drawer ul.main-nav li:nth-child(5),
div.drawer-menu.active .nav-inner .nav-drawer ul.main-nav li:nth-child(5) {
  -moz-transition: opacity 0.4s ease 0.3s, -moz-transform 0.4s ease 0.3s;
  -o-transition: opacity 0.4s ease 0.3s, -o-transform 0.4s ease 0.3s;
  -webkit-transition: opacity 0.4s ease, -webkit-transform 0.4s ease;
  -webkit-transition-delay: 0.3s, 0.3s;
  transition: opacity 0.4s ease 0.3s, transform 0.4s ease 0.3s;
}
div.search-menu .bg-nav,
div.drawer-menu .bg-nav {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
  opacity: .98;
}
@media screen and (min-width: 768px) {
  div.search-menu .bg-nav,
  div.drawer-menu .bg-nav {
    /*--- PC TAB ---*/
    background: url(../img/bg.png) center center/cover fixed no-repeat #eaf5f9;
  }
}
@media screen and (max-width: 768px) {
  div.search-menu .bg-nav,
  div.drawer-menu .bg-nav {
    /*--- SP ---*/
  }
  div.search-menu .bg-nav::before,
  div.drawer-menu .bg-nav::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    background: url(../img/bg.png) center center/cover no-repeat #eaf5f9;
    z-index: -1;
    pointer-events: none;
  }
}
div.search-menu .bg-nav::after,
div.drawer-menu .bg-nav::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  background: url(../img/bg_tile.png) center center fixed repeat;
  background-size: 25px 25px;
  z-index: -2;
  pointer-events: none;
  opacity: .05;
}

/* 表示時のスタイル */
div.search-menu.active,
div.drawer-menu.active {
  opacity: 1;
  visibility: visible;
}
div.search-menu.active .nav-inner,
div.drawer-menu.active .nav-inner {
  -moz-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}

/****************************************

          FEATURE
          
*****************************************/
.featured-article {
  width: 100%;
  position: relative;
}
@media screen and (min-width: 768px) {
  .featured-article {
    /*--- PC TAB ---*/
    max-width: 1280px;
    padding: 0 0 150px 8px;
    margin: 100px auto 0;
  }
}
@media screen and (max-width: 768px) {
  .featured-article {
    /*--- SP ---*/
    width: 91vw;
    padding: 0 0 5vw 6px;
    margin: 16vw auto 15vw;
  }
}
.featured-article::before {
  content: "";
  display: block;
  background: url(../img/bo2.png) top center/contain no-repeat;
  position: absolute;
  top: -1px;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .featured-article::before {
    /*--- PC TAB ---*/
    width: 8px;
    height: 738px;
    left: 51px;
  }
}
@media screen and (max-width: 768px) {
  .featured-article::before {
    /*--- SP ---*/
    width: 6px;
    height: calc( 100% + 2vw );
    left: 0;
  }
}
.featured-article a {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .featured-article a {
    /*--- PC TAB ---*/
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-left: 50px;
    padding-right: 50px;
  }
}
@media screen and (max-width: 768px) {
  .featured-article a {
    /*--- SP ---*/
  }
}
.featured-article a .article-thumbnail {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
  overflow: hidden;
  position: relative;
  aspect-ratio: 1.5 / 1;
}
@media screen and (min-width: 768px) {
  .featured-article a .article-thumbnail {
    /*--- PC TAB ---*/
    width: 58%;
  }
}
@media screen and (max-width: 768px) {
  .featured-article a .article-thumbnail {
    /*--- SP ---*/
    width: 100%;
  }
}
.featured-article a .article-thumbnail img {
  object-fit: cover;
  aspect-ratio: 1.5 / 1;
}
.featured-article a .article-thumbnail image {
  height: auto;
}
.featured-article a:hover .article-detail div.detail-inner .readmore {
  color: #FFF;
  background-color: #35387D;
}
.featured-article a .article-detail {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  padding: 0;
}
@media screen and (min-width: 768px) {
  .featured-article a .article-detail {
    /*--- PC TAB ---*/
    width: 42%;
  }
}
@media screen and (max-width: 768px) {
  .featured-article a .article-detail {
    /*--- SP ---*/
    width: 100%;
  }
}
.featured-article a .article-detail div.detail-inner {
  position: relative;
}
@media screen and (min-width: 768px) {
  .featured-article a .article-detail div.detail-inner {
    /*--- PC TAB ---*/
    padding: 60px 0 60px 40px;
  }
}
@media screen and (max-width: 768px) {
  .featured-article a .article-detail div.detail-inner {
    /*--- SP ---*/
    padding: 5vw 0 0 5vw;
  }
}
.featured-article a .article-detail div.detail-inner::after {
  content: "";
  display: block;
  width: calc( 100% + 30px );
  height: 100%;
  border-radius: 0 30px 30px 0;
  background-color: rgba(255, 255, 255, 0.6);
  position: absolute;
  top: 0;
  left: -30px;
  filter: blur(30px);
  will-change: filter;
  z-index: -1;
}
.featured-article a .article-detail div.detail-inner .detail-meta {
  color: #35387D;
  font-weight: 400;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .featured-article a .article-detail div.detail-inner .detail-meta {
    /*--- PC TAB ---*/
    font-size: 12px;
    margin: 0 0 12px;
  }
}
@media screen and (max-width: 768px) {
  .featured-article a .article-detail div.detail-inner .detail-meta {
    /*--- SP ---*/
    font-size: 2.9vw;
    margin: 0 0 2vw;
  }
}
.featured-article a .article-detail div.detail-inner .detail-meta .feature_tit {
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  margin: 0 10px 0 0;
}
@media screen and (min-width: 768px) {
  .featured-article a .article-detail div.detail-inner .detail-meta .feature_tit {
    /*--- PC TAB ---*/
    font-size: 16px;
  }
}
@media screen and (max-width: 768px) {
  .featured-article a .article-detail div.detail-inner .detail-meta .feature_tit {
    /*--- SP ---*/
    font-size: 3.5vw;
  }
}
.featured-article a .article-detail div.detail-inner .detail-meta time {
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  margin: 0 8px 0 0;
}
.featured-article a .article-detail div.detail-inner .detail-meta .tags {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
.featured-article a .article-detail div.detail-inner .detail-meta .tags li {
  font-size: 11px;
  margin: 0 8px 0 0;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #FFF;
  padding: 2px 12px 2px 10px;
  border-radius: 9999px;
}
@media screen and (min-width: 768px) {
  .featured-article a .article-detail div.detail-inner .detail-meta .tags li {
    /*--- PC TAB ---*/
  }
}
@media screen and (max-width: 768px) {
  .featured-article a .article-detail div.detail-inner .detail-meta .tags li {
    /*--- SP ---*/
    font-size: 2.7vw;
  }
}
.featured-article a .article-detail div.detail-inner h3 {
  color: #35387D;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 500;
  letter-spacing: 0.02em;
}
@media screen and (min-width: 768px) {
  .featured-article a .article-detail div.detail-inner h3 {
    /*--- PC TAB ---*/
    font-size: 20px;
    margin: 0 0 15px;
  }
}
@media screen and (max-width: 768px) {
  .featured-article a .article-detail div.detail-inner h3 {
    /*--- SP ---*/
    font-size: 4vw;
    margin: 0 0 2vw;
  }
}
.featured-article a .article-detail div.detail-inner .readmore {
  color: #35387D;
  width: fit-content;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 400;
  line-height: 1;
  border-radius: 9999px;
  background-color: #FFF;
  -moz-transition: color 0.4s ease, background-color 0.4s ease;
  -o-transition: color 0.4s ease, background-color 0.4s ease;
  -webkit-transition: color 0.4s ease, background-color 0.4s ease;
  transition: color 0.4s ease, background-color 0.4s ease;
}
@media screen and (min-width: 768px) {
  .featured-article a .article-detail div.detail-inner .readmore {
    /*--- PC TAB ---*/
    font-size: 12px;
    padding: 10px 15px;
  }
}
@media screen and (max-width: 768px) {
  .featured-article a .article-detail div.detail-inner .readmore {
    /*--- SP ---*/
    font-size: 2.9vw;
    padding: 8px 12px;
  }
}
.featured-article a .article-detail div.detail-inner .readmore i {
  font-size: 20px;
  margin: 0 8px 0 0;
}
@media screen and (max-width: 768px) {
  .featured-article a .article-detail div.detail-inner .readmore i {
    /*--- SP ---*/
    font-size: 16px;
    margin: 0 5px 0 0;
  }
}

/****************************************

          HOME
          
*****************************************/
.Related-section.swiper {
  position: relative;
  z-index: 1;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper {
    /*--- PC TAB ---*/
    max-width: 1280px;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper {
    /*--- SP ---*/
    width: 91vw;
  }
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide {
    /*--- PC TAB ---*/
    padding: 0 0 150px 8px;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide {
    /*--- SP ---*/
    padding: 0 0 10vw 6px;
  }
}
.Related-section.swiper .swiper-slide::before {
  content: "";
  display: block;
  background: url(../img/bo.png) top left/contain no-repeat;
  position: absolute;
  top: -1px;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide::before {
    /*--- PC TAB ---*/
    width: 8px;
    height: 543px;
    left: 51px;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide::before {
    /*--- SP ---*/
    width: 6px;
    height: 543px;
    left: 0;
  }
}
.Related-section.swiper .swiper-slide a {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a {
    /*--- PC TAB ---*/
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-left: 50px;
    padding-right: 50px;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a {
    /*--- SP ---*/
  }
}
.Related-section.swiper .swiper-slide a .article-thumbnail {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
  overflow: hidden;
  position: relative;
  aspect-ratio: 1.5 / 1;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-thumbnail {
    /*--- PC TAB ---*/
    width: 58%;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-thumbnail {
    /*--- SP ---*/
    width: 100%;
  }
}
.Related-section.swiper .swiper-slide a .article-thumbnail img {
  object-fit: cover;
  aspect-ratio: 1.5 / 1;
}
.Related-section.swiper .swiper-slide a .article-thumbnail image {
  height: auto;
}
.Related-section.swiper .swiper-slide a .article-thumbnail svg path {
  transform: scale(0.00084, 0.00084);
}
.Related-section.swiper .swiper-slide a:hover .article-detail div.detail-inner .readmore {
  color: #FFF;
  background-color: #35387D;
}
.Related-section.swiper .swiper-slide a .article-detail {
  padding: 0;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail {
    /*--- PC TAB ---*/
    width: 42%;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail {
    /*--- SP ---*/
    width: 100%;
    border-radius: 8vw 0 0 8vw;
  }
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner {
  position: relative;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner {
    /*--- PC TAB ---*/
    padding: 40px 40px;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner {
    /*--- SP ---*/
    padding: 5vw 0 0 5vw;
  }
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner::after {
  content: "";
  display: block;
  background-color: rgba(255, 255, 255, 0.6);
  position: absolute;
  top: 0;
  filter: blur(30px);
  will-change: filter;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner::after {
    /*--- PC TAB ---*/
    width: calc( 100% + 30px );
    height: 100%;
    border-radius: 0 30px 30px 0;
    left: -30px;
  }
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-meta {
  color: #35387D;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 400;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-meta {
    /*--- PC TAB ---*/
    font-size: 12px;
    margin: 0 0 12px;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-meta {
    /*--- SP ---*/
    font-size: 2.9vw;
    margin: 0 0 2vw;
  }
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-meta time {
  margin: 0 8px 0 0;
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-meta .tags {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-meta .tags {
    /*--- PC TAB ---*/
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-meta .tags {
    /*--- SP ---*/
    font-size: 2.7vw;
  }
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-meta .tags li {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #FFF;
  padding: 2px 12px 2px 10px;
  border-radius: 9999px;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-meta .tags li {
    /*--- PC TAB ---*/
    font-size: 11px;
    margin: 0 8px 0 0;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-meta .tags li {
    /*--- SP ---*/
    font-size: 2.9vw;
    margin: 0 8px 0 0;
  }
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner h1 {
  color: #35387D;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 500;
  letter-spacing: 0.02em;
  -moz-transition: color 0.4s ease;
  -o-transition: color 0.4s ease;
  -webkit-transition: color 0.4s ease;
  transition: color 0.4s ease;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner h1 {
    /*--- PC TAB ---*/
    font-size: 20px;
    margin: 0 0 15px;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner h1 {
    /*--- SP ---*/
    font-size: 4.5vw;
    margin: 0 0 2vw;
  }
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner .detail-bottom {
  margin: 15px 0 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner .readmore {
  color: #35387D;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 400;
  line-height: 1;
  width: fit-content;
  border-radius: 9999px;
  background-color: #FFF;
  -moz-transition: color 0.4s ease, background-color 0.4s ease;
  -o-transition: color 0.4s ease, background-color 0.4s ease;
  -webkit-transition: color 0.4s ease, background-color 0.4s ease;
  transition: color 0.4s ease, background-color 0.4s ease;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .readmore {
    /*--- PC TAB ---*/
    font-size: 12px;
    padding: 10px 15px;
    margin: 0 0 0 20px;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .readmore {
    /*--- SP ---*/
    font-size: 2.9vw;
    padding: 8px 12px;
    margin: 0 0 0 15px;
  }
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner .readmore i {
  font-size: 20px;
  margin: 0 8px 0 0;
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .readmore i {
    /*--- SP ---*/
    font-size: 16px;
    margin: 0 5px 0 0;
  }
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner .member {
  color: #35387D;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .member {
    /*--- PC TAB ---*/
    font-size: 12px;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .member {
    /*--- SP ---*/
    font-size: 3vw;
  }
}
.Related-section.swiper .swiper-slide a .article-detail div.detail-inner .member .ico-tama {
  background: url(../img/ico_tamacruise.png) center center/contain no-repeat;
}
@media screen and (min-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .member .ico-tama {
    /*--- PC TAB ---*/
    width: 50px;
    height: 50px;
    margin: 0 10px 0 -5px;
  }
}
@media screen and (max-width: 768px) {
  .Related-section.swiper .swiper-slide a .article-detail div.detail-inner .member .ico-tama {
    /*--- SP ---*/
    width: 10vw;
    height: 10vw;
    margin: 0 2vw 0 -1vw;
  }
}

@media screen and (min-width: 768px) {
  .Related-section + section.category-scroller {
    /*--- PC TAB ---*/
    margin: -270px 0 0;
  }
}
@media screen and (max-width: 768px) {
  .Related-section + section.category-scroller {
    /*--- SP ---*/
    margin: -10vw 0 0;
  }
}

@media screen and (min-width: 768px) {
  .article-list-section + section.category-scroller {
    /*--- PC TAB ---*/
    margin: -170px 0 0;
  }
}
@media screen and (max-width: 768px) {
  .article-list-section + section.category-scroller {
    /*--- SP ---*/
    margin: -20vw 0 0;
  }
}

/****************************************

          CATEGORY LOOP
          
*****************************************/
section.category-scroller {
  position: relative;
  overflow: hidden;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  section.category-scroller {
    /*--- PC TAB ---*/
    height: 360px;
  }
}
@media screen and (max-width: 768px) {
  section.category-scroller {
    /*--- SP ---*/
    height: 50vw;
  }
}
section.category-scroller .scroll-track {
  display: flex;
  width: max-content;
  animation: scroll-left 45s linear infinite;
  animation-play-state: running;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  section.category-scroller .scroll-track {
    /*--- PC TAB ---*/
    top: 40px;
  }
}
@media screen and (max-width: 768px) {
  section.category-scroller .scroll-track {
    /*--- SP ---*/
    top: 5vw;
  }
}
section.category-scroller .scroll-track:hover {
  animation-play-state: paused;
}
section.category-scroller::after {
  content: "";
  display: block;
  width: 100%;
  position: absolute;
  left: 0;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  section.category-scroller::after {
    /*--- PC TAB ---*/
    height: 360px;
    margin: -180px 0 0;
    top: 50%;
    background: url(../img/bg_loop.png) center center repeat-x;
    background-size: 1767px 360px;
  }
}
@media screen and (max-width: 768px) {
  section.category-scroller::after {
    /*--- SP ---*/
    height: 100%;
    margin: 0;
    top: 0;
    background: url(../img/bg_loop.png) center center/cover repeat-x;
  }
}

.article-category-list {
  display: flex;
  list-style: none;
}
.article-category-list li {
  display: inline-block;
}
.article-category-list li a {
  color: #35387D;
  position: relative;
  white-space: nowrap;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 400;
  letter-spacing: 0.1em;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .article-category-list li a {
    /*--- PC TAB ---*/
    padding: 8px 16px;
    font-size: 15px;
  }
}
@media screen and (max-width: 768px) {
  .article-category-list li a {
    /*--- SP ---*/
    padding: 2vw 3vw;
    font-size: 3vw;
  }
}
.article-category-list li a::before {
  content: "";
  height: 100%;
  position: absolute;
  top: 0;
  border-radius: 50px;
  background-color: var(--wt);
  z-index: -1;
  transition: background-color .4s ease;
}
@media screen and (min-width: 768px) {
  .article-category-list li a::before {
    /*--- PC TAB ---*/
    width: calc(100% + 8px);
    left: -4px;
  }
}
@media screen and (max-width: 768px) {
  .article-category-list li a::before {
    /*--- SP ---*/
    width: calc(100% + 6px);
    left: -3px;
  }
}
@media screen and (min-width: 768px) {
  .article-category-list li a {
    transition: color .4s ease;
  }
  .article-category-list li a:hover {
    color: var(--wt);
    z-index: 10;
  }
  .article-category-list li a:hover::before {
    background-color: var(--key);
  }
}

/****************************************

          BUTTON
          
*****************************************/
div.button-wrapper {
  display: flex;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  div.button-wrapper {
    /*--- PC TAB ---*/
    margin: 80px 0 110px;
  }
}
@media screen and (max-width: 768px) {
  div.button-wrapper {
    /*--- SP ---*/
    margin: 10vw 0 15vw;
  }
}
div.button-wrapper a.top-button,
div.button-wrapper a.mokurin-button {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #35387D;
  background-color: var(--wt);
  box-shadow: 2px 2px 2px rgba(53, 56, 125, 0.07);
  text-decoration: none;
  border-radius: 9999px;
  font-weight: 600;
  transition: all .4s ease;
}
@media screen and (min-width: 768px) {
  div.button-wrapper a.top-button,
  div.button-wrapper a.mokurin-button {
    /*--- PC TAB ---*/
    font-size: 15px;
    min-width: 210px;
    height: 55px;
    padding: 0 20px;
  }
}
@media screen and (max-width: 768px) {
  div.button-wrapper a.top-button,
  div.button-wrapper a.mokurin-button {
    /*--- SP ---*/
    font-size: 3.5vw;
    min-width: 50vw;
    height: 50px;
    padding: 0 5vw;
  }
}
div.button-wrapper a.top-button:hover,
div.button-wrapper a.mokurin-button:hover {
  color: var(--wt);
}
div.button-wrapper a.top-button i,
div.button-wrapper a.mokurin-button i {
  font-size: 20px;
  margin-right: 10px;
}
div.button-wrapper a.top-button.jp,
div.button-wrapper a.mokurin-button.jp {
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-M", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
}
div.button-wrapper a.top-button {
  color: #35387D;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
}
div.button-wrapper a.top-button:hover {
  color: var(--wt);
  background-color: var(--key);
}
div.button-wrapper a.mokurin-button {
  color: #437d35;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-M", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
}
div.button-wrapper a.mokurin-button:hover {
  color: var(--wt);
  background-color: #437d35;
}

a.btn-insta,
a.btn-mokurin {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  color: #FFF;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-size: 14px;
  font-weight: 400;
  border-radius: 9999px;
  width: fit-content;
  min-width: 150px;
  height: 34px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 2;
  -moz-transition: background-color 0.4s ease;
  -o-transition: background-color 0.4s ease;
  -webkit-transition: background-color 0.4s ease;
  transition: background-color 0.4s ease;
}
a.btn-insta i,
a.btn-mokurin i {
  font-size: 12px;
  margin: 0 5px 0 -5px;
}

a.btn-insta {
  background-color: #35387D;
}
a.btn-insta:hover {
  background-color: #333;
}

a.btn-mokurin {
  background-color: #437d35;
}
a.btn-mokurin:hover {
  background-color: #333;
}

div.read-more-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 768px) {
  div.read-more-wrapper {
    /*--- PC TAB ---*/
    margin: 110px 0 0;
  }
}
@media screen and (max-width: 768px) {
  div.read-more-wrapper {
    /*--- SP ---*/
    margin: 10vw 0 0;
  }
}
div.read-more-wrapper a.read-more-button {
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--key);
  background-color: var(--wt);
  box-shadow: 2px 2px 2px rgba(53, 56, 125, 0.07);
  text-decoration: none;
  border-radius: 9999px;
  font-weight: 600;
  transition: all .4s ease;
}
@media screen and (min-width: 768px) {
  div.read-more-wrapper a.read-more-button {
    /*--- PC TAB ---*/
    min-width: 210px;
    height: 55px;
    padding: 0 15px;
    font-size: 15px;
  }
}
@media screen and (max-width: 768px) {
  div.read-more-wrapper a.read-more-button {
    /*--- SP ---*/
    min-width: 50vw;
    height: 50px;
    padding: 0 3vw;
    font-size: 3.5vw;
  }
}
div.read-more-wrapper a.read-more-button:hover {
  color: var(--wt);
  background-color: var(--key);
}
div.read-more-wrapper a.read-more-button i {
  font-size: 20px;
  margin-right: 8px;
  margin-left: -10px;
}
@media screen and (max-width: 768px) {
  div.read-more-wrapper a.read-more-button i {
    /*--- SP ---*/
    font-size: 5vw;
  }
}

@media screen and (min-width: 768px) {
  .article-list + div.read-more-wrapper {
    /*--- PC TAB ---*/
    margin-top: 40px;
  }
}
@media screen and (max-width: 768px) {
  .article-list + div.read-more-wrapper {
    /*--- SP ---*/
    margin-top: 2vw;
  }
}

div.wp-pagenavi {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 750px;
  font-family: "Roboto Condensed";
}
@media screen and (min-width: 768px) {
  div.wp-pagenavi {
    margin: 120px auto;
  }
}
div.wp-pagenavi span.current,
div.wp-pagenavi a,
div.wp-pagenavi a.page.larger,
div.wp-pagenavi span.extend,
div.wp-pagenavi a.previouspostslink,
div.wp-pagenavi a.nextpostslink {
  display: flex;
  justify-content: center;
  align-items: center;
  line-height: 1;
  color: var(--key);
  background-color: var(--wt);
  border: 1px solid var(--key);
  border-radius: 50px;
}
@media screen and (min-width: 768px) {
  div.wp-pagenavi span.current,
  div.wp-pagenavi a,
  div.wp-pagenavi a.page.larger,
  div.wp-pagenavi span.extend,
  div.wp-pagenavi a.previouspostslink,
  div.wp-pagenavi a.nextpostslink {
    width: 45px;
    height: 45px;
    margin: 0 4px;
    font-size: 15px;
    transition: color .4s ease, border .4s ease, background-color .4s ease;
  }
  div.wp-pagenavi span.current:hover,
  div.wp-pagenavi a:hover,
  div.wp-pagenavi a.page.larger:hover,
  div.wp-pagenavi span.extend:hover,
  div.wp-pagenavi a.previouspostslink:hover,
  div.wp-pagenavi a.nextpostslink:hover {
    color: var(--wt);
    background-color: var(--key);
  }
}
div.wp-pagenavi span.extend {
  border: none;
}
div.wp-pagenavi span.current {
  color: var(--wt);
  background-color: var(--key);
  pointer-events: none;
}
div.wp-pagenavi a.previouspostslink {
  position: relative;
  min-width: 110px;
}
div.wp-pagenavi a.previouspostslink::after {
  content: "";
  width: 8px;
  height: 8px;
  margin: 0 0 0 10px;
  border-bottom: 1px solid var(--key);
  border-left: 1px solid var(--key);
  transform: rotate(45deg);
  transition: all 0.4s ease;
}
@media screen and (min-width: 768px) {
  div.wp-pagenavi a.previouspostslink:hover::after {
    border-bottom: 1px solid var(--wt);
    border-left: 1px solid var(--wt);
  }
}
div.wp-pagenavi a.nextpostslink {
  position: relative;
  min-width: 110px;
}
div.wp-pagenavi a.nextpostslink::before {
  content: "";
  width: 8px;
  height: 8px;
  margin: 0 10px 0 0;
  border-top: 1px solid var(--key);
  border-right: 1px solid var(--key);
  transform: rotate(45deg);
  transition: all 0.4s ease;
}
@media screen and (min-width: 768px) {
  div.wp-pagenavi a.nextpostslink:hover::before {
    border-top: 1px solid var(--wt);
    border-right: 1px solid var(--wt);
  }
}

/****************************************

          FEED
          
*****************************************/
@media screen and (min-width: 768px) {
  .instagram-feed {
    /*--- PC TAB ---*/
  }
}
@media screen and (max-width: 768px) {
  .instagram-feed {
    /*--- SP ---*/
    margin: 10vw auto 0;
  }
}
.instagram-feed .ttl-insta,
.instagram-feed .ttl-mokurin {
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
  width: fit-content;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .instagram-feed .ttl-insta,
  .instagram-feed .ttl-mokurin {
    /*--- PC TAB ---*/
    font-size: 15px;
    margin: 0 auto 14px;
  }
}
@media screen and (max-width: 768px) {
  .instagram-feed .ttl-insta,
  .instagram-feed .ttl-mokurin {
    /*--- SP ---*/
    font-size: 4vw;
    margin: 0 auto 3vw;
  }
}
.instagram-feed .ttl-insta::before,
.instagram-feed .ttl-mokurin::before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  margin: 0 10px 0 0;
}
.instagram-feed .ttl-insta {
  color: #35387D;
}
.instagram-feed .ttl-insta::before {
  background: url(../img/ico_i_b.png) center center/contain no-repeat;
}
.instagram-feed .ttl-mokurin {
  color: #437d35;
}
.instagram-feed .ttl-mokurin::before {
  background: url(../img/ico_i_g.png) center center/contain no-repeat;
}

.feed-scroller {
  position: relative;
  overflow: hidden;
  padding: 0;
  margin: -15px 0 0;
}
.feed-scroller .scroll-track {
  display: flex;
  width: max-content;
  animation: scroll-left 45s linear infinite;
  animation-play-state: running;
}
.feed-scroller .scroll-track:hover {
  animation-play-state: paused;
}

.insta-feed-list {
  display: flex;
  list-style: none;
}
.insta-feed-list li {
  display: inline-block;
}
@media screen and (min-width: 768px) {
  .insta-feed-list li {
    /*--- PC TAB ---*/
    padding: 0 10px;
  }
}
@media screen and (max-width: 768px) {
  .insta-feed-list li {
    /*--- SP ---*/
    padding: 0 2vw;
  }
}
.insta-feed-list li a {
  position: relative;
  display: block;
  height: auto;
  aspect-ratio: 1 / 1;
  z-index: 1;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .insta-feed-list li a {
    /*--- PC TAB ---*/
    width: 240px;
    border-radius: 20px;
  }
}
@media screen and (max-width: 768px) {
  .insta-feed-list li a {
    /*--- SP ---*/
    width: 50vw;
    border-radius: 10vw;
  }
}
.insta-feed-list li a img {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  opacity: 1;
  -moz-transition: opacity 0.4s ease;
  -o-transition: opacity 0.4s ease;
  -webkit-transition: opacity 0.4s ease;
  transition: opacity 0.4s ease;
}
.insta-feed-list li a:hover img {
  opacity: .7;
}

@keyframes scroll-left {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-25%);
  }
}
/****************************************

          FOOTER
          
*****************************************/
.footer {
  text-align: center;
  background-color: var(--wt);
  font-size: 12px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--key);
}
@media screen and (min-width: 768px) {
  .footer {
    /*--- PC TAB ---*/
    padding: 90px 20px 80px;
  }
}
@media screen and (max-width: 768px) {
  .footer {
    /*--- SP ---*/
    padding: 20vw 5vw 30vw;
    margin: 10vw 0 0;
  }
}
.footer-logo {
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .footer-logo {
    /*--- PC TAB ---*/
    width: 175px;
  }
}
@media screen and (max-width: 768px) {
  .footer-logo {
    /*--- SP ---*/
    width: 40vw;
  }
}
@media screen and (min-width: 768px) {
  .footer-logo {
    transition: opacity .4s ease;
  }
  .footer-logo:hover {
    opacity: .5;
  }
}
.footer-address {
  color: inherit;
}
@media screen and (min-width: 768px) {
  .footer-address {
    /*--- PC TAB ---*/
    margin: 20px 0;
  }
}
@media screen and (max-width: 768px) {
  .footer-address {
    /*--- SP ---*/
    font-size: 2.7vw;
    margin: 4vw 0;
  }
}
@media screen and (min-width: 768px) {
  .footer-address a.tel {
    pointer-events: none;
  }
}
.footer-links {
  display: flex;
  justify-content: center;
  list-style: none;
  padding: 0;
  margin: 20px 0;
  color: inherit;
}
@media screen and (min-width: 768px) {
  .footer-links {
    /*--- PC TAB ---*/
    margin: 20px 0;
  }
}
@media screen and (max-width: 768px) {
  .footer-links {
    /*--- SP ---*/
    margin: 4vw 0;
  }
}
.footer-links li {
  position: relative;
}
.footer-links li + li::before {
  opacity: .5;
  content: "｜";
  margin: 0 0 0 5px;
}
.footer-links li a {
  text-decoration: underline;
  text-underline-offset: 3px;
}
@media screen and (min-width: 768px) {
  .footer-links li a {
    /*--- PC TAB ---*/
    font-size: 12px;
  }
}
@media screen and (max-width: 768px) {
  .footer-links li a {
    /*--- SP ---*/
    font-size: 2.7vw;
  }
}
@media screen and (min-width: 768px) {
  .footer-links li a {
    transition: opacity .4s ease;
  }
  .footer-links li a:hover {
    opacity: .5;
  }
}
.footer-copy {
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  color: inherit;
}
@media screen and (min-width: 768px) {
  .footer-copy {
    /*--- PC TAB ---*/
    font-size: 11px;
    margin-top: 20px;
  }
}
@media screen and (max-width: 768px) {
  .footer-copy {
    /*--- SP ---*/
    font-size: 2.7vw;
    margin-top: 4vw;
  }
}

.mask {
  pointer-events: none;
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
}

@media screen and (min-width: 768px) {
  section.about-message-section {
    /*--- PC TAB ---*/
    margin: 60px 0 0;
  }
}
@media screen and (max-width: 768px) {
  section.about-message-section {
    /*--- SP ---*/
    margin: 10vw 0 0;
  }
}
section.about-message-section h1.about-message-heading {
  position: relative;
  display: block;
  width: fit-content;
  margin: 0 auto;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
  line-height: 1.3;
  text-align: center;
  color: var(--key);
}
@media screen and (min-width: 768px) {
  section.about-message-section h1.about-message-heading {
    /*--- PC TAB ---*/
    padding-bottom: 10px;
    font-size: 30px;
  }
}
@media screen and (max-width: 768px) {
  section.about-message-section h1.about-message-heading {
    /*--- SP ---*/
    padding-bottom: 2vw;
    font-size: 6vw;
  }
}
section.about-message-section h1.about-message-heading::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background-color: var(--green);
}
section.about-message-section h2.about-message-sub-heading {
  color: #35387D;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
  line-height: 2;
  text-align: center;
}
@media screen and (min-width: 768px) {
  section.about-message-section h2.about-message-sub-heading {
    /*--- PC TAB ---*/
    max-width: 750px;
    margin: 30px auto 0;
    font-size: 21px;
  }
}
@media screen and (max-width: 768px) {
  section.about-message-section h2.about-message-sub-heading {
    /*--- SP ---*/
    max-width: 88vw;
    margin: 5vw auto 0;
    font-size: 4.2vw;
  }
}
section.about-message-section p.about-message-lead {
  color: #3a3c5b;
  line-height: 2;
  text-align: center;
}
@media screen and (min-width: 768px) {
  section.about-message-section p.about-message-lead {
    /*--- PC TAB ---*/
    max-width: 750px;
    margin: 30px auto 0;
    font-size: 15px;
  }
}
@media screen and (max-width: 768px) {
  section.about-message-section p.about-message-lead {
    /*--- SP ---*/
    max-width: 88vw;
    margin: 5vw auto 0;
    font-size: 3.5vw;
  }
}

section.about-scroller-section {
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  section.about-scroller-section {
    /*--- PC TAB ---*/
    padding: 50px 0 70px;
  }
}
@media screen and (max-width: 768px) {
  section.about-scroller-section {
    /*--- SP ---*/
    padding: 15vw 0 10vw;
  }
}
section.about-scroller-section .scroll-track {
  display: flex;
  width: max-content;
  animation: scroll-left 45s linear infinite;
  animation-play-state: running;
}

.about-photo-list {
  display: flex;
  list-style: none;
}
.about-photo-list li {
  display: inline-block;
  height: auto;
  aspect-ratio: 5 / 3;
  z-index: 1;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .about-photo-list li {
    /*--- PC TAB ---*/
    margin: 0 0 0 -20px;
    width: 500px;
    border-radius: 80px;
  }
}
@media screen and (max-width: 768px) {
  .about-photo-list li {
    /*--- SP ---*/
    margin: 0 0 0 -5vw;
    width: 90vw;
    border-radius: 10vw;
  }
}
.about-photo-list li img {
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

section.tama-cruiser-section h2.tama-cruiser-list-heading {
  position: relative;
  display: flex;
  align-items: center;
  width: fit-content;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
  line-height: 1.3;
  color: var(--key);
}
@media screen and (min-width: 768px) {
  section.tama-cruiser-section h2.tama-cruiser-list-heading {
    /*--- PC TAB ---*/
    margin: 60px auto 0;
    font-size: 18px;
  }
}
@media screen and (max-width: 768px) {
  section.tama-cruiser-section h2.tama-cruiser-list-heading {
    /*--- SP ---*/
    margin: 10vw auto 0;
    font-size: 4.2vw;
  }
}
section.tama-cruiser-section h2.tama-cruiser-list-heading.ico-tama::before {
  content: "";
  display: block;
  background-image: url(../img/ico_tamacruise.png);
  background-size: cover;
}
@media screen and (min-width: 768px) {
  section.tama-cruiser-section h2.tama-cruiser-list-heading.ico-tama::before {
    /*--- PC TAB ---*/
    width: 66px;
    height: 66px;
    margin-right: 20px;
  }
}
@media screen and (max-width: 768px) {
  section.tama-cruiser-section h2.tama-cruiser-list-heading.ico-tama::before {
    /*--- SP ---*/
    width: 15vw;
    height: 15vw;
    margin-right: 3.5vw;
  }
}
@media screen and (min-width: 768px) {
  section.tama-cruiser-section ul.tama-cruiser-list {
    /*--- PC TAB ---*/
    display: flex;
    flex-wrap: wrap;
    max-width: 820px;
    margin: 60px auto 0;
    gap: 30px;
  }
}
@media screen and (max-width: 768px) {
  section.tama-cruiser-section ul.tama-cruiser-list {
    /*--- SP ---*/
    width: 88vw;
    margin: 10vw auto 0;
  }
}
section.tama-cruiser-section ul.tama-cruiser-list li {
  background-color: var(--wt);
  box-sizing: border-box;
}
@media screen and (min-width: 768px) {
  section.tama-cruiser-section ul.tama-cruiser-list li {
    /*--- PC TAB ---*/
    width: calc(50% - 15px);
    padding: 25px;
    border-radius: 0 40px 40px 0;
  }
}
@media screen and (max-width: 768px) {
  section.tama-cruiser-section ul.tama-cruiser-list li {
    /*--- SP ---*/
    width: 100%;
    padding: 3.5vw;
    border-radius: 0 8vw 8vw 0;
    margin: 0 auto 4vw;
  }
}
section.tama-cruiser-section ul.tama-cruiser-list li div.item-header {
  display: flex;
  align-items: center;
}
section.tama-cruiser-section ul.tama-cruiser-list li div.item-header h3.tama-cruiser-heading {
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
  color: var(--key);
}
@media screen and (min-width: 768px) {
  section.tama-cruiser-section ul.tama-cruiser-list li div.item-header h3.tama-cruiser-heading {
    /*--- PC TAB ---*/
    font-size: 15px;
  }
}
@media screen and (max-width: 768px) {
  section.tama-cruiser-section ul.tama-cruiser-list li div.item-header h3.tama-cruiser-heading {
    /*--- SP ---*/
    font-size: 3.8vw;
  }
}
section.tama-cruiser-section ul.tama-cruiser-list li div.item-header p.position {
  color: #3a3c5b;
  margin-left: 10px;
}
@media screen and (min-width: 768px) {
  section.tama-cruiser-section ul.tama-cruiser-list li div.item-header p.position {
    /*--- PC TAB ---*/
    font-size: 12px;
  }
}
@media screen and (max-width: 768px) {
  section.tama-cruiser-section ul.tama-cruiser-list li div.item-header p.position {
    /*--- SP ---*/
    font-size: 3vw;
  }
}
section.tama-cruiser-section ul.tama-cruiser-list li p.profile {
  color: #3a3c5b;
  margin-top: 5px;
  line-height: 1.8;
}
@media screen and (min-width: 768px) {
  section.tama-cruiser-section ul.tama-cruiser-list li p.profile {
    /*--- PC TAB ---*/
    font-size: 12px;
  }
}
@media screen and (max-width: 768px) {
  section.tama-cruiser-section ul.tama-cruiser-list li p.profile {
    /*--- SP ---*/
    font-size: 3vw;
  }
}

/*============================
article
============================*/
article.entry-article section.entry-header {
  position: relative;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header {
    /*--- PC TAB ---*/
    display: flex;
    max-width: 1280px;
    margin: 0 auto 0;
    padding-left: 50px;
    padding-right: 50px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-header {
    /*--- SP ---*/
    width: 91vw;
    margin: 0 auto 10vw;
  }
}
article.entry-article section.entry-header::before {
  content: "";
  display: block;
  background: url(../img/bo2.png) top center/contain no-repeat;
  position: absolute;
  top: -1px;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header::before {
    /*--- PC TAB ---*/
    width: 8px;
    height: 738px;
    left: 42px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-header::before {
    /*--- SP ---*/
    width: 6px;
    height: calc( 100% + 2vw );
    left: -0;
  }
}
article.entry-article section.entry-header figure.article-thumbnail {
  overflow: hidden;
  z-index: 2;
  position: relative;
  aspect-ratio: 1.5 / 1;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header figure.article-thumbnail {
    /*--- PC TAB ---*/
    width: 58%;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-header figure.article-thumbnail {
    /*--- SP ---*/
    width: 100%;
  }
}
article.entry-article section.entry-header figure.article-thumbnail image {
  height: auto;
}
article.entry-article section.entry-header figure.article-thumbnail svg path {
  transform: scale(0.00084, 0.00084);
}
article.entry-article section.entry-header div.article-detail {
  display: flex;
  align-items: center;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header div.article-detail {
    /*--- PC TAB ---*/
    width: 42%;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-header div.article-detail {
    /*--- SP ---*/
    width: 100%;
    border-radius: 8vw 0 0 8vw;
  }
}
article.entry-article section.entry-header div.article-detail div.detail-inner {
  position: relative;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner {
    /*--- PC TAB ---*/
    padding: 40px 0 40px 40px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner {
    /*--- SP ---*/
    padding: 5vw 2vw 0 5vw;
  }
}
article.entry-article section.entry-header div.article-detail div.detail-inner::after {
  content: "";
  display: block;
  background-color: rgba(255, 255, 255, 0.6);
  position: absolute;
  top: 0;
  filter: blur(30px);
  will-change: filter;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner::after {
    /*--- PC TAB ---*/
    width: calc( 100% + 30px );
    height: 100%;
    border-radius: 0 30px 30px 0;
    left: -30px;
  }
}
article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta {
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta {
    /*--- PC TAB ---*/
    font-size: 12px;
    margin: 0 0 12px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta {
    /*--- SP ---*/
    font-size: 2.9vw;
    margin: 0 0 2vw;
  }
}
article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta .feature_tit {
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  margin: 0 10px 0 0;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta .feature_tit {
    /*--- PC TAB ---*/
    font-size: 16px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta .feature_tit {
    /*--- SP ---*/
    font-size: 3.5vw;
  }
}
article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta time {
  display: block;
  font-size: 12px;
  line-height: 1;
  margin: 3px 8px 3px 0;
  color: var(--key);
}
article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta ul.tags {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  margin: 3px 0 3px -3px;
}
article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta ul.tags li {
  color: #35387D;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #FFF;
  padding: 2px 12px 2px 10px;
  border-radius: 9999px;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta ul.tags li {
    /*--- PC TAB ---*/
    font-size: 11px;
    margin: 2px 6px 2px 0;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner div.detail-meta ul.tags li {
    /*--- SP ---*/
    font-size: 2.9vw;
    margin: 2px 6px 2px 0;
  }
}
article.entry-article section.entry-header div.article-detail div.detail-inner h1.article-entry-heading {
  color: #35387D;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
  margin-top: 10px;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner h1.article-entry-heading {
    /*--- PC TAB ---*/
    font-size: 24px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner h1.article-entry-heading {
    /*--- SP ---*/
    font-size: 4.5vw;
  }
}
article.entry-article section.entry-header div.article-detail div.detail-inner div.member {
  display: flex;
  align-items: center;
  margin-top: 15px;
}
article.entry-article section.entry-header div.article-detail div.detail-inner div.member .ico-tama::before {
  content: "";
  display: block;
  background: url(../img/ico_tamacruise.png) center center/contain no-repeat;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner div.member .ico-tama::before {
    /*--- PC TAB ---*/
    width: 50px;
    height: 50px;
    margin: 0 10px 0 -5px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-header div.article-detail div.detail-inner div.member .ico-tama::before {
    /*--- SP ---*/
    width: 10vw;
    height: 10vw;
    margin: 0 2vw 0 -1vw;
  }
}
article.entry-article section.entry-header div.article-detail div.detail-inner div.member p {
  color: #3a3c5b;
  font-size: 11px;
}
article.entry-article section.entry-meta-section {
  color: #35387D;
  max-width: 640px;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-meta-section {
    width: 100%;
    margin: 50px auto;
    font-size: 16px;
    padding: 30px 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: center;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-meta-section {
    font-size: 3.5vw;
    padding: 6vw 0;
    margin: 10vw 6vw;
  }
}
article.entry-article section.entry-meta-section .member {
  color: #35387D;
  font-size: 12px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-meta-section .member {
    /*--- PC TAB ---*/
    margin: 5px 15px 5px 0;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-meta-section .member {
    /*--- SP ---*/
    margin: 0 0 4vw;
  }
}
article.entry-article section.entry-meta-section .member .ico-tama {
  background: url(../img/ico_tamacruise.png) center center/contain no-repeat;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-meta-section .member .ico-tama {
    /*--- PC TAB ---*/
    width: 50px;
    height: 50px;
    margin: 0 10px 0 -5px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-meta-section .member .ico-tama {
    /*--- SP ---*/
    width: 10vw;
    height: 10vw;
    margin: 0 2vw 0 -1vw;
  }
}
article.entry-article section.entry-meta-section .tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-size: 12px;
  letter-spacing: .05em;
  margin: 5px 0 5px -3px;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-meta-section .tags {
    /*--- PC TAB ---*/
    justify-content: center;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-meta-section .tags {
    /*--- SP ---*/
    justify-content: flex-start;
  }
}
article.entry-article section.entry-meta-section .tags li {
  margin: 3px;
  line-height: 1.5;
}
article.entry-article section.entry-meta-section .tags li a {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #FFF;
  padding: 2px 12px 2px 10px;
  border-radius: 9999px;
  -moz-transition: color 0.4s ease, background-color 0.4s ease;
  -o-transition: color 0.4s ease, background-color 0.4s ease;
  -webkit-transition: color 0.4s ease, background-color 0.4s ease;
  transition: color 0.4s ease, background-color 0.4s ease;
}
article.entry-article section.entry-meta-section .tags li a:hover {
  color: #FFF;
  background-color: #35387D;
}
article.entry-article section.profile-section {
  color: #35387D;
  max-width: 640px;
}
@media screen and (min-width: 768px) {
  article.entry-article section.profile-section {
    width: 100%;
    margin: 50px auto;
    font-size: 16px;
    padding: 0 0;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.profile-section {
    font-size: 3.5vw;
    margin: 0 20px;
  }
}
article.entry-article section.profile-section .profile-block {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
@media screen and (min-width: 768px) {
  article.entry-article section.profile-section .profile-block {
    margin: 0 0 30px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.profile-section .profile-block {
    margin: 0 0 6vw;
  }
}
article.entry-article section.profile-section .profile-block:last-child {
  margin-bottom: 0;
}
article.entry-article section.profile-section .profile-block figure {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  article.entry-article section.profile-section .profile-block figure {
    width: 200px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.profile-section .profile-block figure {
    width: 35%;
  }
}
article.entry-article section.profile-section .profile-block figure img {
  border-radius: 5px;
}
article.entry-article section.profile-section .profile-block .profile-detail {
  text-align: left;
}
@media screen and (min-width: 768px) {
  article.entry-article section.profile-section .profile-block .profile-detail {
    width: calc( 100% - 230px );
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.profile-section .profile-block .profile-detail {
    width: 65%;
    padding-left: 3vw;
  }
}
article.entry-article section.profile-section .profile-block .profile-detail .profile-heading {
  color: rgba(0, 0, 0, 0.8);
  font-size: 14px;
  line-height: 1.5;
  margin: 0 0 8px;
}
article.entry-article section.profile-section .profile-block .profile-detail .pforile-text {
  color: rgba(0, 0, 0, 0.6);
  font-size: 11px;
  line-height: 1.5;
}
article.entry-article section.profile-section .profile-block .profile-detail .pforile-text p {
  margin: 0 0 5px;
}
article.entry-article section.profile-section .profile-block .profile-detail .pforile-text p:last-child {
  margin-bottom: 0;
}
article.entry-article section.profile-section .profile-block .profile-detail .pforile-text p a {
  color: #35387D;
  text-decoration: underline;
  -moz-transition: color 0.4s ease;
  -o-transition: color 0.4s ease;
  -webkit-transition: color 0.4s ease;
  transition: color 0.4s ease;
}
article.entry-article section.profile-section .profile-block .profile-detail .pforile-text p a:hover {
  color: #999;
}
article.entry-article section.entry-section {
  color: #3a3c5b;
  max-width: 800px;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-section {
    margin: 80px auto;
    font-size: 15px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section {
    font-size: 3.5vw;
    margin: 0 20px;
  }
}
article.entry-article section.entry-section h1,
article.entry-article section.entry-section h2,
article.entry-article section.entry-section h3,
article.entry-article section.entry-section h4,
article.entry-article section.entry-section h5,
article.entry-article section.entry-section h6,
article.entry-article section.entry-section p,
article.entry-article section.entry-section ul,
article.entry-article section.entry-section ol,
article.entry-article section.entry-section figcaption,
article.entry-article section.entry-section .btn_wrap,
article.entry-article section.entry-section .wp-block-table,
article.entry-article section.entry-section .wp-block-embed,
article.entry-article section.entry-section .wp-block-quote,
article.entry-article section.entry-section .wp-block-preformatted {
  clear: both;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}
#contents.page-about article.entry-article section.entry-section h1, #contents.page-about
article.entry-article section.entry-section h2, #contents.page-about
article.entry-article section.entry-section h3, #contents.page-about
article.entry-article section.entry-section h4, #contents.page-about
article.entry-article section.entry-section h5, #contents.page-about
article.entry-article section.entry-section h6, #contents.page-about
article.entry-article section.entry-section p, #contents.page-about
article.entry-article section.entry-section ul, #contents.page-about
article.entry-article section.entry-section ol, #contents.page-about
article.entry-article section.entry-section figcaption, #contents.page-about
article.entry-article section.entry-section .btn_wrap, #contents.page-about
article.entry-article section.entry-section .wp-block-table, #contents.page-about
article.entry-article section.entry-section .wp-block-embed, #contents.page-about
article.entry-article section.entry-section .wp-block-quote, #contents.page-about
article.entry-article section.entry-section .wp-block-preformatted {
  max-width: 600px;
}
article.entry-article section.entry-section h1:first-child,
article.entry-article section.entry-section h2:first-child,
article.entry-article section.entry-section h3:first-child,
article.entry-article section.entry-section h4:first-child,
article.entry-article section.entry-section h5:first-child,
article.entry-article section.entry-section h6:first-child,
article.entry-article section.entry-section p:first-child,
article.entry-article section.entry-section ul:first-child,
article.entry-article section.entry-section ol:first-child,
article.entry-article section.entry-section figcaption:first-child,
article.entry-article section.entry-section .btn_wrap:first-child,
article.entry-article section.entry-section .wp-block-table:first-child,
article.entry-article section.entry-section .wp-block-embed:first-child,
article.entry-article section.entry-section .wp-block-quote:first-child,
article.entry-article section.entry-section .wp-block-preformatted:first-child {
  margin-top: 0;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section h1,
  article.entry-article section.entry-section h2,
  article.entry-article section.entry-section h3,
  article.entry-article section.entry-section h4,
  article.entry-article section.entry-section h5,
  article.entry-article section.entry-section h6,
  article.entry-article section.entry-section p,
  article.entry-article section.entry-section ul,
  article.entry-article section.entry-section ol,
  article.entry-article section.entry-section figcaption,
  article.entry-article section.entry-section .btn_wrap,
  article.entry-article section.entry-section .wp-block-table,
  article.entry-article section.entry-section .wp-block-embed,
  article.entry-article section.entry-section .wp-block-quote,
  article.entry-article section.entry-section .wp-block-preformatted {
    /*--- SP ---*/
    width: 88vw;
  }
}
article.entry-article section.entry-section h1.has-text-align-center,
article.entry-article section.entry-section h2.has-text-align-center,
article.entry-article section.entry-section h3.has-text-align-center,
article.entry-article section.entry-section h4.has-text-align-center,
article.entry-article section.entry-section h5.has-text-align-center,
article.entry-article section.entry-section h6.has-text-align-center,
article.entry-article section.entry-section p.has-text-align-center,
article.entry-article section.entry-section ul.has-text-align-center,
article.entry-article section.entry-section ol.has-text-align-center,
article.entry-article section.entry-section figcaption.has-text-align-center,
article.entry-article section.entry-section .btn_wrap.has-text-align-center,
article.entry-article section.entry-section .wp-block-table.has-text-align-center,
article.entry-article section.entry-section .wp-block-embed.has-text-align-center,
article.entry-article section.entry-section .wp-block-quote.has-text-align-center,
article.entry-article section.entry-section .wp-block-preformatted.has-text-align-center {
  text-align: center;
}
article.entry-article section.entry-section h1.has-text-align-right,
article.entry-article section.entry-section h2.has-text-align-right,
article.entry-article section.entry-section h3.has-text-align-right,
article.entry-article section.entry-section h4.has-text-align-right,
article.entry-article section.entry-section h5.has-text-align-right,
article.entry-article section.entry-section h6.has-text-align-right,
article.entry-article section.entry-section p.has-text-align-right,
article.entry-article section.entry-section ul.has-text-align-right,
article.entry-article section.entry-section ol.has-text-align-right,
article.entry-article section.entry-section figcaption.has-text-align-right,
article.entry-article section.entry-section .btn_wrap.has-text-align-right,
article.entry-article section.entry-section .wp-block-table.has-text-align-right,
article.entry-article section.entry-section .wp-block-embed.has-text-align-right,
article.entry-article section.entry-section .wp-block-quote.has-text-align-right,
article.entry-article section.entry-section .wp-block-preformatted.has-text-align-right {
  text-align: right;
}
article.entry-article section.entry-section h1.has-text-align-left,
article.entry-article section.entry-section h2.has-text-align-left,
article.entry-article section.entry-section h3.has-text-align-left,
article.entry-article section.entry-section h4.has-text-align-left,
article.entry-article section.entry-section h5.has-text-align-left,
article.entry-article section.entry-section h6.has-text-align-left,
article.entry-article section.entry-section p.has-text-align-left,
article.entry-article section.entry-section ul.has-text-align-left,
article.entry-article section.entry-section ol.has-text-align-left,
article.entry-article section.entry-section figcaption.has-text-align-left,
article.entry-article section.entry-section .btn_wrap.has-text-align-left,
article.entry-article section.entry-section .wp-block-table.has-text-align-left,
article.entry-article section.entry-section .wp-block-embed.has-text-align-left,
article.entry-article section.entry-section .wp-block-quote.has-text-align-left,
article.entry-article section.entry-section .wp-block-preformatted.has-text-align-left {
  text-align: left;
}
article.entry-article section.entry-section h1,
article.entry-article section.entry-section h2,
article.entry-article section.entry-section h3,
article.entry-article section.entry-section h4,
article.entry-article section.entry-section h5,
article.entry-article section.entry-section h6 {
  color: #35387D;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
}
article.entry-article section.entry-section h1 {
  font-size: 24px;
  letter-spacing: .02em;
  line-height: 1.7;
  margin-top: 40px;
  margin-bottom: 20px;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: auto;
}
.en article.entry-article section.entry-section h1 {
  letter-spacing: 0.03em;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section h1 {
    /*--- SP ---*/
    font-size: 4.6vw;
    margin-top: 8vw;
    margin-bottom: 4vw;
  }
}
article.entry-article section.entry-section h2,
article.entry-article section.entry-section h3 {
  font-size: 20px;
  letter-spacing: 0.02em;
  line-height: 1.7;
  margin-top: 40px;
  margin-bottom: 15px;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: auto;
}
.en article.entry-article section.entry-section h2, .en
article.entry-article section.entry-section h3 {
  letter-spacing: 0.03em;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section h2,
  article.entry-article section.entry-section h3 {
    /*--- SP ---*/
    font-size: 4.6vw;
    margin-top: 8vw;
    margin-bottom: 4vw;
  }
}
article.entry-article section.entry-section h4 {
  font-size: 18px;
  letter-spacing: 0.02em;
  line-height: 1.7;
  margin-top: 40px;
  margin-bottom: 15px;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: auto;
}
.en article.entry-article section.entry-section h4 {
  letter-spacing: 0.03em;
}
#specific_trade_law article.entry-article section.entry-section h4 {
  font-size: 18px;
  padding-top: 50px;
  margin-top: 50px;
  border-top: 2px solid #EEE;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section h4 {
    /*--- SP ---*/
    font-size: 4.3vw;
    margin-top: 8vw;
    margin-bottom: 4vw;
  }
  #specific_trade_law article.entry-article section.entry-section h4 {
    font-size: 14px;
    margin-top: 6.5vw;
    padding-top: 6.5vw;
    margin-bottom: 3.5vw;
  }
}
article.entry-article section.entry-section h5,
article.entry-article section.entry-section h6 {
  font-size: 16px;
  letter-spacing: 0.02em;
  line-height: 1.7;
  margin-top: 40px;
  margin-bottom: 15px;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: auto;
}
.en article.entry-article section.entry-section h5, .en
article.entry-article section.entry-section h6 {
  letter-spacing: 0.03em;
}
.site-policy article.entry-article section.entry-section h5, .privacy-policy article.entry-article section.entry-section h5, .site-policy
article.entry-article section.entry-section h6, .privacy-policy
article.entry-article section.entry-section h6 {
  font-size: 15px;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section h5,
  article.entry-article section.entry-section h6 {
    /*--- SP ---*/
    font-size: 3.5vw;
    margin-top: 8vw;
    margin-bottom: 4vw;
  }
}
article.entry-article section.entry-section p {
  color: #3a3c5b;
  font-size: 15px;
  letter-spacing: 0.02em;
  line-height: 2;
  text-align: justify;
  margin-top: 20px;
  margin-bottom: 20px;
  min-height: 16px;
}
article.entry-article section.entry-section p.has-medium-font-size {
  font-size: 16px !important;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section p.has-medium-font-size {
    /*--- SP ---*/
    font-size: 3.5vw !important;
  }
}
article.entry-article section.entry-section p.has-small-font-size {
  font-size: 90% !important;
  margin-top: 20px;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section p.has-small-font-size {
    /*--- SP ---*/
    font-size: 90% !important;
    margin-top: 4.5vw;
    margin-bottom: 4.5vw;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section p {
    /*--- SP ---*/
    font-size: 3.5vw;
    margin-top: 4vw;
    margin-bottom: 4vw;
  }
}
article.entry-article section.entry-section p em,
article.entry-article section.entry-section p i {
  font-style: italic;
}
article.entry-article section.entry-section p.red {
  color: #e74c3c;
}
article.entry-article section.entry-section p:empty {
  display: none;
}
article.entry-article section.entry-section p a {
  color: #35387D;
  width: fit-content;
  position: relative;
  overflow: hidden;
  -moz-transition: all 0.6s ease;
  -o-transition: all 0.6s ease;
  -webkit-transition: all 0.6s ease;
  transition: all 0.6s ease;
}
article.entry-article section.entry-section p a::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #000;
  position: absolute;
  bottom: -1px;
  right: 0;
  will-change: width, background-color;
  -moz-transition: width 0.6s ease, background-color 0.6s ease;
  -o-transition: width 0.6s ease, background-color 0.6s ease;
  -webkit-transition: width 0.6s ease, background-color 0.6s ease;
  transition: width 0.6s ease, background-color 0.6s ease;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5) {
  article.entry-article section.entry-section p a::before {
    height: .5px;
  }
}
article.entry-article section.entry-section p a::after {
  content: "";
  display: block;
  width: 0;
  height: 1px;
  background-color: #AAA;
  position: absolute;
  bottom: -1px;
  left: 0;
  z-index: 1;
  will-change: width, background-color;
  -moz-transition: width 0.6s ease, background-color 0.6s ease;
  -o-transition: width 0.6s ease, background-color 0.6s ease;
  -webkit-transition: width 0.6s ease, background-color 0.6s ease;
  transition: width 0.6s ease, background-color 0.6s ease;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5) {
  article.entry-article section.entry-section p a::after {
    height: .5px;
  }
}
@media (hover: hover) {
  article.entry-article section.entry-section p a:hover {
    color: #AAA;
  }
  article.entry-article section.entry-section p a:hover::before {
    width: 0%;
  }
  article.entry-article section.entry-section p a:hover::after {
    width: 100%;
  }
}
@media (hover: none) {
  article.entry-article section.entry-section p a:active {
    color: #AAA;
  }
  article.entry-article section.entry-section p a:active::before {
    width: 0%;
  }
  article.entry-article section.entry-section p a:active::after {
    width: 100%;
  }
}
article.entry-article section.entry-section hr {
  clear: both;
  max-width: 700px;
  margin: 40px auto;
  border-top: 1px solid #CCC;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5) {
  article.entry-article section.entry-section hr {
    border-width: .5px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section hr {
    /*--- SP ---*/
    margin-top: 6vw;
    margin-bottom: 6vw;
  }
}
article.entry-article section.entry-section ul,
article.entry-article section.entry-section ol {
  clear: both;
  margin-top: 15px;
  margin-bottom: 15px;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section ul,
  article.entry-article section.entry-section ol {
    /*--- SP ---*/
    margin-top: 6vw;
    margin-bottom: 6vw;
  }
}
article.entry-article section.entry-section ul li,
article.entry-article section.entry-section ol li {
  font-size: 13px;
  line-height: 1.6;
  margin: 15px 0 15px 15px;
  width: fit-content;
  position: relative;
}
article.entry-article section.entry-section ul li:first-child,
article.entry-article section.entry-section ol li:first-child {
  margin-top: 0;
}
article.entry-article section.entry-section ul li:last-child,
article.entry-article section.entry-section ol li:last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section ul li,
  article.entry-article section.entry-section ol li {
    /*--- SP ---*/
    font-size: 12px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section ul li,
  article.entry-article section.entry-section ol li {
    /*--- SP ---*/
    font-size: 3.5vw;
    margin-top: 3vw;
    margin-bottom: 3vw;
    margin-left: 22px;
  }
}
article.entry-article section.entry-section ul li::before,
article.entry-article section.entry-section ol li::before {
  content: "";
  display: block;
  width: 7px;
  height: 1px;
  background-color: #000;
  position: absolute;
  top: 9px;
  left: -14px;
  will-change: width, background-color;
  -moz-transition: width 0.6s ease, background-color 0.6s ease;
  -o-transition: width 0.6s ease, background-color 0.6s ease;
  -webkit-transition: width 0.6s ease, background-color 0.6s ease;
  transition: width 0.6s ease, background-color 0.6s ease;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5) {
  article.entry-article section.entry-section ul li::before,
  article.entry-article section.entry-section ol li::before {
    height: .5px;
  }
}
article.entry-article section.entry-section ul li::after,
article.entry-article section.entry-section ol li::after {
  content: "";
  display: block;
  width: 0;
  height: 1px;
  background-color: #AAA;
  position: absolute;
  bottom: -1px;
  left: 0;
  z-index: 1;
  will-change: width, background-color;
  -moz-transition: width 0.6s ease, background-color 0.6s ease;
  -o-transition: width 0.6s ease, background-color 0.6s ease;
  -webkit-transition: width 0.6s ease, background-color 0.6s ease;
  transition: width 0.6s ease, background-color 0.6s ease;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5) {
  article.entry-article section.entry-section ul li::after,
  article.entry-article section.entry-section ol li::after {
    height: .5px;
  }
}
article.entry-article section.entry-section ul li a,
article.entry-article section.entry-section ol li a {
  color: #35387D;
  width: fit-content;
  position: relative;
  overflow: hidden;
  -moz-transition: all 0.6s ease;
  -o-transition: all 0.6s ease;
  -webkit-transition: all 0.6s ease;
  transition: all 0.6s ease;
}
article.entry-article section.entry-section ul li a::before,
article.entry-article section.entry-section ol li a::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #000;
  position: absolute;
  bottom: -1px;
  right: 0;
  will-change: width, background-color;
  -moz-transition: width 0.6s ease, background-color 0.6s ease;
  -o-transition: width 0.6s ease, background-color 0.6s ease;
  -webkit-transition: width 0.6s ease, background-color 0.6s ease;
  transition: width 0.6s ease, background-color 0.6s ease;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5) {
  article.entry-article section.entry-section ul li a::before,
  article.entry-article section.entry-section ol li a::before {
    height: .5px;
  }
}
article.entry-article section.entry-section ul li a::after,
article.entry-article section.entry-section ol li a::after {
  content: "";
  display: block;
  width: 0;
  height: 1px;
  background-color: #AAA;
  position: absolute;
  bottom: -1px;
  left: 0;
  z-index: 1;
  will-change: width, background-color;
  -moz-transition: width 0.6s ease, background-color 0.6s ease;
  -o-transition: width 0.6s ease, background-color 0.6s ease;
  -webkit-transition: width 0.6s ease, background-color 0.6s ease;
  transition: width 0.6s ease, background-color 0.6s ease;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5) {
  article.entry-article section.entry-section ul li a::after,
  article.entry-article section.entry-section ol li a::after {
    height: .5px;
  }
}
@media (hover: hover) {
  article.entry-article section.entry-section ul li a:hover,
  article.entry-article section.entry-section ol li a:hover {
    color: #AAA;
  }
  article.entry-article section.entry-section ul li a:hover::before,
  article.entry-article section.entry-section ol li a:hover::before {
    width: 0%;
  }
  article.entry-article section.entry-section ul li a:hover::after,
  article.entry-article section.entry-section ol li a:hover::after {
    width: 100%;
  }
}
@media (hover: none) {
  article.entry-article section.entry-section ul li a:active,
  article.entry-article section.entry-section ol li a:active {
    color: #AAA;
  }
  article.entry-article section.entry-section ul li a:active::before,
  article.entry-article section.entry-section ol li a:active::before {
    width: 0%;
  }
  article.entry-article section.entry-section ul li a:active::after,
  article.entry-article section.entry-section ol li a:active::after {
    width: 100%;
  }
}
article.entry-article section.entry-section ul li {
  list-style-type: none;
}
article.entry-article section.entry-section ol li {
  list-style-type: decimal;
  padding-left: 10px;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section ol li {
    /*--- SP ---*/
    padding-left: 8px;
  }
}
article.entry-article section.entry-section strong {
  font-weight: 600;
}
article.entry-article section.entry-section sup {
  font-size: 75.5%;
  vertical-align: top;
  position: relative;
  top: -0.1em;
}
article.entry-article section.entry-section .wp-block-image {
  width: 100%;
  max-width: 800px;
  clear: both;
  margin: 40px auto;
  text-align: center;
  opacity: 0;
  -moz-transform: translate(0, 10px);
  -ms-transform: translate(0, 10px);
  -webkit-transform: translate(0, 10px);
  transform: translate(0, 10px);
  will-change: opacity, transform;
  -moz-transition: opacity 0.5s ease, -moz-transform 0.5s ease;
  -o-transition: opacity 0.5s ease, -o-transform 0.5s ease;
  -webkit-transition: opacity 0.5s ease, -webkit-transform 0.5s ease;
  transition: opacity 0.5s ease, transform 0.5s ease;
}
article.entry-article section.entry-section .wp-block-image.active {
  opacity: 1;
  -moz-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}
article.entry-article section.entry-section .wp-block-image.right {
  width: 80%;
  float: right;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .wp-block-image.right {
    /*--- SP ---*/
    width: 90%;
  }
}
article.entry-article section.entry-section .wp-block-image.left {
  width: 80%;
  float: left;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .wp-block-image.left {
    /*--- SP ---*/
    width: 90%;
  }
}
article.entry-article section.entry-section .wp-block-image figcaption {
  color: #777;
  font-size: 11px;
  line-height: 1.6;
  padding-top: 15px;
  text-align: center;
}
article.entry-article section.entry-section .wp-block-image figcaption em {
  font-style: italic;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .wp-block-image {
    /*--- SP ---*/
    margin-top: 7vw;
    margin-bottom: 7vw;
  }
  article.entry-article section.entry-section .wp-block-image figcaption {
    font-size: 10px;
    padding-top: 5px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}
article.entry-article section.entry-section .wp-block-image img {
  border-radius: 5px;
  margin-left: auto;
  margin-right: auto;
}
article.entry-article section.entry-section .wp-block-image img.v {
  max-width: 640px;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-section .wp-block-image img.v {
    /*--- PC TAB ---*/
    max-width: 640px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .wp-block-image img.v {
    /*--- SP ---*/
    max-width: 88vw;
  }
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-section > .wp-block-image {
    /*--- PC TAB ---*/
    margin: 40px auto 40px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section > .wp-block-image {
    /*--- SP ---*/
    margin: 7vw auto 7vw;
  }
}
article.entry-article section.entry-section .wp-block-gallery {
  clear: both;
  max-width: 1200px;
  margin: 40px auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
}
article.entry-article section.entry-section .wp-block-gallery .wp-block-image {
  margin: 10px 0;
}
article.entry-article section.entry-section .wp-block-gallery.columns-2 {
  max-width: 1200px;
}
article.entry-article section.entry-section .wp-block-gallery.columns-2 .wp-block-image {
  width: calc( 50% - 10px );
  margin: 7px 0;
}
article.entry-article section.entry-section .wp-block-gallery.columns-3 {
  max-width: 1400px;
}
article.entry-article section.entry-section .wp-block-gallery.columns-3::after {
  content: "";
  display: block;
  width: calc( 33.3333% - 10px );
  margin: 4px 0;
}
article.entry-article section.entry-section .wp-block-gallery.columns-3 .wp-block-image {
  width: calc( 33.3333% - 10px );
  margin: 4px 0;
}
article.entry-article section.entry-section .wp-block-quote {
  clear: both;
  margin: 25px auto;
  max-width: 640px;
  border-left: 1px solid rgba(0, 0, 0, 0.2);
  padding: 5px 0 5px 22px;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5) {
  article.entry-article section.entry-section .wp-block-quote {
    border-width: .5px;
  }
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-section .wp-block-quote p {
    /*--- PC TAB ---*/
    font-size: 12px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .wp-block-quote p {
    /*--- SP ---*/
    font-size: 3.2vw;
  }
}
article.entry-article section.entry-section .wp-block-quote p:last-child {
  margin-bottom: 0;
}
article.entry-article section.entry-section .video_wrapper {
  clear: both;
  margin: 60px auto;
}
.article-template-single-article-photo article.entry-article section.entry-section .video_wrapper {
  opacity: 0;
  -moz-transform: translate(0, 10px);
  -ms-transform: translate(0, 10px);
  -webkit-transform: translate(0, 10px);
  transform: translate(0, 10px);
  will-change: opacity, transform;
  -moz-transition: opacity 0.5s ease, -moz-transform 0.5s ease;
  -o-transition: opacity 0.5s ease, -o-transform 0.5s ease;
  -webkit-transition: opacity 0.5s ease, -webkit-transform 0.5s ease;
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.article-template-single-article-photo article.entry-article section.entry-section .video_wrapper.scl_on {
  opacity: 1;
  -moz-transform: translate(0, 0);
  -ms-transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .video_wrapper {
    /*--- SP ---*/
    margin-top: 7vw;
    margin-bottom: 7vw;
  }
}
article.entry-article section.entry-section .video_wrapper video {
  width: 100%;
  outline: none;
}
article.entry-article section.entry-section .video_wrapper p {
  color: #777;
  font-size: 11px;
  margin: 15px auto 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .video_wrapper p {
    /*--- SP ---*/
    font-size: 10px;
    margin: 10px auto 0;
  }
}
article.entry-article section.entry-section .wp-block-embed-youtube {
  clear: both;
  position: relative;
  padding-bottom: 56.25%;
  /*アスペクト比 16:9の場合の縦幅*/
  height: 0;
  overflow: hidden;
  margin: 60px auto;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .wp-block-embed-youtube {
    /*--- SP ---*/
    margin-top: 7vw;
    margin-bottom: 7vw;
  }
}
article.entry-article section.entry-section .wp-block-embed-youtube figcaption {
  color: #777;
  font-size: 12px;
  line-height: 1.6;
  padding-top: 15px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .wp-block-embed-youtube {
    /*--- SP ---*/
    margin-top: 7vw;
    margin-bottom: 7vw;
  }
  article.entry-article section.entry-section .wp-block-embed-youtube figcaption {
    font-size: 10px;
    padding-top: 12px;
  }
}
article.entry-article section.entry-section .wp-block-embed-youtube iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
article.entry-article section.entry-section .wp-block-table {
  background-color: #35387D;
}
article.entry-article section.entry-section .wp-block-table td {
  padding: 20px;
  border: 2px solid #FFF;
  min-width: 120px;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .wp-block-table td {
    /*--- SP ---*/
    min-width: 100px;
    padding: 15px;
  }
}
article.entry-article section.entry-section .wp-block-table td small {
  color: #333;
  font-size: 12px;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .wp-block-table td small {
    /*--- SP ---*/
    font-size: 10px;
  }
}
article.entry-article section.entry-section .wp-block-table td.price {
  text-align: center;
}
article.entry-article section.entry-section .youtube {
  clear: both;
  position: relative;
  padding-bottom: 56.25%;
  /*アスペクト比 16:9の場合の縦幅*/
  height: 0;
  overflow: hidden;
  margin: 60px auto;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .youtube {
    /*--- SP ---*/
    margin-top: 7vw;
    margin-bottom: 7vw;
  }
}
article.entry-article section.entry-section .youtube figcaption {
  color: #777;
  font-size: 12px;
  line-height: 1.6;
  padding-top: 15px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .youtube {
    /*--- SP ---*/
    margin-top: 7vw;
    margin-bottom: 7vw;
  }
  article.entry-article section.entry-section .youtube figcaption {
    font-size: 10px;
    padding-top: 12px;
  }
}
article.entry-article section.entry-section .youtube iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
article.entry-article section.entry-section .col {
  clear: both;
  font-size: 13px;
  line-height: 2;
  background-color: #35387D;
  padding: 30px;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .col {
    /*--- SP ---*/
    width: 100%;
    font-size: 11px;
    padding: 4.5vw;
  }
}
article.entry-article section.entry-section .btn_wrap {
  position: relative;
  left: -5px;
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .btn_wrap {
    /*--- SP ---*/
  }
}
article.entry-article section.entry-section .btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: fit-content;
  margin: 0 0 0;
  position: relative;
  border: 1px solid rgba(0, 0, 0, 0.3);
  border-radius: 9999px;
  color: #000;
  letter-spacing: .05em;
  line-height: 1;
  background-color: transparent;
  opacity: 1;
  -moz-transition: color 0.4s ease, padding 0.4s ease, border-color 0.4s ease, background-color 0.4s ease;
  -o-transition: color 0.4s ease, padding 0.4s ease, border-color 0.4s ease, background-color 0.4s ease;
  -webkit-transition: color 0.4s ease, padding 0.4s ease, border-color 0.4s ease, background-color 0.4s ease;
  transition: color 0.4s ease, padding 0.4s ease, border-color 0.4s ease, background-color 0.4s ease;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5) {
  article.entry-article section.entry-section .btn {
    border-width: .5px;
  }
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-section .btn {
    /*--- PC TAB ---*/
    font-size: 13px;
    padding: 15px 40px 15px 20px;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .btn {
    /*--- SP ---*/
    font-size: 3vw;
    padding: 3vw 4vw;
    margin: 0 2vw;
  }
}
@media (hover: hover) {
  article.entry-article section.entry-section .btn:hover {
    color: #000;
    border-color: #000;
    background-color: #FFF;
    padding: 15px 44px 15px 20px;
  }
  article.entry-article section.entry-section .btn:hover span::after {
    right: 15px;
  }
}
@media (hover: none) {
  article.entry-article section.entry-section .btn:active {
    color: #000;
    border-color: #000;
    background-color: #FFF;
    padding: 15px 44px 15px 20px;
  }
  article.entry-article section.entry-section .btn:active span::after {
    right: 15px;
  }
}
article.entry-article section.entry-section .btn span {
  display: flex;
  justify-content: center;
  align-items: center;
}
article.entry-article section.entry-section .btn span::after {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  margin: 0;
  position: absolute;
  right: 17px;
  z-index: 2;
  background: url(../img/arrow-r.svg) center center/contain no-repeat;
  will-change: opacity, right;
  -moz-transition: opacity 0.4s ease, right 0.4s ease;
  -o-transition: opacity 0.4s ease, right 0.4s ease;
  -webkit-transition: opacity 0.4s ease, right 0.4s ease;
  transition: opacity 0.4s ease, right 0.4s ease;
}
article.entry-article section.entry-section .embed_article {
  clear: both;
  width: 100%;
  max-width: 700px;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-section .embed_article {
    /*--- PC TAB ---*/
    margin: 50px auto;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .embed_article {
    /*--- SP ---*/
    margin: 7vw auto;
  }
}
article.entry-article section.entry-section .embed_article article {
  width: 100%;
  padding: 20px;
  background-color: #35387D;
}
@media screen and (min-width: 768px) {
  article.entry-article section.entry-section .embed_article article {
    /*--- PC TAB ---*/
    margin-bottom: 20px;
  }
  article.entry-article section.entry-section .embed_article article:last-child {
    margin-bottom: 0;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .embed_article article {
    /*--- SP ---*/
    margin-bottom: 15px;
  }
}
article.entry-article section.entry-section .embed_article article:last-child {
  margin-bottom: 0;
}
article.entry-article section.entry-section .embed_article article a {
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
}
@media (hover: hover) {
  article.entry-article section.entry-section .embed_article article a:hover figure::before {
    opacity: 1;
    -moz-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  article.entry-article section.entry-section .embed_article article a:hover figure::after {
    opacity: 0.5;
  }
  article.entry-article section.entry-section .embed_article article a:hover .txt {
    color: #35387D;
  }
  article.entry-article section.entry-section .embed_article article a:hover .txt .date_category {
    color: #35387D;
  }
}
@media (hover: none) {
  article.entry-article section.entry-section .embed_article article a:active figure::before {
    opacity: 1;
    -moz-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  article.entry-article section.entry-section .embed_article article a:active figure::after {
    opacity: 0.5;
  }
  article.entry-article section.entry-section .embed_article article a:active .txt {
    color: #35387D;
  }
  article.entry-article section.entry-section .embed_article article a:active .txt .date_category {
    color: #35387D;
  }
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .embed_article article a {
    /*--- SP ---*/
    align-items: flex-start;
  }
}
article.entry-article section.entry-section .embed_article article a figure {
  width: 200px;
  position: relative;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .embed_article article a figure {
    /*--- SP ---*/
    width: 40%;
  }
}
article.entry-article section.entry-section .embed_article article a figure::before {
  color: #FFF;
  content: "READ MORE";
  display: flex;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.08em;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  z-index: 2;
  -moz-transform: translate(0, 5px);
  -ms-transform: translate(0, 5px);
  -webkit-transform: translate(0, 5px);
  transform: translate(0, 5px);
  -moz-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  -o-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}
article.entry-article section.entry-section .embed_article article a figure::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  background-color: #35387D;
  z-index: 1;
  mix-blend-mode: multiply;
  -moz-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  -o-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}
article.entry-article section.entry-section .embed_article article a .txt {
  color: #000;
  width: calc( 100% - 220px );
  font-weight: 600;
  letter-spacing: 0.08em;
  -moz-transition: color 0.4s ease;
  -o-transition: color 0.4s ease;
  -webkit-transition: color 0.4s ease;
  transition: color 0.4s ease;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .embed_article article a .txt {
    /*--- SP ---*/
    width: 60%;
    padding-left: 15px;
  }
}
article.entry-article section.entry-section .embed_article article a .txt .date_category {
  color: #999;
  font-size: 10px;
  line-height: 1;
  min-height: 10px;
  margin: 5px 0 0;
  -moz-transition: color 0.4s ease;
  -o-transition: color 0.4s ease;
  -webkit-transition: color 0.4s ease;
  transition: color 0.4s ease;
}
article.entry-article section.entry-section .embed_article article a .txt .date_category span {
  display: inline-block;
  margin: 5px 7px 0 0;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .embed_article article a .txt .date_category {
    /*--- SP ---*/
    width: 100%;
    font-size: 10px;
    margin: 2px 0 0;
  }
  article.entry-article section.entry-section .embed_article article a .txt .date_category span {
    display: inline-block;
    margin: 5px 7px 0 0;
  }
}
article.entry-article section.entry-section .embed_article article a .txt .subtitle {
  font-size: 13px;
  letter-spacing: 0.05em;
  line-height: 1;
  margin: 0 0 8px;
}
.en article.entry-article section.entry-section .embed_article article a .txt .subtitle {
  letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .embed_article article a .txt .subtitle {
    /*--- SP ---*/
    width: 100%;
    font-size: 11px;
    letter-spacing: 0.04em;
  }
  .en article.entry-article section.entry-section .embed_article article a .txt .subtitle {
    letter-spacing: 0.02em;
  }
}
article.entry-article section.entry-section .embed_article article a .txt h3 {
  font-size: 13px;
  letter-spacing: 0.05em;
  line-height: 1.6;
  margin: 0;
}
.en article.entry-article section.entry-section .embed_article article a .txt h3 {
  letter-spacing: 0.02em;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .embed_article article a .txt h3 {
    /*--- SP ---*/
    width: 100%;
    font-size: 12px;
    letter-spacing: 0.04em;
    line-height: 1.5;
  }
  .en article.entry-article section.entry-section .embed_article article a .txt h3 {
    letter-spacing: 0.02em;
  }
}
article.entry-article section.entry-section .embed_article article a .txt h3 br {
  display: none;
}
article.entry-article section.entry-section .embed_article article a .txt .excerpt {
  margin: 5px 0 0;
}
@media screen and (max-width: 768px) {
  article.entry-article section.entry-section .embed_article article a .txt .excerpt {
    /*--- SP ---*/
    display: none;
  }
}
article.entry-article section.entry-section .embed_article article a .txt .excerpt p {
  font-size: 11px;
  font-weight: 500;
  line-height: 18px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  max-height: calc(18px*2);
  margin: 0 0 10px;
}
article.entry-article section.entry-section .embed_article article a .txt .excerpt p:last-child {
  margin-bottom: 0;
}
article.entry-article section.entry-section .embed_article .has-text-align-center {
  text-align: center;
}
article.entry-article section.entry-section .embed_article .has-text-align-right {
  text-align: right;
}
article.entry-article section.entry-section .embed_article .has-text-align-left {
  text-align: left;
}

.share {
  position: fixed;
  top: 50%;
  right: 25px;
  padding: 30px 10px;
  border-radius: 9999px;
  background-color: var(--wt);
  transform: translateY(-50%);
  box-shadow: 1px 1px 2px rgba(53, 56, 125, 0.07);
  z-index: 3;
  opacity: 0;
  -moz-transition: opacity 0.4s ease;
  -o-transition: opacity 0.4s ease;
  -webkit-transition: opacity 0.4s ease;
  transition: opacity 0.4s ease;
  pointer-events: none;
}
body.vh50 .share {
  opacity: 1;
  pointer-events: auto;
}
@media screen and (max-width: 768px) {
  .share {
    /*--- SP ---*/
    display: none;
  }
}
.share p {
  margin: 0;
  padding: 0;
  font-size: 11px;
  letter-spacing: 0;
  transform: rotate(90deg);
  transform-origin: center center;
  display: block;
}
.share ul {
  list-style: none;
  width: 18px;
  padding: 0;
  margin: 30px auto 0;
  display: flex;
  flex-direction: column;
}
.share ul li {
  display: flex;
  justify-content: center;
}
.share ul li + li {
  margin: 15px 0 0;
}
.share ul li img {
  width: inherit;
  height: 18px;
}
@media screen and (min-width: 768px) {
  .share ul li a {
    transition: opacity .4s ease-in-out;
  }
  .share ul li a:hover {
    opacity: .5;
  }
}

section.article-list-section {
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  section.article-list-section {
    /*--- PC TAB ---*/
    margin-bottom: 60px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section {
    /*--- SP ---*/
    margin-bottom: 10vw;
  }
  .single section.article-list-section {
    margin-top: 20vw;
  }
}
@media screen and (min-width: 768px) {
  section.article-list-section.recommend {
    /*--- PC TAB ---*/
    margin-top: 100px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section.recommend {
    /*--- SP ---*/
    margin-top: 15vw;
  }
}
section.article-list-section h2.article-list-heading {
  position: relative;
  display: flex;
  align-items: center;
  width: fit-content;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
  line-height: 1.3;
  color: var(--key);
}
@media screen and (min-width: 768px) {
  section.article-list-section h2.article-list-heading {
    /*--- PC TAB ---*/
    margin: 60px auto 0;
    font-size: 18px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section h2.article-list-heading {
    /*--- SP ---*/
    margin: 10vw auto 0;
    font-size: 4.2vw;
  }
}
section.article-list-section h2.article-list-heading.ico-tama::before {
  content: "";
  display: block;
  background-image: url(../img/ico_tamacruise.png);
  background-size: cover;
}
@media screen and (min-width: 768px) {
  section.article-list-section h2.article-list-heading.ico-tama::before {
    /*--- PC TAB ---*/
    width: 66px;
    height: 66px;
    margin-right: 20px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section h2.article-list-heading.ico-tama::before {
    /*--- SP ---*/
    width: 15vw;
    height: 15vw;
    margin-right: 3.5vw;
  }
}
section.article-list-section h2.article-list-archive-heading {
  position: relative;
  display: block;
  width: fit-content;
  margin: 0 auto;
  line-height: 1.3;
  text-align: center;
  color: var(--key);
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  section.article-list-section h2.article-list-archive-heading {
    /*--- PC TAB ---*/
    padding-bottom: 10px;
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section h2.article-list-archive-heading {
    /*--- SP ---*/
    padding-bottom: 2vw;
    font-size: 4vw;
  }
}
section.article-list-section h2.article-list-archive-heading span.num {
  margin: 0 5px;
  position: relative;
  top: 1px;
}
@media screen and (min-width: 768px) {
  section.article-list-section h2.article-list-archive-heading span.num {
    /*--- PC TAB ---*/
    font-size: 30px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section h2.article-list-archive-heading span.num {
    /*--- SP ---*/
    font-size: 6vw;
  }
}
section.article-list-section h2.article-list-archive-heading::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background-color: var(--green);
}
section.article-list-section h2.article-list-recommend-heading {
  position: relative;
  display: flex;
  align-items: center;
  width: fit-content;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
  line-height: 1.3;
  color: var(--key);
}
@media screen and (min-width: 768px) {
  section.article-list-section h2.article-list-recommend-heading {
    /*--- PC TAB ---*/
    margin: 60px auto 0;
    font-size: 18px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section h2.article-list-recommend-heading {
    /*--- SP ---*/
    margin: 10vw auto 0;
    font-size: 4.2vw;
  }
}
section.article-list-section ul.article-list {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (min-width: 768px) {
  section.article-list-section ul.article-list {
    /*--- PC TAB ---*/
    max-width: 1280px;
    padding-left: 50px;
    padding-right: 50px;
    margin: 60px auto 0;
  }
  section.article-list-section ul.article-list::after {
    content: "";
    display: block;
    width: 30%;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section ul.article-list {
    /*--- SP ---*/
    max-width: 88vw;
    margin: 10vw auto 0;
  }
}
@media screen and (min-width: 768px) {
  section.article-list-section ul.article-list > li {
    /*--- PC TAB ---*/
    width: 30%;
    margin: 0 0 50px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section ul.article-list > li {
    /*--- SP ---*/
    width: 84%;
    margin: 0 0 9vw;
  }
  section.article-list-section ul.article-list > li:nth-child(even) {
    margin-left: 16%;
  }
}
section.article-list-section ul.article-list > li article {
  position: relative;
  height: 100%;
}
@media screen and (min-width: 768px) {
  section.article-list-section ul.article-list > li article {
    /*--- PC TAB ---*/
    min-height: 320px;
  }
}
section.article-list-section ul.article-list > li article::before {
  content: "";
  position: absolute;
  top: 0;
  height: 100%;
  background-color: var(--wt);
}
@media screen and (min-width: 768px) {
  section.article-list-section ul.article-list > li article::before {
    /*--- PC TAB ---*/
    left: -5px;
    width: 5px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section ul.article-list > li article::before {
    /*--- SP ---*/
    left: -3px;
    width: 3px;
  }
}
section.article-list-section ul.article-list > li article a.article-link:hover figure.article-thumbnail::before {
  opacity: .8;
}
section.article-list-section ul.article-list > li article a.article-link:hover figure.article-thumbnail::after {
  top: 50%;
  opacity: 1;
}
section.article-list-section ul.article-list > li article a.article-link:hover div.article-content h3 {
  color: var(--key);
}
section.article-list-section ul.article-list > li article a.article-link figure.article-thumbnail {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
  overflow: hidden;
  position: relative;
  aspect-ratio: 1.5 / 1;
}
section.article-list-section ul.article-list > li article a.article-link figure.article-thumbnail img {
  width: 100%;
  height: auto;
  object-fit: cover;
  z-index: 0;
}
section.article-list-section ul.article-list > li article a.article-link figure.article-thumbnail image {
  height: auto;
}
section.article-list-section ul.article-list > li article a.article-link figure.article-thumbnail svg path {
  transform: scale(0.00084, 0.00084);
}
section.article-list-section ul.article-list > li article a.article-link figure.article-thumbnail::after {
  content: "READ MORE";
  position: absolute;
  top: 52%;
  left: 50%;
  width: 100%;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  transform: translate(-50%, -50%);
  font-size: 12px;
  font-weight: 400;
  letter-spacing: .07em;
  line-height: 1;
  text-align: center;
  color: #35387D;
  width: fit-content;
  opacity: 0;
  transition: all .4s ease;
  z-index: 2;
  padding: 10px 20px;
  border-radius: 9999px;
  background-color: #eaf5f9;
}
section.article-list-section ul.article-list > li article a.article-link div.article-content {
  flex: 1;
  padding: 12px 0 0 22px;
}
section.article-list-section ul.article-list > li article a.article-link div.article-content time {
  color: var(--key);
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  section.article-list-section ul.article-list > li article a.article-link div.article-content time {
    /*--- PC TAB ---*/
    font-size: 11px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section ul.article-list > li article a.article-link div.article-content time {
    /*--- SP ---*/
    font-size: 10px;
  }
}
section.article-list-section ul.article-list > li article a.article-link div.article-content h3 {
  color: #35387D;
  margin: 3px 0 0;
  font-family: "Inter", "Helvetica Neue", Arial, "DNPShueiGoGinStd-B", "Yu Gothic", "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
  font-weight: 600;
  line-height: 1.5;
  transition: .4s ease-in-out;
}
@media screen and (min-width: 768px) {
  section.article-list-section ul.article-list > li article a.article-link div.article-content h3 {
    /*--- PC TAB ---*/
    font-size: 14px;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section ul.article-list > li article a.article-link div.article-content h3 {
    /*--- SP ---*/
    font-size: 3.5vw;
  }
}
section.article-list-section ul.article-list > li article a.article-link div.article-content ul.tags {
  display: flex;
  flex-wrap: wrap;
  margin: 10px 0 0;
  padding: 0;
  font-family: "Asap Condensed", "FOT-UD角ゴC80 Pro M", "游ゴシック", YuGothic, "游ゴシック体", "Source Sans Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", "Meiryo", sans-serif;
}
section.article-list-section ul.article-list > li article a.article-link div.article-content ul.tags li {
  margin: 0 5px 5px 0;
  font-size: 11px;
  line-height: 1;
  color: var(--key);
}
section.article-list-section ul.article-list > li article a.article-link div.article-content ul.tags li span {
  font-weight: 700;
}
section.article-list-section ul.article-list > li article a.article-link div.article-content ul.tags li::before {
  content: "＃";
}
section.article-list-section .search-not-found {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  section.article-list-section .search-not-found {
    /*--- PC TAB ---*/
    min-height: calc( 100vh - 580px );
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section .search-not-found {
    /*--- SP ---*/
    min-height: 30vh;
  }
}
section.article-list-section .search-not-found p {
  width: 100%;
  color: #35387D;
  line-height: 1.7;
  text-align: center;
}
@media screen and (min-width: 768px) {
  section.article-list-section .search-not-found p {
    /*--- PC TAB ---*/
    font-size: 15px;
    margin: 20px auto 0;
  }
}
@media screen and (max-width: 768px) {
  section.article-list-section .search-not-found p {
    /*--- SP ---*/
    font-size: 3.5vw;
    margin: 3vw auto 0;
  }
}

/*# sourceMappingURL=style.css.map */
