/**
 * 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:not(.js-top-mv-slider):not(.js-futsal-slider):not(.js-pullslider) {
  max-width: 1200px; }

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

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

.swiper-android .swiper-slide, .swiper-wrapper {
  transform: translate3d(0px, 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);
  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;
  -moz-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(0px, -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%;
  -o-object-fit: contain;
     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;
  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;
  backface-visibility: hidden; }

.swiper-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  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;
  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;
  backface-visibility: hidden; }

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

.swiper-cards {
  overflow: visible; }

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

:root {
  --color_main:#004477;
  --color_gray_v1:#969696;
  --color_gray_v2:#666666;
  --color_gray_v3:#cccccc;
  --color_gray_v4:#999999;
  --color_gray_v5:#434343;
  --color_state01:#59c3e1;
  --color_state02:#e92355;
  --color_state03:#f8af00;
  --color_state04:#039BE5;
  --color_state05:#E05145;
  --font_main: "Noto Sans JP", sans-serif;
  --font_sub: "Montserrat", sans-serif; }

body {
  font-family: var(--font_main);
  font-size: 1.4rem;
  line-height: 1.7143;
  color: #333333; }
  body.is-gnav-open {
    overflow: hidden;
    max-height: 100vh; }

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

.u-block {
  padding-inline: calc((15 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .u-block {
      margin-inline: auto;
      width: calc(100% - 60px);
      max-width: 1200px;
      padding-inline: 0; }
      .u-block--1000 {
        max-width: 1000px; } }

@media screen and (max-width: 767px) {
  .u-block--clear--sp {
    padding-inline: calc((0 / 375 ) * 100vw) !important; } }

.u-mt0 {
  margin-top: 0 !important; }

.u-mb0 {
  margin-bottom: 0 !important; }

@media screen and (max-width: 767px) {
  .u-show-pc {
    display: none !important; } }

@media print, screen and (min-width: 768px) {
  .u-show-sp {
    display: none !important; } }

.l-contents {
  padding-top: 0; }
  .l-contents .swiper-pagination {
    line-height: 1; }
    @media print, screen and (min-width: 768px) {
      .l-contents .swiper-pagination {
        bottom: 20px; } }
  .l-contents .swiper-pagination-bullet {
    border: 1px solid var(--color_main);
    background: #fff;
    opacity: 1 !important; }
    @media print, screen and (min-width: 768px) {
      .l-contents .swiper-pagination-bullet {
        margin: 0 8px !important;
        width: 13px;
        height: 13px; } }
  .l-contents .swiper-pagination-bullet-active {
    background-color: var(--color_main); }
  .l-contents .p-top-mv-slider__item img {
    width: 100%;
  aspect-ratio: 75 / 37; }

.l-inner-v1 {
  padding-top: calc((35 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .l-inner-v1 {
      padding-top: 50px; } }
  .l-inner-v1 > .u-block > :first-child {
    margin-top: 0 !important; }

.c-hero {
  background-color: #fff; }

.c-hero__detail__inner {
  display: grid;
  align-items: center;
  grid-template-columns: calc((45 / 375 ) * 100vw) 1fr;
  padding: calc((20 / 375 ) * 100vw) calc((20 / 375 ) * 100vw) 0; }
  @media print, screen and (min-width: 768px) {
    .c-hero__detail__inner {
      max-width: 1200px;
      margin-inline: auto;
      grid-template-columns: 40px 1fr;
      padding: 45px 0 0; } }

.c-hero__icon {
  width: calc((23 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-hero__icon {
      width: 23px; } }

.c-hero__text {
  line-height: 1.4; }

.c-hero__main {
  font-weight: 700;
  font-size: calc((21 / 375 ) * 100vw);
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-hero__main {
      font-size: 21px; } }

.c-hero__sub {
  font-weight: 500;
  font-size: calc((11 / 375 ) * 100vw);
  color: var(--color_gray_v1); }
  @media print, screen and (min-width: 768px) {
    .c-hero__sub {
      font-size: 11px; } }

/* headline-v1 */
.c-headline-v1 {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: calc((10 / 375 ) * 100vw);
  color: var(--color_gray_v2);
  margin: 0 0 calc((26 / 375 ) * 100vw);
  padding-bottom: calc((6 / 375 ) * 100vw);
  border-bottom: 1px solid var(--color_gray_v1); }
  @media print, screen and (min-width: 768px) {
    .c-headline-v1 {
      gap: 0;
      padding-bottom: 4px;
      margin: 0 0 35px; } }
  .c-headline-v1--left {
    justify-content: flex-start; }
    @media print, screen and (min-width: 768px) {
      .c-headline-v1--left {
        gap: 0 20px; } }

.c-headline-v1__main {
  font-size: calc((17 / 375 ) * 100vw);
  font-weight: 700;
  line-height: 1.2; }
  @media print, screen and (min-width: 768px) {
    .c-headline-v1__main {
      font-size: 21px; } }

.c-headline-v1__sub {
  padding-top: 0.4em;
  font-family: var(--font_sub);
  font-weight: 700;
  font-size: calc((11 / 375 ) * 100vw);
  letter-spacing: 0.1em;
  line-height: 1;
  color: var(--color_gray_v1); }
  @media print, screen and (min-width: 768px) {
    .c-headline-v1__sub {
      font-size: 12px; } }

/* c-hamburger-menu */
.c-hamburger-menu {
  display: block;
  position: absolute;
  z-index: 5;
  top: 18px;
  left: 20px;
  border: none;
  width: 30px;
  height: 18px;
  padding: 0;
  cursor: pointer;
  background: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none; }
  @media print, screen and (min-width: 768px) {
    .c-hamburger-menu {
      display: none; } }
  .c-hamburger-menu > span {
    display: block;
    position: absolute;
    height: 2px;
    border-radius: 5px;
    width: 100%;
    background-color: #fff;
    transition: all 0.3s ease; }
    .c-hamburger-menu > span:nth-child(1) {
      top: 0; }
    .c-hamburger-menu > span:nth-child(2) {
      top: 50%;
      transform: translateY(-50%); }
    .c-hamburger-menu > span:nth-child(3) {
      bottom: 0; }

body.is-gnav-open .c-hamburger-menu > span:nth-child(1) {
  top: 50%;
  transform: translateY(-50%) rotate(45deg); }

body.is-gnav-open .c-hamburger-menu > span:nth-child(2) {
  opacity: 0; }

body.is-gnav-open .c-hamburger-menu > span:nth-child(3) {
  bottom: 50%;
  transform: translateY(50%) rotate(-45deg); }

