@charset "UTF-8";
/*! modern-normalize v3.0.1 | MIT License | https://github.com/sindresorhus/modern-normalize */
/*
Document
========
*/
/**
Use a better box model (opinionated).
*/
*,
::before,
::after {
  box-sizing: border-box;
}

html {
  /* Improve consistency of default fonts in all browsers. (https://github.com/sindresorhus/modern-normalize/issues/3) */
  font-family: system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
  line-height: 1.15; /* 1. Correct the line height in all browsers. */
  -webkit-text-size-adjust: 100%; /* 2. Prevent adjustments of font size after orientation changes in iOS. */
  tab-size: 4; /* 3. Use a more readable tab size (opinionated). */
}

/*
Sections
========
*/
body {
  margin: 0; /* Remove the margin in all browsers. */
}

/*
Text-level semantics
====================
*/
/**
Add the correct font weight in Chrome and Safari.
*/
b,
strong {
  font-weight: bolder;
}

/**
1. Improve consistency of default fonts in all browsers. (https://github.com/sindresorhus/modern-normalize/issues/3)
2. Correct the odd 'em' font sizing in all browsers.
*/
code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
Add the correct font size in all browsers.
*/
small {
  font-size: 80%;
}

/**
Prevent 'sub' and 'sup' elements from affecting the line height in all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
Tabular data
============
*/
/**
Correct table border color inheritance in Chrome and Safari. (https://issues.chromium.org/issues/40615503, https://bugs.webkit.org/show_bug.cgi?id=195016)
*/
table {
  border-color: currentcolor;
}

/*
Forms
=====
*/
/**
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
*/
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
Correct the inability to style clickable types in iOS and Safari.
*/
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
Remove the padding so developers are not caught out when they zero out 'fieldset' elements in all browsers.
*/
legend {
  padding: 0;
}

/**
Add the correct vertical alignment in Chrome and Firefox.
*/
progress {
  vertical-align: baseline;
}

/**
Correct the cursor style of increment and decrement buttons in Safari.
*/
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/**
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
Remove the inner padding in Chrome and Safari on macOS.
*/
::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to 'inherit' in Safari.
*/
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/*
Interactive
===========
*/
/*
Add the correct display in Chrome and Safari.
*/
summary {
  display: list-item;
}

/*------------------------------------*
	設定
*------------------------------------*/
:root {
  --base-color: #111111;
  --sub-color: #ddd;
  --accent-color: #dab300;
  --container-gutter: 4%;
  --dolphins-color: #cd1b2f;
  --annotation: #e1250b;
  --neophoenix-color: #d2001e;
  --seahorses-color: #1a4899;
  --eagles-color: #0b318f;
  --day1-color: #353535;
  --day2-color: #7b7b7b;
}

/*------------------------------------*
	media query

  @include mix.media(md) {
  }
*------------------------------------*/
/*------------------------------------*
	vw
*------------------------------------*/
/*------------------------------------*
	font size
*------------------------------------*/
/*------------------------------------*
	hover

  @include mix.hover() {
    opacity: .9;
  }
*------------------------------------*/
/*------------------------------------*
	Custom easing functions.
  http://easings.net/ja
*------------------------------------*/
/*------------------------------------*
	media query
*------------------------------------*/
/*------------------------------------*
	Google Font
*------------------------------------*/
.noto-sans-jp-100 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 100;
  font-style: normal;
}

.noto-sans-jp-200 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 200;
  font-style: normal;
}

.noto-sans-jp-300 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
}

.noto-sans-jp-400 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.noto-sans-jp-500 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.noto-sans-jp-600 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-style: normal;
}

.noto-sans-jp-700 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

.noto-sans-jp-800 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 800;
  font-style: normal;
}

.noto-sans-jp-900 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 900;
  font-style: normal;
}

a {
  color: var(--accent-color);
}

/*------------------------------------*
	Adobe Font
*------------------------------------*/
.octin-college {
  font-family: "octin-college", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.shuei-n-min {
  font-family: "dnp-shuei-nmincho-std", sans-serif;
  font-weight: 400;
  font-style: normal;
}

html {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.7;
}

.h0 {
  margin-bottom: 0;
  font-weight: normal;
}
@media screen and (min-width: 769px) {
  .h0 {
    font-size: 80px;
    font-size: 5rem;
    line-height: 1.5;
  }
}

h1,
.h1 {
  font-weight: normal;
  font-size: 40px;
  font-size: 2.5rem;
  line-height: 1.2;
}
@media screen and (min-width: 769px) {
  h1,
  .h1 {
    font-size: 40px;
    font-size: 2.5rem;
    line-height: 1.2;
  }
}

h1 {
  font-weight: 700;
}

h2,
.h2 {
  font-weight: normal;
  font-size: 32px;
  font-size: 2rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  h2,
  .h2 {
    font-size: 32px;
    font-size: 2rem;
    line-height: 1.5;
  }
}

h2 {
  font-weight: 700;
}

h3,
.h3 {
  font-weight: normal;
  font-size: 24px;
  font-size: 1.5rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  h3,
  .h3 {
    font-size: 24px;
    font-size: 1.5rem;
    line-height: 1.5;
  }
}

h3 {
  font-weight: 700;
}

h4,
.h4 {
  font-weight: normal;
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  h4,
  .h4 {
    font-size: 18px;
    font-size: 1.125rem;
    line-height: 1.5;
  }
}

h4 {
  font-weight: bold;
}

h5,
.h5 {
  font-weight: normal;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  h5,
  .h5 {
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1.5;
  }
}

h5 {
  font-weight: bold;
}

h6,
.h6 {
  font-weight: normal;
  font-size: 12px;
  font-size: 0.75rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  h6,
  .h6 {
    font-size: 12px;
    font-size: 0.75rem;
    line-height: 1.5;
  }
}

h6 {
  font-weight: bold;
}

small,
.small {
  display: block;
  font-size: 12px;
  font-size: 0.75rem;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  small,
  .small {
    font-size: 12px;
    font-size: 0.75rem;
    line-height: 1.7;
  }
}

/*------------------------------------*
	icomoon
*------------------------------------*/
@font-face {
  font-family: "icomoon";
  src: url("../fonts/icomoon.eot?53ten0");
  src: url("../fonts/icomoon.eot?53ten0#iefix") format("embedded-opentype"), url("../fonts/icomoon.ttf?53ten0") format("truetype"), url("../fonts/icomoon.woff?53ten0") format("woff"), url("../fonts/icomoon.svg?53ten0#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^=icon-],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "icomoon" !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-newwin:before {
  content: "\e900";
}

.icon-X:before {
  content: "\e901";
  color: #fff;
}

.icon-circle-up:before {
  content: "\ea41";
}

.icon-circle-right:before {
  content: "\ea42";
}

.icon-circle-down:before {
  content: "\ea43";
}

.icon-circle-left:before {
  content: "\ea44";
}

.icon-instagram:before {
  content: "\ea92";
}

/*------------------------------------*
スクロールアテンション
*------------------------------------*/
@keyframes scroll-attention {
  0% {
    height: 100%;
    transform: translateY(-100%);
  }
  50% {
    height: 100%;
    transform: translateY(0);
  }
  100% {
    height: 100%;
    transform: translateY(100%);
  }
}
@keyframes blink {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0.8;
  }
}
/*------------------------------------*
bg-movie
*------------------------------------*/
#bg-movie {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100lvh;
}
#bg-movie video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#bg-movie .bg-movie__cover {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  background-image: radial-gradient(circle, #000000 2px, transparent 2px);
  background-position: 0 0;
  background-size: 8px 8px;
  transition: opacity 1s cubic-bezier(0.25, 0.25, 0.75, 0.75);
  opacity: 0.4;
}
#bg-movie.darken .bg-movie__cover {
  opacity: 0.9;
}

