@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: antialiased;
}

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

ul,
ol {
  list-style: none;
}

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

button,
input,
select,
textarea {
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  font-family: inherit;
  font-size: inherit;
  color: inherit;
  outline: none;
}

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

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

select, input {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  border: none;
  outline: none;
}
select::-ms-expand, input::-ms-expand {
  display: none;
}
select:focus, input:focus {
  outline: none;
}

@media (min-width: 1024px) {
  a, button {
    cursor: pointer;
    transition: opacity 0.3s ease;
  }
  a:hover, button:hover {
    opacity: 0.6;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  line-height: 1.5;
  color: #000000;
}

html, body, p, li {
  font-size: 16px;
  font-weight: 400;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 900;
}

/**
 * Swiper 11.2.0
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2025 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: January 2, 2025
 */
@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;
}

:host {
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  z-index: 1;
}

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

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

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  box-sizing: content-box;
}

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

.swiper-horizontal {
  touch-action: pan-y;
}

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

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

.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-css-mode .swiper-wrapper {
  perspective: 1200px;
}

.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-3d {
  perspective: 1200px;
}

.swiper-3d .swiper-cube-shadow, .swiper-3d .swiper-slide {
  transform-style: preserve-3d;
}

.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-css-mode.swiper-horizontal > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}

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

.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
  scroll-snap-type: none;
}

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

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

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

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

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

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

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

.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-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-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: var(--swiper-navigation-top-offset, 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: 0.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 svg, .swiper-button-prev svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  transform-origin: center;
}

.swiper-rtl .swiper-button-next svg, .swiper-rtl .swiper-button-prev svg {
  transform: rotate(180deg);
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
  left: var(--swiper-navigation-sides-offset, 10px);
  right: auto;
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 10px);
  left: auto;
}

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

.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:after, .swiper-rtl .swiper-button-next:after {
  content: "prev";
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 10px);
  left: auto;
}

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

.swiper-pagination {
  position: absolute;
  text-align: center;
  transition: 0.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: var(--swiper-pagination-bottom, 8px);
  top: var(--swiper-pagination-top, auto);
  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: var(--swiper-pagination-bullet-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: var(--swiper-pagination-right, 8px);
  left: var(--swiper-pagination-left, auto);
  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: 0.2s transform, 0.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: 0.2s transform, 0.2s left;
}

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

.swiper-pagination-fraction {
  color: var(--swiper-pagination-fraction-color, inherit);
}

.swiper-pagination-progressbar {
  background: var(--swiper-pagination-progressbar-bg-color, 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: var(--swiper-pagination-progressbar-size, 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: var(--swiper-pagination-progressbar-size, 4px);
  height: 100%;
  left: 0;
  top: 0;
}

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

.swiper-scrollbar {
  border-radius: var(--swiper-scrollbar-border-radius, 10px);
  position: relative;
  touch-action: none;
  background: var(--swiper-scrollbar-bg-color, 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: var(--swiper-scrollbar-sides-offset, 1%);
  bottom: var(--swiper-scrollbar-bottom, 4px);
  top: var(--swiper-scrollbar-top, auto);
  z-index: 50;
  height: var(--swiper-scrollbar-size, 4px);
  width: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%));
}

.swiper-scrollbar.swiper-scrollbar-vertical, .swiper-vertical > .swiper-scrollbar {
  position: absolute;
  left: var(--swiper-scrollbar-left, auto);
  right: var(--swiper-scrollbar-right, 4px);
  top: var(--swiper-scrollbar-sides-offset, 1%);
  z-index: 50;
  width: var(--swiper-scrollbar-size, 4px);
  height: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%));
}

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, 0.5));
  border-radius: var(--swiper-scrollbar-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;
  touch-action: none;
}

.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 {
  pointer-events: auto;
}

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

.swiper.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-prev {
  pointer-events: auto;
  visibility: visible;
}

.swiper-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  width: 100%;
  height: 100%;
  opacity: 0.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-cube .swiper-slide-next + .swiper-slide {
  pointer-events: auto;
  visibility: visible;
}

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

.swiper.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-flip.swiper-slide-shadow-bottom, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-left, .swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-right, .swiper-flip .swiper-slide-shadow-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.swiper-cards {
  overflow: visible;
}

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

/*--------------------------------------------
文字数カット
--------------------------------------------*/
.u-cut1,
.u-cut2,
.u-cut3 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
}

.u-cut1 {
  -webkit-line-clamp: 1;
}

.u-cut2 {
  -webkit-line-clamp: 2;
}

.u-cut3 {
  -webkit-line-clamp: 3;
}

/*--------------------------------------------
ブレイクポイントでの表示・非表示
--------------------------------------------*/
@media (width < 1024px) {
  .u-sp-none {
    display: none !important;
  }
}
@media (1024px <= width) {
  .u-pc-none {
    display: none !important;
  }
}
/*--------------------------------------------
flex
--------------------------------------------*/
.u-flex {
  display: flex;
}

.u-flex-wrap {
  display: flex;
  flex-wrap: wrap;
}

.u-flex-col {
  display: flex;
  flex-direction: column;
}

/*--------------------------------------------
margin
--------------------------------------------*/
.u-container {
  margin: 0 16px;
}

