@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Bai+Jamjuree:ital,wght@0,200;0,300;0,400;0,500;0,600;0,700;1,200;1,300;1,400;1,500;1,600;1,700&family=Battambang:wght@100;300;400;700;900&display=swap');

@media screen and (min-width: 701px) {

  .sp {
    display: none !important;
  }

  .pc {
    display: block;
  }
}

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

  .sp {
    display: block;
  }
}

@media screen and (min-width: 901px) {

  .nav-sp {
    display: none !important;
  }

  .nav-pc {
    display: block;
  }
}

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

  .nav-sp {
    display: block;
  }
}

/*
--nav font--
font-family: "Battambang", system-ui;
 */

html {
  scroll-behavior: smooth;
}

body,
html {
  margin: 0;
  padding: 0;
  height: 100%;
  font-size: 16px;
  font-family: "kozuka-gothic-pr6n", sans-serif;
  background: #FFFBFB;
}

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

.e-text {
  font-family: "Bai Jamjuree", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.header {
  position: fixed;
  top: 24px;
  right: 32px;
}

.header nav ul {
  display: flex;
  gap: 32px;
  font-family: "Battambang", system-ui;
  color: #1D1818;
}

.header nav ul li:nth-child(2) a {
  background: #D5502C;
  color: #FFFBFB;
  padding: 0 4px;
}



.kv {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 90%;
  margin: 0 auto;
  height: 100dvh;
  min-height: 100%;
  /* 新しい安全なvh */
}

.kv-box {
  display: flex;
  justify-content: center;
  gap: 64px;
  max-width: 1200px;
  margin: 0 auto;
}


.kv-left img {
  height: 100%;
  width: auto;
  max-width: 100%;
  object-fit: contain;
}

/* 右テキスト */
.kv-right {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  font-family: "Bai Jamjuree", sans-serif;
}

.kv-right dl {
  margin-bottom: 4px;
}

.kv-right dt {
  font-size: clamp(14px, 4vw, 32px);
  font-weight: 400;
  color: #1D1818;
}

.kv-right dd {
  font-size: clamp(32px, 8vw, 96px);
  font-weight: 800;
  margin-top: -8px;
  margin-left: -3px;
  color: #D5502C;
}

.kv-jyacket {
  max-width: 300px;
}

.date {
  font-size: clamp(18px, 4vw, 48px);
  font-weight: 400;
  color: #1D1818;
  margin-top: -14px;
}

.logo {
  max-width: clamp(120px, 20vw, 200px);
  margin-bottom: 20px;
}

.kv-jyacket {
  margin-bottom: 20px;
}


.section {
  padding: 96px 0 0;
}

.content {
  width: 90%;
  margin: 0 auto;
}

.h2 {
  font-size: 24px;
  text-align: center;
  font-family: "Battambang", system-ui;
  font-size: clamp();
  font-weight: 400;
  letter-spacing: 0.05em;
  margin-bottom: 40px;
}

.release-h3 {
  font-size: 20px;
  text-align: center;
  font-family: "Battambang", system-ui;
  font-size: clamp();
  font-weight: 400;
  letter-spacing: 0.05em;
  margin-bottom: 40px;
}

.release-h4 {
  font-size: 18px;
  text-align: center;
  font-family: "Battambang", system-ui;
  font-size: clamp();
  font-weight: 400;
  letter-spacing: 0.05em;
  border-bottom: 1px solid #ffffff;
  padding: 14px 0 10px;
}

.release {
  background: #D5502C;
  color: #FFFBFB;
  padding: 96px 0;
}

.release-box {
  display: grid;
  gap: 56px;
  align-items: center;
  grid-template-columns: 1fr 1fr;
  max-width: 1000px;
  margin: 0 auto;
  font-family: "Bai Jamjuree", sans-serif;
}

.release-left {
  box-shadow: 0px 0px 12px 3px rgba(255, 255, 255, 0.2);
}

.release-title {
  font-size: clamp(32px, 8vw, 72px);
  font-weight: 800;
}

.release-date {
  font-size: clamp(18px, 4vw, 40px);
  font-weight: 400;
}

.release-right dl {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 400;
  font-size: 14px;
  margin: 32px 0 56px;
}

.release-right dt {
  padding: 2px 10px;
  border: 1px solid #FFFBFB;
  font-weight: 400;
}

.event {
  text-align: center;
  border: 1px solid #FFFFFF;
  max-width: 800px;
  margin: 56px auto 0;
}

.button {
  display: block;
  width: 100%;
  color: #D5502C;
  background: #FFFBFB;
  text-align: center;
  font-weight: 500;
  max-width: 350px;
  padding: 10px 10px;
  font-family: "kozuka-gothic-pr6n", sans-serif;
  transition: all 0.2s ease;
}

.button:hover {
  color: #FFFBFB;
  background: #7b2b15;
}

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

.cd-book a{
  font-size: 14px;
}

.cd-book p{
  margin-top: 10px;
  line-height: 120%;
  font-size: 14px;
}

.cd-info {
  margin-top: 64px;
}

.cd-info-logo {
  text-align: center;
  font-family: "Bai Jamjuree", sans-serif;
  font-size: clamp(18px, 4vw, 32px);
  font-weight: 400;
}

.cd-title {
  font-family: "Bai Jamjuree", sans-serif;
  font-size: clamp(18px, 4vw, 56px);
  font-weight: 800;
  text-align: center;
  margin: 10px -20px 6px 0;
}

.cd-date {
  font-family: "Bai Jamjuree", sans-serif;
  font-size: clamp(18px, 4vw, 48px);
  font-weight: 800;
  text-align: center;
}

.cd-date span {
  font-size: 24px;
  margin-left: -10px;
}

.event-box {
  padding: 24px 20px;
}

.event-date {
  font-size: clamp(18px, 4vw, 32px);
  margin-top: 4px;
}

.event-date span {
  margin-left: 4px;
  margin-right: 8px;
}

.event-title {
  font-size: clamp(18px, 4vw, 28px);
  font-weight: 800;
}

.event-ul {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 16px auto 14px;
  font-weight: 600;
}

.event-info {
  font-size: 14px;
  font-weight: 400;
}

.event-button {
  margin-top: 24px !important;
}

.event-miniTitle {
  margin: 32px auto 0;
  max-width: 500px;
}

.event-miniTitle p:nth-child(1) {
  font-weight: 500;
  border-bottom: 1px solid #FFFFFF;
  padding-bottom: 8px;
  margin-bottom: 14px;
}

.event-miniTitle p:nth-child(2) {
  font-size: 18px;
  font-weight: 700;
}

.event-miniTitle p:nth-child(3) {
  line-height: 150%;
  font-size: 14px;
  margin-top: 14px;
}

.cd-info-detail {
  display: grid;
  column-gap: 16px;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  max-width: 400px;
  margin: 24px auto 0;
}

.cd-info-detail li {
  display: flex;
  align-items: center;
  gap: 10px;
}

.cd-info-detail li p:first-child {
  font-size: 14px;
  border: 1px solid #ffffff;
  padding: 4px 16px;
}

.cd-info-detail li p:last-child span {
  font-size: 14px;
}

.cd-package {
  max-width: 400px;
  margin: 32px auto;
  line-height: 140%;
}

.cd-package p {
  border-bottom: 1px solid #ffffff;
  padding-bottom: 4px;
  margin-bottom: 16px;
}

.button-2 {
  max-width: 400px;
  margin: 40px auto 0;
}

.schdule {
  color: #1D1818;
  text-align: left;
  font-family: "Bai Jamjuree", sans-serif;
}

.schedule-div {
  max-width: 1000px;
  margin: 32px auto 0;
}

.schedule-div h3 {
  font-size: 1.5rem;
  margin-bottom: 24px;
}

.schdule ul li {
  display: flex;
  gap: 40px;
  align-items: center;
  justify-content: center;
  font-weight: 500;
  width: 100%;
  padding: 18px 20px 18px;
  line-height: 140%;
  font-size: 0.8rem;
}

.schdule ul li p:nth-child(1) {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 0;
  font-size: 1.5rem;
  font-weight: 500;
  width: 10%;
  margin-top: 4px;
}

.schdule ul li p:nth-child(1) span {
  font-size: 0.8rem;
  margin-top: 4px;
  line-height: 120%;
}

.schdule ul li p:nth-child(2) {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 15%;
}

.schdule ul li p:nth-child(3) {
  width: 25%;
  text-align: center;
}

.schdule ul li p:nth-child(4) {
  width: 20%;
  text-align: center;
}

.schdule ul li p:nth-child(4) span {
  font-size: 0.8rem;
}

.schdule ul li p:nth-child(5) {
  width: 25%;
  text-align: center;
}

.schdule ul li p:nth-child(5) a {
  text-decoration: underline;
}

.ul-title li {
  text-align: center;
  font-size: 0.8rem
}

.ul-title li p:nth-child(1) {
  font-size: 0.8rem !important;
}

.ul-title li p:nth-child(3) {
  border-left: none !important;
}

.schdule ul li:nth-child(5) p:nth-child(1) span {
  margin-top: 0;
}

.schdule-pc li {
  border-top: 1px solid #cccccc;
}

.ticket-box {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  text-align: center;
  column-gap: 24px;
  max-width: 1000px;
  margin: 0 auto;
}

.ticket-box dt {
  background: #D5502C;
  color: #FFFBFB;
  padding: 8px 0;
  font-family: "kozuka-gothic-pr6n", sans-serif;
  max-width: 500px;
  margin: 0 auto;
  font-size: 14px;
  font-weight: 500;
}


.ticket-box dd {
  font-size: 16px;
  line-height: 130%;
  font-weight: 600;
  margin: 16px auto 0;
}

.ticket-box dd span {
  font-size: 14px;
  margin-left: -4px;
}

.comingsoon {
  text-align: center;
  border: 1px solid #cccccc;
  padding: 20px 10px;
  max-width: 1000px;
  margin: 0 auto;
}


.place {
  line-height: 150%;
  font-weight: 700;
  font-size: 1rem !important;
  margin: 10px auto 4px;
}

.red {
  color: #ff2c2c;
}

.blue {
  color: #32eaff;
}


.footer {
  background: #D5502C;
  margin-top: 96px;
  padding: 40px 0 8px;
  text-align: center;
  color: #FFFBFB;
}

.official-logo {
  max-width: 150px;
  margin: 0 auto;
}

.official-logo a {
  transition: all 0.2s ease;
}

.official-logo a:hover {
  opacity: 0.5;
}

.sns-link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
  margin: 32px auto 40px;
}