/*------------------------------------*
btn
*------------------------------------*/
.btn-external,
[class*=btn-external--] {
  position: relative;
  z-index: 20;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: var(--accent-color);
  max-width: 320px;
  padding: 8px 16px;
  border: 2px solid var(--accent-color);
  transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.btn-external p,
[class*=btn-external--] p {
  margin: 0;
  font-weight: bold;
}
.btn-external p::after,
[class*=btn-external--] p::after {
  font-family: "icomoon" !important;
  content: "\e900";
  margin-left: 16px;
}
@media screen and (min-width: 769px) {
  .btn-external,
  [class*=btn-external--] {
    padding: 16px 32px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .btn-external:hover,
  [class*=btn-external--]:hover {
    color: var(--sub-color);
    background-color: var(--accent-color);
  }
}

.btn-external--beta {
  color: var(--base-color);
  transition: color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
  background-color: var(--accent-color);
}

.btn-buy,
[class*=btn-buy--sub] {
  text-decoration: none;
  color: var(--accent-color);
  position: relative;
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  border: 2px solid var(--accent-color);
  transition: color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75), background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75), background-blend-mode 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (min-width: 769px) {
  .btn-buy,
  [class*=btn-buy--sub] {
    width: 64%;
  }
}
.btn-buy p,
[class*=btn-buy--sub] p {
  position: relative;
  z-index: 2;
  margin: 0 0 0 16px;
  font-weight: bold;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .btn-buy p,
  [class*=btn-buy--sub] p {
    font-size: 24px;
    font-size: 1.5rem;
    line-height: 1;
  }
}
.btn-buy img,
[class*=btn-buy--sub] img {
  position: relative;
  z-index: 2;
  margin: 0;
  width: 80px;
  transition: mix-blend-mode 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (min-width: 769px) {
  .btn-buy img,
  [class*=btn-buy--sub] img {
    width: 120px;
  }
}
.btn-buy::before,
[class*=btn-buy--sub]::before {
  content: "";
  position: absolute;
  top: 8px;
  left: 8px;
  width: calc(100% - 16px);
  height: calc(100% - 16px);
  border: 1px solid var(--accent-color);
  transition: background-color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (min-width: 769px) {
  .btn-buy::before,
  [class*=btn-buy--sub]::before {
    top: 4px;
    left: 4px;
    width: calc(100% - 8px);
    height: calc(100% - 8px);
  }
}
.btn-buy::after,
[class*=btn-buy--sub]::after {
  position: absolute;
  bottom: 8px;
  right: 16px;
  z-index: 2;
  font-size: 16px;
  font-family: "icomoon";
  content: "\e900";
}
@media screen and (min-width: 769px) {
  .btn-buy::after,
  [class*=btn-buy--sub]::after {
    bottom: 8px;
    right: 16px;
    font-size: 16px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .btn-buy:hover,
  [class*=btn-buy--sub]:hover {
    color: var(--sub-color);
    background-blend-mode: lighten;
  }
  .btn-buy:hover::before,
  [class*=btn-buy--sub]:hover::before {
    background-color: var(--accent-color);
  }
  .btn-buy:hover img,
  [class*=btn-buy--sub]:hover img {
    mix-blend-mode: screen;
  }
}
.btn-buy.disabled,
[class*=btn-buy--sub].disabled {
  color: #7b7b7b;
  pointer-events: none;
  cursor: default;
}
.btn-buy.disabled img,
[class*=btn-buy--sub].disabled img {
  filter: grayscale(1);
}
.btn-buy.disabled::after,
[class*=btn-buy--sub].disabled::after {
  display: none;
}

.btn-buy-sub {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 40px auto 0;
  text-align: center;
  text-decoration: none;
}
.btn-buy-sub p {
  position: relative;
  margin: 0;
  text-decoration: underline;
}
.btn-buy-sub::after {
  display: none;
  position: relative;
  z-index: 2;
  font-size: 16px;
  font-family: "icomoon";
  content: "\e900";
  margin-left: 16px;
}
.btn-buy-s {
  color: var(--base-color);
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  z-index: 9999;
  bottom: 24px;
  min-width: 200px;
  left: 50%;
  transform: translateX(-50%);
  padding: 16px;
  border: 2px solid var(--accent-color);
  transition: color 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
.btn-buy-s::after {
  position: absolute;
  display: block;
  content: "";
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  background-color: var(--accent-color);
}
.btn-buy-s p {
  position: relative;
  z-index: 10;
  margin: 0;
  font-weight: bold;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1;
}
.btn-buy-s p::after {
  position: relative;
  font-family: "icomoon";
  content: "\e900";
  margin-left: 4px;
}
@media (hover: hover) and (pointer: fine) {
  .btn-buy-s:hover {
    color: var(--sub-color);
  }
}
@media screen and (min-width: 769px) {
  .btn-buy-s {
    left: auto;
    right: var(--container-gutter);
    transform: translateX(0);
  }
}

/*------------------------------------*
	Container
*------------------------------------*/
.container,
[class*=container--] {
  padding-left: var(--container-gutter);
  padding-right: var(--container-gutter);
}

.container--s {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

/*------------------------------------*
Loader
*------------------------------------*/
#site-loader {
  pointer-events: none;
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 99999;
  background-color: var(--base-color);
  transition: opacity 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
#site-loader.hide {
  opacity: 0;
}

/*------------------------------------*
	共通設定
*------------------------------------*/
::selection {
  background: var(--accent-color);
  color: var(--base-color);
}

body {
  position: relative;
  color: var(--sub-color);
  background-color: var(--base-color);
}

.site-body {
  position: relative;
  z-index: 100;
}

dl,
dt,
dd,
ul,
li {
  margin: 0;
  padding: 0;
  list-style: none;
}

svg {
  width: 100%;
  height: auto;
}

figure {
  margin: 0;
  padding: 0;
}

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

.annotation {
  color: var(--annotation);
}

.br-pc {
  display: none;
}
@media screen and (min-width: 769px) {
  .br-pc {
    display: block;
  }
}

@media screen and (min-width: 769px) {
  .br-sp {
    display: none;
  }
}

[class*=section--] {
  padding-top: 80px;
  padding-bottom: 80px;
}
[class*=section--] .section-header {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}
[class*=section--] .section-header h4,
[class*=section--] .section-header h1,
[class*=section--] .section-header p {
  margin: 0;
}
[class*=section--] .section-header h4 {
  color: var(--accent-color);
}
[class*=section--] .section-header h1 {
  font-size: 40px;
  font-size: 2.5rem;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  [class*=section--] .section-header h1 {
    font-size: 80px;
    font-size: 5rem;
    line-height: 1;
  }
}
[class*=section--] .section-header hgroup {
  width: 100%;
}
[class*=section--] .section-header p {
  width: 100%;
  margin-bottom: 8px;
}
@media screen and (min-width: 769px) {
  [class*=section--] .section-header {
    align-items: flex-end;
  }
  [class*=section--] .section-header hgroup {
    width: auto;
  }
  [class*=section--] .section-header p {
    width: auto;
    flex: 1;
  }
}
[class*=section--] .section-body {
  position: relative;
  margin-top: 40px;
}

/*------------------------------------*
site-header
*------------------------------------*/
/*------------------------------------*
header
*------------------------------------*/
.site-header {
  pointer-events: none;
  position: fixed;
  width: 100%;
  z-index: 9000;
  line-height: 1;
  transition: transform 0.6s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.site-header a {
  color: var(--sub-color);
  text-decoration: none;
}
.site-header nav {
  transform: translateX(-100vw);
  height: 100dvh;
  background-color: rgba(0, 0, 0, 0.9);
  transition: transform 1s cubic-bezier(0.19, 1, 0.22, 1), background-color 0.5s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
@media screen and (min-width: 769px) {
  .site-header nav {
    height: 80px;
    transform: translateX(0);
  }
  .site-header nav.bg-hide {
    background-color: rgba(17, 17, 17, 0);
  }
}
.site-header ul {
  font-size: 24px;
  font-size: 1.5rem;
  line-height: 1;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-left: var(--container-gutter);
  gap: 8px;
  height: 100%;
}
.site-header ul a {
  pointer-events: all;
}
@media (hover: hover) and (pointer: fine) {
  .site-header ul a:hover p::after {
    transform: scaleX(1);
    transform-origin: left;
  }
}
.site-header ul p {
  display: inline-block;
  position: relative;
  margin: 0;
}
.site-header ul p::after {
  position: absolute;
  bottom: -2px;
  left: 0;
  content: "";
  width: 100%;
  height: 2px;
  transform: scaleX(0);
  background-color: var(--sub-color);
  transition: transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  transform-origin: 0;
  transform-origin: right;
}
@media screen and (min-width: 769px) {
  .site-header ul {
    font-size: 12px;
    font-size: 0.75rem;
    line-height: 1;
    padding-left: 0;
    flex-direction: row;
    align-items: center;
  }
}
@media screen and (min-width: 960px) {
  .site-header ul {
    font-size: 16px;
    font-size: 1rem;
    line-height: 1;
  }
}
@media screen and (min-width: 1280px) {
  .site-header ul {
    font-size: 24px;
    font-size: 1.5rem;
    line-height: 1;
    gap: 16px;
  }
}
.site-header .nav-btn {
  pointer-events: all;
  position: absolute;
  top: 8px;
  left: var(--container-gutter);
  z-index: 99999;
  width: 40px;
  height: 40px;
}
.site-header .nav-btn div {
  position: absolute;
  top: 16px;
  width: 40px;
  height: 2px;
  background-color: var(--sub-color);
  transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}
.site-header .nav-btn div:nth-child(2) {
  top: 24px;
}
.site-header .nav-btn div:nth-child(3) {
  top: 32px;
}
@media screen and (min-width: 769px) {
  .site-header .nav-btn {
    display: none;
  }
}
.site-header.hide {
  transform: translateY(-80px);
}
.site-header.open-nav nav {
  transform: translateX(0);
}
.site-header.open-nav .nav-btn div:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}
.site-header.open-nav .nav-btn div:nth-child(2) {
  transform: rotate(45deg);
  opacity: 0;
}
.site-header.open-nav .nav-btn div:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}

.header__right {
  display: flex;
  align-items: center;
  gap: 16px;
  pointer-events: all;
  position: absolute;
  top: 16px;
  right: var(--container-gutter);
  z-index: 100;
}
.header__right i {
  font-size: 24px;
  font-size: 1.5rem;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .header__right {
    top: 24px;
  }
}

.logo-chukyo-tv {
  width: 80px;
}

/*------------------------------------*
site-footer
https://web-design-pallet.site/css-loop/
*------------------------------------*/
.site-footer {
  padding-top: 40px;
  position: relative;
  z-index: 8000;
}
.site-footer .sns {
  padding-bottom: 80px;
  display: flex;
  gap: 24px;
  justify-content: center;
}
.site-footer .sns a {
  color: var(--sub-color);
  text-decoration: none;
}
.site-footer .sns i {
  font-size: 40px;
  font-size: 2.5rem;
  line-height: 1;
}
.site-footer .ticker {
  position: relative;
  bottom: 0;
  z-index: 10;
  display: flex;
  overflow: hidden;
  line-height: 1;
}
.site-footer .ticker .ticker__item {
  font-weight: 900;
  flex: 0 0 auto;
  white-space: nowrap;
  overflow: hidden;
  width: 2400px;
  padding-right: 80px;
  opacity: 0.4;
}
.site-footer .ticker .ticker__item:nth-child(odd) {
  animation: ticker-loop 40s -20s linear infinite;
}
.site-footer .ticker .ticker__item:nth-child(even) {
  animation: ticker-loop2 40s linear infinite;
}
@media screen and (min-width: 769px) {
  .site-footer .ticker .ticker__item {
    width: 3200px;
  }
}
.site-footer .footer__figure {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 160px;
  z-index: 100;
}
.site-footer .footer__figure * {
  fill: var(--accent-color);
  vertical-align: bottom;
}
@media screen and (min-width: 769px) {
  .site-footer .footer__figure {
    width: 240px;
  }
}
.site-footer .copy {
  display: block;
  position: absolute;
  bottom: 16px;
  left: 0px;
  margin: 0;
  width: 60%;
}

@keyframes ticker-loop {
  0% {
    transform: translateX(100%);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes ticker-loop2 {
  0% {
    transform: translateX(0);
  }
  to {
    transform: translateX(-200%);
  }
}
/*------------------------------------*
hero
*------------------------------------*/
html.home .hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100lvh;
}
html.home .hero .logo {
  width: 80%;
}
@media screen and (min-width: 769px) {
  html.home .hero .logo {
    width: calc(540 / 1280 * (100vw - var(--scrollbar-width)));
  }
}
html.home .hero .date {
  margin-top: 32px;
  width: 56%;
}
@media screen and (min-width: 769px) {
  html.home .hero .date {
    width: calc(400 / 1280 * (100vw - var(--scrollbar-width)));
  }
}
html.home .hero p {
  margin: 8px 0 0;
  font-size: calc(96 / 1280 * (100vw - var(--scrollbar-width)));
  line-height: 1;
}
@media screen and (min-width: 769px) {
  html.home .hero p {
    font-size: calc(64 / 1280 * (100vw - var(--scrollbar-width)));
  }
}

/*------------------------------------*
lead
*------------------------------------*/
html.home .lead {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-top: 40px;
  padding-bottom: 40px;
}
html.home .lead h2 {
  color: var(--accent-color);
  font-size: calc(20 / 375 * (100vw - var(--scrollbar-width)));
  line-height: 2.4;
}
@media screen and (min-width: 769px) {
  html.home .lead {
    height: 100svh;
  }
  html.home .lead h2 {
    font-size: calc(56 / 1280 * (100vw - var(--scrollbar-width)));
    line-height: 2;
  }
}

/*------------------------------------*
ticket
*------------------------------------*/
@media screen and (min-width: 769px) {
  html.home #news {
    text-align: center;
  }
}
@media screen and (min-width: 769px) {
  html.home #news .section-header {
    justify-content: center;
  }
}
html.home #news dl {
  text-align: left;
  display: flex;
  flex-wrap: wrap;
  gap: 0px;
  margin-top: 16px;
}
html.home #news dl:first-child {
  padding-top: 0;
}
html.home #news dl p {
  margin: 0;
}
html.home #news dl dd {
  min-width: 100%;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  html.home #news dl dd {
    min-width: auto;
  }
}
html.home #news dl dt {
  flex: 1;
}
@media screen and (min-width: 769px) {
  html.home #news dl dt {
    margin-left: 16px;
  }
}