@media screen and (min-width: 1024px) {
  .u-container {
    max-width: 1232px;
    margin: 0 auto;
    padding: 0 16px;
  }
  .u-m-4 {
    margin: 4px;
  }
  .u-mt-4 {
    margin-top: 4px;
  }
  .u-mr-4 {
    margin-right: 4px;
  }
  .u-mb-4 {
    margin-bottom: 4px;
  }
  .u-ml-4 {
    margin-left: 4px;
  }
  .u-mx-4 {
    margin-left: 4px;
    margin-right: 4px;
  }
  .u-my-4 {
    margin-top: 4px;
    margin-bottom: 4px;
  }
  .u-m-8 {
    margin: 8px;
  }
  .u-mt-8 {
    margin-top: 8px;
  }
  .u-mr-8 {
    margin-right: 8px;
  }
  .u-mb-8 {
    margin-bottom: 8px;
  }
  .u-ml-8 {
    margin-left: 8px;
  }
  .u-mx-8 {
    margin-left: 8px;
    margin-right: 8px;
  }
  .u-my-8 {
    margin-top: 8px;
    margin-bottom: 8px;
  }
  .u-m-16 {
    margin: 16px;
  }
  .u-mt-16 {
    margin-top: 16px;
  }
  .u-mr-16 {
    margin-right: 16px;
  }
  .u-mb-16 {
    margin-bottom: 16px;
  }
  .u-ml-16 {
    margin-left: 16px;
  }
  .u-mx-16 {
    margin-left: 16px;
    margin-right: 16px;
  }
  .u-my-16 {
    margin-top: 16px;
    margin-bottom: 16px;
  }
  .u-m-24 {
    margin: 24px;
  }
  .u-mt-24 {
    margin-top: 24px;
  }
  .u-mr-24 {
    margin-right: 24px;
  }
  .u-mb-24 {
    margin-bottom: 24px;
  }
  .u-ml-24 {
    margin-left: 24px;
  }
  .u-mx-24 {
    margin-left: 24px;
    margin-right: 24px;
  }
  .u-my-24 {
    margin-top: 24px;
    margin-bottom: 24px;
  }
  .u-m-32 {
    margin: 32px;
  }
  .u-mt-32 {
    margin-top: 32px;
  }
  .u-mr-32 {
    margin-right: 32px;
  }
  .u-mb-32 {
    margin-bottom: 32px;
  }
  .u-ml-32 {
    margin-left: 32px;
  }
  .u-mx-32 {
    margin-left: 32px;
    margin-right: 32px;
  }
  .u-my-32 {
    margin-top: 32px;
    margin-bottom: 32px;
  }
  .u-m-48 {
    margin: 48px;
  }
  .u-mt-48 {
    margin-top: 48px;
  }
  .u-mr-48 {
    margin-right: 48px;
  }
  .u-mb-48 {
    margin-bottom: 48px;
  }
  .u-ml-48 {
    margin-left: 48px;
  }
  .u-mx-48 {
    margin-left: 48px;
    margin-right: 48px;
  }
  .u-my-48 {
    margin-top: 48px;
    margin-bottom: 48px;
  }
  .u-m-56 {
    margin: 56px;
  }
  .u-mt-56 {
    margin-top: 56px;
  }
  .u-mr-56 {
    margin-right: 56px;
  }
  .u-mb-56 {
    margin-bottom: 56px;
  }
  .u-ml-56 {
    margin-left: 56px;
  }
  .u-mx-56 {
    margin-left: 56px;
    margin-right: 56px;
  }
  .u-my-56 {
    margin-top: 56px;
    margin-bottom: 56px;
  }
  .u-m-64 {
    margin: 64px;
  }
  .u-mt-64 {
    margin-top: 64px;
  }
  .u-mr-64 {
    margin-right: 64px;
  }
  .u-mb-64 {
    margin-bottom: 64px;
  }
  .u-ml-64 {
    margin-left: 64px;
  }
  .u-mx-64 {
    margin-left: 64px;
    margin-right: 64px;
  }
  .u-my-64 {
    margin-top: 64px;
    margin-bottom: 64px;
  }
  .u-m-80 {
    margin: 80px;
  }
  .u-mt-80 {
    margin-top: 80px;
  }
  .u-mr-80 {
    margin-right: 80px;
  }
  .u-mb-80 {
    margin-bottom: 80px;
  }
  .u-ml-80 {
    margin-left: 80px;
  }
  .u-mx-80 {
    margin-left: 80px;
    margin-right: 80px;
  }
  .u-my-80 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .u-m-128 {
    margin: 128px;
  }
  .u-mt-128 {
    margin-top: 128px;
  }
  .u-mr-128 {
    margin-right: 128px;
  }
  .u-mb-128 {
    margin-bottom: 128px;
  }
  .u-ml-128 {
    margin-left: 128px;
  }
  .u-mx-128 {
    margin-left: 128px;
    margin-right: 128px;
  }
  .u-my-128 {
    margin-top: 128px;
    margin-bottom: 128px;
  }
  .u-m-160 {
    margin: 160px;
  }
  .u-mt-160 {
    margin-top: 160px;
  }
  .u-mr-160 {
    margin-right: 160px;
  }
  .u-mb-160 {
    margin-bottom: 160px;
  }
  .u-ml-160 {
    margin-left: 160px;
  }
  .u-mx-160 {
    margin-left: 160px;
    margin-right: 160px;
  }
  .u-my-160 {
    margin-top: 160px;
    margin-bottom: 160px;
  }
  /*--------------------------------------------
  padding
  --------------------------------------------*/
  .u-p-4 {
    padding: 4px;
  }
  .u-pt-4 {
    padding-top: 4px;
  }
  .u-pr-4 {
    padding-right: 4px;
  }
  .u-pb-4 {
    padding-bottom: 4px;
  }
  .u-pl-4 {
    padding-left: 4px;
  }
  .u-px-4 {
    padding-left: 4px;
    padding-right: 4px;
  }
  .u-py-4 {
    padding-top: 4px;
    padding-bottom: 4px;
  }
  .u-p-8 {
    padding: 8px;
  }
  .u-pt-8 {
    padding-top: 8px;
  }
  .u-pr-8 {
    padding-right: 8px;
  }
  .u-pb-8 {
    padding-bottom: 8px;
  }
  .u-pl-8 {
    padding-left: 8px;
  }
  .u-px-8 {
    padding-left: 8px;
    padding-right: 8px;
  }
  .u-py-8 {
    padding-top: 8px;
    padding-bottom: 8px;
  }
  .u-p-16 {
    padding: 16px;
  }
  .u-pt-16 {
    padding-top: 16px;
  }
  .u-pr-16 {
    padding-right: 16px;
  }
  .u-pb-16 {
    padding-bottom: 16px;
  }
  .u-pl-16 {
    padding-left: 16px;
  }
  .u-px-16 {
    padding-left: 16px;
    padding-right: 16px;
  }
  .u-py-16 {
    padding-top: 16px;
    padding-bottom: 16px;
  }
  .u-p-24 {
    padding: 24px;
  }
  .u-pt-24 {
    padding-top: 24px;
  }
  .u-pr-24 {
    padding-right: 24px;
  }
  .u-pb-24 {
    padding-bottom: 24px;
  }
  .u-pl-24 {
    padding-left: 24px;
  }
  .u-px-24 {
    padding-left: 24px;
    padding-right: 24px;
  }
  .u-py-24 {
    padding-top: 24px;
    padding-bottom: 24px;
  }
  .u-p-32 {
    padding: 32px;
  }
  .u-pt-32 {
    padding-top: 32px;
  }
  .u-pr-32 {
    padding-right: 32px;
  }
  .u-pb-32 {
    padding-bottom: 32px;
  }
  .u-pl-32 {
    padding-left: 32px;
  }
  .u-px-32 {
    padding-left: 32px;
    padding-right: 32px;
  }
  .u-py-32 {
    padding-top: 32px;
    padding-bottom: 32px;
  }
  .u-p-48 {
    padding: 48px;
  }
  .u-pt-48 {
    padding-top: 48px;
  }
  .u-pr-48 {
    padding-right: 48px;
  }
  .u-pb-48 {
    padding-bottom: 48px;
  }
  .u-pl-48 {
    padding-left: 48px;
  }
  .u-px-48 {
    padding-left: 48px;
    padding-right: 48px;
  }
  .u-py-48 {
    padding-top: 48px;
    padding-bottom: 48px;
  }
  .u-p-56 {
    padding: 56px;
  }
  .u-pt-56 {
    padding-top: 56px;
  }
  .u-pr-56 {
    padding-right: 56px;
  }
  .u-pb-56 {
    padding-bottom: 56px;
  }
  .u-pl-56 {
    padding-left: 56px;
  }
  .u-px-56 {
    padding-left: 56px;
    padding-right: 56px;
  }
  .u-py-56 {
    padding-top: 56px;
    padding-bottom: 56px;
  }
  .u-p-64 {
    padding: 64px;
  }
  .u-pt-64 {
    padding-top: 64px;
  }
  .u-pr-64 {
    padding-right: 64px;
  }
  .u-pb-64 {
    padding-bottom: 64px;
  }
  .u-pl-64 {
    padding-left: 64px;
  }
  .u-px-64 {
    padding-left: 64px;
    padding-right: 64px;
  }
  .u-py-64 {
    padding-top: 64px;
    padding-bottom: 64px;
  }
  .u-p-80 {
    padding: 80px;
  }
  .u-pt-80 {
    padding-top: 80px;
  }
  .u-pr-80 {
    padding-right: 80px;
  }
  .u-pb-80 {
    padding-bottom: 80px;
  }
  .u-pl-80 {
    padding-left: 80px;
  }
  .u-px-80 {
    padding-left: 80px;
    padding-right: 80px;
  }
  .u-py-80 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .u-p-128 {
    padding: 128px;
  }
  .u-pt-128 {
    padding-top: 128px;
  }
  .u-pr-128 {
    padding-right: 128px;
  }
  .u-pb-128 {
    padding-bottom: 128px;
  }
  .u-pl-128 {
    padding-left: 128px;
  }
  .u-px-128 {
    padding-left: 128px;
    padding-right: 128px;
  }
  .u-py-128 {
    padding-top: 128px;
    padding-bottom: 128px;
  }
  .u-p-160 {
    padding: 160px;
  }
  .u-pt-160 {
    padding-top: 160px;
  }
  .u-pr-160 {
    padding-right: 160px;
  }
  .u-pb-160 {
    padding-bottom: 160px;
  }
  .u-pl-160 {
    padding-left: 160px;
  }
  .u-px-160 {
    padding-left: 160px;
    padding-right: 160px;
  }
  .u-py-160 {
    padding-top: 160px;
    padding-bottom: 160px;
  }
  /*--------------------------------------------
  width
  --------------------------------------------*/
  .u-w-32 {
    width: 32px;
  }
  .u-w-40 {
    width: 40px;
  }
  .u-w-48 {
    width: 48px;
  }
  .u-w-56 {
    width: 56px;
  }
  .u-w-64 {
    width: 64px;
  }
  .u-w-80 {
    width: 80px;
  }
  .u-w-88 {
    width: 88px;
  }
  .u-w-96 {
    width: 96px;
  }
  .u-w-104 {
    width: 104px;
  }
  .u-w-112 {
    width: 112px;
  }
  .u-w-128 {
    width: 128px;
  }
  .u-w-144 {
    width: 144px;
  }
  .u-w-160 {
    width: 160px;
  }
  .u-w-176 {
    width: 176px;
  }
  .u-w-192 {
    width: 192px;
  }
  .u-w-200 {
    width: 200px;
  }
  .u-w-208 {
    width: 208px;
  }
  .u-w-224 {
    width: 224px;
  }
  .u-w-240 {
    width: 240px;
  }
  .u-w-256 {
    width: 256px;
  }
  .u-w-272 {
    width: 272px;
  }
  .u-w-288 {
    width: 288px;
  }
  .u-w-296 {
    width: 296px;
  }
  .u-w-304 {
    width: 304px;
  }
  .u-w-320 {
    width: 320px;
  }
  .u-w-336 {
    width: 336px;
  }
  .u-w-352 {
    width: 352px;
  }
  .u-w-368 {
    width: 368px;
  }
  .u-w-384 {
    width: 384px;
  }
  .u-w-400 {
    width: 400px;
  }
  .u-w-416 {
    width: 416px;
  }
  .u-w-432 {
    width: 432px;
  }
  .u-w-464 {
    width: 464px;
  }
  .u-w-480 {
    width: 480px;
  }
  .u-w-512 {
    width: 512px;
  }
  .u-w-544 {
    width: 544px;
  }
  .u-w-576 {
    width: 576px;
  }
  .u-w-608 {
    width: 608px;
  }
  .u-w-640 {
    width: 640px;
  }
  .u-w-800 {
    width: 800px;
  }
  /*--------------------------------------------
  height
  --------------------------------------------*/
  .u-h-32 {
    min-height: 32px;
  }
  .u-h-40 {
    min-height: 40px;
  }
  .u-h-48 {
    min-height: 48px;
  }
  .u-h-56 {
    min-height: 56px;
  }
  .u-h-64 {
    min-height: 64px;
  }
  .u-h-80 {
    min-height: 80px;
  }
  .u-h-88 {
    min-height: 88px;
  }
  .u-h-96 {
    min-height: 96px;
  }
  .u-h-104 {
    min-height: 104px;
  }
  .u-h-112 {
    min-height: 112px;
  }
  .u-h-128 {
    min-height: 128px;
  }
  .u-h-144 {
    min-height: 144px;
  }
  .u-h-160 {
    min-height: 160px;
  }
  .u-h-176 {
    min-height: 176px;
  }
  .u-h-192 {
    min-height: 192px;
  }
  .u-h-208 {
    min-height: 208px;
  }
  .u-h-224 {
    min-height: 224px;
  }
  .u-h-240 {
    min-height: 240px;
  }
  .u-h-256 {
    min-height: 256px;
  }
  .u-h-272 {
    min-height: 272px;
  }
  .u-h-288 {
    min-height: 288px;
  }
  .u-h-296 {
    min-height: 296px;
  }
  .u-h-304 {
    min-height: 304px;
  }
  .u-h-320 {
    min-height: 320px;
  }
}
.c-button {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100px;
}
.c-button.--lg {
  width: 240px;
  height: 48px;
  padding: 16px 12px;
  gap: 4px;
}
.c-button.--lg img {
  width: 24px;
  height: 24px;
}
.c-button.--lg p {
  font-weight: 700;
}
.c-button.--md {
  width: 128px;
  height: 32px;
  padding: 8px 4px;
  gap: 4px;
}
.c-button.--md img {
  width: 20px;
  height: 20px;
}
.c-button.--md p {
  font-weight: 500;
}
.c-button.--sm {
  width: 80px;
  height: 24px;
  padding: 8px 3px;
}
.c-button.--sm p {
  font-size: 14px;
}
.c-button.--black {
  background-color: #000000;
  border: none;
}
.c-button.--black p {
  color: #ffffff;
}
.c-button.--white {
  background-color: #ffffff;
  border: none;
}
.c-button.--white p {
  color: #000000;
}
.c-button.--border {
  background-color: #ffffff;
  border: 1px solid #000000;
}
.c-button.--border p {
  color: #000000;
}