.sns-link a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  transition: all 0.2s ease;
}

.sns-link a:hover {
  opacity: 0.5;
}

.sns-link a img {
  object-fit: contain;
}

.link-youtube {
  height: 32px !important;
}

.copy {
  margin-top: 32px;
}

.banner {
  margin: 64px auto 0;
  max-width: 600px;
}

.banner a {
  transition: all 0.2s ease;
}

.banner a:hover {
  filter: brightness(0.6);
}

.youtube {
  max-width: 600px;
  margin: 56px auto 0;
}

.youtube iframe {
  aspect-ratio: 16/9;
}


@media screen and (max-width: 900px) {

  .hamburger {
    display: flex;
    flex-direction: column;
    gap: 6px;
    background: none;
    border: none;
    cursor: pointer;

    position: fixed;
    top: 24px;
    right: 32px;
    z-index: 1100;
  }

  .hamburger span {
    width: 28px;
    height: 2px;
    background: #1D1818;
    display: block;
  }

  /* メニューを非表示に */
  .nav {
    position: fixed;
    top: 0;
    right: 0;
    width: 30%;
    height: 100vh;
    background: rgba(255, 251, 251, 0.9);
    backdrop-filter: blur(10px);
    transform: translateX(100%);
    transition: transform 0.4s ease;
    z-index: 1000;
    box-shadow: -4px 0px 8px 0px rgba(167, 167, 167, 0.2);
  }

  .nav ul {
    flex-direction: column;
    gap: 24px;
    padding: 120px 32px;
    font-size: 20px;
  }

  /* 開いた状態 */
  .nav.is-open {
    transform: translateX(0);
  }

  .hamburger.is-open span:nth-child(1) {
    transform: translateY(8px) rotate(45deg);
  }

  .hamburger.is-open span:nth-child(2) {
    opacity: 0;
  }

  .hamburger.is-open span:nth-child(3) {
    transform: translateY(-8px) rotate(-45deg);
  }

  .hamburger span {
    transition: transform 0.3s ease, opacity 0.3s ease;
  }


  .kv {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 800px;
    padding: 0 0 64px;
  }

  .kv-right {
    justify-content: flex-start;
    text-align: center;
  }

  .logo {
    max-width: 150px;
    margin: 0 auto 0;
  }

  .kv-right dt {
    font-size: clamp(14px, 6vw, 24px);
  }

  .kv-right dd {
    font-size: clamp(14px, 13vw, 96px);
  }

  .date {
    font-size: clamp(18px, 5vw, 60px);
  }


  .kv-box {
    gap: 24px;
    flex-direction: column;
    align-items: center;
  }

  .release-box {
    display: grid;
    grid-template-columns: 1fr;
    max-width: 400px;
    gap: 24px;
  }

  .release-right dl {
    margin: 24px auto 40px;
  }

  .button {
    max-width: 400px;
  }

  .schdule ul li {
    display: block;
    max-width: 350px;
    margin: 0 auto;
    width: 100%;
    font-size: 0.8rem;
    padding: 0;

    border-bottom: 1px solid #cccccc;
    margin-bottom: 32px;
    padding-bottom: 24px;
  }

  .schdule ul li:last-child {
    border-bottom: none;
  }

  .schdule ul li div {
    display: flex;
    align-items: flex-start;
    gap: 24px;
    margin-top: 10px;
  }

  .schdule ul li a {
    text-decoration: underline;
  }

  .schdule h3 {
    display: block;
    max-width: 500px;
    margin: 0 auto;
    text-align: center;
  }

  .schdule ul li p:nth-child(1) {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 0.8rem;
    font-weight: 800;
    width: 100%;
    font-weight: 900;
    background: #1D1818;
    color: #FFFBFB;
    padding: 0 4px !important;
    max-width: 100px;
    min-width: 100px;
  }


  .venue {
    font-size: 1rem;
  }

  .date span {
    font-size: 0.8rem;
    margin-left: 8px;
  }


  .schdule ul li p:nth-child(2) {
    display: block;
    width: 100%;
  }

  .schdule ul li p:nth-child(3) {
    width: 100%;
    border-left: none;
    padding-left: 8px;
  }

  .schdule ul li p:nth-child(4) {
    width: 100%;
  }

  .ticket-box {
    grid-template-columns: 1fr;
  }

  .ticket-box dd {
    margin: 16px auto 40px;
  }

  .ticket-box dl:last-child dd {
    margin: 16px auto 0;
  }

  .release-h3 {
    margin-bottom: 24px;
  }

  .cd-title {
    font-size: 32px;
  }

  .cd-date {
    font-size: 28px;
  }

  .cd-date span {
    font-size: 16px;
    margin-left: -4px;
  }

  .cd-info-detail {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .cd-info-detail li {
    flex-direction: column;
  }

  .cd-info-detail li p:nth-child(2) {
    font-size: 16px;
  }

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

  .event{
    margin: 56px auto 0;
  }

  .event-ul{
    margin: 24px auto 14px;
    gap: 16px;
  }

  .event-info{
    gap: 4px;
  }


}

@media screen and (max-width: 600px) {

  .nav {
    width: 70%;
  }

  .schdule ul {
    display: grid;
    grid-template-columns: 1fr;
    row-gap: 0;
    column-gap: 0;
    max-width: 400px;
    margin: 0 auto 0;
  }

  .schdule ul li h3 span:first-child {
    font-size: 2rem;
  }

  .kv {
    align-items: flex-start;
    min-height: auto;
    height: 100%;
  }

  .kv-box {
    align-items: center;
  }

  .logo {
    margin-bottom: 20px;
  }

  .kv-right dt {
    font-size: clamp(14px, 6vw, 20px);
  }

  .kv-right dd {
    font-size: clamp(14px, 15vw, 96px);
  }

  .date {
    font-size: clamp(18px, 8vw, 60px);
  }

  .release-date {
    font-size: clamp(18px, 10vw, 32px);
  }

  .release-title {
    font-size: clamp(32px, 15vw, 64px);
  }

  .section {
    padding: 64px 0 0;
  }

  .release {
    padding: 64px 0;
  }

  .h2 {
    font-size: 18px;
    margin-bottom: 24px;
  }


}