/*------------------------------------*
team
*------------------------------------*/
html.home #team .section-body {
  display: flex;
  flex-wrap: wrap;
}
html.home #team [class*=block-team--] {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
  background-repeat: no-repeat;
  background-size: cover;
  overflow: hidden;
}
html.home #team [class*=block-team--] .block-team__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  z-index: 10;
}
html.home #team [class*=block-team--] .block-team__inner h4 {
  margin: 16px 0 0;
  font-weight: normal;
}
html.home #team [class*=block-team--] .btn-external {
  position: absolute;
  bottom: 32px;
}
@media screen and (min-width: 769px) {
  html.home #team [class*=block-team--] .btn-external {
    bottom: 32px;
  }
}
html.home #team [class*=block-team--] .player,
html.home #team [class*=block-team--] .player-shadow {
  position: absolute;
  z-index: 2;
  filter: brightness(0.4);
}
html.home #team [class*=block-team--] .player-shadow {
  z-index: 1;
  opacity: 0.5;
}
html.home #team [class*=block-team--].block-team--eagles {
  background-color: var(--eagles-color);
  background-image: url("../img/eagles_bg.png");
}
html.home #team [class*=block-team--].block-team--eagles .logo {
  width: 50%;
}
@media screen and (min-width: 960px) {
  html.home #team [class*=block-team--].block-team--eagles .logo {
    width: 60%;
  }
}
html.home #team [class*=block-team--].block-team--eagles .player,
html.home #team [class*=block-team--].block-team--eagles .player-shadow {
  width: 140%;
  top: 0;
  left: -40%;
}
html.home #team [class*=block-team--].block-team--eagles .player-shadow {
  left: -30%;
}
html.home #team [class*=block-team--].block-team--dolphins {
  background-color: var(--dolphins-color);
  background-image: url("../img/dolphins_bg.png");
}
html.home #team [class*=block-team--].block-team--dolphins .logo {
  width: 40%;
}
@media screen and (min-width: 960px) {
  html.home #team [class*=block-team--].block-team--dolphins .logo {
    width: 60%;
  }
}
html.home #team [class*=block-team--].block-team--dolphins .player {
  width: 130%;
  top: 0%;
  left: -16%;
}
html.home #team [class*=block-team--].block-team--dolphins .player-shadow {
  width: 130%;
  top: 0%;
  left: -26%;
}
html.home #team [class*=block-team--].block-team--seahorses {
  background-color: var(--seahorses-color);
  background-image: url("../img/seahorses_bg.png");
}
html.home #team [class*=block-team--].block-team--seahorses .logo {
  width: 60%;
}
@media screen and (min-width: 960px) {
  html.home #team [class*=block-team--].block-team--seahorses .logo {
    width: 75%;
  }
}
html.home #team [class*=block-team--].block-team--seahorses .player {
  width: 86%;
  top: -80%;
  left: 30%;
}
html.home #team [class*=block-team--].block-team--seahorses .player-shadow {
  width: 86%;
  top: -80%;
  left: 20%;
}
html.home #team [class*=block-team--].block-team--neophoenix {
  background-color: var(--neophoenix-color);
  background-image: url("../img/neophoenix_bg.png");
}
html.home #team [class*=block-team--].block-team--neophoenix .logo {
  width: 60%;
}
@media screen and (min-width: 960px) {
  html.home #team [class*=block-team--].block-team--neophoenix .logo {
    width: 70%;
  }
}
html.home #team [class*=block-team--].block-team--neophoenix .player {
  width: 70%;
  top: -20%;
  left: -16%;
}
html.home #team [class*=block-team--].block-team--neophoenix .player-shadow {
  width: 70%;
  top: -20%;
  left: -6%;
}
@media screen and (min-width: 769px) {
  html.home #team [class*=block-team--] {
    width: 50%;
  }
}