.c-heading.--lg {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 50px;
  padding: 0 8px;
  margin-bottom: 16px;
  position: relative;
}
.c-heading.--lg::before {
  content: "";
  position: absolute;
  left: 8px;
  right: 8px;
  margin-top: 0;
  width: calc(100% - 16px);
  height: 100%;
  border-bottom: 1px dashed #000000;
  border-radius: 4px;
}
.c-heading.--lg::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 100%;
  background: #ffffff;
  border: 1px solid #000000;
  border-radius: 4px;
  transform: translateY(-4px);
  transform: rotate(-1deg);
  transition: transform 0.5s ease;
}
@media (min-width: 768px) {
  .c-heading.--lg::after {
    transform: rotate(-0.5deg);
  }
}
.c-heading.--lg a {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 10;
  transition: opacity 0.5s ease;
}
.c-heading.--lg a:hover ~ * {
  opacity: 0.6;
}
.c-heading.--lg h1, .c-heading.--lg h2 {
  font-size: 22px;
  z-index: 1;
}
.c-heading.--lg h1::first-letter, .c-heading.--lg h2::first-letter {
  letter-spacing: 0.05em;
  font-size: 28px;
}
.c-heading.--lg div {
  z-index: 1;
}

.c-heading.--md > * {
  font-size: 16px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.c-heading.--md > *::before {
  content: "";
  display: inline-flex;
  width: 8px;
  height: 24px;
  transform: skewX(-14deg);
  margin-left: 4px;
  margin-right: 4px;
}

.c-heading.--sm * {
  font-size: 16px;
  font-weight: 700;
}

.c-heading.--lg.--black h1::first-letter, .c-heading.--lg.--black h2::first-letter {
  color: #000000;
}

.c-heading.--lg.--gray-1 h1::first-letter, .c-heading.--lg.--gray-1 h2::first-letter {
  color: #111111;
}

.c-heading.--lg.--gray-2 h1::first-letter, .c-heading.--lg.--gray-2 h2::first-letter {
  color: #222222;
}

.c-heading.--lg.--gray-3 h1::first-letter, .c-heading.--lg.--gray-3 h2::first-letter {
  color: #333333;
}

.c-heading.--lg.--gray-4 h1::first-letter, .c-heading.--lg.--gray-4 h2::first-letter {
  color: #444444;
}

.c-heading.--lg.--gray-5 h1::first-letter, .c-heading.--lg.--gray-5 h2::first-letter {
  color: #555555;
}

.c-heading.--lg.--gray-6 h1::first-letter, .c-heading.--lg.--gray-6 h2::first-letter {
  color: #666666;
}

.c-heading.--lg.--gray-7 h1::first-letter, .c-heading.--lg.--gray-7 h2::first-letter {
  color: #777777;
}

.c-heading.--lg.--gray-8 h1::first-letter, .c-heading.--lg.--gray-8 h2::first-letter {
  color: #888888;
}

.c-heading.--lg.--gray-9 h1::first-letter, .c-heading.--lg.--gray-9 h2::first-letter {
  color: #999999;
}

.c-heading.--lg.--gray-a h1::first-letter, .c-heading.--lg.--gray-a h2::first-letter {
  color: #aaaaaa;
}

.c-heading.--lg.--gray-b h1::first-letter, .c-heading.--lg.--gray-b h2::first-letter {
  color: #bbbbbb;
}

.c-heading.--lg.--gray-c h1::first-letter, .c-heading.--lg.--gray-c h2::first-letter {
  color: #cccccc;
}

.c-heading.--lg.--gray-d h1::first-letter, .c-heading.--lg.--gray-d h2::first-letter {
  color: #dddddd;
}

.c-heading.--lg.--gray-e h1::first-letter, .c-heading.--lg.--gray-e h2::first-letter {
  color: #eeeeee;
}

.c-heading.--lg.--gray-f9 h1::first-letter, .c-heading.--lg.--gray-f9 h2::first-letter {
  color: #f9f9f9;
}

.c-heading.--lg.--white h1::first-letter, .c-heading.--lg.--white h2::first-letter {
  color: #ffffff;
}

.c-heading.--lg.--primary h1::first-letter, .c-heading.--lg.--primary h2::first-letter {
  color: #ff5a62;
}

.c-heading.--lg.--primary-20 h1::first-letter, .c-heading.--lg.--primary-20 h2::first-letter {
  color: #FFDEE0;
}

.c-heading.--lg.--secondary h1::first-letter, .c-heading.--lg.--secondary h2::first-letter {
  color: #FFC73B;
}

.c-heading.--lg.--secondary-20 h1::first-letter, .c-heading.--lg.--secondary-20 h2::first-letter {
  color: #FFF4D8;
}

.c-heading.--lg.--tertiary h1::first-letter, .c-heading.--lg.--tertiary h2::first-letter {
  color: #50EFD0;
}

.c-heading.--lg.--tertiary-20 h1::first-letter, .c-heading.--lg.--tertiary-20 h2::first-letter {
  color: #DCFCF6;
}

.c-heading.--lg.--quaternary h1::first-letter, .c-heading.--lg.--quaternary h2::first-letter {
  color: #17C1F4;
}

.c-heading.--lg.--quaternary-20 h1::first-letter, .c-heading.--lg.--quaternary-20 h2::first-letter {
  color: #D1F3FD;
}

.c-heading.--lg.--quinary h1::first-letter, .c-heading.--lg.--quinary h2::first-letter {
  color: #AC7AFC;
}

.c-heading.--lg.--quinary-20 h1::first-letter, .c-heading.--lg.--quinary-20 h2::first-letter {
  color: #EEE4FE;
}

.c-heading.--md.--black > *::before {
  background-color: #000000;
}

.c-heading.--md.--gray-1 > *::before {
  background-color: #111111;
}

.c-heading.--md.--gray-2 > *::before {
  background-color: #222222;
}

.c-heading.--md.--gray-3 > *::before {
  background-color: #333333;
}

.c-heading.--md.--gray-4 > *::before {
  background-color: #444444;
}

.c-heading.--md.--gray-5 > *::before {
  background-color: #555555;
}

.c-heading.--md.--gray-6 > *::before {
  background-color: #666666;
}

.c-heading.--md.--gray-7 > *::before {
  background-color: #777777;
}

.c-heading.--md.--gray-8 > *::before {
  background-color: #888888;
}

.c-heading.--md.--gray-9 > *::before {
  background-color: #999999;
}

.c-heading.--md.--gray-a > *::before {
  background-color: #aaaaaa;
}

.c-heading.--md.--gray-b > *::before {
  background-color: #bbbbbb;
}

.c-heading.--md.--gray-c > *::before {
  background-color: #cccccc;
}

.c-heading.--md.--gray-d > *::before {
  background-color: #dddddd;
}

.c-heading.--md.--gray-e > *::before {
  background-color: #eeeeee;
}

.c-heading.--md.--gray-f9 > *::before {
  background-color: #f9f9f9;
}

.c-heading.--md.--white > *::before {
  background-color: #ffffff;
}

.c-heading.--md.--primary > *::before {
  background-color: #ff5a62;
}

.c-heading.--md.--primary-20 > *::before {
  background-color: #FFDEE0;
}

.c-heading.--md.--secondary > *::before {
  background-color: #FFC73B;
}

.c-heading.--md.--secondary-20 > *::before {
  background-color: #FFF4D8;
}

.c-heading.--md.--tertiary > *::before {
  background-color: #50EFD0;
}

.c-heading.--md.--tertiary-20 > *::before {
  background-color: #DCFCF6;
}

.c-heading.--md.--quaternary > *::before {
  background-color: #17C1F4;
}

.c-heading.--md.--quaternary-20 > *::before {
  background-color: #D1F3FD;
}

.c-heading.--md.--quinary > *::before {
  background-color: #AC7AFC;
}

.c-heading.--md.--quinary-20 > *::before {
  background-color: #EEE4FE;
}

.c-cms {
  width: 100%;
}
.c-cms > * {
  margin-bottom: 16px;
}
@media (min-width: 1024px) {
  .c-cms > * {
    margin-bottom: 32px;
  }
}
.c-cms > h1, .c-cms > h2, .c-cms > h3, .c-cms > h4, .c-cms > h5, .c-cms > h6 {
  margin-bottom: 8px;
}
@media (min-width: 1024px) {
  .c-cms > h1, .c-cms > h2, .c-cms > h3, .c-cms > h4, .c-cms > h5, .c-cms > h6 {
    margin-bottom: 16px;
  }
}
.c-cms > h1 {
  font-size: 20px;
  font-weight: 700;
  border-left: 8px solid #ff5a62;
  padding-left: 4px;
}
.c-cms > h2 {
  font-size: 20px;
  font-weight: 700;
  border-left: 8px solid #ff5a62;
  padding-left: 4px;
}
.c-cms > h3 {
  font-size: 18px;
  font-weight: 700;
}
.c-cms > h4, .c-cms > h5 .c-cms > h6 {
  font-size: 16px;
  font-weight: 700;
}
.c-cms > img, .c-cms > iframe {
  width: 100%;
  max-width: 640px;
  border-radius: 8px;
  margin-left: auto;
  margin-right: auto;
  display: block;
}
.c-cms > p {
  font-size: 16px;
  line-height: 1.7;
}
.c-cms > p a {
  color: #ff5a62;
  text-decoration: underline;
  font-weight: 700;
}
.c-cms > .c-card-article {
  background-color: #f9f9f9;
  border-radius: 8px;
  padding: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.c-cms > ul, .c-cms > ol {
  padding-left: 20px;
}
.c-cms > ul > li, .c-cms > ol > li {
  list-style: decimal;
}
.c-cms > ul > li:not(:first-child), .c-cms > ol > li:not(:first-child) {
  margin-top: 8px;
}
.c-cms > ul > li > ul, .c-cms > ul > li > ol, .c-cms > ol > li > ul, .c-cms > ol > li > ol {
  padding-left: 20px;
}
.c-cms > ul > li > ul > li, .c-cms > ul > li > ol > li, .c-cms > ol > li > ul > li, .c-cms > ol > li > ol > li {
  list-style: lower-alpha;
  margin-top: 8px;
}

.c-card-article.--lg {
  gap: 8px;
}

.c-card-article.--sm {
  gap: 4px;
}
.c-card-article.--sm .c-card-article__wrap {
  display: flex;
  align-items: center;
  gap: 4px;
}
.c-card-article.--sm .c-card-article__wrap .c-card-article__title {
  position: relative;
  padding-right: 16px;
}
.c-card-article.--sm .c-card-article__wrap .c-card-article__title::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 2px;
  display: block;
  width: 8px;
  height: 8px;
  border-top: 2px solid #000000;
  border-right: 2px solid #000000;
  transform: translateY(-50%) rotate(45deg);
}
.c-card-article.--sm .c-card-article__image-wrap {
  width: 128px;
  flex-shrink: 0;
}

.c-card-article {
  display: flex;
  flex-direction: column;
}

.c-card-article__image-wrap {
  width: 100%;
  border-radius: 8px;
  aspect-ratio: 424/258;
  overflow: hidden;
}
.c-card-article__image-wrap img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.c-card-article__title {
  width: 100%;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 16px;
  font-weight: 400;
}

.c-card-article__block {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.c-card-article__block object {
  width: calc(100% - 72px);
  height: 20px;
}
.c-card-article__block object a + a {
  margin-left: 8px;
}
.c-card-article__block .c-card-article__text:not(object) {
  flex-shrink: 0;
}
.c-card-article__block .c-card-article__text {
  font-size: 14px;
  color: #888888;
}

.c-card-comment-type {
  display: flex;
  align-items: center;
  gap: 4px;
  z-index: 10;
}
.c-card-comment-type img {
  width: 20px;
  height: 20px;
}
.c-card-comment-type p {
  font-size: 12px;
  color: #888888;
}

.c-card-comment {
  display: flex;
  flex-direction: column;
  height: 100%;
  gap: 8px;
  border-radius: 8px;
  background-color: #ffffff;
  padding: 16px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  position: relative;
  transition: opacity 0.3s ease;
}
.c-card-comment::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  display: block;
  width: 8px;
  height: 8px;
  border-top: 2px solid #000000;
  border-right: 2px solid #000000;
  transform: translateY(-50%) rotate(45deg);
}
.c-card-comment:hover {
  opacity: 0.6;
}
.c-card-comment .c-card-comment__link {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.c-card-comment__text {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis;
  position: relative;
  padding-right: 16px;
  font-size: 20px;
  font-weight: 700;
  color: #ff5a62;
}

.c-card-vtuber {
  border-radius: 8px;
  overflow: hidden;
  background-color: #ffffff;
}

.c-card-vtuber__img-wrap {
  border-radius: 8px 8px 0 0;
  position: relative;
  width: 100%;
  aspect-ratio: 128/72;
  overflow: hidden;
}
.c-card-vtuber__img-wrap::before {
  content: "";
  width: 100%;
  height: 50%;
  position: absolute;
  bottom: 0;
  left: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.5) 100%);
}
.c-card-vtuber__img-wrap .c-card-vtuber__thumbnail {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-card-vtuber__img-wrap .c-card-vtuber__title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: calc(100% - 80px - 24px);
  position: absolute;
  bottom: 8px;
  right: 8px;
  z-index: 1;
  font-size: 12px;
  color: #ffffff;
}
.c-card-vtuber__img-wrap img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.c-card-vtuber__text-wrap {
  border-radius: 0 0 8px 8px;
  position: relative;
  z-index: 10;
  display: flex;
  padding: 8px;
  background-color: #f9f9f9;
}
.c-card-vtuber__text-wrap .c-card-vtuber__img-wrap2 {
  width: 80px;
  height: 112px;
  margin-top: -70px;
  overflow: hidden;
  border: 2px solid #ffffff;
  border-radius: 4px;
  flex-shrink: 0;
}
.c-card-vtuber__text-wrap .c-card-vtuber__img-wrap2 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.c-card-vtuber__text-box {
  width: calc(100% - 80px - 8px - 18px);
  margin-left: 8px;
}
.c-card-vtuber__text-box::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  display: block;
  width: 8px;
  height: 8px;
  border-top: 2px solid #000000;
  border-right: 2px solid #000000;
  transform: translateY(-50%) rotate(45deg);
}
.c-card-vtuber__text-box .c-card-vtuber__name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 16px;
  font-weight: 700;
  color: #000000;
}
.c-card-vtuber__text-box .c-card-vtuber__anime-title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 12px;
  color: #666666;
}

