@charset "UTF-8";
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; outline: 0; font-size: 100%; vertical-align: baseline; background: transparent; }

body { line-height: 1; }

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

nav ul { list-style: none; }

blockquote, q { quotes: none; }

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

a { margin: 0; padding: 0; font-size: 100%; vertical-align: baseline; background: transparent; color: inherit; text-decoration: none; }

/* change colours to suit your needs */
ins { background-color: #ff9; color: #000; text-decoration: none; }

/* change colours to suit your needs */
mark { background-color: #ff9; color: #000; font-style: italic; font-weight: bold; }

del { text-decoration: line-through; }

abbr[title], dfn[title] { border-bottom: 1px dotted; cursor: help; }

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

/* change border colour to suit your needs */
hr { display: block; height: 1px; border: 0; border-top: 1px solid #cccccc; margin: 1em 0; padding: 0; }

input, button, textarea, select { margin: 0; padding: 0; background: none; border: none; border-radius: 0; outline: none; -webkit-appearance: none; -moz-appearance: none; appearance: none; }

textarea { resize: none; }

html, body { -webkit-text-size-adjust: none; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }

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

img[src$=".svg"] { width: 100%; }

li { list-style: none; }

main { display: block; }

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

img { width: 100%; }

*:focus { outline: none; }

/* --------------------------------------------------
Common
-------------------------------------------------- */
html, body { font-family: var(--font-family); color: var(--primary-color); }

body.is-loaded #wrapper { opacity: 1 !important; transition: opacity 1s ease 0s; }

@media screen and (max-width: 767px) { .pc { display: none !important; } }
@media screen and (min-width: 768px) { .sp { display: none !important; } }
*:not(img)::selection { background: var(--primary-color); color: var(--bg-color); }

*:not(img)::-moz-selection { background: var(--primary-color); color: var(--bg-color); }

/* --------------------------------------------------
Contents
-------------------------------------------------- */
:root { font-size: 10px; --font-family: "Noto Sans JP", sans-serif; --font-heading: "Noto Serif JP", serif; --font-en: "pragmatica", sans-serif; --primary-color: #000; --white-color: #fff; --bg-color: #fff; --ease: cubic-bezier(0.25, 0.1, 0.25, 1); --easein: cubic-bezier(0.32, 0, 0.67, 0); --easeout: cubic-bezier(0.33, 1, 0.68, 1); --easeinout: cubic-bezier(0.55, 0.05, 0.22, 0.99); --bounce: cubic-bezier(0.68, -0.6, 0.32, 1.6); --back: cubic-bezier(0.34, 1.56, 0.64, 1); }

body #wrapper .site-title { width: 49.07%; margin: 0 auto; padding: 19.2% 0 16.53%; opacity: 0; transform: scale(0.5); filter: blur(1rem); }
body #wrapper .site-title .logo { margin: 0 0 9.24%; }
body #wrapper .site-title .logo img { aspect-ratio: 166 / 150; }
body #wrapper .site-title .release { opacity: 0; }
body #wrapper .site-title .release img { aspect-ratio: 100 / 37; }
body #wrapper .mv { opacity: 0; overflow: hidden; }
body #wrapper .mv img { aspect-ratio: 16 / 10; }
body #wrapper .contents [data-inview] { opacity: 0; transform: translate(0, 5rem); }
body #wrapper .contents [data-inview].is-show { opacity: 1; transform: none; transition: opacity 1.2s var(--easeout) 0s, transform 1.2s var(--easeout) 0s; }
body #wrapper .contents .section .link-btn { height: 5.4rem; font-size: 1.4rem; letter-spacing: 0.042em; }
body #wrapper .contents .section .link-btn a { height: 100%; display: flex; justify-content: center; align-items: center; border: 0.1rem solid var(--primary-color); border-radius: 2.7rem; }
body #wrapper .contents .section--intro { padding: 4rem 0 3rem; }
body #wrapper .contents .section--intro .inner { width: 85.33%; margin: 0 auto; }
body #wrapper .contents .section--intro .inner .catch { font-family: var(--font-heading); font-weight: 700; font-size: 1.5rem; line-height: 1.73; margin: 0 0 8rem; }
body #wrapper .contents .section--intro .inner .detail .head { margin: 0 0 4rem; }
body #wrapper .contents .section--intro .inner .detail .head .title { font-family: var(--font-heading); font-weight: 700; font-size: 1.9rem; line-height: 1.58; margin: 0 0 0.8rem; }
body #wrapper .contents .section--intro .inner .detail .head .produce { font-size: 1.3rem; line-height: 1.54; }
body #wrapper .contents .section--intro .inner .detail .edition .data { font-size: 1.3rem; line-height: 1.85; letter-spacing: 0.06em; }
body #wrapper .contents .section--intro .inner .detail .edition .data .row-group .row dt { font-weight: 500; }
body #wrapper .contents .section--intro .inner .detail .edition .data .row-group:not(:last-child) { margin: 0 0 1.6rem; }
body #wrapper .contents .section--intro .inner .detail .edition .data .row-group:not(:last-child) .row { display: flex; }
body #wrapper .contents .section--intro .inner .detail .edition .data:not(:last-child) { margin: 0 0 4rem; }
body #wrapper .contents .section--benefits { padding: 3rem 0 4rem; }
body #wrapper .contents .section--benefits .inner { width: 85.33%; margin: 0 auto; }
body #wrapper .contents .section--benefits .inner .title { font-family: var(--font-heading); font-weight: 700; font-size: 1.9rem; line-height: 1.47; margin: 0 0 4rem; }
body #wrapper .contents .section--benefits .inner .title span { font-size: 2.2rem; }
body #wrapper .contents .section--benefits .inner .detail .data { font-size: 1.4rem; line-height: 1.71; margin: 0 0 4rem; }
body #wrapper .contents .section--benefits .inner .detail .data .row { padding: 1.6rem 0; border-bottom: 0.1rem solid #707070; }
body #wrapper .contents .section--benefits .inner .detail .data .row dt span { font-size: 1.1rem; }
body #wrapper .contents .section--benefits .inner .detail .data .row dt::before { display: inline; content: "●"; margin: 0 0.5em 0 0; }
body #wrapper .contents .section--benefits .inner .detail .data .row dd { padding: 0 0 0 1em; }
body #wrapper .contents .section--benefits .inner .detail .data .row:first-child { padding-top: 0; }
body #wrapper .contents .section--benefits .inner .detail .caption { font-size: 1.1rem; letter-spacing: 0.042em; line-height: 1.82; margin: 0 0 6rem; }
body #wrapper .contents .section--tour { padding: 4rem 0 0; }
body #wrapper .contents .section--tour .inner .title { text-align: center; margin: 0 0 3.2rem; }
body #wrapper .contents .section--tour .inner .title span { display: block; }
body #wrapper .contents .section--tour .inner .title span.text-line1 { font-family: var(--font-en); font-weight: 300; font-size: 5rem; letter-spacing: -0.04em; margin: 0 0 0.5rem; }
body #wrapper .contents .section--tour .inner .title span.text-line2 { font-family: var(--font-en); font-weight: 700; font-size: 6.7rem; letter-spacing: -0.04em; margin: 0 0 0.7rem; }
body #wrapper .contents .section--tour .inner .title span.text-line3 { font-family: var(--font-heading); font-weight: 600; font-size: 3.7rem; letter-spacing: 0.08em; }
body #wrapper .contents .section--tour .inner .link-btn { width: 85.33%; margin: 0 auto 4rem; }
body #wrapper .contents .section--tour .inner .movie { position: relative; }
body #wrapper .contents .section--tour .inner .movie .imagearea img { aspect-ratio: 16 / 9; }
body #wrapper .contents .section--tour .inner .movie .iframe-wrapper { position: absolute; inset: 0; }
body #wrapper .contents .section--tour .inner .movie .iframe-wrapper iframe { width: 100% !important; height: 100% !important; position: absolute; left: 0; top: 0; }
body #wrapper .footer { padding: 4rem 0 2.4rem; }
body #wrapper .footer .inner { width: 85.33%; margin: 0 auto; }
body #wrapper .footer .inner .sns-links { margin: 0 0 3.2rem; }
body #wrapper .footer .inner .sns-links ul { display: flex; justify-content: center; align-items: center; column-gap: 3rem; }
body #wrapper .footer .inner .sns-links ul li.x, body #wrapper .footer .inner .sns-links ul li.instagram { width: 2.4rem; }
body #wrapper .footer .inner .sns-links ul li.youtube { width: 2.8rem; }
body #wrapper .footer .inner .sns-links ul li.facebook, body #wrapper .footer .inner .sns-links ul li.line { width: 2.6rem; }
body #wrapper .footer .inner .link-btn { height: 8rem; white-space: nowrap; font-family: var(--font-en); margin: 0 0 3.2rem; }
body #wrapper .footer .inner .link-btn a { height: 100%; display: flex; flex-direction: column; justify-content: center; align-items: center; row-gap: 0.5rem; border: 0.1rem solid var(--primary-color); }
body #wrapper .footer .inner .link-btn a .text-line1 { font-weight: 200; font-size: 2.6rem; letter-spacing: 0.06em; }
body #wrapper .footer .inner .link-btn a .text-line2 { font-weight: 700; font-style: italic; font-size: 2rem; }
body #wrapper .footer .inner .totop { width: 9rem; aspect-ratio: 1; margin: 0 auto 3.1rem; }
body #wrapper .footer .inner .totop a { height: 100%; display: flex; justify-content: center; align-items: center; position: relative; z-index: 1; }
body #wrapper .footer .inner .totop a img { width: 2rem; }
body #wrapper .footer .inner .totop a::after { display: block; content: ""; position: absolute; inset: 0; background: var(--primary-color); border-radius: 50%; z-index: -1; }
body #wrapper .footer .inner .copyright { display: block; text-align: center; font-family: var(--font-en); font-weight: 300; font-size: 1.2rem; }
body.is-loaded #wrapper .site-title { opacity: 1; transform: none; filter: none; transition: opacity 2s var(--easeout) 0s, transform 3s var(--easeout) 0s, filter 3s var(--easeout) 0s; }
body.is-loaded #wrapper .site-title .release { opacity: 1; transition: opacity 1s var(--easeout) 2s; }
body.is-loaded #wrapper .mv { opacity: 1; transition: opacity 3s var(--easeout) 2s; }

@media screen and (min-width: 768px) { body #wrapper .site-title { width: 16.25%; margin: 0; padding: 4.38% 0 0 4.38%; position: fixed; left: 0; top: 0; z-index: 99; filter: none; transform: none; }
  body #wrapper .site-title .logo { width: 76.92%; margin: 0 auto 6.15%; }
  body #wrapper .site-title .logo img { transition: opacity 1s var(--easeout) 0s; }
  body #wrapper .site-title .release img { aspect-ratio: 130 / 11; transition: opacity 1s var(--easeout) 0s; }
  body #wrapper .mv img { filter: blur(2rem); transform: scale(1.1); }
  body #wrapper .contents .section .link-btn { max-width: 24rem; height: 4rem; margin: 0 auto; }
  body #wrapper .contents .section .link-btn a { border-radius: 2rem; transition: background 0.4s var(--ease) 0s, color 0.4s var(--ease) 0s; }
  body #wrapper .contents .section .link-btn a:hover { background: var(--primary-color); color: var(--white-color); }
  body #wrapper .contents .section--intro { padding: 8rem 0 4rem; }
  body #wrapper .contents .section--intro .inner { width: 72.2rem; }
  body #wrapper .contents .section--intro .inner .catch { font-size: 2.6rem; line-height: 1.62; letter-spacing: 0.069em; }
  body #wrapper .contents .section--intro .inner .detail .head .title { font-size: 2.4rem; margin: 0; }
  body #wrapper .contents .section--intro .inner .detail .edition .data { font-size: 1.5rem; line-height: 1.6; }
  body #wrapper .contents .section--intro .inner .detail .edition .data .row-group .row { display: flex; }
  body #wrapper .contents .section--intro .inner .detail .edition .data .row-group:not(:last-child) { margin: 0; display: flex; column-gap: 1em; }
  body #wrapper .contents .section--intro .inner .detail .edition .data:not(:last-child) { margin: 0 0 1.6em; }
  body #wrapper .contents .section--benefits { padding: 4rem 0 12rem; }
  body #wrapper .contents .section--benefits .inner { width: 72.2rem; }
  body #wrapper .contents .section--benefits .inner .title { font-size: 2.4rem; line-height: 1; }
  body #wrapper .contents .section--benefits .inner .title span { font-size: 2.6rem; }
  body #wrapper .contents .section--benefits .inner .detail .data { font-size: 1.5rem; line-height: 1; }
  body #wrapper .contents .section--benefits .inner .detail .data .row { padding: 1.3rem 0; display: flex; }
  body #wrapper .contents .section--benefits .inner .detail .data .row dt { flex: 1; }
  body #wrapper .contents .section--benefits .inner .detail .data .row dt span { font-size: 1.3rem; }
  body #wrapper .contents .section--benefits .inner .detail .data .row dt::before { margin: 0 1em 0 0; }
  body #wrapper .contents .section--benefits .inner .detail .data .row dd { padding: 0; width: 29rem; }
  body #wrapper .contents .section--benefits .inner .detail .caption { font-size: 1.2rem; letter-spacing: 0.01em; }
  body #wrapper .contents .section--tour .inner .title span.text-line1 { margin: 0 0 1rem; }
  body #wrapper .contents .section--tour .inner .title span.text-line2 { font-size: 8rem; }
  body #wrapper .contents .section--tour .inner .title span.text-line3 { font-size: 4.7rem; }
  body #wrapper .contents .section--tour .inner .link-btn { margin: 0 auto 6rem; }
  body #wrapper .footer .inner { width: 90.63%; position: relative; }
  body #wrapper .footer .inner .sns-links ul li img { display: block; transition: transform 0.4s var(--ease) 0s; }
  body #wrapper .footer .inner .sns-links ul li:hover img { transform: translate(0, -0.8rem); }
  body #wrapper .footer .inner .link-btn { width: 72rem; margin: 0 auto 3.2rem; }
  body #wrapper .footer .inner .link-btn a { transition: background 0.4s var(--ease) 0s, color 0.4s var(--ease) 0s; }
  body #wrapper .footer .inner .link-btn a:hover { background: var(--primary-color); color: var(--white-color); }
  body #wrapper .footer .inner .totop { margin: 0; position: absolute; right: 0; top: 50%; transform: translate(0, -50%); }
  body #wrapper .footer .inner .totop a::after { transition: transform 0.4s var(--ease) 0s; }
  body #wrapper .footer .inner .totop a:hover::after { transform: scale(1.56); }
  body.is-loaded #wrapper .site-title { transition: opacity 1s var(--easeout) 2s; }
  body.is-loaded #wrapper .mv { transition: opacity 2s var(--easeout) 0.4s; }
  body.is-loaded #wrapper .mv img { transform: none; filter: none; transition: transform 4s var(--easeout) 0.4s, filter 4s var(--easeout) 0.4s; }
  body.is-scroll #wrapper .site-title .logo img, body.is-scroll #wrapper .site-title .release img { opacity: 0; } }