/*------------------------------------*
tournament
*------------------------------------*/
@media screen and (min-width: 769px) {
  html.home #tournament .tournament-map {
    max-width: 960px;
    margin: 0 auto;
  }
}
html.home #tournament small {
  margin-top: 16px;
}
html.home #tournament [class*=block-schedule--] {
  margin-top: 40px;
}
@media screen and (min-width: 769px) {
  html.home #tournament [class*=block-schedule--] {
    display: flex;
  }
}
html.home #tournament [class*=block-schedule--] .block-schedule__header {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 16px;
  padding: 4px 8px;
  background-color: rgba(53, 53, 53, 0.8);
}
html.home #tournament [class*=block-schedule--] .block-schedule__header h2,
html.home #tournament [class*=block-schedule--] .block-schedule__header h3 {
  text-align: center;
  margin: 0;
  font-weight: normal;
}
@media screen and (min-width: 769px) {
  html.home #tournament [class*=block-schedule--] .block-schedule__header {
    width: 30%;
    flex-direction: row;
    gap: 0;
    padding: 32px;
  }
  html.home #tournament [class*=block-schedule--] .block-schedule__header h2 {
    width: 100%;
  }
}
html.home #tournament [class*=block-schedule--] .block-schedule__body {
  padding: 16px;
  gap: 16px;
  background-color: rgba(17, 17, 17, 0.8);
}
@media screen and (min-width: 769px) {
  html.home #tournament [class*=block-schedule--] .block-schedule__body {
    width: 100%;
    display: flex;
    align-items: center;
  }
}
html.home #tournament [class*=block-schedule--] .block-schedule__body dl {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  font-size: 18px;
  font-size: 1.125rem;
  line-height: 1.5;
}
html.home #tournament [class*=block-schedule--] .block-schedule__body dl dt {
  width: 100%;
}
html.home #tournament [class*=block-schedule--] .block-schedule__body dl dd {
  font-weight: bold;
}
html.home #tournament [class*=block-schedule--] .block-schedule__body dl dd:nth-child(2) {
  margin-left: 16px;
}
html.home #tournament [class*=block-schedule--] .block-schedule__body dl:not(:first-child) {
  margin-top: 8px;
}
@media screen and (min-width: 769px) {
  html.home #tournament [class*=block-schedule--] .block-schedule__body dl {
    width: 100%;
  }
  html.home #tournament [class*=block-schedule--] .block-schedule__body dl dt {
    width: auto;
    margin-left: 16px;
  }
}
html.home #tournament [class*=block-schedule--].block-schedule--day2 .block-schedule__header {
  background-color: rgba(123, 123, 123, 0.8);
}