.c-card-work {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.c-card-work__img-wrap {
  width: 100%;
  aspect-ratio: 80/112;
  overflow: hidden;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.c-card-work__img-wrap img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.c-card-work__title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 14px;
  font-weight: 400;
  color: #666666;
}

.c-card-vod {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px;
  position: relative;
  background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  padding-right: 16px;
}
.c-card-vod::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  display: block;
  width: 8px;
  height: 8px;
  border-top: 2px solid #000000;
  border-right: 2px solid #000000;
  transform: translateY(-50%) rotate(45deg);
}
.c-card-vod .c-card-vod__img-wrap {
  width: 32px;
  height: 32px;
}
.c-card-vod .c-card-vod__text {
  font-size: 14px;
}
.c-card-vod.--disabled {
  opacity: 0.4;
  pointer-events: none;
}

.c-form__list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.c-form__title {
  font-weight: 700;
  margin-bottom: 8px;
}
.c-form__note {
  text-align: center;
  margin-top: 32px;
}
.c-form__note a {
  color: #ff5a62;
  font-weight: 700;
  text-decoration: underline;
}

.c-input-text {
  width: 100%;
  height: 48px;
  background-color: #f9f9f9;
  border: 1px solid #eeeeee;
  border-radius: 4px;
  padding: 0 8px;
}

.c-textarea {
  width: 100%;
  min-height: 128px;
  background-color: #f9f9f9;
  border: 1px solid #eeeeee;
  border-radius: 4px;
  padding: 8px;
  word-break: break-all;
  resize: vertical;
}

.c-select {
  width: 100%;
  height: 48px;
  background-color: #f9f9f9;
  border: 1px solid #eeeeee;
  border-radius: 4px;
  display: block;
  position: relative;
}
.c-select select {
  width: 100%;
  height: 100%;
  padding: 0 26px 0 8px;
  position: absolute;
  top: 0;
  left: 0;
  cursor: pointer;
}
.c-select::after {
  content: "";
  position: absolute;
  top: calc(50% - 4px);
  right: 8px;
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
  border-top: 8px solid #000000;
  border-bottom: 0;
}

.c-search {
  width: 100%;
  height: 48px;
  background-color: #f9f9f9;
  border: 1px solid #eeeeee;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.c-search input {
  width: 100%;
  height: 100%;
  padding: 0 4px 0 8px;
}
.c-search button {
  width: 40px;
  height: 40px;
  background-color: #000000;
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-right: 4px;
}
.c-search img {
  width: 24px;
  height: 24px;
}

.c-input-error {
  font-size: 12px;
  color: #ff5a62;
  margin-top: 8px;
}

.c-pagination {
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-width: 343px;
  margin: 32px auto;
}

.c-pagination__controls {
  display: flex;
  align-items: center;
  gap: 16px;
}
.c-pagination__controls a.c-button {
  min-width: unset;
  max-width: 163px;
  width: 50%;
}
.c-pagination__controls a.c-button.--disable {
  background-color: #eeeeee;
  pointer-events: none;
}
.c-pagination__controls a.c-button.--disable p {
  color: #aaaaaa;
}