/* location search */
.c-locationsearch {
  margin-top: calc((50 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-locationsearch {
      margin-top: 50px; } }

.c-locationsearch__item {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  border: 1px solid var(--color_main);
  padding: calc((10 / 375 ) * 100vw) calc((20 / 375 ) * 100vw);
  background-color: var(--color_main);
  font-weight: 500;
  font-size: calc((12 / 375 ) * 100vw);
  color: #fff; }
  @media print, screen and (min-width: 768px) {
    .c-locationsearch__item {
      margin: 0 auto;
      padding: 12px;
      width: 400px;
      font-size: 13px;
      transition: all 0.3s ease; }
      .c-locationsearch__item:hover {
        opacity: 0.5; } }
  @media screen and (max-width: 767px) {
    .c-locationsearch__item:active {
      opacity: 0.5; } }
  .c-locationsearch__item:before {
    content: '';
    display: inline-block;
    margin-right: calc((8 / 375 ) * 100vw);
    width: calc((20 / 375 ) * 100vw);
    height: calc((20 / 375 ) * 100vw);
    background-color: #fff;
    -webkit-mask: url("../img/common/icon_target.ced1c4aa6f62.svg?ver=2") no-repeat 50% 50%/contain;
            mask: url("../img/common/icon_target.ced1c4aa6f62.svg?ver=2") no-repeat 50% 50%/contain;
    vertical-align: middle; }
    @media print, screen and (min-width: 768px) {
      .c-locationsearch__item:before {
        margin-right: 8px;
        width: 20px;
        height: 20px; } }
  .c-locationsearch__item--blue {
    border-color: var(--color_main);
    background-color: var(--color_main);
    color: #fff; }
    .c-locationsearch__item--blue:before {
      background-color: #fff; }

.js-accordion-contents {
  display: none; }

/* c-morecontents */
.c-morecontents__btn {
  display: block;
  margin: calc((25 / 375 ) * 100vw) auto 0;
  width: -moz-fit-content;
  width: fit-content;
  font-size: calc((12 / 375 ) * 100vw);
  text-align: center;
  color: var(--color_main); }
  @media print, screen and (min-width: 768px) {
    .c-morecontents__btn {
      display: none;
      margin: 20px auto 0;
      font-size: 13px; }
      .c-morecontents__btn:hover {
        text-decoration: underline; } }
  @media screen and (max-width: 767px) {
    .c-morecontents__btn:active {
      text-decoration: underline; } }

/* c-button-list */
.c-button-list {
  display: flex;
  flex-wrap: wrap;
  gap: calc((6 / 375 ) * 100vw);
  margin-bottom: calc((6 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-button-list {
      gap: 18px 20px;
      margin: 20px 0 0; } }
  @media print, screen and (min-width: 768px) {
    .c-button-list--strong {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 18px 15px; } }

.c-button-v1 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 calc((6 / 375 ) * 100vw);
  border: 1px solid #c8c9ca;
  padding: calc((13 / 375 ) * 100vw) calc((16 / 375 ) * 100vw);
  background-color: #fff;
  color: #666666;
  font-weight: 500;
  font-size: calc((12 / 375 ) * 100vw);
  font-feature-settings: "palt"; }
  @media print, screen and (min-width: 768px) {
    .c-button-v1 {
      gap: 0 10px;
      padding: 25px 20px;
      font-size: 17px;
      transition: all 0.2s ease; }
      .c-button-v1:hover {
        background-color: var(--color_main);
        color: #fff; }
        .c-button-v1:hover:after {
          background-image: url("../img/common/icon_arw03.svg?ver=2"); } }
  @media screen and (max-width: 767px) {
    .c-button-v1:active {
      background-color: var(--color_main);
      color: #fff; }
      .c-button-v1:active:after {
        background-image: url("../img/common/icon_arw03.svg?ver=2"); } }
  .c-button-v1:after {
    content: '';
    position: relative;
    top: 1px;
    display: inline-block;
    z-index: 2;
    font-size: calc((10 / 375 ) * 100vw);
    width: calc((10 / 375 ) * 100vw);
    height: calc((10 / 375 ) * 100vw);
    background: url("../img/common/icon_arw01.svg?ver=2") no-repeat 50% 50%/contain; }
    @media print, screen and (min-width: 768px) {
      .c-button-v1:after {
        top: 1px;
        font-size: 15px;
        width: 16px;
        height: 16px; } }

.c-button-v2 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 calc((6 / 375 ) * 100vw);
  border: 1px solid #c8c9ca;
  padding: calc((8 / 375 ) * 100vw) calc((12 / 375 ) * 100vw);
  background-color: #fff;
  color: #666666;
  font-weight: 500;
  font-size: calc((12 / 375 ) * 100vw);
  font-feature-settings: "palt";
  line-height: 1.4; }
  @media print, screen and (min-width: 768px) {
    .c-button-v2 {
      gap: 8px;
      padding: 15px 15px 15px;
      font-size: 13px;
      transition: all 0.2s ease; }
      .c-button-v2:hover {
        background-color: var(--color_main);
        color: #fff; } }
  @media screen and (max-width: 767px) {
    .c-button-v2:active {
      background-color: var(--color_main);
      color: #fff; } }

.c-morebutton-wrap {
  display: flex;
  justify-content: center;
  margin-top: calc((30 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-morebutton-wrap {
      margin-top: 50px; } }

.c-morebutton {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color_main);
  padding: calc((9 / 375 ) * 100vw) calc((20 / 375 ) * 100vw) calc((11 / 375 ) * 100vw);
  min-height: calc((42 / 375 ) * 100vw);
  width: calc((225 / 375 ) * 100vw);
  background-color: var(--color_main);
  color: #fff;
  font-size: calc((12 / 375 ) * 100vw);
  font-weight: 500;
  line-height: 1; }
  @media print, screen and (min-width: 768px) {
    .c-morebutton {
      width: 280px;
      height: auto;
      min-height: 48px;
      padding: 11px 12px 13px;
      font-size: 16px;
      transition: opacity 0.3s; }
      .c-morebutton:hover {
        opacity: 0.7; } }
  @media screen and (max-width: 767px) {
    .c-morebutton:active {
      opacity: 0.7; } }
  .c-morebutton:before {
    position: relative;
    top: calc((1 / 375 ) * 100vw);
    content: '';
    vertical-align: middle;
    display: inline-block;
    z-index: 2;
    margin-right: calc((8 / 375 ) * 100vw);
    width: calc((12 / 375 ) * 100vw);
    height: calc((12 / 375 ) * 100vw);
    background: url("../img/common/icon_arw03.svg?ver=2") no-repeat 50% 50%/contain; }
    @media print, screen and (min-width: 768px) {
      .c-morebutton:before {
        top: 1px;
        margin-right: 8px;
        width: 13px;
        height: 13px; } }
  .c-morebutton--white {
    border-color: #ffffff;
    background-color: #ffffff;
    color: var(--color_main); }
    .c-morebutton--white:before {
      background-image: url("../img/common/icon_arw01.svg?ver=2"); }

/**/
@media print, screen and (min-width: 768px) {
  .c-arealist-wrap {
    display: grid;
    justify-content: space-between;
    grid-template-columns: repeat(2, 48%);
    gap: 15px; } }

.c-arealist {
  margin-top: calc((20 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-arealist {
      margin-top: 0; } }

.c-arealist__title {
  margin: 0 0 calc((6 / 375 ) * 100vw);
  font-feature-settings: "palt"; }
  @media print, screen and (min-width: 768px) {
    .c-arealist__title {
      position: relative;
      top: -2px;
      margin: 0 0 .6em;
      font-feature-settings: normal; } }
  .c-arealist__title a,
  .c-arealist__title span {
    color: var(--color_gray_v2);
    font-size: calc((13 / 375 ) * 100vw);
    font-weight: 700; }
    @media print, screen and (min-width: 768px) {
      .c-arealist__title a,
      .c-arealist__title span {
        font-size: 14px; }
        .c-arealist__title a:hover {
          text-decoration: underline; } }
    @media screen and (max-width: 767px) {
      .c-arealist__title a:active {
        text-decoration: underline; } }
  .c-arealist__title span { color: var(--color_gray_v3); }

.c-arealist__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3em 0.8em;
  line-height: 1.4; }
  .c-arealist__list + .c-arealist__title { margin-top: calc((20 / 375) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-arealist__list {
      gap: 0.3em 1.1em; }
    .c-arealist__list + .c-arealist__title { margin-top: 2em;} }
    
  .c-arealist__list li { width: calc((100 / 375 ) * 100vw)}
  .c-arealist__list > li > a,
  .c-arealist__list > li > span {
    font-weight: 500;
    font-size: calc((13 / 375 ) * 100vw);
    color: var(--color_main);
    font-feature-settings: "palt"; }
    @media print, screen and (min-width: 768px) {
      .c-arealist__list li { width: auto;}
      .c-arealist__list > li > a,
      .c-arealist__list > li > span {
        font-size: 14px; }
        .c-arealist__list > li > a:hover {
          text-decoration: underline; } }
    @media screen and (max-width: 767px) {
      .c-arealist__list > li > a:active {
        text-decoration: underline; } }
  .c-arealist__list > li > span { color: var(--color_gray_v3); }
  .c-arealist__title + .c-arealist__list + .c-arealist__list { margin: calc((6 / 375 ) * 100vw) 0 0; }
  @media print, screen and (min-width: 768px) {
    .c-arealist__title + .c-arealist__list + .c-arealist__list { margin: 0.6em 0 0; } }

.c-taglist {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6em 1.5em;
  line-height: 1.4;
  font-weight: 500;
  font-size: calc((13 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-taglist {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: 1em 1em;
      font-size: 14px; } }
  .c-taglist > a {
    color: var(--color_main);
    font-feature-settings: "palt"; }
    @media print, screen and (min-width: 768px) {
      .c-taglist > a:hover {
        text-decoration: underline; } }
    @media screen and (max-width: 767px) {
      .c-taglist > a:active {
        text-decoration: underline; } }

.c-tagicon {
  display: flex;
  flex-wrap: wrap;
  gap: 0 calc((4 / 375 ) * 100vw);
  margin-top: calc((6 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-tagicon {
      margin-top: 10px;
      gap: 0 6px; } }
  .c-tagicon > li {
    border: 1px solid var(--color_gray_v3);
    line-height: 1;
    min-width: calc((70 / 375 ) * 100vw);
    padding: calc((3 / 375 ) * 100vw) calc((4 / 375 ) * 100vw) calc((4 / 375 ) * 100vw);
    font-size: calc((10 / 375 ) * 100vw);
    font-weight: 500;
    text-align: center;
    color: var(--color_gray_v2);
    background-color: #fff; }
    @media print, screen and (min-width: 768px) {
      .c-tagicon > li {
        min-width: 80px;
    margin-right: 3px;
        padding: 4px 4px 5px;
        font-size: 12px; } }
    @media print, screen and (max-width: 767px) {
      .c-tagicon { margin-bottom: -4px; }
      .c-tagicon > li {
        margin-bottom: 4px; } }

.c-bookmarkbtn {
  border: none;
  background: url("../img/common/icon_bookmark_off.909beb41f1e3.svg?ver=2") no-repeat 50% 50%/contain;
  width: calc((28 / 375 ) * 100vw);
  height: calc((28 / 375 ) * 100vw);
  display: block;
  border-radius: 50%;
  margin-top: calc((10 / 375 ) * 100vw);
  background-color: #fff; }
  .c-bookmarkbtn.is-active {
    background-image: url("../img/common/icon_bookmark_on.79cd606df28b.svg?ver=2"); }
  @media print, screen and (min-width: 768px) {
    .c-bookmarkbtn {
      margin-top: 0;
      width: 35px;
      height: 35px;
      display: block;
      transition: transform 0.3s ease; } }
  @media print, screen and (min-width: 768px) {
    .c-bookmarkbtn:hover, .c-bookmarkbtn:focus {
      transform: scale(1.1); } }
  @media screen and (max-width: 767px) {
    .c-bookmarkbtn:active {
      transform: scale(1.1); } }

.c-fixicon {
  position: absolute;
  z-index: 5;
  top: 0;
  left: 0;
  background-color: var(--color_main);
  color: #fff;
  font-size: calc((10 / 375 ) * 100vw);
  padding: calc((0 / 375 ) * 100vw) calc((12 / 375 ) * 100vw) calc((1 / 375 ) * 100vw) calc((8 / 375 ) * 100vw);
  min-width: calc((70 / 375 ) * 100vw);
  text-align: center;
  clip-path: polygon(0 0, 100% 0%, calc(100% - 8px) 100%, 0% 100%); }
  @media print, screen and (min-width: 768px) {
    .c-fixicon {
      padding: 0 8px 2px 5px;
      min-width: 80px;
      font-size: 14px; } }

.c-imgbnr {
  display: grid;
  gap: calc((8 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-imgbnr {
      gap: 20px;
      grid-template-columns: 1fr 1fr 1fr; } }

.c-imgbnr__item {
  position: relative;
  display: block;
  border: 1px solid #c8c8c8;
  min-height: calc((60 / 375 ) * 100vw);
  display: flex;
  align-items: center; }
  @media print, screen and (min-width: 768px) {
    .c-imgbnr__item {
      min-height: 80px;
      transition: opacity 0.3s ease; }
      .c-imgbnr__item:hover {
        opacity: 0.5; } }
  @media screen and (max-width: 767px) {
    .c-imgbnr__item:active {
      opacity: 0.5; } }
  .c-imgbnr__item:after {
    content: '';
    display: inline-block;
    position: absolute;
    z-index: 2;
    top: 50%;
    right: calc((16 / 375 ) * 100vw);
    width: calc((10 / 375 ) * 100vw);
    height: calc((10 / 375 ) * 100vw);
    transform: translateY(-50%);
    background: url("../img/common/icon_arw01.svg?ver=2") no-repeat 50% 50%/contain; }
    @media print, screen and (min-width: 768px) {
      .c-imgbnr__item:after {
        right: 16px;
        font-size: 10px;
        width: 10px;
        height: 10px; } }

.c-imgbnr__img {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  height: 100%;
  width: 30%; }
  .c-imgbnr__img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover; }
  .c-imgbnr__img:after {
    content: '';
    display: block;
    position: absolute;
    z-index: 2;
    top: 0;
    right: -1px;
    height: 100%;
    width: 100%;
    background: linear-gradient(-70deg, white 25%, rgba(255, 255, 255, 0) 50%); }

.c-imgbnr__title {
  position: relative;
  z-index: 5;
  width: 100%;
  padding-right: calc((30 / 375 ) * 100vw);
  padding-left: calc((120 / 375 ) * 100vw);
  font-size: calc((14 / 375 ) * 100vw);
  font-weight: 500;
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-imgbnr__title {
      padding: 0 40px 0 36%;
      font-size: 19px;
      line-height: 1.4; } }

.c-newicon {
  vertical-align: middle;
  margin-right: calc((10 / 375 ) * 100vw);
  padding: calc((3 / 375 ) * 100vw) calc((4 / 375 ) * 100vw);
  color: #fff;
  background-color: #fa0000;
  font-size: calc((9 / 375 ) * 100vw);
  font-family: var(--font_sub); }
  @media print, screen and (min-width: 768px) {
    .c-newicon {
      position: relative;
      top: -1px;
      padding: 3px 4px;
      margin-right: 10px;
      font-size: 10px; } }

/* c-articlecard-v1 */
@media print, screen and (min-width: 768px) {
  .c-articlecard-container {
    overflow: hidden; } }

@media print, screen and (min-width: 768px) {
  .c-articlecard-wrap {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    margin: 0 -40px; } }

.c-articlecard-v1 {
  display: grid;
  align-items: flex-start;
  grid-template-columns: calc((100 / 375 ) * 100vw) 1fr;
  gap: calc((10 / 375 ) * 100vw);
  padding: calc((25 / 375 ) * 100vw) 0;
  border-bottom: 1px solid var(--color_gray_v1); }
  @media print, screen and (min-width: 768px) {
    .c-articlecard-v1 {
      grid-template-columns: 100%;
      display: block;
      padding: 0 40px;
      border: none; }
      .c-articlecard-v1 + .c-articlecard-v1 {
        border-left: 1px solid var(--color_gray_v1); }
      .c-articlecard-v1:hover .c-articlecard__img {
        opacity: 0.5; }
      .c-articlecard-v1:hover .c-articlecard__title {
        text-decoration: underline; } }
  @media screen and (max-width: 767px) {
    .c-articlecard-v1:active .c-articlecard__img {
      opacity: 0.5; }
    .c-articlecard-v1:active .c-articlecard__title {
      text-decoration: underline; } }
  .c-articlecard-v1:first-child {
    padding-top: 0; }

@media print, screen and (min-width: 768px) {
  .c-articlecard__img {
    transition: opacity 0.3s ease;
    margin: 0 0 18px; } }

.c-articlecard__img img {
  width: 100%; }

.c-articlecard__detail {
  color: var(--color_gray_v2); }

.c-articlecard__title {
  margin-top: 0;
  font-size: calc((14 / 375 ) * 100vw);
  font-weight: 700;
  line-height: 1.3; }
  @media print, screen and (min-width: 768px) {
    .c-articlecard__title {
      margin: 0;
      font-size: 14px; } }

.c-articlecard__text {
  margin-top: 0.5em;
  font-size: calc((11 / 375 ) * 100vw);
  line-height: 1.4545; }
  @media print, screen and (min-width: 768px) {
    .c-articlecard__text {
      margin-top: 0.8em;
      font-size: 12px; } }

@media print, screen and (min-width: 768px) {
  .c-tab {
    max-width: 1000px;
    margin: 0 auto; } }

.c-tab__header {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: calc((16 / 375 ) * 100vw);
  margin-inline: calc((-15 / 375 ) * 100vw);
  padding-inline: calc((15 / 375 ) * 100vw);
  padding-bottom: 1px; }
  @media print, screen and (min-width: 768px) {
    .c-tab__header {
      justify-content: center;
      grid-template-columns: 300px 300px;
      margin: 0 auto;
      padding-inline: 30px;
      gap: 35px; } }
  .c-tab__header:after {
    content: '';
    display: block;
    position: absolute;
    z-index: 2;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: var(--color_main);
    pointer-events: none; }

.c-tab__header__item {
  position: relative;
  padding: calc((10 / 375 ) * 100vw);
  border-radius: 2px 2px 0 0;
  background-color: var(--color_gray_v3);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: calc((13 / 375 ) * 100vw);
  font-weight: 500; }
  @media print, screen and (min-width: 768px) {
    .c-tab__header__item {
      border-radius: 4px 4px 0 0;
      padding: 7px;
      font-size: 15px;
      transition: background-color 0.2s ease; }
      .c-tab__header__item:hover, .c-tab__header__item:focus {
        background-color: var(--color_main); } }
  @media screen and (max-width: 767px) {
    .c-tab__header__item:active {
      background-color: var(--color_main); } }
  .c-tab__header__item small {
    vertical-align: baseline;
    font-size: 70%; }
    @media print, screen and (min-width: 768px) {
      .c-tab__header__item small {
        font-size: 13px; } }
  .c-tab__header__item.is-icon01:before {
    margin-right: 0.4em;
    content: '';
    display: block;
    background: url("../img/common/icon_sports.2b9c7f964a61.svg?ver=2") no-repeat 50% 50%/contain;
    width: calc((17 / 375 ) * 100vw);
    height: calc((17 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .c-tab__header__item.is-icon01:before {
        width: 17px;
        height: 17px; } }
  .c-tab__header__item.is-icon02:before {
    margin-right: 0.4em;
    content: '';
    display: block;
    background: url("../img/common/icon_event.a61a2b277604.svg?ver=2") no-repeat 50% 50%/contain;
    width: calc((14 / 375 ) * 100vw);
    height: calc((14 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .c-tab__header__item.is-icon02:before {
        width: 17px;
        height: 17px; } }
  .c-tab__header__item.is-current {
    transform: scale(1.1);
    transform-origin: 50% 100%;
    background-color: var(--color_main);
    pointer-events: none; }

.c-tab__body {
  padding-top: calc((14 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-tab__body {
      border: 1px solid var(--color_gray_v3);
      border-top: none;
      padding: 28px; } }

.js-tab__panel {
  opacity: 0;
  visibility: hidden;
  height: 0;
  overflow: hidden; }
  .js-tab__panel.is-current {
    opacity: 1;
    visibility: visible;
    transition: opacity 0.3s ease 0.2s;
    height: auto; }

/*c-result*/
@media print, screen and (min-width: 768px) {
  .p-search-result {
    display: flex;
    align-items: center;
    gap: 0 calc((25 / 1200) * 100%);
    margin: 70px 0 40px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--color_gray_v1); } }

.c-result-headline {
  margin: 0 0 calc((5 / 375 ) * 100vw);
  font-size: calc((17 / 375 ) * 100vw);
  font-weight: 500;
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-result-headline {
      margin: 0;
      padding: 0;
      font-size: 2.1rem;
      line-height: 1; } }

.c-result-infomation {
  color: var(--color_main); }
  @media print, screen and (min-width: 768px) {
    .c-result-infomation {
      line-height: 1;
      font-size: 1.7rem; } }

.c-result-infomation__find {
  font-weight: 700; }
  @media print, screen and (min-width: 768px) {
    .c-result-infomation__find {
      font-size: 2.1rem; } }

.c-result-infomation__guide {
  font-size: 80%; }

.c-pulldown {
  position: relative;
  display: flex;
  justify-content: flex-end;
  margin: calc((20 / 375 ) * 100vw) 0; }
  @media print, screen and (min-width: 768px) {
    .c-pulldown {
      margin: 0;
      margin-left: auto; } }
  .c-pulldown:before {
    position: absolute;
    z-index: 2;
    top: calc(50% - 2px);
    right: calc((8 / 375 ) * 100vw);
    border: 5px solid transparent;
    border-top-color: var(--color_gray_v3);
    content: "";
    pointer-events: none; }
    @media print, screen and (min-width: 768px) {
      .c-pulldown:before {
        top: calc(50% - 2px);
        right: 10px; } }
  .c-pulldown select {
    border: 1px solid var(--color_gray_v3);
    padding: calc((3 / 375 ) * 100vw) calc((25 / 375 ) * 100vw) calc((3 / 375 ) * 100vw) calc((10 / 375 ) * 100vw);
    font-size: calc((11 / 375 ) * 100vw);
    font-weight: 500;
    color: var(--color_gray_v2);
    cursor: pointer; }
    .c-pulldown select:focus {
      border-color: var(--color_gray_v2); }
    @media print, screen and (min-width: 768px) {
      .c-pulldown select {
        padding: 3px 35px 3px 10px;
        font-size: 13px; } }

.c-pagination {
  display: flex;
  justify-content: center;
  gap: calc((4 / 375 ) * 100vw);
  margin-top: calc((35 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-pagination {
      margin-top: 60px;
      gap: 5px; } }

.c-pagination__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc((30 / 375 ) * 100vw);
  border: 1px solid var(--color_gray_v3);
  color: var(--color_gray_v2);
  aspect-ratio: 1;
  font-size: calc((10 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-pagination__link {
      transition: all 0.3s ease;
      width: 44px;
      font-size: 14px; }
      .c-pagination__link:hover {
        border-color: var(--color_main);
        background-color: var(--color_main);
        color: #fff; } }
  @media screen and (max-width: 767px) {
    .c-pagination__link:active {
      border-color: var(--color_main);
      background-color: var(--color_main);
      color: #fff; } }
  .c-pagination__link.is-current {
    border-color: var(--color_main);
    background-color: var(--color_main);
    color: #fff; }

.c-eventcard-wrap {
  margin-top: calc((20 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-eventcard-wrap {
      display: grid;
      grid-template-columns: 100%;
      gap: 20px 0;
      margin-top: 40px; } }

.c-eventcard {
  position: relative;
  display: grid;
  grid-template-columns: calc((70 / 375 ) * 100vw) 1fr;
  gap: 0 calc((10 / 375 ) * 100vw);
  margin: 0 calc((-15 / 375 ) * 100vw);
  padding: calc((15 / 375 ) * 100vw) calc((15 / 375 ) * 100vw);
  border-bottom: 1px solid var(--color_gray_v3);
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-eventcard {
      grid-template-columns: 220px 1fr;
      gap: 0 35px;
      border: 1px solid var(--color_gray_v3);
      margin: 0;
      padding: 20px 35px;
      transition: background-color 0.3s ease; }
      .c-eventcard:hover {
        background-color: #fbfbfb; } }
  @media screen and (max-width: 767px) {
    .c-eventcard:active {
      background-color: #fbfbfb; } }
  .c-eventcard:first-child {
    border-top: 1px solid var(--color_gray_v3); }

.c-eventcard__date {
  padding-top: calc((8 / 375 ) * 100vw);
  align-self: center;
  grid-row: 1 / 2;
  text-align: center; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__date {
      display: flex;
      align-items: center;
      justify-content: center;
      flex-wrap: wrap;
      gap: 0 6px;
      padding: 0; } }

.c-eventcard__date__day {
  margin-bottom: 0.2em;
  font-weight: 500;
  font-size: calc((20 / 375 ) * 100vw);
  line-height: 1; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__date__day {
      margin: 0;
      font-size: 3.0rem; } }

.c-eventcard__date__week {
  margin: 0 auto;
  width: -moz-fit-content;
  width: fit-content;
  min-width: calc((30 / 375 ) * 100vw);
  background-color: var(--color_gray_v2);
  color: #fff;
  font-family: var(--font_sub);
  font-size: calc((11 / 375 ) * 100vw);
  font-weight: 500;
  padding: calc((2 / 375 ) * 100vw) calc((4 / 375 ) * 100vw);
  line-height: 0.9; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__date__week {
      position: relative;
      top: 0.3em;
      margin: 0;
      padding: 0.2em;
      min-width: 45px;
      font-size: 14px; } }
  .c-eventcard__date__week.土,
  .c-eventcard__date__week.sat {
    background-color: var(--color_state04) !important; }
  .c-eventcard__date__week.日,
  .c-eventcard__date__week.sun,
  .c-eventcard__date__week.hlliday {
    background-color: var(--color_state05); }

.c-eventcard__date__time {
  margin-top: 0.2em;
  font-weight: 500;
  font-size: calc((13 / 375 ) * 100vw);
  line-height: 1; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__date__time {
      margin-top: 10px;
      width: 100%;
      font-size: 17px; } }

.c-eventcard__limit {
  align-self: center;
  grid-row: 2 / 3;
  border-top: 1px solid var(--color_gray_v3);
  margin: calc((16 / 375 ) * 100vw) 0 0;
  padding: calc((10 / 375 ) * 100vw) 0 0; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__limit {
      display: flex;
      align-items: center;
      justify-content: center;
      flex-wrap: wrap;
      gap: 0 10px;
      margin: 20px 0 0;
      padding: 20px 0 0; }
    .c-eventcard__limit.hide_limit {
      margin-top: -20px; }}

.c-eventcard__limit__label {
  display: flex;
  justify-content: center;
  align-self: center;
  font-weight: 500;
  font-size: calc((11 / 375 ) * 100vw);
  text-align: center;
  line-height: 1;
  margin-left: -1em; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__limit__label {
      font-size: 16px; } }
  .c-eventcard__limit__label > span {
    padding-top: 0.15em; }
  .c-eventcard__limit__label:before {
    position: relative;
    margin-right: 0.4em;
    content: '';
    display: inline-block;
    width: calc((12 / 375 ) * 100vw);
    height: calc((15 / 375 ) * 100vw);
    background: url("../img/common/icon_human.0630377c2204.svg?ver=2") no-repeat 50% 50%/contain; }
    @media print, screen and (min-width: 768px) {
      .c-eventcard__limit__label:before {
        width: 17px;
        height: 21px; } }

.c-eventcard__limit__count {
  margin-top: 0em;
  font-size: calc((11 / 375 ) * 100vw);
  font-weight: 500;
  text-align: center;
  line-height: 1; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__limit__count {
      margin-top: -0.2em;
      margin-right: -0.8em;
      font-size: 16px; } }
  .c-eventcard__limit__count span {
    margin-right: 0.1em;
    font-size: calc((20 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .c-eventcard__limit__count span {
        font-size: 30px; } }

.c-eventcard__limit__note {
  margin-top: 0.7em;
  font-size: calc((10 / 375 ) * 100vw);
  color: var(--color_gray_v1);
  line-height: 1.5;
  width: 100%;
  text-align: center; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__limit__note {
      margin-top: 0.5em;
      font-weight: 500;
      font-size: 14px; } }

.c-eventcard__detail {
  grid-template-columns: 100%;
  border-left: 1px solid var(--color_gray_v3);
  padding-left: calc((10 / 375 ) * 100vw);
  grid-row: 1 / 3; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__detail {
      padding-left: 45px; } }

.c-eventcard__state {
  display: block;
  margin: 0 0 calc((8 / 375 ) * 100vw);
  padding: calc((3 / 375 ) * 100vw) calc((4 / 375 ) * 100vw) calc((4 / 375 ) * 100vw);
  width: -moz-fit-content;
  width: fit-content;
  line-height: 1;
  min-width: calc((77 / 375 ) * 100vw);
  background-color: var(--color_state01);
  font-weight: 500;
  font-size: calc((10 / 375 ) * 100vw);
  color: #fff;
  text-align: center; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__state {
      margin: 0 0 12px;
      padding: 6px;
      min-width: 117px;
      font-size: 15px; } }
  .c-eventcard__state.キャンセル待ち,
  .c-eventcard__state.空いたら通知 {
    background-color: var(--color_state03); }
  .c-eventcard__state.受付け開始前,
  .c-eventcard__state.満席,
  .c-eventcard__state.受付け終了,
  .c-eventcard__state.受付け停止中 {
    background-color: #a0a0a0; }
  .c-eventcard__state.開催中止 {
    background-color: var(--color_state02); }

.c-eventcard__title {
  font-size: calc((14 / 375 ) * 100vw);
  font-weight: 700;
  line-height: 1.5;
  display: -webkit-box; 
  -webkit-line-clamp: 2; 
  -webkit-box-orient: vertical; 
  overflow: hidden; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__title {
      font-size: 2rem; } }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__title a:hover {
      text-decoration: underline; } }
  @media screen and (max-width: 767px) {
    .c-eventcard__title a:active {
      text-decoration: underline; } }
  .c-eventcard__title a:before {
    content: '';
    display: block;
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: transparent; }

.c-eventcard__text {
  margin-top: 1.2em;
  font-size: calc((11 / 375 ) * 100vw);
  line-height: 1.5455; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard__text {
      margin-top: 1.3em;
      font-size: 1.4rem; } }
  .c-eventcard__text a {
    position: relative;
    z-index: 5;
    display: inline-block;
    color: var(--color_main); }
    @media print, screen and (min-width: 768px) {
      .c-eventcard__text a:hover {
        text-decoration: underline; } }
    @media screen and (max-width: 767px) {
      .c-eventcard__text a {
        pointer-events: none; } }
  .c-eventcard__text + .c-eventcard__text {
    margin-top: 0; }

.c-eventcard-v2-wrap {
  display: grid;
  grid-template-columns: 100%;
  gap: calc((10 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-eventcard-v2-wrap {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 20px; } }

.c-eventcard-v2 {
  position: relative;
  border: 1px solid var(--color_gray_v3);
  background-color: #fff;
  padding: calc((30 / 375 ) * 100vw) calc((16 / 375 ) * 100vw) calc((16 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-eventcard-v2 {
      padding: 40px 30px 20px;
      transition: background-color 0.3s ease; }
      .c-eventcard-v2:hover {
        background-color: #fbfbfb; } }
  @media screen and (max-width: 767px) {
    .c-eventcard-v2:active {
      background-color: #fbfbfb; } }
  .c-eventcard-v2 .c-fixicon {
    position: absolute;
    z-index: 5;
    top: 0;
    left: 0;
    min-width: calc((50 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .c-eventcard-v2 .c-fixicon {
        min-width: 80px; } }
  .c-eventcard-v2 .c-tagicon {
    margin-top: calc((6 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .c-eventcard-v2 .c-tagicon {
        margin-top: 10px; } }

@media print, screen and (min-width: 768px) {
  .c-eventcard-v2__detail {
    height: 100%;
    display: flex;
    flex-direction: column; } }

.c-eventcard-v2__date {
  display: flex;
  align-items: center;
  gap: calc((6 / 375 ) * 100vw);
  line-height: 1;
  margin: 0 0 calc((12 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-eventcard-v2__date {
      gap: 0 8px;
      margin: 0 0 12px; } }

.c-eventcard-v2__date__day {
  font-weight: 500;
  font-size: calc((21 / 375 ) * 100vw);
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-eventcard-v2__date__day {
      font-size: 27px; } }

.c-eventcard-v2__date__week {
  position: relative;
  top: 1px;
  width: calc((30 / 375 ) * 100vw);
  padding: calc((1 / 375 ) * 100vw) calc((4 / 375 ) * 100vw) calc((2 / 375 ) * 100vw);
  font-weight: 500;
  font-size: calc((10 / 375 ) * 100vw);
  background-color: var(--color_gray_v2);
  color: #fff;
  text-align: center; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard-v2__date__week {
      width: 45px;
      padding: 1px 4px 4px;
      font-size: 15px; } }
  .c-eventcard-v2__date__week.sat,
  .c-eventcard-v2__date__week.土 {
    background-color: #59c3e1; }
  .c-eventcard-v2__date__week.sun,
  .c-eventcard-v2__date__week.日 {
    background-color: #e92355; }

.c-eventcard-v2__date__time {
  font-weight: 500;
  font-size: calc((14 / 375 ) * 100vw);
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-eventcard-v2__date__time {
      font-size: 20px; } }

.c-eventcard-v2__title {
  font-size: calc((14 / 375 ) * 100vw);
  font-weight: 700;
  line-height: 1.5;
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-eventcard-v2__title {
      flex-grow: 1;
      font-size: 17px; } }
  @media print, screen and (min-width: 768px) {
    .c-eventcard-v2__title a:hover {
      text-decoration: underline; } }
  @media screen and (max-width: 767px) {
    .c-eventcard-v2__title a:active {
      text-decoration: underline; } }
  .c-eventcard-v2__title a:before {
    content: '';
    display: block;
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: transparent; }

.c-eventcard-v2__desc {
  display: flex;
  align-items: center;
  margin-top: calc((16 / 375 ) * 100vw);
  line-height: 1; }
  @media print, screen and (min-width: 768px) {
    .c-eventcard-v2__desc {
      margin-top: 20px; } }
  .c-eventcard-v2__desc dt {
    color: var(--color_gray_v1);
    font-weight: 500;
    font-size: calc((10 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .c-eventcard-v2__desc dt {
        flex-shrink: 0;
        font-size: 14px; } }
  .c-eventcard-v2__desc dd {
    position: relative;
    z-index: 5;
    font-size: calc((12 / 375 ) * 100vw);
    color: var(--color_main); }
    @media print, screen and (min-width: 768px) {
      .c-eventcard-v2__desc dd {
        flex-grow: 1;
        font-size: 14px; } }
    @media print, screen and (min-width: 768px) {
      .c-eventcard-v2__desc dd a:hover {
        text-decoration: underline; } }
    @media screen and (max-width: 767px) {
      .c-eventcard-v2__desc dd a:active {
        text-decoration: underline; } }

@media print, screen and (min-width: 768px) {
  .c-facilitycard-wrap {
    display: grid;
    gap: 20px; } }

.c-facilitycard {
  position: relative;
  border-bottom: 1px solid var(--color_gray_v3);
  margin: 0 calc((-15 / 375 ) * 100vw);
  padding: calc((20 / 375 ) * 100vw) calc((15 / 375 ) * 100vw) calc((20 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard {
      margin: 0;
      padding: 0;
      display: grid;
      grid-template-columns: 320px 1fr;
      gap: 0;
      border: 1px solid var(--color_gray_v3);
      transition: background-color 0.3s ease; }
      .c-facilitycard:hover {
        background-color: #fbfbfb; } }
  @media screen and (max-width: 767px) {
    .c-facilitycard:active {
      background-color: #fbfbfb; } }
  .c-facilitycard .c-tagicon {
    margin-top: calc((12 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .c-facilitycard .c-tagicon {
        margin-top: 15px;
        display: -webkit-box; 
        -webkit-line-clamp: 1; 
        -webkit-box-orient: vertical; 
        overflow: hidden;} 
      .c-facilitycard .c-tagicon li {
        display: inline-block; }}
  .c-facilitycard .c-bookmarkbtn {
    position: absolute;
    z-index: 2;
    bottom: 0;
    right: 0; }
    @media print, screen and (min-width: 768px) {
      .c-facilitycard .c-bookmarkbtn {
        bottom: auto;
        top: 12px;
        right: 30px; } }
  .c-facilitycard:first-child {
    padding-top: 0; }

.c-facilitycard__slider {
  position: relative;
  z-index: 10;
  margin-right: calc((-15 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard__slider {
      margin: 0; } }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard__slider .swiper-slide a {
      transition: opacity 0.3s ease; }
      .c-facilitycard__slider .swiper-slide a:hover {
        opacity: 0.8; } }
  @media screen and (max-width: 767px) {
    .c-facilitycard__slider .swiper-slide a:active {
      opacity: 0.8; } }

@media print, screen and (min-width: 768px) {
  .c-facilitycard__detail {
    padding: 10px 35px 10px 38px; } }

.c-facilitycard__title {
  margin-top: calc((10 / 375 ) * 100vw);
  font-size: calc((14 / 375 ) * 100vw);
  font-weight: 700;
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard__title {
      flex-grow: 1;
      margin-top: 0;
      font-size: 20px; } }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard__title a:hover {
      text-decoration: underline; } }
  @media screen and (max-width: 767px) {
    .c-facilitycard__title a:active {
      text-decoration: underline; } }
  .c-facilitycard__title a:before {
    content: '';
    display: block;
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: transparent; }

.c-facilitycard__subtitle {
  font-size: calc((12 / 375 ) * 100vw);
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard__subtitle {
      font-size: 14px; } }

.c-facilitycard__category {
  display: flex;
  flex-wrap: wrap;
  font-size: calc((10 / 375 ) * 100vw);
  margin-top: calc((6 / 375 ) * 100vw);
  color: var(--color_gray_v2);
  line-height: 1.2; }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard__category {
      margin: 10px 0 0;
      font-size: 13px;
      display: -webkit-box; 
      -webkit-line-clamp: 1; 
      -webkit-box-orient: vertical; 
      overflow: hidden;} 
    .c-facilitycard__category dt,
    .c-facilitycard__category dd {
      display: inline-block; }}
  .c-facilitycard__category dt {
    font-weight: 400; }
  .c-facilitycard__category dd {
    margin-right: 1em; }

.c-facilitycard__footer {
  position: relative;
  padding-right: calc((35 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard__footer {
      position: static;
      padding: 0; } }

.c-facilitycard__aside {
  display: none; }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard__aside {
      display: block;
      margin-top: 10px; } }

.c-facilitycard__aside__expect {
  font-size: 1.2rem;
  line-height: 1.4167;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  color: var(--color_gray_v2); }

.c-facilitycard__aside__buttons {
  border-top: 1px solid var(--color_gray_v3);
  margin-top: 10px;
  padding-top: 10px;
  display: flex;
  gap: 10px;
  font-size: 1.5rem;
  font-weight: 500;
  text-align: center; }

.c-facilitycard__aside__buttons__cv,
.c-facilitycard__aside__buttons__more {
  position: relative;
  z-index: 10;
  padding: 2px;
  color: #fff;
  min-width: 150px;
  transition: opacity 0.3s ease; }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard__aside__buttons__cv:hover,
    .c-facilitycard__aside__buttons__more:hover {
      opacity: 0.5; } }
  @media screen and (max-width: 767px) {
    .c-facilitycard__aside__buttons__cv,
    .c-facilitycard__aside__buttons__more {
      pointer-events: none; } }

.c-facilitycard__aside__buttons__cv {
  background-color: #5acdc8; }

.c-facilitycard__aside__buttons__more {
  background-color: var(--color_main); }

.c-facilitycard-control {
  position: absolute;
  z-index: 5;
  top: 50%;
  z-index: 10;
  width: 13px;
  height: 20px;
  background: url("../img/common/icon_arw04.d76f3b6154e5.svg?ver=2") no-repeat 50% 50%/contain;
  cursor: pointer;
  filter: drop-shadow(0 0 2px black); }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard-control {
      transition: opacity 0.3s ease; }
      .c-facilitycard-control:hover {
        opacity: 0.5; } }
  @media screen and (max-width: 767px) {
    .c-facilitycard-control {
      display: none; } }
  .c-facilitycard-control.swiper-button-disabled {
    opacity: 0;
    pointer-events: none; }
  .c-facilitycard-control.is-prev {
    left: 10px;
    transform: rotate(180deg); }
  .c-facilitycard-control.is-next {
    right: 10px; }

.c-facilitycard-v2-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc((20 / 375 ) * 100vw) calc((12 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard-v2-wrap {
      gap: 35px 35px;
      grid-template-columns: repeat(4, 1fr); } }

.c-facilitycard-v2 {
  position: relative;
  border-bottom: 1px solid var(--color_gray_v3); }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard-v2:hover .c-facilitycard-v2__image img {
      opacity: 0.7; }
    .c-facilitycard-v2:hover .c-facilitycard-v2__title {
      text-decoration: underline; } }
  @media screen and (max-width: 767px) {
    .c-facilitycard-v2:active .c-facilitycard-v2__image img {
      opacity: 0.7; }
    .c-facilitycard-v2:active .c-facilitycard-v2__title {
      text-decoration: underline; } }
  @media screen and (max-width: 767px) {
    .c-facilitycard-v2 .c-fixicon {
      min-width: calc((50 / 375 ) * 100vw); } }
  .c-facilitycard-v2:after {
    content: '';
    display: block;
    position: absolute;
    z-index: 2;
    bottom: calc((5 / 375 ) * 100vw);
    right: 0;
    width: calc((10 / 375 ) * 100vw);
    height: calc((10 / 375 ) * 100vw);
    background: url("../img/common/icon_arw01.svg?ver=2") no-repeat 50% 50%/contain; }
    @media print, screen and (min-width: 768px) {
      .c-facilitycard-v2:after {
        right: 5px;
        bottom: 10px;
        width: 15px;
        height: 15px; } }

.c-facilitycard-v2__image {
  background-color: #fff; }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard-v2__image img {
      transition: opacity 0.3s; } }

.c-facilitycard-v2__detail {
  position: relative;
  padding: calc((10 / 375 ) * 100vw) 0 calc((20 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard-v2__detail {
      padding: 10px 0 40px; } }

.c-facilitycard-v2__title {
  font-size: calc((11 / 375 ) * 100vw);
  line-height: 1.3636;
  font-weight: 500;
  text-align: justify;
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-facilitycard-v2__title {
      font-size: 15px;
      line-height: 1.5333; } }

/* column */
@media print, screen and (min-width: 768px) {
  .c-colummncard-wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 45px 0; } }

.c-colummncard {
  display: grid;
  grid-template-columns: calc((100 / 375 ) * 100vw) 1fr;
  gap: calc((18 / 375 ) * 100vw);
  padding: calc((20 / 375 ) * 100vw) 0;
  border-bottom: 1px solid var(--color_gray_v3); }
  @media print, screen and (min-width: 768px) {
    .c-colummncard {
      border-bottom: none;
      grid-template-columns: 170px 1fr;
      gap: 30px;
      padding: 0; }
      .c-colummncard:nth-child(odd) {
        padding-right: 45px; }
      .c-colummncard:nth-child(even) {
        padding-left: 45px;
        border-left: 1px solid var(--color_gray_v3); }
      .c-colummncard:hover .c-colummncard__title {
        text-decoration: underline; }
      .c-colummncard:hover .c-colummncard__image {
        opacity: 0.5; } }
  @media screen and (max-width: 767px) {
    .c-colummncard:active .c-colummncard__title {
      text-decoration: underline; }
    .c-colummncard:active .c-colummncard__image {
      opacity: 0.5; } }
  .c-colummncard:first-child {
    padding-top: 0; }

@media print, screen and (min-width: 768px) {
  .c-colummncard__image {
    transition: opacity 0.3s; } }

.c-colummncard__image img {
  width: 100%;
  aspect-ratio: 1 / 1;
  -o-object-fit: cover;
     object-fit: cover; }

.c-colummncard__detail {
  position: relative;
  display: flex;
  align-items: center;
  padding: calc((14 / 375 ) * 100vw) 0; }
  @media print, screen and (min-width: 768px) {
    .c-colummncard__detail {
      padding: 18px 0; } }
  .c-colummncard__detail:after {
    content: '';
    display: inline-block;
    position: absolute;
    z-index: 2;
    bottom: 0;
    right: calc((6 / 375 ) * 100vw);
    width: calc((10 / 375 ) * 100vw);
    height: calc((10 / 375 ) * 100vw);
    background: url("../img/common/icon_arw01.svg?ver=2") no-repeat 50% 50%/contain; }
    @media print, screen and (min-width: 768px) {
      .c-colummncard__detail:after {
        right: 0;
        width: 15px;
        height: 15px; } }

.c-colummncard__title {
  font-size: calc((14 / 375 ) * 100vw);
  font-weight: 500;
  line-height: 1.5;
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .c-colummncard__title {
      font-size: 18px;
      font-weight: 500;
      line-height: 1.6111; } }

.c-linklist {
  display: grid;
  grid-template-columns: 100%;
  gap: calc((10 / 375 ) * 100vw);
  line-height: 1.2; }
  @media print, screen and (min-width: 768px) {
    .c-linklist {
      gap: 15px; } }
  .c-linklist > li > a {
    position: relative;
    display: inline-block;
    padding-left: 1.1em;
    font-size: calc((13 / 375 ) * 100vw);
    color: var(--color_gray_v2); }
    @media print, screen and (min-width: 768px) {
      .c-linklist > li > a {
        font-size: 18px; }
        .c-linklist > li > a:hover {
          text-decoration: underline; } }
    @media screen and (max-width: 767px) {
      .c-linklist > li > a:active {
        text-decoration: underline; } }
    .c-linklist > li > a:before {
      content: '';
      display: block;
      position: absolute;
      z-index: 2;
      top: 0.4em;
      left: 0;
      font-size: calc((10 / 375 ) * 100vw);
      width: calc((10 / 375 ) * 100vw);
      height: calc((10 / 375 ) * 100vw);
      background: url("../img/common/icon_arw01.svg?ver=2") no-repeat 50% 50%/contain; }
      @media print, screen and (min-width: 768px) {
        .c-linklist > li > a:before {
          top: 0.30em;
          font-size: 15px;
          width: 15px;
          height: 15px; } }

.p-top-mv {
  position: relative; }

.l-section {
  padding: calc((40 / 375 ) * 100vw) 0 calc((60 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .l-section {
      padding: 50px 0 100px; }}
  .l-section.ads_footer {
    border-bottom: solid 1px #EEE;
    padding: calc((40 / 375 ) * 100vw) 0 calc((40 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
    .l-section.ads_footer {
      padding: 50px 0; }}
  .l-section > .u-block:first-child > :first-child {
    margin-top: 0 !important; }
  .l-section--last {
    padding-bottom: calc((110 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .l-section--last {
        padding-bottom: 120px; } }
  .l-section--gray {
    background-color: #f8f8f8; }

@media print, screen and (min-width: 768px) {
  .p-top-about {
    display: grid;
    grid-template-columns: 1fr 417px;
    gap: 0 30px; } }

.p-top-about__figure {
  margin: calc((40 / 375 ) * 100vw) auto calc((10 / 375 ) * 100vw);
  width: 90%; }
  @media print, screen and (min-width: 768px) {
    .p-top-about__figure {
      width: auto;
      margin: 0; } }

.p-top-about__logo {
  width: calc((220 / 375 ) * 100vw);
  margin: 0 0 calc((20 / 375 ) * 100vw);
  line-height: 1; }
  @media print, screen and (min-width: 768px) {
    .p-top-about__logo {
      width: 300px;
      margin: 0 0 20px; } }
  .p-top-about__logo img {
    width: 100%; }

.p-top-about__title {
  font-size: calc((14 / 375 ) * 100vw);
  font-weight: 700;
  line-height: 1.7143;
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .p-top-about__title {
      margin-bottom: 6px;
      font-size: 18px; }
      .p-top-about__title + * {
        margin-top: 0 !important; } }

.p-top-about__text {
  margin-top: 1em;
  font-size: calc((11 / 375 ) * 100vw);
  line-height: 1.4545;
  color: var(--color_gray_v2); }
  @media print, screen and (min-width: 768px) {
    .p-top-about__text {
      margin-top: 1.5em;
      font-size: 14px;
      line-height: 1.7143; } }

.p-top-about__button {
  border: 1px solid #666666;
  display: block;
  margin: calc((20 / 375 ) * 100vw) auto 0;
  padding: calc((8 / 375 ) * 100vw) calc((10 / 375 ) * 100vw);
  width: 100%;
  font-size: calc((13 / 375 ) * 100vw);
  color: #666666;
  text-align: center; }
  @media print, screen and (min-width: 768px) {
    .p-top-about__button {
      margin: 40px auto 0;
      padding: 12px 8px;
      width: 400px;
      font-weight: 500;
      font-size: 13px;
      transition: all 0.3s ease; }
      .p-top-about__button:hover {
        color: #fff;
        background-color: var(--color_main); } }
  @media screen and (max-width: 767px) {
    .p-top-about__button:active {
      color: #fff;
      background-color: var(--color_main); } }

.p-top-search {
  padding-top: calc((25 / 375 ) * 100vw);
  padding-bottom: calc((40 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .p-top-search {
      padding-top: 30px;
      padding-bottom: 40px; } }

.l-header {
  position: sticky;
  z-index: 1000;
  top: 0;
  left: 0;
}
.p-header {
  width: 100%;
  background-color: var(--color_main);
  line-height: 1; }

.p-header__inner {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 54px; }
  @media print, screen and (min-width: 768px) {
    .p-header__inner {
      justify-content: space-between;
      margin: 0 auto;
      padding: 10px 0;
      height: 100px;
      width: calc(100% - 40px);
      max-width: 1200px; } }

.p-header__logo {
  width: calc((125 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .p-header__logo {
      width: 238px; } }

@media print, screen and (min-width: 768px) {
  .p-header__utility {
    position: absolute;
    z-index: 5;
    bottom: 20px;
    right: 10px;
    display: flex;
    align-items: center;
    gap: 0 15px;
    font-size: 1.5rem; }
    .p-header__user + .p-header__utility {
      margin-bottom: 5px;
      margin-right: 40px; } }

.p-header__utility__link {
  border: 1px solid #fff; }
  @media screen and (max-width: 767px) {
    .p-header__utility__link {
      position: absolute;
      z-index: 5;
      top: 50%;
      right: calc((15 / 375 ) * 100vw);
      transform: translateY(-50%);
      color: #fff;
      padding: calc((4 / 375 ) * 100vw) calc((6 / 375 ) * 100vw);
      font-size: calc((11 / 375 ) * 100vw);
      font-weight: 500;
      text-align: center;
      display: block;
      margin-left: auto; } }
  @media print, screen and (min-width: 768px) {
    .p-header__utility__link {
      padding: 6px 12px;
      color: #fff;
      transition: opacity 0.3s ease; }
      .p-header__utility__link:hover {
        opacity: 0.7; } }
  @media screen and (max-width: 767px) {
    .p-header__utility__link:active {
      opacity: 0.7; } }

.p-header__utility__link-v2 {
  position: relative;
  padding-left: 18px;
  font-weight: 500;
  color: #fff;
  transition: opacity 0.3s ease;
  font-size: 1.5rem;
  line-height: 1.6; }
  @media print, screen and (min-width: 768px) {
    .p-header__utility__link-v2:hover {
      opacity: 0.7; } }
  @media screen and (max-width: 767px) {
    .p-header__utility__link-v2:active {
      opacity: 0.7; } }
  .p-header__utility__link-v2:before {
    position: absolute;
    z-index: 2;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    content: '';
    display: block;
    width: 18px;
    aspect-ratio: 18 / 20;
    background: #fff;
    -webkit-mask: url("../img/common/gnav_ic01.svg?ver=2") no-repeat 50% 50%/contain;
            mask: url("../img/common/gnav_ic01.svg?ver=2") no-repeat 50% 50%/contain; }
  .p-header__utility__link-v2.is-set01 {
    padding-left: 25px;
    margin-right: 15px; }
  .p-header__utility__link-v2.is-set02 {
    margin-right: 15px; }
    .p-header__utility__link-v2.is-set02:before {
      margin-top: 1px;
      width: 14px;
      aspect-ratio: 14 / 16;
      -webkit-mask: url("../img/common/gnav_ic02.svg?ver=2") no-repeat 50% 50%/contain;
              mask: url("../img/common/gnav_ic02.svg?ver=2") no-repeat 50% 50%/contain; }

.p-header__user {
  position: absolute;
  z-index: 5;
  top: 50%;
  right: calc((15 / 375 ) * 100vw);
  transform: translateY(-50%);
  width: calc((30 / 375 ) * 100vw);
  display: block; }
  .p-header__user img {
    width: 100%;
    border-radius: 100px; }
  @media print, screen and (min-width: 768px) {
    .p-header__user {
      top: auto;
      bottom: 20px;
      right: 0;
      transform: none;
      width: 40px; } }

.l-footer {
  position: relative; }

.p-footer__top {
  padding: calc((50 / 375 ) * 100vw) calc((36 / 375 ) * 100vw) calc((70 / 375 ) * 100vw);
  background-color: #3c3c3c;
  color: #fff; }
  @media print, screen and (min-width: 768px) {
    .p-footer__top {
      padding: 85px 0 70px; } }

.p-footer__bottom {
  text-align: center;
  background-color: var(--color_main);
  color: #fff; }

.p-footer__nav {
  display: grid;
  grid-template-columns: 100%;
  gap: calc((40 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .p-footer__nav {
      gap: 40px;
      grid-template-columns: 1fr 1fr 1fr;
      max-width: 1000px;
      margin: 0 auto; } }

.p-footer__nav__title {
  border-bottom: 1px solid #fff;
  margin-bottom: calc((14 / 375 ) * 100vw);
  padding-bottom: calc((6 / 375 ) * 100vw);
  font-weight: 700;
  font-family: var(--font_sub);
  font-size: calc((15 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .p-footer__nav__title {
      margin: 0 0 14px;
      padding: 0 0 14px;
      font-size: 16px;
      line-height: 1; } }

.p-footer__nav__list {
  display: grid;
  grid-template-columns: auto;
  gap: 0.2em;
  font-size: calc((12 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .p-footer__nav__list {
      font-size: 12px; } }
  @media print, screen and (min-width: 768px) {
    .p-footer__nav__list > li > a:hover {
      text-decoration: underline; } }
  @media screen and (max-width: 767px) {
    .p-footer__nav__list > li > a:active {
      text-decoration: underline; } }
  .p-footer__nav__list > li > a[target="_blank"]:after {
    position: relative;
    top: -0.1em;
    content: '';
    margin-left: 0.6em;
    vertical-align: middle;
    display: inline-block;
    background: #000;
    width: calc((10 / 375 ) * 100vw);
    height: calc((10 / 375 ) * 100vw);
    background: url("../img/common/icon_blank.82aef6dcbb7b.svg?ver=2") no-repeat 50% 50%/contain; }
    @media print, screen and (min-width: 768px) {
      .p-footer__nav__list > li > a[target="_blank"]:after {
        width: 10px;
        height: 10px; } }

.p-footer__copyright {
  padding: calc((18 / 375 ) * 100vw);
  font-size: calc((9 / 375 ) * 100vw);
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1; }
  @media print, screen and (min-width: 768px) {
    .p-footer__copyright {
      padding: 18px;
      font-size: 13px; } }

.js-accordion__contents {
  height: 0;
  overflow: hidden;
  transition: height 0.3s; }
  @media print, screen and (min-width: 768px) {
    .js-accordion__contents {
      height: auto; } }

@media print, screen and (min-width: 768px) {
  .p-search {
    display: grid;
    grid-template-columns: auto 114px;
    max-width: 880px;
    margin: 0 auto; } }

.p-search--static {
  margin-top: calc((-15 / 375 ) * 100vw);
  margin-bottom: calc((35 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .p-search--static {
      margin-top: 0;
      margin-bottom: 0; } }

.p-search--fixed {
  display: none; }
  @media screen and (max-width: 767px) {
    .p-search--fixed {
      display: block;
      position: fixed;
      z-index: 100;
      top: 54px;
      left: 0;
      width: 100%;
      background-color: #fff;
      box-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
      transition: transform ease 0.7s 0.1s;
      transform: translateY(-200%); }
      .is-fixedsearch-show .p-search--fixed {
        transform: translateY(0%); }
      .p-search--fixed .p-search {
        padding: calc((8 / 375 ) * 100vw) calc((15 / 375 ) * 100vw); } }

.p-search__filter {
  margin-right: -5px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px 5px;}
  @media print, screen and (min-width: 768px) {
    .p-search__filter {
      margin-right: -1px;
      flex-wrap: nowrap;
      gap: 0; } }


.p-search__select {
  width: calc(33.333% - 5px);
  position: relative; }
  .p-search__filter--single .p-search__select { width: calc(100% - 5px);} 
  .p-search__select:last-child:nth-child(2),
  .p-search__select:last-child:nth-child(4) { width: 100%;}
  .p-search__select:last-child:nth-child(5) { width: 66.66%;}
  @media print, screen and (min-width: 768px) {
      .p-search__select {
        width:100%;}
      .p-search__select #id_keyword {
        width: 240px;
        min-width: 240px; }
      .p-search__filter--single .p-search__select #id_keyword {
        width: 594px;
      }}
  .p-search__select:not(:has(#id_keyword)):before {
    position: absolute;
    z-index: 2;
    top: calc(50% - 3px);
    right: calc((12 / 375 ) * 100vw);
    border: 4px solid transparent;
    border-top-color: var(--color_gray_v3);
    content: "";
    pointer-events: none; }
    @media print, screen and (min-width: 768px) {
      .p-search__select:not(:has(#id_keyword)):before {
        right: 15px; } }
  .p-search__select select,
  .p-search__select input {
    width: 100%;
    border: 1px solid var(--color_gray_v3);
    padding: calc((8 / 375 ) * 100vw) calc((12 / 375 ) * 100vw);
    padding-right: 30px;
    color: var(--color_gray_v2);
    font-size: calc((12 / 375 ) * 100vw);
    font-weight: 500; }
    .p-search__select select {
      cursor: pointer; }
    .p-search__select select:focus,
    .p-search__select input:focus {
      position: relative;
      z-index: 5;
      border-color: var(--color_gray_v2); }
    .p-search__select select option:disabled {
      color: var(--color_gray_v3); }
    @media print, screen and (min-width: 768px) {
      .p-search__select select,
      .p-search__select input {
        padding: 0 26px 0 15px;
        height: 46px;
        font-size: 1.3rem; } }
  @media print, screen and (min-width: 768px) {
    .p-search__select + .p-search__select {
      margin-left: -1px; } }
  
  #id_keyword {
    width: calc(100% - 5px); }
  @media print, screen and (min-width: 768px) {
    #id_keyword {
      width: 240px; } }

/* .p-search__input {
  margin-top: calc((5 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .p-search__input {
      margin: 0 -1px; } }
  .p-search__input input {
    border: 1px solid var(--color_gray_v3);
    width: 100%;
    padding: calc((8 / 375 ) * 100vw) calc((12 / 375 ) * 100vw);
    color: var(--color_gray_v4);
    font-size: calc((12 / 375 ) * 100vw);
    font-weight: 500; }
    @media print, screen and (min-width: 768px) {
      .p-search__input input {
        height: 100%;
        padding: 8px 15px;
        font-size: 1.3rem; } }
    .p-search__input input:focus {
      position: relative;
      z-index: 5;
      border-color: var(--color_gray_v2); }
    .p-search__input input::-moz-placeholder {
      color: var(--color_gray_v4); }
    .p-search__input input::placeholder {
      color: var(--color_gray_v4); } */

.p-search__submit {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: calc((5 / 375 ) * 100vw);
  height: calc((40 / 375 ) * 100vw);
  width: 100%;
  background-color: var(--color_main);
  color: #fff;
  font-size: calc((14 / 375 ) * 100vw);
  font-weight: 400; }
  @media print, screen and (min-width: 768px) {
    .p-search__submit {
      margin: 0;
      width: 100%;
      height: 46px;
      font-size: 1.4rem;
      transition: opacity 0.3s; }
      .p-search__submit:focus, .p-search__submit:hover {
        opacity: 0.7; } }
  @media screen and (max-width: 767px) {
    .p-search__submit:active {
      opacity: 0.7; } }
  .p-search__submit:before {
    position: relative;
    margin-right: 0.5em;
    content: '';
    display: block;
    z-index: 2;
    background: url("../img/common/icon_search.428c99d0c1ae.svg?ver=2") no-repeat 50% 50%/contain;
    width: calc((16 / 375 ) * 100vw);
    height: calc((16 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-search__submit:before {
        width: 14px;
        height: 14px; } }

.p-futsal-hero {
  position: relative;
  overflow: hidden;
  background-color: #fff; }

.p-futsal-hero__title {
  width: calc((218 / 375 ) * 100vw);
  position: absolute;
  z-index: 50;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  filter: drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.8)); }
  @media print, screen and (min-width: 768px) {
    .p-futsal-hero__title {
      width: 456px;
      width: calc((456 / 1440 ) * 100vw); } }
  .p-futsal-hero__title img {
    width: 100%; }

.p-futsal-hero__bg img {
  width: 100%; }

@keyframes flowtext {
  0% {
    transform: translateX(0); }
  100% {
    transform: translateX(-100%); } }

.p-futsal-search {
  padding: calc((25 / 375 ) * 100vw) 0 calc((50 / 375 ) * 100vw);
  background-color: #fff; }
  @media print, screen and (min-width: 768px) {
    .p-futsal-search {
      padding: 30px 0 20px; } }

.p-futsal-parallax {
  position: relative;
  padding: calc((90 / 375 ) * 100vw) 0 calc((100 / 375 ) * 100vw);
  color: #fff;
  overflow: hidden; }
  @media print, screen and (min-width: 768px) {
    .p-futsal-parallax {
      margin: 0;
      padding: calc((180 / 1440 ) * 100vw) 0 calc((140 / 1440 ) * 100vw); }
      .p-futsal-parallax.is-bg01 {
        background: url("../img/futsal/futsal_bg02_pc.fc31a8664b84.webp?ver=250515") no-repeat 50% 50%/cover;
        background-attachment: fixed; }
      .p-futsal-parallax.is-bg02 {
        background: url("../img/futsal/futsal_bg03_pc.567c46048704.webp?ver=250515") no-repeat 50% 50%/cover;
        background-attachment: fixed; }
      .p-futsal-parallax.is-bg03 {
        background: url("../img/futsal/futsal_bg04_pc.c0abcd064503.webp?ver=250515") no-repeat 50% 50%/cover;
        background-attachment: fixed; } }
  .p-futsal-parallax--last {
    padding: calc((140 / 375 ) * 100vw) 0 calc((110 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-parallax--last {
        padding-top: calc((220 / 1440 ) * 100vw);
        padding-bottom: calc((100 / 1440 ) * 100vw); } }
    .p-futsal-parallax--last:after {
      display: none; }
  .p-futsal-parallax:before, .p-futsal-parallax:after {
    content: '';
    position: absolute;
    z-index: 2;
    left: 0;
    width: 100%;
    height: calc((50 / 375 ) * 100vw);
    background-color: #fff; }
    @media print, screen and (min-width: 768px) {
      .p-futsal-parallax:before, .p-futsal-parallax:after {
        height: calc((120 / 1440 ) * 100vw); } }
  .p-futsal-parallax:before {
    top: -1px;
    clip-path: polygon(0 0, 100% 0%, 0% 100%); }
  .p-futsal-parallax:after {
    bottom: -1px;
    clip-path: polygon(0% 100%, 100% 100%, 100% 0%); }
  .p-futsal-parallax .c-headline-v1 {
    border-color: #fff;
    color: #fff; }
  .p-futsal-parallax .c-headline-v1__main {
    filter: drop-shadow(1px 1px 1px rgba(0, 0, 0, 0.8)); }
  .p-futsal-parallax .c-headline-v1__sub {
    color: #fff;
    filter: drop-shadow(1px 1px 1px rgba(0, 0, 0, 0.8)); }
  .p-futsal-parallax .c-linklist > li > a {
    text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.6);
    font-weight: 500;
    color: #fff; }
  @media screen and (max-width: 767px) {
    .p-futsal-parallax .c-facilitycard-v2-wrap {
      gap: calc((12 / 375 ) * 100vw); } }
  .p-futsal-parallax .c-facilitycard-v2 {
    border: none;
    background: #fff;
    box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.4); }
    @media screen and (max-width: 767px) {
      .p-futsal-parallax .c-facilitycard-v2:after {
        bottom: calc((5 / 375 ) * 100vw);
        right: calc((5 / 375 ) * 100vw); } }
    @media print, screen and (min-width: 768px) {
      .p-futsal-parallax .c-facilitycard-v2:after {
        right: 15px; } }
  .p-futsal-parallax .c-facilitycard-v2__detail {
    padding-inline: calc((6 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-parallax .c-facilitycard-v2__detail {
        padding-inline: 10px; } }

.p-futsal-parallax__inner {
  position: relative;
  z-index: 5; }

.p-futsal-parallax-bg {
  position: sticky;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  background-color: #fff; }
  @media print, screen and (min-width: 768px) {
    .p-futsal-parallax-bg {
      display: none; } }

.p-futsal-parallax-bg__item {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  min-height: 100vh;
  transition: opacity 0.1s; }
  .p-futsal-parallax-bg__item:nth-child(n+2) {
    opacity: 0; }
  .p-futsal-parallax-bg__item img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover; }
  .p-futsal-parallax-bg__item.is-active {
    opacity: 1; }
  .p-futsal-parallax-bg__item.is-footer:after {
    content: '';
    display: block;
    position: absolute;
    z-index: 100;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 50%;
    background-color: var(--color_main); }

.p-futsal-section {
  padding: calc((80 / 375 ) * 100vw) 0 calc((50 / 375 ) * 100vw);
  background-color: #fff; }
  @media print, screen and (min-width: 768px) {
    .p-futsal-section {
      padding: 70px 0 50px; } }

.p-futsal-result {
  margin-bottom: calc((25 / 375 ) * 100vw);
  font-weight: 500;
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.6); }
  @media print, screen and (min-width: 768px) {
    .p-futsal-result {
      margin: 12px 0 20px;
      font-size: 1.7rem; } }

.p-futsal-result__count {
  font-size: 123%; }

.p-futsal-iconset {
  position: relative; }

.p-futsal-iconset__icon {
  position: absolute;
  z-index: 5;
  bottom: calc((5 / 375 ) * 100vw);
  right: calc((0 / 375 ) * 100vw);
  width: calc((65 / 375 ) * 100vw);
  opacity: 0;
  transform: translateX(15px);
  transition: ease 0.6s;
  transition-property: transform, opacity; }
  .is-show .p-futsal-iconset__icon {
    opacity: 1;
    transform: translateX(0px); }
  .p-futsal-iconset__icon img {
    width: 100%;
    height: auto; }
  .p-futsal-iconset__icon.is-size01 {
    width: calc((65 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-iconset__icon.is-size01 {
        width: 94px; } }
  .p-futsal-iconset__icon.is-size02 {
    width: calc((77 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-iconset__icon.is-size02 {
        width: 115px; } }
  .p-futsal-iconset__icon.is-size03 {
    width: calc((67 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-iconset__icon.is-size03 {
        width: 101px; } }
  .p-futsal-iconset__icon.is-size04 {
    width: calc((95 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-iconset__icon.is-size04 {
        width: 143px; } }

.p-futsal-eventcard-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: calc((4 / 375 ) * 100vw); }
  @media print, screen and (min-width: 768px) {
    .p-futsal-eventcard-wrap {
      grid-template-columns: repeat(3, 1fr);
      gap: 20px; } }

.p-futsal-eventcard {
  position: relative;
  display: flex;
  align-items: center;
  border: 1px solid #c8c9ca;
  padding: calc((13 / 375 ) * 100vw);
  height: calc((80 / 375 ) * 100vw);
  border-radius: 3px;
  background-color: #fff; }
  @media print, screen and (min-width: 768px) {
    .p-futsal-eventcard {
      border-radius: 4px;
      border-width: 2px;
      padding: 30px;
      height: 104px; }
      .p-futsal-eventcard:hover .p-futsal-eventcard__detail {
        opacity: 0.5; }
      .p-futsal-eventcard:hover .p-futsal-eventcard__image img {
        transform: scale(1.1); } }
  @media screen and (max-width: 767px) {
    .p-futsal-eventcard:active .p-futsal-eventcard__detail {
      opacity: 0.5; }
    .p-futsal-eventcard:active .p-futsal-eventcard__image img {
      transform: scale(1.1); } }

.p-futsal-eventcard__detail {
  font-size: calc((12 / 375 ) * 100vw);
  font-weight: 500;
  color: var(--color_gray_v2);
  transition: opacity 0.3s; }
  @media print, screen and (min-width: 768px) {
    .p-futsal-eventcard__detail {
      font-size: 1.6rem; } }

.p-futsal-eventcard__image {
  position: absolute;
  z-index: 2;
  top: 50%;
  right: calc((10 / 375 ) * 100vw);
  transform: translateY(-50%);
  width: calc((60 / 375 ) * 100vw); }
  .p-futsal-eventcard__image.is-size01 {
    right: calc((20 / 375 ) * 100vw);
    width: calc((42 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-eventcard__image.is-size01 {
        right: 24px;
        width: 55px; } }
  .p-futsal-eventcard__image.is-size02 {
    right: calc((25 / 375 ) * 100vw);
    width: calc((28 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-eventcard__image.is-size02 {
        right: 37px;
        width: 37px; } }
  .p-futsal-eventcard__image.is-size03 {
    right: calc((13 / 375 ) * 100vw);
    width: calc((60 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-eventcard__image.is-size03 {
        right: 20px;
        width: 78px; } }
  .p-futsal-eventcard__image.is-size04 {
    right: calc((15 / 375 ) * 100vw);
    width: calc((50 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-eventcard__image.is-size04 {
        right: 24px;
        width: 64px; } }
  .p-futsal-eventcard__image.is-size05 {
    right: calc((12 / 375 ) * 100vw);
    width: calc((68 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-eventcard__image.is-size05 {
        right: 12px;
        width: 87px; } }
  .p-futsal-eventcard__image.is-size06 {
    right: calc((12 / 375 ) * 100vw);
    width: calc((65 / 375 ) * 100vw); }
    @media print, screen and (min-width: 768px) {
      .p-futsal-eventcard__image.is-size06 {
        right: 20px;
        width: 84px; } }
  .p-futsal-eventcard__image img {
    transition: transform 0.3s;
    width: 100%; }

.c-gnav {
  position: fixed;
  z-index: 400;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateX(-100%);
  transition: ease transform 0.3s;
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px); }
  body.is-gnav-open .c-gnav {
    transform: translateX(0%); }
  @media print, screen and (min-width: 768px) {
    .c-gnav {
      display: none; } }

.c-gnav__inner {
  max-height: 100dvh;
  overflow-y: auto;
  min-height: 100dvh;
  padding: 54px 0 0; }

.c-gnav-contents {
  width: 76%;
  margin-top: 10px;
  margin-bottom: 20px;
  box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.4); }

.c-gnav-section--hr:before {
  content: '';
  display: block;
  height: 10px;
  background-color: #eeeeee;
  border-top: 1px solid var(--color_gray_v3);
  border-bottom: 1px solid var(--color_gray_v3); }

.c-gnav-section__title {
  padding: 6px 20px;
  background-color: var(--color_main);
  color: #fff;
  font-weight: 500;
  font-size: calc((14 / 375 ) * 100vw); }

.c-gnav-section__list__item {
  position: relative;
  display: grid;
  grid-template-columns: 35px 1fr;
  align-items: center;
  padding: 10px 40px 10px 20px;
  border-bottom: 1px solid var(--color_gray_v3);
  background-color: #fff; }
  @media print, screen and (min-width: 768px) {
    .c-gnav-section__list__item:hover {
      background-color: #fbfbfb; } }
  @media screen and (max-width: 767px) {
    .c-gnav-section__list__item:active {
      background-color: #fbfbfb; } }
  .c-gnav-section__list__item:last-child {
    border-bottom: none; }
  .c-gnav-section__list__item:after {
    position: absolute;
    z-index: 2;
    top: calc(50% - 5px);
    right: 20px;
    width: 10px;
    height: 10px;
    transform: rotate(45deg);
    border-top: 1px solid var(--color_gray_v2);
    border-right: 1px solid var(--color_gray_v2);
    content: "";
    display: inline-block;
    transition: ease all 0.3s; }

.c-gnav-section__list__item__icon {
  line-height: 1; }
  .c-gnav-section__list__item__icon.is-size01 img {
    border-radius: 3px;
    width: 28px; }
  .c-gnav-section__list__item__icon.is-size02 img {
    margin-left: 6px;
    width: 19px; }
  .c-gnav-section__list__item__icon.is-size03 img {
    margin-left: 8px;
    width: 15px; }
  .c-gnav-section__list__item__icon.is-size04 img {
    margin-left: 7px;
    width: 14px; }
  .c-gnav-section__list__item__icon.is-size05 img {
    margin-left: 4px;
    width: 19px; }
  .c-gnav-section__list__item__icon.is-size06 img {
    margin-left: 6px;
    width: 19px; }
  .c-gnav-section__list__item__icon.is-size07 img {
    margin-left: 2px;
    width: 28px;
    border-radius: 28px; }

.c-gnav-section__notfound {
  background: #FFF;
  padding: 10px 20px;
}

.c-gnav-close {
  position: relative;
  display: block;
  margin-top: -1px;
  border-top: 1px solid var(--color_gray_v3);
  width: 100%;
  height: 56px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: #fff; }
  .c-gnav-close:before, .c-gnav-close:after {
    position: absolute;
    z-index: 2;
    top: calc(50% - 1px);
    right: 20px;
    content: "";
    display: block;
    width: 23px;
    height: 2px;
    background-color: var(--color_main);
    transform: rotate(-45deg); }
  .c-gnav-close:after {
    transform: rotate(45deg); }
  @media print, screen and (min-width: 768px) {
    .c-gnav-close:hover:before, .c-gnav-close:hover:after {
      opacity: 0.7; } }
  @media screen and (max-width: 767px) {
    .c-gnav-close:active:before, .c-gnav-close:active:after {
      opacity: 0.7; } }

.animation-fadeup {
  opacity: 0;
  transform: translateY(20px);
  transition: 0.6s ease;
  transition-property: opacity, transform; }
  .animation-fadeup.is-show {
    opacity: 1;
    transform: translateY(0px); }

.order-hidden { display: none; }

.ads_dummy span {
  display: block;
  margin: 0 auto;
  background: var(--color_gray_v2);
  color: #FFF;
  text-align: center;
  font-size: 12px;
  font-size: 1.2rem;
}
.ads_dummy.header span {
  width: 100%;
  height: 100px;
  line-height: 100px; }
  @media screen and (min-width: 768px) {
    .ads_dummy.header { display: none;}
  }
.ads_dummy.left span {
  width: 160px;
  height: 600px;
  padding: 280px 20px;
  line-height: 20px; }
  @media screen and (max-width: 767px) {
    .ads_dummy.left { display: none;}
  }
.ads_dummy.overlay {
  position: sticky;
  bottom: 0;
  width: 100%;
  background: rgba(0, 0, 0, 0.35);
  z-index: 10000; }
  @media screen and (min-width: 768px) {
    .ads_dummy.overlay:not(.pc_overlay) { display: none;}
  }
  @media screen and (max-width: 767px) {
    .ads_dummy.overlay.pc_overlay { display: none;}
  }
.ads_dummy.overlay span {
  width: 100%;
  height: 100px;
  line-height: 100px; }
  
.ads_dummy.pc_overlay span {
  max-width: 100%;
  width: 728px;
  height: 90px;
  line-height: 90px; }
.ads_dummy.bottom span {
  width: 336px;
  line-height: 280px; }

.ads_header {
  text-align: center; }
.ads_footer {
  display: block;
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
  background: #FFF; }
  @media print, screen and (min-width: 768px) {
    .ads_footer {
      display: flex;
      display: -ms-flexbox;
      display: -webkit-flex;
      justify-content: center; }}
.ads_footer .ads_footer_inner + .ads_footer_inner {
  margin: 20px 0 0 0; }
  @media print, screen and (min-width: 768px) {
    .ads_footer .ads_footer_inner + .ads_footer_inner { margin: 0 0 0 20px; }}


#sticky_wrapper {
  position: relative;
  margin: 0 auto; }
  @media print, screen and (min-width: 768px) {
  #sticky_wrapper {
    min-height: 640px; }}
#sticky_wrapper .ads_side_wrapper {
  position: absolute;
  left: calc(50% - 800px);
  top: 0;
  height: 100%;
  z-index: 10; }
  #sticky_wrapper .ads_side_wrapper__top {
    padding: 50px 0; }
  #sticky_wrapper .ads_side_wrapper__sports_top {
    padding: 0 0 50px; }
  #sticky_wrapper .ads_side_wrapper__futsal_top {
    padding: calc((180 / 1440) * 100vw) 0 calc((50 / 1440) * 100vw);
  }
#sticky_wrapper .ads_side {
  position: sticky;
  left: 0;
  top: 140px;
}

.ui-dialog {
  max-width: calc(100% - 20px);
  width: 600px;
  z-index: 10001;
}

.ui-dialog .ui-dialog-titlebar {
  position: relative;
  margin: 0 auto;
  padding: 14px 44px;
  border-radius: 10px 10px 0 0;
  border: none;
  background: var(--color_main);
  font-size: 16px;
  font-size: 1.6rem;
  color: #FFF;
  text-align: center;
  font-weight: normal;
  cursor: move;
  line-height: 1; }

.ui-dialog .ui-dialog-title {
  margin: 0; }

.ui-dialog .ui-dialog-titlebar-close {
  position: absolute;
  top: 10px;
  right: 10px;
  margin: 0;
  width: 24px;
  height: 24px;
  border-radius: 5px;
  background: rgba(0, 0, 0, 0.2) url("../img/close10.47861809982d.png") no-repeat center;
  background-size: 10px 10px;
  font-size: 0; }
.ui-dialog .ui-dialog-titlebar-close:hover { background-color: rgba(0, 0, 0, 0.4); }

.ui-dialog .ui-dialog-content {
    text-align: center;
    overflow-y: auto;
    padding: 20px 10px;
    background: #FFF;}
  @media print, screen and (min-width: 768px) {
    .ui-dialog .ui-dialog-content { padding: 30px 40px; }}

.ui-dialog .ui-dialog-content p {
  line-height: 1.5;
  font-size: 14px;
  font-size: 1.4rem; }
.ui-dialog .ui-dialog-content small {
  font-size: 12px;
  font-size: 1.2rem;
  margin-top: 1em; }
.ui-dialog .ui-dialog-content .btns {
  font-size: 0;
  margin: 20px 0 0; }
.ui-dialog .ui-dialog-content .btns a {
  display: inline-block;
  height: auto;
  width: 100px;
  margin: 0;
  padding: 15px 0;
  border: none;
  border-radius: 5px;
  background: #DB4D47;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
  color: #FFF;
  outline: none;
  vertical-align: top;
  transition: opacity 0.2s ease;
  cursor: pointer; }
  @media print, screen and (min-width: 768px) {
    .ui-dialog .ui-dialog-content .btns a {
      width: 150px;
      font-size: 16px;
      font-size: 1.6rem; }}
.ui-dialog .ui-dialog-content .btns a + a { margin-left: 10px;}
.ui-dialog .ui-dialog-content .btns a:active {
  opacity: .7; }
  @media print, screen and (min-width: 768px) {
    .ui-dialog .ui-dialog-content .btns a:active,
    .ui-dialog .ui-dialog-content .btns a:hover { opacity: .7; }}
#dialog-follow .btns a {
  background: #009FD2; }
#dialog-follow .btns a + a {
  background: #3C925E; }

.ui-dialog .ui-dialog-buttonpane {
  margin: 0 auto;
  padding: 20px 10px;
  border: none;
  border-top: solid 1px #DCE1E9;
  background: #FFF;
  border-radius: 0 0 10px 10px;
  text-align: center;
  font-size: 0; }
  @media print, screen and (min-width: 768px) {
    .ui-dialog .ui-dialog-buttonpane {
      padding: 20px; }}

.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset button {
  display: inline-block;
  height: auto;
  width: 100px;
  margin: 0;
  padding: 15px 0;
  border: none;
  border-radius: 5px;
  background: #DB4D47;
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1;
  color: #FFF;
  outline: none;
  vertical-align: top;
  transition: opacity 0.2s ease;
  cursor: pointer; }
  @media print, screen and (min-width: 768px) {
    .ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset button {
      width: 150px;
      font-size: 16px;
      font-size: 1.6rem; }}
.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset button + button {
  margin-left: 10px;
  background: var(--color_main);}
  @media print, screen and (min-width: 768px) {
    .ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset button + button {
      margin-left: 20px; }}

.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset button:active {
  opacity: .7; }
  @media print, screen and (min-width: 768px) {
    .ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset button:active,
    .ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset button:hover { opacity: .7; }}

.ui-widget-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.6);
  opacity: 1;
  z-index: 10000; }