/*------------------------------------*
ticket
*------------------------------------*/
@media screen and (min-width: 769px) {
  html.home #prize {
    text-align: center;
  }
}
@media screen and (min-width: 769px) {
  html.home #prize .section-header {
    justify-content: center;
  }
}
html.home #prize .section-body .h2 {
  margin: 0;
}
html.home #prize .award {
  margin: 40px auto 0;
  line-height: 1.6;
}
html.home #prize .award header {
  padding-bottom: 24px;
  border-bottom: 1px solid var(--sub-color);
}
html.home #prize .award header h3 {
  margin: 0;
}
@media screen and (min-width: 769px) {
  html.home #prize .award header h3 {
    text-align: center;
  }
}
html.home #prize .award header p {
  margin: 16px 0 0;
}
html.home #prize .award ul {
  text-align: left;
}
html.home #prize .award li {
  border-bottom: 1px solid var(--day2-color);
  display: flex;
  vertical-align: top;
  padding: 24px 0;
}
html.home #prize .award li time {
  width: 20%;
}
html.home #prize .award li p {
  margin: 0;
  width: 50%;
}
html.home #prize .award li p:last-child {
  text-align: right;
}

/*------------------------------------*
ticket
*------------------------------------*/
html.home #ticket small {
  margin-top: 16px;
}
html.home #ticket [class^=ticket-box--day] h2 {
  color: var(--accent-color);
}
html.home #ticket [class^=ticket-box--day] .ticket-box__header {
  display: flex;
  flex-wrap: wrap;
  background-color: var(--day1-color);
}
html.home #ticket [class^=ticket-box--day] .ticket-box__header figure {
  display: flex;
  align-items: center;
  position: relative;
  width: 33%;
  padding: 2%;
}
html.home #ticket [class^=ticket-box--day] .ticket-box__header figure::after {
  position: absolute;
  right: 0;
  content: "";
  width: 2px;
  height: 80%;
  background-color: var(--sub-color);
}
html.home #ticket [class^=ticket-box--day] .ticket-box__header figure:nth-child(3)::after {
  content: none;
}
html.home #ticket [class^=ticket-box--day] .ticket-box__header .txt {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 0 4% 4% 4%;
}
@media screen and (min-width: 769px) {
  html.home #ticket [class^=ticket-box--day] .ticket-box__header figure {
    width: 16%;
    padding: 2%;
  }
  html.home #ticket [class^=ticket-box--day] .ticket-box__header .txt {
    width: 50%;
    padding: 2%;
  }
}
html.home #ticket [class^=ticket-box--day] .ticket-box__body {
  padding: 32px 16px;
  border: 2px solid var(--day1-color);
  background-color: rgba(0, 0, 0, 0.8);
}
html.home #ticket [class^=ticket-box--day] .ticket-box__body dl:not(:first-child) {
  margin-top: 32px;
}
html.home #ticket [class^=ticket-box--day] .ticket-box__body dt {
  color: var(--accent-color);
}
html.home #ticket [class^=ticket-box--day] .ticket-box__body dd {
  margin-top: 16px;
  line-height: 1.6;
}
html.home #ticket [class^=ticket-box--day] .ticket-box__period {
  margin-top: 16px;
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
html.home #ticket [class^=ticket-box--day] .ticket-box__period .box {
  display: inline-flex;
  align-items: center;
  padding: 16px;
  border: 1px solid var(--sub-color);
  line-height: 1.4;
}
html.home #ticket [class^=ticket-box--day] .ticket-box__period p {
  display: flex;
  align-items: center;
  width: 100%;
  margin: 0;
}
@media screen and (min-width: 769px) {
  html.home #ticket [class^=ticket-box--day] .ticket-box__period p {
    width: auto;
    flex: 1;
  }
}
html.home #ticket [class^=ticket-box--day].ticket-box--day2 .ticket-box__header {
  background-color: var(--day2-color);
}
html.home #ticket [class^=ticket-box--day].ticket-box--day2 .ticket-box__body {
  border-color: var(--day2-color);
}
html.home #ticket .ticket-about {
  margin-top: 80px;
}
html.home #ticket .ticket-about h3 {
  margin: 0;
}
html.home #ticket .ticket-about dl {
  margin-top: 32px;
}
html.home #ticket .ticket-about dl dt {
  margin-top: 16px;
  font-weight: bold;
  margin-left: 1em;
  text-indent: -1em;
}
html.home #ticket .ticket-about dl dt span {
  color: #ed4332;
}
html.home #ticket .ticket-about dl dt:nth-child(3) span {
  color: #0051bd;
}
html.home #ticket .ticket-about dl dt:nth-child(5) span {
  color: #ed4332;
}
html.home #ticket .ticket-about dl dt:nth-child(7) span {
  color: #0051bd;
}
html.home #ticket .ticket-about dl dt:nth-child(9) span {
  color: #009944;
}
html.home #ticket .ticket-about .ticket-about__img {
  flex: 1;
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
}
@media screen and (min-width: 769px) {
  html.home #ticket .ticket-about .ticket-about__img > .col {
    width: 50%;
  }
}
html.home #ticket .ticket-about table {
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.5;
  width: 100%;
  flex: 1;
  border-collapse: collapse;
}
html.home #ticket .ticket-about table th,
html.home #ticket .ticket-about table td {
  padding: 8px;
  border: 1px solid var(--base-color);
  text-align: center;
  vertical-align: middle;
}
html.home #ticket .ticket-about table th.red,
html.home #ticket .ticket-about table td.red {
  background-color: rgba(237, 67, 50, 0.4);
}
html.home #ticket .ticket-about table th.blue,
html.home #ticket .ticket-about table td.blue {
  background-color: rgba(0, 81, 189, 0.4);
}
html.home #ticket .ticket-about table th.day-1,
html.home #ticket .ticket-about table td.day-1 {
  background-color: rgba(53, 53, 53, 0.8);
}
html.home #ticket .ticket-about table th.day-2,
html.home #ticket .ticket-about table td.day-2 {
  background-color: rgba(123, 123, 123, 0.8);
}
html.home #ticket .ticket-about table th {
  width: 20%;
}
html.home #ticket .ticket-about table td {
  width: 40%;
}
html.home #ticket .ticket-about table td > p {
  margin: 4px 0 0;
}
html.home #ticket .ticket-about table .logo-neophoenix {
  width: 80%;
}
html.home #ticket .ticket-about table .logo-dolphins {
  width: 40%;
}
html.home #ticket .ticket-about table .logo-seahorses {
  width: 80%;
}
html.home #ticket .ticket-about table .logo-eagles {
  width: 60%;
}
html.home #ticket .ticket-about table .row {
  display: flex;
  align-items: center;
  justify-content: center;
}
html.home #ticket .ticket-about table .row img {
  width: 40%;
}
html.home #ticket .ticket-about table .row img.logo-dolphins {
  width: 24%;
}
html.home #ticket .ticket-about table .row img.logo-eagles {
  width: 32%;
}
html.home #ticket .ticket-about table .row p {
  margin: 0 8px;
}
html.home #ticket .ticket-price {
  margin-top: 80px;
}
html.home #ticket .ticket-price h3 {
  margin: 0;
}
html.home #ticket .ticket-price__body {
  margin-top: 32px;
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
}
html.home #ticket .ticket-price__body figure:first-child {
  position: sticky;
  top: 0;
  height: fit-content;
}
@media screen and (min-width: 769px) {
  html.home #ticket .ticket-price__body figure {
    flex: 1;
  }
  html.home #ticket .ticket-price__body figure:first-child {
    top: 80px;
  }
}
html.home #ticket .ticket-notice {
  margin-top: 80px;
  border: 2px solid var(--sub-color);
  padding: 16px;
}
html.home #ticket .ticket-notice h3 {
  margin: 0;
}
html.home #ticket .ticket-notice ul {
  margin-top: 16px;
}
html.home #ticket .ticket-notice li {
  margin-top: 16px;
  margin-left: 1em;
  text-indent: -1em;
}
html.home #ticket .ticket-buy {
  padding-top: 80px;
}
html.home #ticket .ticket-buy__body {
  position: relative;
  text-align: center;
}
html.home #ticket .ticket-buy__body > p {
  margin: 8px 0 0;
}