.c-pagination__list {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.c-pagination__list li a {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background-color: #eeeeee;
}
.c-pagination__list li .c-pagination__ellipsis {
  pointer-events: none;
  background: transparent;
}
.c-pagination__list li a.active {
  background-color: unset;
  pointer-events: none;
}

.c-breadcrumbs {
  background-color: #f9f9f9;
}

.c-breadcrumbs__list {
  width: 100%;
  max-width: 1280px;
  padding: 8px 16px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  overflow-x: auto;
}
.c-breadcrumbs__list::-webkit-scrollbar {
  display: none;
}
.c-breadcrumbs__list .c-breadcrumbs__item {
  font-size: 12px;
  position: relative;
  padding-right: 16px;
}
.c-breadcrumbs__list .c-breadcrumbs__item:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 2px;
  display: block;
  width: 6px;
  height: 6px;
  border-top: 2px solid #666666;
  border-right: 2px solid #666666;
  transform: translateY(-50%) rotate(45deg);
}
.c-breadcrumbs__list .c-breadcrumbs__item:not(:last-child) {
  color: #17C1F4;
}
.c-breadcrumbs__list .c-breadcrumbs__item:last-child a {
  pointer-events: none;
}

.c-modal__btn.--share {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 72px;
  padding: 3px 6px;
}
.c-modal__btn.--share .c-modal__text.--share {
  font-size: 12px;
  font-weight: 700;
}

.c-modal__wrap.--share {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
}

.c-share-sns {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 64px;
}
.c-share-sns .c-share-sns__img-wrap {
  width: 48px;
  height: 48px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  border-radius: 50%;
}
.c-share-sns .c-share-sns__img-wrap img {
  width: 100%;
  height: 100%;
}
.c-share-sns .c-share-sns__text {
  font-size: 12px;
  color: #666666;
}

.c-modal__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #000000;
  border-radius: 8px;
}
.c-modal__btn .c-modal__img-wrap {
  width: 24px;
  height: 24px;
}
.c-modal__btn .c-modal__img-wrap img {
  width: 100%;
  height: 100%;
}
.c-modal__btn .c-modal__text {
  color: #ffffff;
}

.c-modal {
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1000;
}
.c-modal.is-active {
  opacity: 1;
  pointer-events: auto;
}
.c-modal.is-active .c-modal__content {
  transform: scale(1);
}
.c-modal__overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.2);
}
.c-modal__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  background-color: #ffffff;
  border-radius: 8px;
  padding: 16px 16px 32px;
  z-index: 1;
  width: calc(100% - 32px);
  max-width: 480px;
  transform: scale(0.95);
  transition: transform 0.3s ease;
}
.c-modal__title {
  font-weight: 700;
}

.c-share-sns {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 64px;
}
.c-share-sns .c-share-sns__img-wrap {
  width: 48px;
  height: 48px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  border-radius: 50%;
}
.c-share-sns .c-share-sns__img-wrap img {
  width: 100%;
  height: 100%;
}
.c-share-sns p {
  font-size: 12px;
  color: #666666;
}

.c-player {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: fixed;
  top: 100%;
  left: 0;
  z-index: 1000;
  opacity: 0;
  transition: top 0.4s ease, opacity 0.4s ease;
  background-color: #000000;
}
@media (min-width: 1024px) {
  .c-player {
    background-color: rgba(0, 0, 0, 0.4);
    transition: top 0s ease, opacity 0.4s ease;
  }
}
.c-player.is-active {
  top: 0;
  opacity: 1;
}
.c-player__close {
  width: 48px;
  height: 48px;
  background-color: rgba(0, 0, 0, 0.7);
  border-radius: 100%;
  padding: 10px;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 8px;
  right: 8px;
  cursor: pointer;
}
.c-player__inner {
  width: 100%;
  height: 100svh;
  background-color: #000000;
  position: relative;
}
@media (min-width: 1024px) {
  .c-player__inner.--short {
    width: unset;
    height: calc(100svh - 64px);
    max-height: 1024px;
    aspect-ratio: 9/16;
  }
}
@media (min-width: 1024px) {
  .c-player__inner.--long {
    height: unset;
    max-width: 1024px;
    aspect-ratio: 16/9;
  }
  .c-player__inner.--long .c-player__actions {
    background-color: #000000;
    bottom: -80px;
  }
}
.c-player__inner iframe {
  width: 100%;
  height: 100%;
}
.c-player__actions {
  width: 100%;
  height: 80px;
  background: linear-gradient(0deg, rgb(0, 0, 0) 50%, rgba(0, 0, 0, 0) 100%);
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  position: absolute;
  left: 0;
  bottom: 0;
}
.c-player__work {
  width: 100%;
  max-width: 480px;
  height: 48px;
  font-size: 16px;
  font-weight: 700;
  color: #ffffff;
  background-color: rgba(0, 0, 0, 0.7);
  border: 2px solid #ffffff;
  border-radius: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.c-player__share {
  width: 72px;
  height: 48px;
  color: #ffffff;
  background-color: rgba(0, 0, 0, 0.5);
  border: 2px solid rgba(255, 255, 255, 0.7);
  font-size: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  flex-shrink: 0;
}
.c-player__share img {
  width: 24px;
}
.c-player__share span {
  display: block;
}

#player {
  width: 100%;
  height: 100svh;
  -o-object-fit: cover;
     object-fit: cover;
}

@media (min-width: 1024px) {
  .c-frame {
    border-radius: 8px;
    border: 1px solid #eeeeee;
    padding: 32px;
  }
}