/*------------------------------------*
rule
*------------------------------------*/
html.home #rule .section-body > section:not(:first-child) {
  margin-top: 80px;
}
html.home #rule .section-body > section h3 {
  margin: 0;
}
html.home #rule dl {
  margin-top: 2px;
}
html.home #rule dl.accordion-open dt::after {
  transform: rotate(180deg);
}
html.home #rule dt {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px;
  background-color: var(--day1-color);
  cursor: pointer;
}
html.home #rule dt p {
  margin: 0;
  padding-right: 18px;
}
html.home #rule dt::after {
  font-family: "icomoon" !important;
  content: "\ea43";
  font-weight: normal;
  font-size: 24px;
  font-size: 1.5rem;
  line-height: 1;
  transition: transform 0.2s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
html.home #rule dd {
  display: none;
  padding: 16px;
  background-color: rgba(0, 0, 0, 0.6);
}
html.home #rule dd > ul > li {
  margin-left: 1em;
  text-indent: -1em;
}
html.home #rule dd > ul > li:not(:first-child) {
  margin-top: 8px;
}
html.home #rule dd > ul > li ul {
  margin-left: 1em;
}

/*------------------------------------*
event
*------------------------------------*/
html.home #event .section-body > section:not(:first-child) {
  margin-top: 80px;
}
html.home #event .section-body > section h3 {
  margin: 0;
}
html.home #event .mascot-article {
  margin-top: 32px;
}
html.home #event .mascot-article > header {
  text-align: center;
  color: var(--accent-color);
}
html.home #event .mascot-article > header h3,
html.home #event .mascot-article > header h4 {
  margin: 0;
  display: inline-block;
  line-height: 1.2;
}
html.home #event .mascot-article > header h4 {
  margin-bottom: 8px;
}
html.home #event .mascot-article > header hgroup {
  display: flex;
  align-items: center;
}
html.home #event .mascot-article > header hgroup h3 {
  margin: 0 32px;
}
html.home #event .mascot-article > header hgroup::before, html.home #event .mascot-article > header hgroup::after {
  flex: 1;
  position: relative;
  display: block;
  content: "";
  width: 100%;
  height: 2px;
  background-color: var(--accent-color);
}
html.home #event .mascot-article ul {
  margin-top: 32px;
  display: flex;
  flex-wrap: wrap;
}
html.home #event .mascot-article li {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  width: 50%;
  aspect-ratio: 4/5;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: rgba(0, 0, 0, 0.4);
  background-blend-mode: darken;
}
html.home #event .mascot-article li img {
  width: auto;
  height: 90%;
}
html.home #event .mascot-article li:nth-child(1) {
  background-image: url(../img/mascot_eagles_bg.jpg);
}
html.home #event .mascot-article li:nth-child(2) {
  background-image: url(../img/mascot_neophoenix_bg.jpg);
}
html.home #event .mascot-article li:nth-child(3) {
  background-image: url(../img/mascot_seahorses_bg.jpg);
}
html.home #event .mascot-article li:nth-child(4) {
  background-image: url(../img/mascot_dolphins_bg.jpg);
}
@media screen and (min-width: 769px) {
  html.home #event .mascot-article li {
    width: 25%;
  }
}
html.home #event .event-cheer ul {
  margin-top: 32px;
  display: flex;
  flex-wrap: wrap;
}
html.home #event .event-cheer li {
  width: 100%;
}
@media screen and (min-width: 769px) {
  html.home #event .event-cheer li {
    width: 50%;
  }
}
html.home #event .event-food ul {
  margin-top: 32px;
  display: flex;
  flex-wrap: wrap;
}
html.home #event .event-food li {
  position: relative;
  width: 50%;
  aspect-ratio: 1/1;
  display: flex;
  align-items: flex-end;
}
html.home #event .event-food li img {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
html.home #event .event-food li p {
  position: relative;
  margin: 0;
  padding: 8px 16px;
  width: 100%;
  z-index: 10;
  background-color: rgba(0, 0, 0, 0.6);
}
@media screen and (min-width: 769px) {
  html.home #event .event-food li {
    width: 25%;
  }
}
html.home #event .event-goods [class*=goods--] {
  position: relative;
}
html.home #event .event-goods [class*=goods--]:not(:first-child) {
  margin-top: 40px;
}
html.home #event .event-goods [class*=goods--] header {
  text-align: center;
  padding: 8px 32px;
  background-color: currentColor;
}
html.home #event .event-goods [class*=goods--] header h4 {
  margin: 0;
  color: var(--sub-color);
}
@media screen and (min-width: 769px) {
  html.home #event .event-goods [class*=goods--] header {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
  }
}
html.home #event .event-goods [class*=goods--] .goods-body {
  border-top: 2px solid;
  border-left: 2px solid;
}
html.home #event .event-goods [class*=goods--] .block {
  aspect-ratio: 2/1;
  display: flex;
  border-right: 2px solid;
  border-bottom: 2px solid;
  background-color: rgba(0, 0, 0, 0.6);
}
html.home #event .event-goods [class*=goods--] .img {
  width: 50%;
  aspect-ratio: 1/1;
}
html.home #event .event-goods [class*=goods--] .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
html.home #event .event-goods [class*=goods--] .txt {
  aspect-ratio: 1/1;
  color: var(--sub-color);
  width: 50%;
  display: grid;
  place-content: center;
  padding: 16px;
  font-size: 14px;
  font-size: 0.875rem;
  line-height: 1.4;
}
html.home #event .event-goods [class*=goods--] .txt dt {
  font-weight: bold;
  margin-bottom: 8px;
}
html.home #event .event-goods [class*=goods--] .txt dd + dd {
  margin-top: 16px;
}
@media screen and (min-width: 769px) {
  html.home #event .event-goods [class*=goods--] .txt {
    font-size: 16px;
    font-size: 1rem;
    line-height: 1.4;
  }
  html.home #event .event-goods [class*=goods--] .txt dd {
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1.4;
  }
}
@media screen and (min-width: 769px) {
  html.home #event .event-goods [class*=goods--] .goods-body {
    display: flex;
  }
  html.home #event .event-goods [class*=goods--] .goods-body .block {
    width: 50%;
  }
}
html.home #event .event-goods .goods--eagles {
  color: var(--eagles-color);
}
html.home #event .event-goods .goods--neophoenix {
  color: var(--neophoenix-color);
}
html.home #event .event-goods .goods--seahorses {
  color: var(--seahorses-color);
}
html.home #event .event-goods .goods--dolphins {
  color: var(--dolphins-color);
}

/*------------------------------------*
schedule
*------------------------------------*/
@media screen and (min-width: 769px) {
  html.home #schedule {
    text-align: center;
  }
}
@media screen and (min-width: 769px) {
  html.home #schedule .section-header {
    justify-content: center;
  }
}
html.home #schedule .section-body > p {
  margin-top: 40px;
}
html.home #schedule .day {
  text-align: center;
}
html.home #schedule .day > h2 {
  text-align: center;
  margin: 0 auto;
  padding: 16px;
  line-height: 1;
  background-color: var(--day1-color);
}
html.home #schedule .day:nth-child(2) {
  margin-top: 40px;
}
html.home #schedule .day:nth-child(2) > h2 {
  background-color: var(--day2-color);
}
html.home #schedule .games {
  display: flex;
  flex-wrap: wrap;
  gap: var(--container-gutter);
}
html.home #schedule .game {
  width: 100%;
  margin-top: 32px;
}
html.home #schedule .game h4 {
  margin: 0;
  color: var(--accent-color);
}
html.home #schedule .game ul {
  text-align: left;
}
html.home #schedule .game h3 {
  margin: 0;
}
html.home #schedule .game .vs {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  width: 80%;
  margin: 0 auto 0;
}
html.home #schedule .game .vs span {
  font-size: 24px;
  font-size: 1.5rem;
  line-height: 1;
}
html.home #schedule .game .vs img {
  width: 100%;
  height: 40px;
}
@media screen and (min-width: 769px) {
  html.home #schedule .game .vs {
    width: 56%;
  }
  html.home #schedule .game .vs img {
    height: 56px;
  }
}
html.home #schedule .game li {
  border-bottom: 1px solid var(--day2-color);
  display: flex;
  vertical-align: top;
  padding: 24px 0;
}
html.home #schedule .game li time {
  width: 20%;
}
html.home #schedule .game li p {
  margin: 0;
  width: 80%;
}
@media screen and (min-width: 769px) {
  html.home #schedule .game {
    width: 48%;
  }
}