.c-section {
  width: calc(100% + 32px);
  margin-left: -16px;
  padding: 32px 16px;
  position: relative;
  overflow: hidden;
}
@media (min-width: 1024px) {
  .c-section {
    width: 100%;
    margin-left: 0;
    padding: 32px 0;
  }
}
.c-section::before, .c-section::after {
  content: "";
  border-radius: 100%;
  aspect-ratio: 1/1;
  display: block;
  position: absolute;
  z-index: -1;
}
.c-section::before {
  width: 200px;
  top: 100px;
  left: -100px;
}
@media (min-width: 1024px) {
  .c-section::before {
    left: 0;
  }
}
.c-section::after {
  width: 200px;
  top: 0;
  right: -100px;
}
@media (min-width: 1024px) {
  .c-section::after {
    width: 300px;
    right: 0;
  }
}
.c-section.primary::before {
  background-color: #FFDEE0;
}
.c-section.primary::after {
  background-color: #FFDEE0;
}
.c-section.secondary::before {
  background-color: #FFF4D8;
}
.c-section.secondary::after {
  background-color: #FFF4D8;
}
.c-section.tertiary::before {
  background-color: #DCFCF6;
}
.c-section.tertiary::after {
  background-color: #DCFCF6;
}
.c-section.quaternary::before {
  background-color: #D1F3FD;
}
.c-section.quaternary::after {
  background-color: #D1F3FD;
}
.c-section.quinary::before {
  background-color: #EEE4FE;
}
.c-section.quinary::after {
  background-color: #EEE4FE;
}
.c-sns {
  gap: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.c-sns li {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.c-sns a {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  border-radius: 50%;
}
.c-sns img {
  width: 100%;
  height: 100%;
}
.c-sns p {
  width: 64px;
  text-align: center;
  font-size: 12px;
  color: #666666;
}

.c-ad {
  background-color: #eeeeee;
  margin: 8px 0;
  flex-shrink: 0;
  width: calc(100% + 32px) !important;
  margin-left: -16px !important;
  height: 320px;
}
@media (min-width: 1024px) {
  .c-ad {
    width: 100% !important;
    margin-left: 0 !important;
    height: 220px;
  }
}

.p-search-type {
  width: 100%;
  margin-bottom: 16px;
}
@media (min-width: 1024px) {
  .p-search-type {
    width: 480px;
  }
}

.c-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.c-list__item {
  border-bottom: 1px solid #eeeeee;
  padding-bottom: 16px;
}
.c-list__title {
  font-weight: 700;
  margin-bottom: 8px;
}
.l-header {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 1000;
  width: 100%;
  padding: 8px;
  background-color: #ffffff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media (min-width: 1024px) {
  .l-header {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

.l-header-hamburger {
  width: 48px;
  height: 48px;
  gap: 5px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.l-header-hamburger span {
  display: block;
  width: 24px;
  height: 3px;
  background-color: #000000;
  border-radius: 2px;
}

.l-header-logo {
  width: 133px;
  height: 48px;
  display: flex;
  flex-direction: column;
}
.l-header-logo p {
  font-size: 10px;
  color: #888888;
}

.l-container {
  width: 100%;
  gap: 16px;
  display: flex;
  flex-direction: column;
}
@media (min-width: 1024px) {
  .l-container {
    gap: 32px;
  }
}

.l-contents {
  width: 100%;
  max-width: 1280px;
  padding: 0 16px;
  margin: 0 auto;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
@media (min-width: 1024px) {
  .l-contents {
    gap: 16px;
  }
}

.l-main {
  width: 100%;
}
@media (min-width: 1024px) {
  .l-main {
    width: calc(100% - 360px - 16px);
  }
}

.l-aside {
  display: flex;
  flex-direction: column;
}
@media (min-width: 1024px) {
  .l-aside {
    gap: 24px;
    width: 360px;
    flex-shrink: 0;
  }
}

.l-aside__contents {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1001;
  width: 100%;
  height: 100vh;
  overflow-y: auto;
  background-color: #ffffff;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  display: flex;
  flex-direction: column;
}
.l-aside__contents.is-active {
  opacity: 1;
  pointer-events: auto;
}
@media (min-width: 1024px) {
  .l-aside__contents {
    position: unset;
    z-index: 0;
    height: auto;
    overflow-y: unset;
    opacity: 1;
    pointer-events: all;
  }
}

.l-aside__contents-wrap {
  padding: 16px 16px 128px 16px;
  gap: 24px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
@media (min-width: 1024px) {
  .l-aside__contents-wrap {
    padding: 16px 0 0 0;
  }
}
.l-aside__contents-wrap .c-button {
  margin: 0 auto;
}
.l-aside__contents-wrap .c-button span {
  font-weight: 700;
}

.l-aside__block {
  gap: 8px;
  display: flex;
  flex-direction: column;
}
.l-aside__block .c-heading.--md {
  padding-left: 4px;
}

.l-aside__inner {
  gap: 8px;
  display: flex;
  flex-direction: column;
}
.l-aside__inner.--wrap {
  gap: 8px;
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
}

.l-aside__group {
  gap: 8px;
  display: flex;
  flex-direction: column;
}

.l-aside__item {
  height: 40px;
  background-color: #f9f9f9;
  border-radius: 4px;
}
.l-aside__item a {
  width: 100%;
  height: 100%;
}
.l-aside__item.--sm {
  width: calc((100% - 32px) / 5);
}
.l-aside__item.--sm a {
  font-weight: 700;
  color: #ff5a62;
  display: flex;
  align-items: center;
  justify-content: center;
}
.l-aside__item.--md {
  width: calc((100% - 8px) / 2);
}
.l-aside__item.--md a {
  padding: 8px;
  color: #17C1F4;
  display: flex;
  align-items: center;
}
.l-aside__item.--md span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.l-aside__heading {
  font-size: 20px;
  font-weight: 900;
  color: #ffffff;
}
.l-aside__heading-wrap {
  height: 48px;
  width: 100%;
  padding: 16px 12px;
  background-color: #000000;
  z-index: 1;
  display: flex;
  align-items: center;
}
@media (min-width: 1024px) {
  .l-aside__heading-wrap {
    border-radius: 4px;
  }
}

.l-aside__img-wrap {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.l-aside__img-wrap.--absolute {
  position: absolute;
  top: 0;
  right: 0;
}
.l-aside__img-wrap.--cover {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  border-radius: 50%;
}
.l-aside__img-wrap.--cover img {
  width: 100%;
  height: 100%;
}
.l-aside__img-wrap img {
  width: 32px;
  height: 32px;
}

.l-aside__input-wrap {
  position: relative;
  border-radius: 4px;
  overflow: hidden;
}

.l-aside__menu-list {
  gap: 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.l-aside__menu-item {
  width: 100%;
  background-color: #f9f9f9;
  border-radius: 4px;
}
.l-aside__menu-item.--works {
  gap: 8px;
  padding: 8px 0;
  margin: 8px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.l-aside__menu-item-title {
  font-weight: 700;
}
.l-aside__menu-item-wrap {
  gap: 16px;
  display: flex;
  align-items: center;
}
.l-aside__menu-link {
  padding: 8px;
  display: block;
  width: 100%;
  position: relative;
}
.l-aside__menu-link.--sub {
  color: #666666;
}
.l-aside__menu-link::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 2px;
  display: block;
  width: 8px;
  height: 8px;
  border-top: 2px solid #000000;
  border-right: 2px solid #000000;
  transform: translateY(-50%) rotate(45deg);
  right: 8px;
}

.c-footer {
  width: 100%;
  background-color: #f9f9f9;
  border-top: 1px solid #eeeeee;
  margin-top: 64px;
}

.c-footer__inner {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 16px;
}

.c-footer__main {
  padding: 32px 0;
  border-bottom: 1px solid #eeeeee;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
@media (min-width: 1024px) {
  .c-footer__main {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-direction: row;
    gap: 16px;
  }
  .c-footer__main > * {
    width: calc((100% - 32px) / 2);
  }
}

.c-footer__main-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 32px;
}
@media (min-width: 1024px) {
  .c-footer__main-left {
    align-items: flex-start;
  }
}

.l-footer__logo {
  width: 133px;
  height: 48px;
  display: flex;
  flex-direction: column;
}
.l-footer__logo p {
  font-size: 10px;
  color: #888888;
}

.l-footer__sns {
  gap: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  justify-content: flex-start;
}
.l-footer__sns a {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  border-radius: 50%;
}
.l-footer__sns img {
  width: 100%;
  height: 100%;
}

.c-footer__main-right {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.c-footer__main-right > p {
  font-size: 14px;
  letter-spacing: -0.05em;
}

.c-footer__sub {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 32px 0;
}

.c-footer__list {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 8px 16px;
}
.c-footer__list li {
  font-size: 14px;
  width: calc((100% - 16px) / 2);
}
@media (min-width: 1024px) {
  .c-footer__list li {
    width: -moz-fit-content;
    width: fit-content;
  }
}
.c-footer__list a {
  color: #666666;
}

.c-footer__copy {
  width: 100%;
  height: 32px;
  font-size: 14px;
  color: #ffffff;
  background-color: #000000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.l-actions {
  width: 100%;
  gap: 16px;
  margin-top: 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media (min-width: 1024px) {
  .l-actions {
    flex-direction: row;
  }
}

.p-kv {
  width: 100%;
  padding: 6px 0;
  background-color: #f9f9f9;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.p-kv .swiper-wrapper {
  transition-timing-function: linear;
}
.p-kv .swiper-slide {
  width: -moz-fit-content;
  width: fit-content;
}
.p-kv img {
  -o-object-fit: cover;
     object-fit: cover;
}
.p-kv ul {
  display: flex;
  justify-content: flex-start;
  gap: 6px;
  padding: 0 6px;
}
.p-kv ul:nth-child(2) {
  flex-direction: row-reverse;
}
.p-kv li {
  flex-shrink: 0;
}
.p-kv__item {
  display: grid;
  grid-template-columns: auto auto auto auto;
  grid-template-rows: auto auto auto;
  gap: 6px;
}
.p-kv__bakusoku {
  grid-row: 1/4;
  grid-column: 1/2;
}
.p-kv__bakusoku img {
  width: 128px;
  height: 200px;
}
@media (min-width: 1024px) {
  .p-kv__bakusoku img {
    width: 192px;
    height: 300px;
  }
}
.p-kv__song {
  grid-row: 1/3;
  grid-column: 2/3;
}
.p-kv__song img {
  width: 178px;
  height: 100px;
}
@media (min-width: 1024px) {
  .p-kv__song img {
    width: 267px;
    height: 150px;
  }
}
.p-kv__viewing {
  grid-row: 1/3;
  grid-column: 3/4;
}
.p-kv__viewing img {
  width: 178px;
  height: 100px;
}
@media (min-width: 1024px) {
  .p-kv__viewing img {
    width: 267px;
    height: 150px;
  }
}
.p-kv__article {
  grid-row: 3/4;
  grid-column: 2/4;
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.p-kv__article > * {
  width: 50%;
  height: 96px;
}
@media (min-width: 1024px) {
  .p-kv__article > * {
    height: 144px;
  }
}
.p-kv__article div {
  display: flex;
  align-items: center;
  padding: 6px;
  background-color: #ffffff;
}
.p-kv__article p {
  font-size: 12px;
  color: #ff5a62;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
  text-overflow: ellipsis;
}
.p-kv__comment {
  grid-row: 1/2;
  grid-column: 4/5;
  width: 100px;
  height: 56px;
  background-color: #17C1F4;
  display: flex;
  align-items: center;
  padding: 6px;
}
@media (min-width: 1024px) {
  .p-kv__comment {
    width: 150px;
    height: 84px;
  }
}
.p-kv__comment p {
  font-size: 12px;
  color: #ffffff;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis;
}
.p-kv__work {
  grid-row: 2/4;
  grid-column: 4/5;
}
.p-kv__work img {
  width: 100px;
  height: 140px;
}
@media (min-width: 1024px) {
  .p-kv__work img {
    width: 150px;
    height: 210px;
  }
}

.p-top__desc {
  font-size: 14px;
  color: #666666;
  margin-bottom: 16px;
}
.p-top__slide {
  width: calc(100% + 32px);
  margin-left: -16px;
  padding-left: 16px;
  padding-right: 16px;
  padding-bottom: 8px;
  overflow: hidden;
  position: relative;
}
@media (min-width: 1024px) {
  .p-top__slide {
    width: 100%;
    margin-left: 0;
    padding-left: 0;
    padding-right: 0;
  }
}
.p-top__slide img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}
.p-top__slide.bakusoku img {
  aspect-ratio: 111/162;
}
.p-top__slide.song img {
  aspect-ratio: 128/72;
}
@media (min-width: 1024px) {
  .p-top__btn {
    width: 40px;
    height: 40px;
    background-color: rgba(0, 0, 0, 0.6);
    border-radius: 100%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    display: block;
    position: absolute;
    top: calc(50% - 20px);
    z-index: 1;
    cursor: pointer;
  }
  .p-top__btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 2px;
    display: block;
    width: 8px;
    height: 8px;
    border-top: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
    transform: translateY(-50%) rotate(45deg);
    left: 13px;
  }
  .p-top__btn.prev {
    left: 0;
    transform: scale(-1, 1);
  }
  .p-top__btn.next {
    right: 0;
  }
  .p-top__btn.swiper-button-disabled {
    display: none;
  }
}

.p-top__article {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 24px;
}
@media (min-width: 1024px) {
  .p-top__article {
    gap: 16px;
  }
}
.p-top__article li {
  width: 100%;
}
@media (min-width: 1024px) {
  .p-top__article li {
    width: calc((100% - 16px) / 2);
  }
}

.p-top__viewing {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 24px;
}
@media (min-width: 1024px) {
  .p-top__viewing {
    gap: 16px;
  }
}
.p-top__viewing li {
  width: 100%;
}
@media (min-width: 1024px) {
  .p-top__viewing li {
    width: calc((100% - 16px) / 2);
  }
}

.p-top__comment {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 16px;
}
.p-top__comment li {
  width: 100%;
}
@media (min-width: 1024px) {
  .p-top__comment li {
    width: calc((100% - 16px) / 2);
  }
}

.p-top__work {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 8px;
}
.p-top__work li {
  width: calc((100% - 8px) / 2);
  aspect-ratio: 80/112;
}
@media (min-width: 1024px) {
  .p-top__work li {
    width: calc((100% - 24px) / 4);
  }
}

.p-bakusoku-list {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  margin-bottom: 32px;
  gap: 8px;
}
.p-bakusoku-list__item {
  width: calc((100% - 8px) / 2);
  aspect-ratio: 111/162;
}
@media (min-width: 1024px) {
  .p-bakusoku-list__item {
    width: calc((100% - 24px) / 4);
  }
}
.p-bakusoku-list__item > a > img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 4px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}
@media (min-width: 1024px) {
  .p-bakusoku-list__item > a > img {
    border-radius: 8px;
  }
}

.p-song-list {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  margin-bottom: 32px;
  gap: 16px;
}
.p-song-list__item {
  width: 100%;
  aspect-ratio: 128/72;
}
@media (min-width: 1024px) {
  .p-song-list__item {
    width: calc((100% - 16px) / 2);
  }
}
.p-song-list__item > a > img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.p-viewing-list {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  margin-bottom: 32px;
  gap: 24px;
}
@media (min-width: 1024px) {
  .p-viewing-list {
    gap: 16px;
  }
}
.p-viewing-list__item {
  width: 100%;
}
@media (min-width: 1024px) {
  .p-viewing-list__item {
    width: calc((100% - 16px) / 2);
  }
}
.p-viewing-list img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (min-width: 1024px) {
  .p-viewing-list img {
    border-radius: 4px;
  }
}

.p-work-list {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  margin-bottom: 32px;
  gap: 8px;
}
.p-work-list__item {
  width: calc((100% - 8px) / 2);
}
@media (min-width: 1024px) {
  .p-work-list__item {
    width: calc((100% - 24px) / 4);
  }
}
.p-work-list img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-work-kana {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-bottom: 16px;
}
.p-work-kana li {
  width: calc((100% - 32px) / 5);
  height: 40px;
  font-weight: 700;
  border-radius: 4px;
  color: #ff5a62;
  background-color: #f9f9f9;
}
.p-work-kana li.is-active {
  color: #ffffff;
  background-color: #ff5a62;
}
.p-work-kana a {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.p-work-single__fv {
  width: calc(100% + 32px);
  margin-left: -16px;
  margin-top: -16px;
  padding-bottom: 16px;
  border-bottom: 1px solid #eeeeee;
}
@media (min-width: 1024px) {
  .p-work-single__fv {
    width: 100%;
    margin-left: 0;
    margin-top: 0;
  }
}
.p-work-single__fv-cover {
  width: 100%;
  aspect-ratio: 120/63;
}
.p-work-single__fv-cover img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (min-width: 1024px) {
  .p-work-single__fv-cover img {
    border-radius: 8px;
  }
}
.p-work-single__fv-info {
  position: relative;
}
.p-work-single__fv-kv {
  width: 80px;
  aspect-ratio: 80/112;
  border: 2px solid #ffffff;
  position: absolute;
  top: -56px;
  left: 16px;
}
@media (min-width: 1024px) {
  .p-work-single__fv-kv {
    width: 160px;
    top: -112px;
    left: 16px;
  }
}
.p-work-single__fv-kv img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-work-single__fv-bottom {
  width: 100%;
  min-height: 56px;
  padding-top: 8px;
  padding-left: 104px;
  padding-right: 16px;
}
@media (min-width: 1024px) {
  .p-work-single__fv-bottom {
    min-height: 112px;
    padding-left: 192px;
  }
}
.p-work-single__fv-quotation {
  width: -moz-fit-content;
  width: fit-content;
  font-size: 10px;
  color: #666666;
  display: block;
}
.p-work-single__fv-title {
  font-size: 16px;
  font-weight: 700;
}
@media (min-width: 1024px) {
  .p-work-single__fv-title {
    font-size: 24px;
  }
}
.p-work-single__fv-copyright {
  font-size: 10px;
  color: #666666;
}
@media (min-width: 1024px) {
  .p-work-single__fv-copyright {
    font-size: 12px;
  }
}
.p-work-single__fv-category {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
  padding: 0 16px;
}
@media (min-width: 1024px) {
  .p-work-single__fv-category {
    margin-top: 16px;
    padding: 0;
  }
}
.p-work-single__fv-category li {
  flex-shrink: 0;
}
.p-work-single__fv-category a {
  color: #ff5a62;
  background-color: #f9f9f9;
  border-radius: 4px;
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}
@media (min-width: 1024px) {
  .p-work-single__fv-category a {
    font-size: 14px;
  }
}
.p-work-single__fv-tag {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
  padding: 0 16px;
}
@media (min-width: 1024px) {
  .p-work-single__fv-tag {
    margin-top: 16px;
    padding: 0;
  }
}
.p-work-single__fv-tag li {
  flex-shrink: 0;
}
.p-work-single__fv-tag a {
  font-size: 14px;
}
@media (min-width: 1024px) {
  .p-work-single__fv-tag a {
    font-size: 16px;
  }
}
.p-work-single__fv-tag a::before {
  content: "#";
}
.p-work-single__fv-official {
  color: #ff5a62;
  font-size: 12px;
  margin-top: 8px;
  padding: 0 16px;
}
@media (min-width: 1024px) {
  .p-work-single__fv-official {
    font-size: 14px;
    margin-top: 16px;
    padding: 0;
  }
}
.p-work-single__fv-official a {
  text-decoration: underline;
}

.p-work-single__sns {
  border-top: 4px solid #eeeeee;
  border-bottom: 4px solid #eeeeee;
  padding-top: 16px;
  padding-bottom: 24px;
}
.p-work-single__sns-title {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 24px;
}

._icon i, .p-work-single__song-thumb i, .p-work-single__bakusoku-thumb i {
  width: 80px;
  height: 80px;
  background-color: rgba(255, 255, 255, 0.8);
  border: 1px solid #ffffff;
  border-radius: 100%;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  position: absolute;
  top: calc(50% - 40px);
  left: calc(50% - 40px);
  display: block;
}
._icon i:after, .p-work-single__song-thumb i:after, .p-work-single__bakusoku-thumb i:after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent transparent transparent #ff5a62;
  border-width: 16px 0px 16px 24px;
  position: absolute;
  top: calc(50% - 16px);
  left: calc(50% - 10px);
}
._icon img, .p-work-single__song-thumb img, .p-work-single__bakusoku-thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-work-single__bakusoku {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px;
}
.p-work-single__bakusoku-thumb {
  width: 100%;
  max-width: 400px;
  aspect-ratio: 111/162;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  position: relative;
  display: block;
}

.p-work-single__song {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px;
}
.p-work-single__song-item {
  width: 100%;
  max-width: 600px;
}
.p-work-single__song-thumb {
  width: 100%;
  aspect-ratio: 128/72;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
  position: relative;
  display: block;
}
.p-work-single__song-tool {
  text-align: center;
  color: #666666;
}
.p-work-single__song-desc {
  margin-top: 16px;
  height: 144px;
  overflow: hidden;
  position: relative;
}
.p-work-single__song-desc::after {
  content: "";
  width: 100%;
  height: 48px;
  background: linear-gradient(0deg, rgb(255, 255, 255) 0%, rgba(255, 255, 255, 0) 100%);
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
}
.p-work-single__song-desc.is-active {
  height: auto;
}
.p-work-single__song-desc.is-active::after {
  height: 0;
}
.p-work-single__song-btn {
  width: 100%;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 14px;
  color: #ff5a62;
  position: relative;
}
.p-work-single__song-btn::before {
  content: "歌詞を見る";
}
.p-work-single__song-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 2px;
  display: block;
  width: 6px;
  height: 6px;
  border-top: 2px solid #000000;
  border-right: 2px solid #000000;
  transform: translateY(-50%) rotate(45deg);
  transform: rotate(135deg);
  position: static;
  margin-top: 0;
  margin-bottom: 4px;
}
.p-work-single__song-btn.is-active::before {
  content: "閉じる";
}
.p-work-single__song-btn.is-active::after {
  transform: rotate(315deg);
  margin-top: 4px;
  margin-bottom: 0;
}

.p-work-single__story {
  margin-top: 32px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.p-work-single__story-title {
  width: 100%;
  height: 40px;
  background-color: #ffffff;
  border: 1px solid #ff5a62;
  border-radius: 4px;
  font-size: 16px;
  font-weight: 900;
  color: #ff5a62;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  margin-bottom: 8px;
}
.p-work-single__story-title::after {
  content: "";
  width: 16px;
  height: 16px;
  transform: rotate(45deg);
  border-right: 1px solid #ff5a62;
  border-bottom: 1px solid #ff5a62;
  background-color: #ffffff;
  position: absolute;
  left: calc(50% - 10px);
  bottom: -10px;
}
.p-work-single__story-heading {
  font-size: 20px;
  font-weight: 700;
  border-left: 8px solid #ff5a62;
  padding-left: 4px;
}
.p-work-single__story-point {
  width: -moz-fit-content;
  width: fit-content;
  font-size: 12px;
  font-weight: 900;
  color: #ffffff;
  padding: 4px;
  margin-bottom: 4px;
  position: relative;
}
.p-work-single__story-point span {
  position: relative;
}
.p-work-single__story-point::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: #ff5a62;
  transform: rotate(-2deg);
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}
.p-work-single__story-sub {
  font-size: 16px;
  font-weight: 700;
}
.p-work-single__story-desc {
  font-size: 14px;
  margin-top: 8px;
}

.p-work-single__vod {
  width: calc(100% + 32px);
  margin-left: -16px;
  padding: 32px 16px;
  background-color: #FFF4D8;
}
@media (min-width: 1024px) {
  .p-work-single__vod {
    width: 100%;
    margin-left: 0;
    padding: 32px;
    border-radius: 8px;
  }
}
.p-work-single__vod-title {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 16px;
}
@media (min-width: 1024px) {
  .p-work-single__vod-title {
    margin-bottom: 32px;
  }
}
.p-work-single__vod-list {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
.p-work-single__vod-list li {
  width: calc((100% - 16px) / 2);
}
@media (min-width: 1024px) {
  .p-work-single__vod-list li {
    width: calc((100% - 48px) / 4);
  }
}

.p-work-single__chara {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.p-work-single__chara-item {
  width: 100%;
  gap: 16px;
  display: flex;
  flex-direction: column;
}
@media (min-width: 1024px) {
  .p-work-single__chara-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: row;
  }
  .p-work-single__chara-item:nth-child(even) {
    flex-direction: row-reverse;
  }
}
.p-work-single__chara-top {
  width: 100%;
}
.p-work-single__chara-bottom {
  flex-shrink: 0;
}
.p-work-single__chara-heading {
  font-size: 20px;
  font-weight: 700;
  border-left: 8px solid #ff5a62;
  padding-left: 4px;
}
.p-work-single__chara-desc {
  margin-top: 8px;
}
.p-work-single__chara-pic {
  width: 100%;
  border: 1px solid #eeeeee;
  border-radius: 4px;
  overflow: hidden;
  flex-shrink: 0;
}
@media (min-width: 1024px) {
  .p-work-single__chara-pic {
    width: 320px;
  }
}
.p-work-single__chara-pic img {
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  background-color: #ffffff;
}
.p-work-single__chara-copyright {
  text-align: center;
  color: #666666;
  font-size: 12px;
  margin-bottom: 4px;
}
.p-work-single__chara-name {
  text-align: center;
  color: #666666;
  font-size: 16px;
  font-weight: 700;
}
.p-work-single__chara-actor {
  text-align: center;
  color: #666666;
  font-size: 14px;
}

.p-work-single__viewing {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
}
@media (min-width: 1024px) {
  .p-work-single__viewing {
    gap: 16px;
  }
}
.p-work-single__viewing-item {
  width: 100%;
}
@media (min-width: 1024px) {
  .p-work-single__viewing-item {
    width: calc((100% - 16px) / 2);
  }
}
.p-work-single__viewing-thumb {
  border-radius: 8px;
  position: relative;
  width: 100%;
  aspect-ratio: 128/72;
  overflow: hidden;
}
.p-work-single__viewing-thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-work-single__viewing-title {
  color: #ff5a62;
  font-weight: 700;
  margin-top: 8px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  text-overflow: ellipsis;
}
.p-work-single__viewing-sub {
  width: 100%;
  display: block;
  color: #888888;
  font-size: 12px;
  margin-top: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.p-work-single__staff {
  font-size: 14px;
  background-color: #f9f9f9;
  border-radius: 8px;
  padding: 16px;
}

.p-work-single__work {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 8px;
}
.p-work-single__work li {
  width: calc((100% - 8px) / 2);
  aspect-ratio: 80/112;
}
@media (min-width: 1024px) {
  .p-work-single__work li {
    width: calc((100% - 24px) / 4);
  }
}

.p-article-list {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  margin-bottom: 32px;
  gap: 24px;
}
@media (min-width: 1024px) {
  .p-article-list {
    gap: 16px;
  }
}
.p-article-list__item {
  width: 100%;
}
@media (min-width: 1024px) {
  .p-article-list__item {
    width: calc((100% - 16px) / 2);
  }
}
.p-article-list img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-article-single {
  margin-bottom: 32px;
}
.p-article-single__header {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.p-article-single__info {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.p-article-single__category {
  display: flex;
  gap: 8px;
}
.p-article-single__category a {
  width: -moz-fit-content;
  width: fit-content;
  min-height: 32px;
  font-size: 14px;
  color: #ff5a62;
  background-color: #f9f9f9;
  padding: 4px 8px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-article-single__date {
  font-size: 14px;
  color: #888888;
  flex-shrink: 0;
}
.p-article-single__heading {
  font-size: 20px;
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 4px solid #eeeeee;
}
@media (min-width: 1024px) {
  .p-article-single__heading {
    font-size: 24px;
    margin-bottom: 32px;
  }
}

.p-article-single__works {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (min-width: 1024px) {
  .p-article-single__works {
    gap: 32px;
  }
}

.p-article-single__work {
  width: 100%;
  border-radius: 8px;
  overflow: hidden;
  background-color: #f9f9f9;
}
.p-article-single__work-header {
  width: 100%;
  height: 48px;
  line-height: 48px;
  font-size: 20px;
  font-weight: 900;
  text-align: center;
  color: #ffffff;
  background-color: #000000;
}
.p-article-single__work-body {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-bottom: 32px;
}
@media (min-width: 1024px) {
  .p-article-single__work-body {
    flex-direction: row;
    display: flex;
    align-items: center;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    padding: 16px;
  }
}
.p-article-single__work-left {
  width: 100%;
  flex-shrink: 0;
}
@media (min-width: 1024px) {
  .p-article-single__work-left {
    width: 360px;
  }
}
.p-article-single__work-right {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
}
@media (min-width: 1024px) {
  .p-article-single__work-right {
    align-items: flex-start;
  }
}
.p-article-single__work-cover {
  width: 100%;
  aspect-ratio: 120/63;
}
.p-article-single__work-cover img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-article-single__work-info {
  position: relative;
}
.p-article-single__work-kv {
  width: 80px;
  height: 112px;
  aspect-ratio: 80/112;
  border: 2px solid #ffffff;
  position: absolute;
  top: -56px;
  left: 8px;
}
.p-article-single__work-kv img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-article-single__work-bottom {
  width: 100%;
  padding-left: 96px;
}
.p-article-single__work-title {
  margin-top: 8px;
  font-size: 16px;
  font-weight: 700;
}
.p-article-single__work-copyright {
  font-size: 12px;
  color: #666666;
}
.p-article-single__work-desc {
  padding: 8px;
}
@media (min-width: 1024px) {
  .p-article-single__work-desc {
    padding: 0;
  }
}

.p-article-single__sns {
  border-top: 4px solid #eeeeee;
  border-bottom: 4px solid #eeeeee;
  padding-top: 16px;
  padding-bottom: 24px;
}
.p-article-single__sns-title {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 24px;
}

.p-article-single__copy {
  font-size: 14px !important;
  color: #888888;
}

.p-about__frame > * {
  margin-bottom: 16px;
}
@media (min-width: 1024px) {
  .p-about__frame > * {
    margin-bottom: 32px;
  }
}
.p-about__heading {
  margin-bottom: 16px;
}
.p-about__text a {
  color: #ff5a62;
  font-weight: 700;
  text-decoration: underline;
}
.p-about__sns {
  margin-top: 32px;
  margin-bottom: 32px;
}

.p-contact__pic {
  width: 240px;
  height: 240px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px auto;
}
.p-contact__check {
  width: 64px;
  height: 96px;
  border-bottom: 16px solid #17C1F4;
  border-right: 16px solid #17C1F4;
  transform: rotate(45deg);
  position: relative;
  margin-top: -40px;
}
.p-contact__text {
  margin-bottom: 16px;
}
@media (min-width: 1024px) {
  .p-contact__text {
    text-align: center;
  }
}
.p-contact__note {
  font-size: 14px;
  color: #888888;
  margin-bottom: 16px;
}
@media (min-width: 1024px) {
  .p-contact__note {
    text-align: center;
  }
}

.p-common-section {
  padding: 24px 0;
}
@media (min-width: 1024px) {
  .p-common-section {
    padding: 32px 0;
  }
}

@media (min-width: 1024px) {
  .p-common-about__body {
    display: flex;
    gap: 16px;
  }
}
.p-common-about__pic {
  flex-shrink: 0;
  width: 100%;
  margin-bottom: 16px;
}
@media (min-width: 1024px) {
  .p-common-about__pic {
    width: 300px;
    margin-bottom: 0;
  }
}
.p-common-about__pic img {
  width: 100%;
}
.p-common-about__main {
  width: 100%;
}
.p-common-about__desc {
  margin-top: 8px;
}
.p-common-about__actions {
  width: 100%;
  gap: 16px;
  margin-top: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (min-width: 1024px) {
  .p-common-about__actions {
    justify-content: flex-start;
  }
}

.p-common-result {
  margin-bottom: 16px;
}

.p-common-actions {
  margin-top: 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
}/*# sourceMappingURL=style.css.map */