/*------------------------------------*
archive
*------------------------------------*/
html.home #archive {
  padding-bottom: 0;
}
html.home #archive .section-body {
  text-align: center;
  padding-top: 80px;
  padding-bottom: 80px;
}
html.home #archive .row {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  position: relative;
  z-index: 10;
}
html.home #archive dl {
  display: flex;
  flex-direction: column;
  width: 100%;
}
html.home #archive dl dt {
  padding: 16px;
  background-color: rgba(53, 53, 53, 0.9);
}
html.home #archive dl dd {
  padding: 16px;
  background-color: rgba(17, 17, 17, 0.9);
  height: 100%;
}
@media screen and (min-width: 769px) {
  html.home #archive dl {
    width: auto;
    flex: 1;
  }
}
html.home #archive figure {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  overflow: hidden;
  filter: brightness(0.4);
}
html.home #archive figure img {
  width: 100%;
  height: 100vh;
  object-fit: cover;
}
html.home #archive .btn-external--beta {
  margin-top: 32px;
}

/*------------------------------------*
ticket
*------------------------------------*/
html.home #summary {
  text-align: center;
}
html.home #summary .section-header {
  justify-content: center;
}
html.home #summary dl {
  text-align: left;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--day2-color);
}
html.home #summary dl:first-child {
  padding-top: 0;
}
html.home #summary dl p {
  margin: 0;
}
html.home #summary dl p:not(:first-child) {
  margin-top: 4px;
}
html.home #summary dl dt {
  min-width: 100%;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  html.home #summary dl dt {
    min-width: 240px;
  }
}
html.home #summary dl dd {
  flex: 1;
}

/*------------------------------------*
home
*------------------------------------*/
html.home .scroll-attention {
  display: none;
  pointer-events: none;
  position: fixed;
  bottom: 0;
  z-index: 20;
  left: 50%;
  width: 1px;
  height: 10svh;
  opacity: 0;
  overflow: hidden;
  transition: opacity 0.5s cubic-bezier(0.25, 0.25, 0.75, 0.75);
}
html.home .scroll-attention:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 1px;
  height: 100%;
  background-color: white;
  animation: scroll-attention 2s 0s infinite normal cubic-bezier(0.785, 0.135, 0.15, 0.86);
}
html.home .scroll-attention.show {
  opacity: 1;
}
@media screen and (min-width: 769px) {
  html.home .scroll-attention {
    display: block;
  }
}

/*-----------------------------------*
	$style
*------------------------------------*/