@charset "UTF-8";
:root {
  --gold: #c9a96e;
  --gold-light: #e8d5a3;
  --gold-dim: #7a6240;
  --black: #080808;
  --deep: #0e0e0e;
  --surface: #141414;
  --surface2: #1a1a1a;
  --text: #e8e0d4;
  --text-muted: #8a7d6e;
  --text-dim: #4a4035;
  --white: #f5f0e8;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  font-size: 1rem;
  overflow-x: hidden;
}

body {
  background: var(--black);
  color: var(--text);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  letter-spacing: 0.08em;
  width: 100%;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
  cursor: none;
}
@media screen and (max-width: 980px) {
  body {
    font-size: 0.9rem;
  }
}
@media screen and (max-width: 480px) {
  body {
    font-size: 0.85rem;
  }
}

.conbox {
  padding-top: 5rem;
}
@media screen and (max-width: 480px) {
  .conbox {
    padding-top: 3rem;
  }
}
.conbox .con-article {
  background: rgba(20, 20, 20, 0.3);
}
.conbox .con-article h3 {
  margin-bottom: 1.8rem;
}
.conbox .con-article p {
  margin-bottom: 1.8rem;
}

.shortwid {
  margin-left: auto;
  margin-right: auto;
  width: 90%;
  max-width: 1280px;
}

/* Custom cursor */
.cursor {
  position: fixed;
  top: 0;
  left: 0;
  width: 22px;
  height: 16px;
  background: url("../img/wingpoit.svg") center/contain no-repeat;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: width 0.3s, height 0.3s, opacity 0.3s;
}

.cursor-ring {
  position: fixed;
  top: 0;
  left: 0;
  width: 32px;
  height: 32px;
  border: 1px solid rgba(201, 169, 110, 0.4);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%, -50%);
  transition: transform 0.15s ease-out, width 0.3s, height 0.3s;
}

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

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

.larger {
  font-size: larger;
}

.smaller {
  font-size: smaller;
}

.clr2 {
  color: #FFF;
}

.tac {
  text-align: center;
}

.indentleft {
  text-indent: -1.6rem;
  margin-left: 1.6rem;
}

.pcNon {
  display: inline;
}

@media screen and (min-width: 980px) {
  .pcNon {
    display: none;
  }
}
.m-0 {
  margin: 0rem !important;
}

.my-0 {
  margin: 0rem 0 !important;
}

.mx-0 {
  margin: 0 0rem !important;
}

.mt-0 {
  margin-top: 0rem !important;
}

.mb-0 {
  margin-bottom: 0rem !important;
}

.ml-0 {
  margin-left: 0rem !important;
}

.mr-0 {
  margin-right: 0rem !important;
}

.p-0 {
  padding: 0rem !important;
}

.py-0 {
  padding: 0rem 0 !important;
}

.px-0 {
  padding: 0 0rem !important;
}

.pt-0 {
  padding-top: 0rem !important;
}

.pb-0 {
  padding-bottom: 0rem !important;
}

.pl-0 {
  padding-left: 0rem !important;
}

.pr-0 {
  padding-right: 0rem !important;
}

.m-5 {
  margin: 0.5rem !important;
}

.my-5 {
  margin: 0.5rem 0 !important;
}

.mx-5 {
  margin: 0 0.5rem !important;
}

.mt-5 {
  margin-top: 0.5rem !important;
}

.mb-5 {
  margin-bottom: 0.5rem !important;
}

.ml-5 {
  margin-left: 0.5rem !important;
}

.mr-5 {
  margin-right: 0.5rem !important;
}

.p-5 {
  padding: 0.5rem !important;
}

.py-5 {
  padding: 0.5rem 0 !important;
}

.px-5 {
  padding: 0 0.5rem !important;
}

.pt-5 {
  padding-top: 0.5rem !important;
}

.pb-5 {
  padding-bottom: 0.5rem !important;
}

.pl-5 {
  padding-left: 0.5rem !important;
}

.pr-5 {
  padding-right: 0.5rem !important;
}

.m-10 {
  margin: 1rem !important;
}

.my-10 {
  margin: 1rem 0 !important;
}

.mx-10 {
  margin: 0 1rem !important;
}

.mt-10 {
  margin-top: 1rem !important;
}

.mb-10 {
  margin-bottom: 1rem !important;
}

.ml-10 {
  margin-left: 1rem !important;
}

.mr-10 {
  margin-right: 1rem !important;
}

.p-10 {
  padding: 1rem !important;
}

.py-10 {
  padding: 1rem 0 !important;
}

.px-10 {
  padding: 0 1rem !important;
}

.pt-10 {
  padding-top: 1rem !important;
}

.pb-10 {
  padding-bottom: 1rem !important;
}

.pl-10 {
  padding-left: 1rem !important;
}

.pr-10 {
  padding-right: 1rem !important;
}

.m-15 {
  margin: 1.5rem !important;
}

.my-15 {
  margin: 1.5rem 0 !important;
}

.mx-15 {
  margin: 0 1.5rem !important;
}

.mt-15 {
  margin-top: 1.5rem !important;
}

.mb-15 {
  margin-bottom: 1.5rem !important;
}

.ml-15 {
  margin-left: 1.5rem !important;
}

.mr-15 {
  margin-right: 1.5rem !important;
}

.p-15 {
  padding: 1.5rem !important;
}

.py-15 {
  padding: 1.5rem 0 !important;
}

.px-15 {
  padding: 0 1.5rem !important;
}

.pt-15 {
  padding-top: 1.5rem !important;
}

.pb-15 {
  padding-bottom: 1.5rem !important;
}

.pl-15 {
  padding-left: 1.5rem !important;
}

.pr-15 {
  padding-right: 1.5rem !important;
}

.m-20 {
  margin: 2rem !important;
}

.my-20 {
  margin: 2rem 0 !important;
}

.mx-20 {
  margin: 0 2rem !important;
}

.mt-20 {
  margin-top: 2rem !important;
}

.mb-20 {
  margin-bottom: 2rem !important;
}

.ml-20 {
  margin-left: 2rem !important;
}

.mr-20 {
  margin-right: 2rem !important;
}

.p-20 {
  padding: 2rem !important;
}

.py-20 {
  padding: 2rem 0 !important;
}

.px-20 {
  padding: 0 2rem !important;
}

.pt-20 {
  padding-top: 2rem !important;
}

.pb-20 {
  padding-bottom: 2rem !important;
}

.pl-20 {
  padding-left: 2rem !important;
}

.pr-20 {
  padding-right: 2rem !important;
}

.m-25 {
  margin: 2.5rem !important;
}

.my-25 {
  margin: 2.5rem 0 !important;
}

.mx-25 {
  margin: 0 2.5rem !important;
}

.mt-25 {
  margin-top: 2.5rem !important;
}

.mb-25 {
  margin-bottom: 2.5rem !important;
}

.ml-25 {
  margin-left: 2.5rem !important;
}

.mr-25 {
  margin-right: 2.5rem !important;
}

.p-25 {
  padding: 2.5rem !important;
}

.py-25 {
  padding: 2.5rem 0 !important;
}

.px-25 {
  padding: 0 2.5rem !important;
}

.pt-25 {
  padding-top: 2.5rem !important;
}

.pb-25 {
  padding-bottom: 2.5rem !important;
}

.pl-25 {
  padding-left: 2.5rem !important;
}

.pr-25 {
  padding-right: 2.5rem !important;
}

.m-30 {
  margin: 3rem !important;
}

.my-30 {
  margin: 3rem 0 !important;
}

.mx-30 {
  margin: 0 3rem !important;
}

.mt-30 {
  margin-top: 3rem !important;
}

.mb-30 {
  margin-bottom: 3rem !important;
}

.ml-30 {
  margin-left: 3rem !important;
}

.mr-30 {
  margin-right: 3rem !important;
}

.p-30 {
  padding: 3rem !important;
}

.py-30 {
  padding: 3rem 0 !important;
}

.px-30 {
  padding: 0 3rem !important;
}

.pt-30 {
  padding-top: 3rem !important;
}

.pb-30 {
  padding-bottom: 3rem !important;
}

.pl-30 {
  padding-left: 3rem !important;
}

.pr-30 {
  padding-right: 3rem !important;
}

.m-35 {
  margin: 3.5rem !important;
}

.my-35 {
  margin: 3.5rem 0 !important;
}

.mx-35 {
  margin: 0 3.5rem !important;
}

.mt-35 {
  margin-top: 3.5rem !important;
}

.mb-35 {
  margin-bottom: 3.5rem !important;
}

.ml-35 {
  margin-left: 3.5rem !important;
}

.mr-35 {
  margin-right: 3.5rem !important;
}

.p-35 {
  padding: 3.5rem !important;
}

.py-35 {
  padding: 3.5rem 0 !important;
}

.px-35 {
  padding: 0 3.5rem !important;
}

.pt-35 {
  padding-top: 3.5rem !important;
}

.pb-35 {
  padding-bottom: 3.5rem !important;
}

.pl-35 {
  padding-left: 3.5rem !important;
}

.pr-35 {
  padding-right: 3.5rem !important;
}

.m-40 {
  margin: 4rem !important;
}

.my-40 {
  margin: 4rem 0 !important;
}

.mx-40 {
  margin: 0 4rem !important;
}

.mt-40 {
  margin-top: 4rem !important;
}

.mb-40 {
  margin-bottom: 4rem !important;
}

.ml-40 {
  margin-left: 4rem !important;
}

.mr-40 {
  margin-right: 4rem !important;
}

.p-40 {
  padding: 4rem !important;
}

.py-40 {
  padding: 4rem 0 !important;
}

.px-40 {
  padding: 0 4rem !important;
}

.pt-40 {
  padding-top: 4rem !important;
}

.pb-40 {
  padding-bottom: 4rem !important;
}

.pl-40 {
  padding-left: 4rem !important;
}

.pr-40 {
  padding-right: 4rem !important;
}

.m-45 {
  margin: 4.5rem !important;
}

.my-45 {
  margin: 4.5rem 0 !important;
}

.mx-45 {
  margin: 0 4.5rem !important;
}

.mt-45 {
  margin-top: 4.5rem !important;
}

.mb-45 {
  margin-bottom: 4.5rem !important;
}

.ml-45 {
  margin-left: 4.5rem !important;
}

.mr-45 {
  margin-right: 4.5rem !important;
}

.p-45 {
  padding: 4.5rem !important;
}

.py-45 {
  padding: 4.5rem 0 !important;
}

.px-45 {
  padding: 0 4.5rem !important;
}

.pt-45 {
  padding-top: 4.5rem !important;
}

.pb-45 {
  padding-bottom: 4.5rem !important;
}

.pl-45 {
  padding-left: 4.5rem !important;
}

.pr-45 {
  padding-right: 4.5rem !important;
}

.m-50 {
  margin: 5rem !important;
}

.my-50 {
  margin: 5rem 0 !important;
}

.mx-50 {
  margin: 0 5rem !important;
}

.mt-50 {
  margin-top: 5rem !important;
}

.mb-50 {
  margin-bottom: 5rem !important;
}

.ml-50 {
  margin-left: 5rem !important;
}

.mr-50 {
  margin-right: 5rem !important;
}

.p-50 {
  padding: 5rem !important;
}

.py-50 {
  padding: 5rem 0 !important;
}

.px-50 {
  padding: 0 5rem !important;
}

.pt-50 {
  padding-top: 5rem !important;
}

.pb-50 {
  padding-bottom: 5rem !important;
}

.pl-50 {
  padding-left: 5rem !important;
}

.pr-50 {
  padding-right: 5rem !important;
}

.m-55 {
  margin: 5.5rem !important;
}

.my-55 {
  margin: 5.5rem 0 !important;
}

.mx-55 {
  margin: 0 5.5rem !important;
}

.mt-55 {
  margin-top: 5.5rem !important;
}

.mb-55 {
  margin-bottom: 5.5rem !important;
}

.ml-55 {
  margin-left: 5.5rem !important;
}

.mr-55 {
  margin-right: 5.5rem !important;
}

.p-55 {
  padding: 5.5rem !important;
}

.py-55 {
  padding: 5.5rem 0 !important;
}

.px-55 {
  padding: 0 5.5rem !important;
}

.pt-55 {
  padding-top: 5.5rem !important;
}

.pb-55 {
  padding-bottom: 5.5rem !important;
}

.pl-55 {
  padding-left: 5.5rem !important;
}

.pr-55 {
  padding-right: 5.5rem !important;
}

.m-60 {
  margin: 6rem !important;
}

.my-60 {
  margin: 6rem 0 !important;
}

.mx-60 {
  margin: 0 6rem !important;
}

.mt-60 {
  margin-top: 6rem !important;
}

.mb-60 {
  margin-bottom: 6rem !important;
}

.ml-60 {
  margin-left: 6rem !important;
}

.mr-60 {
  margin-right: 6rem !important;
}

.p-60 {
  padding: 6rem !important;
}

.py-60 {
  padding: 6rem 0 !important;
}

.px-60 {
  padding: 0 6rem !important;
}

.pt-60 {
  padding-top: 6rem !important;
}

.pb-60 {
  padding-bottom: 6rem !important;
}

.pl-60 {
  padding-left: 6rem !important;
}

.pr-60 {
  padding-right: 6rem !important;
}

.m-65 {
  margin: 6.5rem !important;
}

.my-65 {
  margin: 6.5rem 0 !important;
}

.mx-65 {
  margin: 0 6.5rem !important;
}

.mt-65 {
  margin-top: 6.5rem !important;
}

.mb-65 {
  margin-bottom: 6.5rem !important;
}

.ml-65 {
  margin-left: 6.5rem !important;
}

.mr-65 {
  margin-right: 6.5rem !important;
}

.p-65 {
  padding: 6.5rem !important;
}

.py-65 {
  padding: 6.5rem 0 !important;
}

.px-65 {
  padding: 0 6.5rem !important;
}

.pt-65 {
  padding-top: 6.5rem !important;
}

.pb-65 {
  padding-bottom: 6.5rem !important;
}

.pl-65 {
  padding-left: 6.5rem !important;
}

.pr-65 {
  padding-right: 6.5rem !important;
}

.m-70 {
  margin: 7rem !important;
}

.my-70 {
  margin: 7rem 0 !important;
}

.mx-70 {
  margin: 0 7rem !important;
}

.mt-70 {
  margin-top: 7rem !important;
}

.mb-70 {
  margin-bottom: 7rem !important;
}

.ml-70 {
  margin-left: 7rem !important;
}

.mr-70 {
  margin-right: 7rem !important;
}

.p-70 {
  padding: 7rem !important;
}

.py-70 {
  padding: 7rem 0 !important;
}

.px-70 {
  padding: 0 7rem !important;
}

.pt-70 {
  padding-top: 7rem !important;
}

.pb-70 {
  padding-bottom: 7rem !important;
}

.pl-70 {
  padding-left: 7rem !important;
}

.pr-70 {
  padding-right: 7rem !important;
}

.m-75 {
  margin: 7.5rem !important;
}

.my-75 {
  margin: 7.5rem 0 !important;
}

.mx-75 {
  margin: 0 7.5rem !important;
}

.mt-75 {
  margin-top: 7.5rem !important;
}

.mb-75 {
  margin-bottom: 7.5rem !important;
}

.ml-75 {
  margin-left: 7.5rem !important;
}

.mr-75 {
  margin-right: 7.5rem !important;
}

.p-75 {
  padding: 7.5rem !important;
}

.py-75 {
  padding: 7.5rem 0 !important;
}

.px-75 {
  padding: 0 7.5rem !important;
}

.pt-75 {
  padding-top: 7.5rem !important;
}

.pb-75 {
  padding-bottom: 7.5rem !important;
}

.pl-75 {
  padding-left: 7.5rem !important;
}

.pr-75 {
  padding-right: 7.5rem !important;
}

.m-80 {
  margin: 8rem !important;
}

.my-80 {
  margin: 8rem 0 !important;
}

.mx-80 {
  margin: 0 8rem !important;
}

.mt-80 {
  margin-top: 8rem !important;
}

.mb-80 {
  margin-bottom: 8rem !important;
}

.ml-80 {
  margin-left: 8rem !important;
}

.mr-80 {
  margin-right: 8rem !important;
}

.p-80 {
  padding: 8rem !important;
}

.py-80 {
  padding: 8rem 0 !important;
}

.px-80 {
  padding: 0 8rem !important;
}

.pt-80 {
  padding-top: 8rem !important;
}

.pb-80 {
  padding-bottom: 8rem !important;
}

.pl-80 {
  padding-left: 8rem !important;
}

.pr-80 {
  padding-right: 8rem !important;
}

.m-85 {
  margin: 8.5rem !important;
}

.my-85 {
  margin: 8.5rem 0 !important;
}

.mx-85 {
  margin: 0 8.5rem !important;
}

.mt-85 {
  margin-top: 8.5rem !important;
}

.mb-85 {
  margin-bottom: 8.5rem !important;
}

.ml-85 {
  margin-left: 8.5rem !important;
}

.mr-85 {
  margin-right: 8.5rem !important;
}

.p-85 {
  padding: 8.5rem !important;
}

.py-85 {
  padding: 8.5rem 0 !important;
}

.px-85 {
  padding: 0 8.5rem !important;
}

.pt-85 {
  padding-top: 8.5rem !important;
}

.pb-85 {
  padding-bottom: 8.5rem !important;
}

.pl-85 {
  padding-left: 8.5rem !important;
}

.pr-85 {
  padding-right: 8.5rem !important;
}

.m-90 {
  margin: 9rem !important;
}

.my-90 {
  margin: 9rem 0 !important;
}

.mx-90 {
  margin: 0 9rem !important;
}

.mt-90 {
  margin-top: 9rem !important;
}

.mb-90 {
  margin-bottom: 9rem !important;
}

.ml-90 {
  margin-left: 9rem !important;
}

.mr-90 {
  margin-right: 9rem !important;
}

.p-90 {
  padding: 9rem !important;
}

.py-90 {
  padding: 9rem 0 !important;
}

.px-90 {
  padding: 0 9rem !important;
}

.pt-90 {
  padding-top: 9rem !important;
}

.pb-90 {
  padding-bottom: 9rem !important;
}

.pl-90 {
  padding-left: 9rem !important;
}

.pr-90 {
  padding-right: 9rem !important;
}

.m-95 {
  margin: 9.5rem !important;
}

.my-95 {
  margin: 9.5rem 0 !important;
}

.mx-95 {
  margin: 0 9.5rem !important;
}

.mt-95 {
  margin-top: 9.5rem !important;
}

.mb-95 {
  margin-bottom: 9.5rem !important;
}

.ml-95 {
  margin-left: 9.5rem !important;
}

.mr-95 {
  margin-right: 9.5rem !important;
}

.p-95 {
  padding: 9.5rem !important;
}

.py-95 {
  padding: 9.5rem 0 !important;
}

.px-95 {
  padding: 0 9.5rem !important;
}

.pt-95 {
  padding-top: 9.5rem !important;
}

.pb-95 {
  padding-bottom: 9.5rem !important;
}

.pl-95 {
  padding-left: 9.5rem !important;
}

.pr-95 {
  padding-right: 9.5rem !important;
}

.m-100 {
  margin: 10rem !important;
}

.my-100 {
  margin: 10rem 0 !important;
}

.mx-100 {
  margin: 0 10rem !important;
}

.mt-100 {
  margin-top: 10rem !important;
}

.mb-100 {
  margin-bottom: 10rem !important;
}

.ml-100 {
  margin-left: 10rem !important;
}

.mr-100 {
  margin-right: 10rem !important;
}

.p-100 {
  padding: 10rem !important;
}

.py-100 {
  padding: 10rem 0 !important;
}

.px-100 {
  padding: 0 10rem !important;
}

.pt-100 {
  padding-top: 10rem !important;
}

.pb-100 {
  padding-bottom: 10rem !important;
}

.pl-100 {
  padding-left: 10rem !important;
}

.pr-100 {
  padding-right: 10rem !important;
}

@media screen and (max-width: 980px) {
  .m-tab-0 {
    margin: 0rem !important;
  }
  .my-tab-0 {
    margin: 0rem 0 !important;
  }
  .mx-tab-0 {
    margin: 0 0rem !important;
  }
  .mt-tab-0 {
    margin-top: 0rem !important;
  }
  .mb-tab-0 {
    margin-bottom: 0rem !important;
  }
  .ml-tab-0 {
    margin-left: 0rem !important;
  }
  .mr-tab-0 {
    margin-right: 0rem !important;
  }
  .p-tab-0 {
    padding: 0rem !important;
  }
  .py-tab-0 {
    padding: 0rem 0 !important;
  }
  .px-tab-0 {
    padding: 0 0rem !important;
  }
  .pt-tab-0 {
    padding-top: 0rem !important;
  }
  .pb-tab-0 {
    padding-bottom: 0rem !important;
  }
  .pl-tab-0 {
    padding-left: 0rem !important;
  }
  .pr-tab-0 {
    padding-right: 0rem !important;
  }
  .m-tab-5 {
    margin: 0.5rem !important;
  }
  .my-tab-5 {
    margin: 0.5rem 0 !important;
  }
  .mx-tab-5 {
    margin: 0 0.5rem !important;
  }
  .mt-tab-5 {
    margin-top: 0.5rem !important;
  }
  .mb-tab-5 {
    margin-bottom: 0.5rem !important;
  }
  .ml-tab-5 {
    margin-left: 0.5rem !important;
  }
  .mr-tab-5 {
    margin-right: 0.5rem !important;
  }
  .p-tab-5 {
    padding: 0.5rem !important;
  }
  .py-tab-5 {
    padding: 0.5rem 0 !important;
  }
  .px-tab-5 {
    padding: 0 0.5rem !important;
  }
  .pt-tab-5 {
    padding-top: 0.5rem !important;
  }
  .pb-tab-5 {
    padding-bottom: 0.5rem !important;
  }
  .pl-tab-5 {
    padding-left: 0.5rem !important;
  }
  .pr-tab-5 {
    padding-right: 0.5rem !important;
  }
  .m-tab-10 {
    margin: 1rem !important;
  }
  .my-tab-10 {
    margin: 1rem 0 !important;
  }
  .mx-tab-10 {
    margin: 0 1rem !important;
  }
  .mt-tab-10 {
    margin-top: 1rem !important;
  }
  .mb-tab-10 {
    margin-bottom: 1rem !important;
  }
  .ml-tab-10 {
    margin-left: 1rem !important;
  }
  .mr-tab-10 {
    margin-right: 1rem !important;
  }
  .p-tab-10 {
    padding: 1rem !important;
  }
  .py-tab-10 {
    padding: 1rem 0 !important;
  }
  .px-tab-10 {
    padding: 0 1rem !important;
  }
  .pt-tab-10 {
    padding-top: 1rem !important;
  }
  .pb-tab-10 {
    padding-bottom: 1rem !important;
  }
  .pl-tab-10 {
    padding-left: 1rem !important;
  }
  .pr-tab-10 {
    padding-right: 1rem !important;
  }
  .m-tab-15 {
    margin: 1.5rem !important;
  }
  .my-tab-15 {
    margin: 1.5rem 0 !important;
  }
  .mx-tab-15 {
    margin: 0 1.5rem !important;
  }
  .mt-tab-15 {
    margin-top: 1.5rem !important;
  }
  .mb-tab-15 {
    margin-bottom: 1.5rem !important;
  }
  .ml-tab-15 {
    margin-left: 1.5rem !important;
  }
  .mr-tab-15 {
    margin-right: 1.5rem !important;
  }
  .p-tab-15 {
    padding: 1.5rem !important;
  }
  .py-tab-15 {
    padding: 1.5rem 0 !important;
  }
  .px-tab-15 {
    padding: 0 1.5rem !important;
  }
  .pt-tab-15 {
    padding-top: 1.5rem !important;
  }
  .pb-tab-15 {
    padding-bottom: 1.5rem !important;
  }
  .pl-tab-15 {
    padding-left: 1.5rem !important;
  }
  .pr-tab-15 {
    padding-right: 1.5rem !important;
  }
  .m-tab-20 {
    margin: 2rem !important;
  }
  .my-tab-20 {
    margin: 2rem 0 !important;
  }
  .mx-tab-20 {
    margin: 0 2rem !important;
  }
  .mt-tab-20 {
    margin-top: 2rem !important;
  }
  .mb-tab-20 {
    margin-bottom: 2rem !important;
  }
  .ml-tab-20 {
    margin-left: 2rem !important;
  }
  .mr-tab-20 {
    margin-right: 2rem !important;
  }
  .p-tab-20 {
    padding: 2rem !important;
  }
  .py-tab-20 {
    padding: 2rem 0 !important;
  }
  .px-tab-20 {
    padding: 0 2rem !important;
  }
  .pt-tab-20 {
    padding-top: 2rem !important;
  }
  .pb-tab-20 {
    padding-bottom: 2rem !important;
  }
  .pl-tab-20 {
    padding-left: 2rem !important;
  }
  .pr-tab-20 {
    padding-right: 2rem !important;
  }
  .m-tab-25 {
    margin: 2.5rem !important;
  }
  .my-tab-25 {
    margin: 2.5rem 0 !important;
  }
  .mx-tab-25 {
    margin: 0 2.5rem !important;
  }
  .mt-tab-25 {
    margin-top: 2.5rem !important;
  }
  .mb-tab-25 {
    margin-bottom: 2.5rem !important;
  }
  .ml-tab-25 {
    margin-left: 2.5rem !important;
  }
  .mr-tab-25 {
    margin-right: 2.5rem !important;
  }
  .p-tab-25 {
    padding: 2.5rem !important;
  }
  .py-tab-25 {
    padding: 2.5rem 0 !important;
  }
  .px-tab-25 {
    padding: 0 2.5rem !important;
  }
  .pt-tab-25 {
    padding-top: 2.5rem !important;
  }
  .pb-tab-25 {
    padding-bottom: 2.5rem !important;
  }
  .pl-tab-25 {
    padding-left: 2.5rem !important;
  }
  .pr-tab-25 {
    padding-right: 2.5rem !important;
  }
  .m-tab-30 {
    margin: 3rem !important;
  }
  .my-tab-30 {
    margin: 3rem 0 !important;
  }
  .mx-tab-30 {
    margin: 0 3rem !important;
  }
  .mt-tab-30 {
    margin-top: 3rem !important;
  }
  .mb-tab-30 {
    margin-bottom: 3rem !important;
  }
  .ml-tab-30 {
    margin-left: 3rem !important;
  }
  .mr-tab-30 {
    margin-right: 3rem !important;
  }
  .p-tab-30 {
    padding: 3rem !important;
  }
  .py-tab-30 {
    padding: 3rem 0 !important;
  }
  .px-tab-30 {
    padding: 0 3rem !important;
  }
  .pt-tab-30 {
    padding-top: 3rem !important;
  }
  .pb-tab-30 {
    padding-bottom: 3rem !important;
  }
  .pl-tab-30 {
    padding-left: 3rem !important;
  }
  .pr-tab-30 {
    padding-right: 3rem !important;
  }
  .m-tab-35 {
    margin: 3.5rem !important;
  }
  .my-tab-35 {
    margin: 3.5rem 0 !important;
  }
  .mx-tab-35 {
    margin: 0 3.5rem !important;
  }
  .mt-tab-35 {
    margin-top: 3.5rem !important;
  }
  .mb-tab-35 {
    margin-bottom: 3.5rem !important;
  }
  .ml-tab-35 {
    margin-left: 3.5rem !important;
  }
  .mr-tab-35 {
    margin-right: 3.5rem !important;
  }
  .p-tab-35 {
    padding: 3.5rem !important;
  }
  .py-tab-35 {
    padding: 3.5rem 0 !important;
  }
  .px-tab-35 {
    padding: 0 3.5rem !important;
  }
  .pt-tab-35 {
    padding-top: 3.5rem !important;
  }
  .pb-tab-35 {
    padding-bottom: 3.5rem !important;
  }
  .pl-tab-35 {
    padding-left: 3.5rem !important;
  }
  .pr-tab-35 {
    padding-right: 3.5rem !important;
  }
  .m-tab-40 {
    margin: 4rem !important;
  }
  .my-tab-40 {
    margin: 4rem 0 !important;
  }
  .mx-tab-40 {
    margin: 0 4rem !important;
  }
  .mt-tab-40 {
    margin-top: 4rem !important;
  }
  .mb-tab-40 {
    margin-bottom: 4rem !important;
  }
  .ml-tab-40 {
    margin-left: 4rem !important;
  }
  .mr-tab-40 {
    margin-right: 4rem !important;
  }
  .p-tab-40 {
    padding: 4rem !important;
  }
  .py-tab-40 {
    padding: 4rem 0 !important;
  }
  .px-tab-40 {
    padding: 0 4rem !important;
  }
  .pt-tab-40 {
    padding-top: 4rem !important;
  }
  .pb-tab-40 {
    padding-bottom: 4rem !important;
  }
  .pl-tab-40 {
    padding-left: 4rem !important;
  }
  .pr-tab-40 {
    padding-right: 4rem !important;
  }
  .m-tab-45 {
    margin: 4.5rem !important;
  }
  .my-tab-45 {
    margin: 4.5rem 0 !important;
  }
  .mx-tab-45 {
    margin: 0 4.5rem !important;
  }
  .mt-tab-45 {
    margin-top: 4.5rem !important;
  }
  .mb-tab-45 {
    margin-bottom: 4.5rem !important;
  }
  .ml-tab-45 {
    margin-left: 4.5rem !important;
  }
  .mr-tab-45 {
    margin-right: 4.5rem !important;
  }
  .p-tab-45 {
    padding: 4.5rem !important;
  }
  .py-tab-45 {
    padding: 4.5rem 0 !important;
  }
  .px-tab-45 {
    padding: 0 4.5rem !important;
  }
  .pt-tab-45 {
    padding-top: 4.5rem !important;
  }
  .pb-tab-45 {
    padding-bottom: 4.5rem !important;
  }
  .pl-tab-45 {
    padding-left: 4.5rem !important;
  }
  .pr-tab-45 {
    padding-right: 4.5rem !important;
  }
  .m-tab-50 {
    margin: 5rem !important;
  }
  .my-tab-50 {
    margin: 5rem 0 !important;
  }
  .mx-tab-50 {
    margin: 0 5rem !important;
  }
  .mt-tab-50 {
    margin-top: 5rem !important;
  }
  .mb-tab-50 {
    margin-bottom: 5rem !important;
  }
  .ml-tab-50 {
    margin-left: 5rem !important;
  }
  .mr-tab-50 {
    margin-right: 5rem !important;
  }
  .p-tab-50 {
    padding: 5rem !important;
  }
  .py-tab-50 {
    padding: 5rem 0 !important;
  }
  .px-tab-50 {
    padding: 0 5rem !important;
  }
  .pt-tab-50 {
    padding-top: 5rem !important;
  }
  .pb-tab-50 {
    padding-bottom: 5rem !important;
  }
  .pl-tab-50 {
    padding-left: 5rem !important;
  }
  .pr-tab-50 {
    padding-right: 5rem !important;
  }
  .m-tab-55 {
    margin: 5.5rem !important;
  }
  .my-tab-55 {
    margin: 5.5rem 0 !important;
  }
  .mx-tab-55 {
    margin: 0 5.5rem !important;
  }
  .mt-tab-55 {
    margin-top: 5.5rem !important;
  }
  .mb-tab-55 {
    margin-bottom: 5.5rem !important;
  }
  .ml-tab-55 {
    margin-left: 5.5rem !important;
  }
  .mr-tab-55 {
    margin-right: 5.5rem !important;
  }
  .p-tab-55 {
    padding: 5.5rem !important;
  }
  .py-tab-55 {
    padding: 5.5rem 0 !important;
  }
  .px-tab-55 {
    padding: 0 5.5rem !important;
  }
  .pt-tab-55 {
    padding-top: 5.5rem !important;
  }
  .pb-tab-55 {
    padding-bottom: 5.5rem !important;
  }
  .pl-tab-55 {
    padding-left: 5.5rem !important;
  }
  .pr-tab-55 {
    padding-right: 5.5rem !important;
  }
  .m-tab-60 {
    margin: 6rem !important;
  }
  .my-tab-60 {
    margin: 6rem 0 !important;
  }
  .mx-tab-60 {
    margin: 0 6rem !important;
  }
  .mt-tab-60 {
    margin-top: 6rem !important;
  }
  .mb-tab-60 {
    margin-bottom: 6rem !important;
  }
  .ml-tab-60 {
    margin-left: 6rem !important;
  }
  .mr-tab-60 {
    margin-right: 6rem !important;
  }
  .p-tab-60 {
    padding: 6rem !important;
  }
  .py-tab-60 {
    padding: 6rem 0 !important;
  }
  .px-tab-60 {
    padding: 0 6rem !important;
  }
  .pt-tab-60 {
    padding-top: 6rem !important;
  }
  .pb-tab-60 {
    padding-bottom: 6rem !important;
  }
  .pl-tab-60 {
    padding-left: 6rem !important;
  }
  .pr-tab-60 {
    padding-right: 6rem !important;
  }
  .m-tab-65 {
    margin: 6.5rem !important;
  }
  .my-tab-65 {
    margin: 6.5rem 0 !important;
  }
  .mx-tab-65 {
    margin: 0 6.5rem !important;
  }
  .mt-tab-65 {
    margin-top: 6.5rem !important;
  }
  .mb-tab-65 {
    margin-bottom: 6.5rem !important;
  }
  .ml-tab-65 {
    margin-left: 6.5rem !important;
  }
  .mr-tab-65 {
    margin-right: 6.5rem !important;
  }
  .p-tab-65 {
    padding: 6.5rem !important;
  }
  .py-tab-65 {
    padding: 6.5rem 0 !important;
  }
  .px-tab-65 {
    padding: 0 6.5rem !important;
  }
  .pt-tab-65 {
    padding-top: 6.5rem !important;
  }
  .pb-tab-65 {
    padding-bottom: 6.5rem !important;
  }
  .pl-tab-65 {
    padding-left: 6.5rem !important;
  }
  .pr-tab-65 {
    padding-right: 6.5rem !important;
  }
  .m-tab-70 {
    margin: 7rem !important;
  }
  .my-tab-70 {
    margin: 7rem 0 !important;
  }
  .mx-tab-70 {
    margin: 0 7rem !important;
  }
  .mt-tab-70 {
    margin-top: 7rem !important;
  }
  .mb-tab-70 {
    margin-bottom: 7rem !important;
  }
  .ml-tab-70 {
    margin-left: 7rem !important;
  }
  .mr-tab-70 {
    margin-right: 7rem !important;
  }
  .p-tab-70 {
    padding: 7rem !important;
  }
  .py-tab-70 {
    padding: 7rem 0 !important;
  }
  .px-tab-70 {
    padding: 0 7rem !important;
  }
  .pt-tab-70 {
    padding-top: 7rem !important;
  }
  .pb-tab-70 {
    padding-bottom: 7rem !important;
  }
  .pl-tab-70 {
    padding-left: 7rem !important;
  }
  .pr-tab-70 {
    padding-right: 7rem !important;
  }
  .m-tab-75 {
    margin: 7.5rem !important;
  }
  .my-tab-75 {
    margin: 7.5rem 0 !important;
  }
  .mx-tab-75 {
    margin: 0 7.5rem !important;
  }
  .mt-tab-75 {
    margin-top: 7.5rem !important;
  }
  .mb-tab-75 {
    margin-bottom: 7.5rem !important;
  }
  .ml-tab-75 {
    margin-left: 7.5rem !important;
  }
  .mr-tab-75 {
    margin-right: 7.5rem !important;
  }
  .p-tab-75 {
    padding: 7.5rem !important;
  }
  .py-tab-75 {
    padding: 7.5rem 0 !important;
  }
  .px-tab-75 {
    padding: 0 7.5rem !important;
  }
  .pt-tab-75 {
    padding-top: 7.5rem !important;
  }
  .pb-tab-75 {
    padding-bottom: 7.5rem !important;
  }
  .pl-tab-75 {
    padding-left: 7.5rem !important;
  }
  .pr-tab-75 {
    padding-right: 7.5rem !important;
  }
  .m-tab-80 {
    margin: 8rem !important;
  }
  .my-tab-80 {
    margin: 8rem 0 !important;
  }
  .mx-tab-80 {
    margin: 0 8rem !important;
  }
  .mt-tab-80 {
    margin-top: 8rem !important;
  }
  .mb-tab-80 {
    margin-bottom: 8rem !important;
  }
  .ml-tab-80 {
    margin-left: 8rem !important;
  }
  .mr-tab-80 {
    margin-right: 8rem !important;
  }
  .p-tab-80 {
    padding: 8rem !important;
  }
  .py-tab-80 {
    padding: 8rem 0 !important;
  }
  .px-tab-80 {
    padding: 0 8rem !important;
  }
  .pt-tab-80 {
    padding-top: 8rem !important;
  }
  .pb-tab-80 {
    padding-bottom: 8rem !important;
  }
  .pl-tab-80 {
    padding-left: 8rem !important;
  }
  .pr-tab-80 {
    padding-right: 8rem !important;
  }
  .m-tab-85 {
    margin: 8.5rem !important;
  }
  .my-tab-85 {
    margin: 8.5rem 0 !important;
  }
  .mx-tab-85 {
    margin: 0 8.5rem !important;
  }
  .mt-tab-85 {
    margin-top: 8.5rem !important;
  }
  .mb-tab-85 {
    margin-bottom: 8.5rem !important;
  }
  .ml-tab-85 {
    margin-left: 8.5rem !important;
  }
  .mr-tab-85 {
    margin-right: 8.5rem !important;
  }
  .p-tab-85 {
    padding: 8.5rem !important;
  }
  .py-tab-85 {
    padding: 8.5rem 0 !important;
  }
  .px-tab-85 {
    padding: 0 8.5rem !important;
  }
  .pt-tab-85 {
    padding-top: 8.5rem !important;
  }
  .pb-tab-85 {
    padding-bottom: 8.5rem !important;
  }
  .pl-tab-85 {
    padding-left: 8.5rem !important;
  }
  .pr-tab-85 {
    padding-right: 8.5rem !important;
  }
  .m-tab-90 {
    margin: 9rem !important;
  }
  .my-tab-90 {
    margin: 9rem 0 !important;
  }
  .mx-tab-90 {
    margin: 0 9rem !important;
  }
  .mt-tab-90 {
    margin-top: 9rem !important;
  }
  .mb-tab-90 {
    margin-bottom: 9rem !important;
  }
  .ml-tab-90 {
    margin-left: 9rem !important;
  }
  .mr-tab-90 {
    margin-right: 9rem !important;
  }
  .p-tab-90 {
    padding: 9rem !important;
  }
  .py-tab-90 {
    padding: 9rem 0 !important;
  }
  .px-tab-90 {
    padding: 0 9rem !important;
  }
  .pt-tab-90 {
    padding-top: 9rem !important;
  }
  .pb-tab-90 {
    padding-bottom: 9rem !important;
  }
  .pl-tab-90 {
    padding-left: 9rem !important;
  }
  .pr-tab-90 {
    padding-right: 9rem !important;
  }
  .m-tab-95 {
    margin: 9.5rem !important;
  }
  .my-tab-95 {
    margin: 9.5rem 0 !important;
  }
  .mx-tab-95 {
    margin: 0 9.5rem !important;
  }
  .mt-tab-95 {
    margin-top: 9.5rem !important;
  }
  .mb-tab-95 {
    margin-bottom: 9.5rem !important;
  }
  .ml-tab-95 {
    margin-left: 9.5rem !important;
  }
  .mr-tab-95 {
    margin-right: 9.5rem !important;
  }
  .p-tab-95 {
    padding: 9.5rem !important;
  }
  .py-tab-95 {
    padding: 9.5rem 0 !important;
  }
  .px-tab-95 {
    padding: 0 9.5rem !important;
  }
  .pt-tab-95 {
    padding-top: 9.5rem !important;
  }
  .pb-tab-95 {
    padding-bottom: 9.5rem !important;
  }
  .pl-tab-95 {
    padding-left: 9.5rem !important;
  }
  .pr-tab-95 {
    padding-right: 9.5rem !important;
  }
  .m-tab-100 {
    margin: 10rem !important;
  }
  .my-tab-100 {
    margin: 10rem 0 !important;
  }
  .mx-tab-100 {
    margin: 0 10rem !important;
  }
  .mt-tab-100 {
    margin-top: 10rem !important;
  }
  .mb-tab-100 {
    margin-bottom: 10rem !important;
  }
  .ml-tab-100 {
    margin-left: 10rem !important;
  }
  .mr-tab-100 {
    margin-right: 10rem !important;
  }
  .p-tab-100 {
    padding: 10rem !important;
  }
  .py-tab-100 {
    padding: 10rem 0 !important;
  }
  .px-tab-100 {
    padding: 0 10rem !important;
  }
  .pt-tab-100 {
    padding-top: 10rem !important;
  }
  .pb-tab-100 {
    padding-bottom: 10rem !important;
  }
  .pl-tab-100 {
    padding-left: 10rem !important;
  }
  .pr-tab-100 {
    padding-right: 10rem !important;
  }
}
@media screen and (max-width: 480px) {
  .m-sp-0 {
    margin: 0rem !important;
  }
  .my-sp-0 {
    margin: 0rem 0 !important;
  }
  .mx-sp-0 {
    margin: 0 0rem !important;
  }
  .mt-sp-0 {
    margin-top: 0rem !important;
  }
  .mb-sp-0 {
    margin-bottom: 0rem !important;
  }
  .ml-sp-0 {
    margin-left: 0rem !important;
  }
  .mr-sp-0 {
    margin-right: 0rem !important;
  }
  .p-sp-0 {
    padding: 0rem !important;
  }
  .py-sp-0 {
    padding: 0rem 0 !important;
  }
  .px-sp-0 {
    padding: 0 0rem !important;
  }
  .pt-sp-0 {
    padding-top: 0rem !important;
  }
  .pb-sp-0 {
    padding-bottom: 0rem !important;
  }
  .pl-sp-0 {
    padding-left: 0rem !important;
  }
  .pr-sp-0 {
    padding-right: 0rem !important;
  }
  .m-sp-5 {
    margin: 0.5rem !important;
  }
  .my-sp-5 {
    margin: 0.5rem 0 !important;
  }
  .mx-sp-5 {
    margin: 0 0.5rem !important;
  }
  .mt-sp-5 {
    margin-top: 0.5rem !important;
  }
  .mb-sp-5 {
    margin-bottom: 0.5rem !important;
  }
  .ml-sp-5 {
    margin-left: 0.5rem !important;
  }
  .mr-sp-5 {
    margin-right: 0.5rem !important;
  }
  .p-sp-5 {
    padding: 0.5rem !important;
  }
  .py-sp-5 {
    padding: 0.5rem 0 !important;
  }
  .px-sp-5 {
    padding: 0 0.5rem !important;
  }
  .pt-sp-5 {
    padding-top: 0.5rem !important;
  }
  .pb-sp-5 {
    padding-bottom: 0.5rem !important;
  }
  .pl-sp-5 {
    padding-left: 0.5rem !important;
  }
  .pr-sp-5 {
    padding-right: 0.5rem !important;
  }
  .m-sp-10 {
    margin: 1rem !important;
  }
  .my-sp-10 {
    margin: 1rem 0 !important;
  }
  .mx-sp-10 {
    margin: 0 1rem !important;
  }
  .mt-sp-10 {
    margin-top: 1rem !important;
  }
  .mb-sp-10 {
    margin-bottom: 1rem !important;
  }
  .ml-sp-10 {
    margin-left: 1rem !important;
  }
  .mr-sp-10 {
    margin-right: 1rem !important;
  }
  .p-sp-10 {
    padding: 1rem !important;
  }
  .py-sp-10 {
    padding: 1rem 0 !important;
  }
  .px-sp-10 {
    padding: 0 1rem !important;
  }
  .pt-sp-10 {
    padding-top: 1rem !important;
  }
  .pb-sp-10 {
    padding-bottom: 1rem !important;
  }
  .pl-sp-10 {
    padding-left: 1rem !important;
  }
  .pr-sp-10 {
    padding-right: 1rem !important;
  }
  .m-sp-15 {
    margin: 1.5rem !important;
  }
  .my-sp-15 {
    margin: 1.5rem 0 !important;
  }
  .mx-sp-15 {
    margin: 0 1.5rem !important;
  }
  .mt-sp-15 {
    margin-top: 1.5rem !important;
  }
  .mb-sp-15 {
    margin-bottom: 1.5rem !important;
  }
  .ml-sp-15 {
    margin-left: 1.5rem !important;
  }
  .mr-sp-15 {
    margin-right: 1.5rem !important;
  }
  .p-sp-15 {
    padding: 1.5rem !important;
  }
  .py-sp-15 {
    padding: 1.5rem 0 !important;
  }
  .px-sp-15 {
    padding: 0 1.5rem !important;
  }
  .pt-sp-15 {
    padding-top: 1.5rem !important;
  }
  .pb-sp-15 {
    padding-bottom: 1.5rem !important;
  }
  .pl-sp-15 {
    padding-left: 1.5rem !important;
  }
  .pr-sp-15 {
    padding-right: 1.5rem !important;
  }
  .m-sp-20 {
    margin: 2rem !important;
  }
  .my-sp-20 {
    margin: 2rem 0 !important;
  }
  .mx-sp-20 {
    margin: 0 2rem !important;
  }
  .mt-sp-20 {
    margin-top: 2rem !important;
  }
  .mb-sp-20 {
    margin-bottom: 2rem !important;
  }
  .ml-sp-20 {
    margin-left: 2rem !important;
  }
  .mr-sp-20 {
    margin-right: 2rem !important;
  }
  .p-sp-20 {
    padding: 2rem !important;
  }
  .py-sp-20 {
    padding: 2rem 0 !important;
  }
  .px-sp-20 {
    padding: 0 2rem !important;
  }
  .pt-sp-20 {
    padding-top: 2rem !important;
  }
  .pb-sp-20 {
    padding-bottom: 2rem !important;
  }
  .pl-sp-20 {
    padding-left: 2rem !important;
  }
  .pr-sp-20 {
    padding-right: 2rem !important;
  }
  .m-sp-25 {
    margin: 2.5rem !important;
  }
  .my-sp-25 {
    margin: 2.5rem 0 !important;
  }
  .mx-sp-25 {
    margin: 0 2.5rem !important;
  }
  .mt-sp-25 {
    margin-top: 2.5rem !important;
  }
  .mb-sp-25 {
    margin-bottom: 2.5rem !important;
  }
  .ml-sp-25 {
    margin-left: 2.5rem !important;
  }
  .mr-sp-25 {
    margin-right: 2.5rem !important;
  }
  .p-sp-25 {
    padding: 2.5rem !important;
  }
  .py-sp-25 {
    padding: 2.5rem 0 !important;
  }
  .px-sp-25 {
    padding: 0 2.5rem !important;
  }
  .pt-sp-25 {
    padding-top: 2.5rem !important;
  }
  .pb-sp-25 {
    padding-bottom: 2.5rem !important;
  }
  .pl-sp-25 {
    padding-left: 2.5rem !important;
  }
  .pr-sp-25 {
    padding-right: 2.5rem !important;
  }
  .m-sp-30 {
    margin: 3rem !important;
  }
  .my-sp-30 {
    margin: 3rem 0 !important;
  }
  .mx-sp-30 {
    margin: 0 3rem !important;
  }
  .mt-sp-30 {
    margin-top: 3rem !important;
  }
  .mb-sp-30 {
    margin-bottom: 3rem !important;
  }
  .ml-sp-30 {
    margin-left: 3rem !important;
  }
  .mr-sp-30 {
    margin-right: 3rem !important;
  }
  .p-sp-30 {
    padding: 3rem !important;
  }
  .py-sp-30 {
    padding: 3rem 0 !important;
  }
  .px-sp-30 {
    padding: 0 3rem !important;
  }
  .pt-sp-30 {
    padding-top: 3rem !important;
  }
  .pb-sp-30 {
    padding-bottom: 3rem !important;
  }
  .pl-sp-30 {
    padding-left: 3rem !important;
  }
  .pr-sp-30 {
    padding-right: 3rem !important;
  }
  .m-sp-35 {
    margin: 3.5rem !important;
  }
  .my-sp-35 {
    margin: 3.5rem 0 !important;
  }
  .mx-sp-35 {
    margin: 0 3.5rem !important;
  }
  .mt-sp-35 {
    margin-top: 3.5rem !important;
  }
  .mb-sp-35 {
    margin-bottom: 3.5rem !important;
  }
  .ml-sp-35 {
    margin-left: 3.5rem !important;
  }
  .mr-sp-35 {
    margin-right: 3.5rem !important;
  }
  .p-sp-35 {
    padding: 3.5rem !important;
  }
  .py-sp-35 {
    padding: 3.5rem 0 !important;
  }
  .px-sp-35 {
    padding: 0 3.5rem !important;
  }
  .pt-sp-35 {
    padding-top: 3.5rem !important;
  }
  .pb-sp-35 {
    padding-bottom: 3.5rem !important;
  }
  .pl-sp-35 {
    padding-left: 3.5rem !important;
  }
  .pr-sp-35 {
    padding-right: 3.5rem !important;
  }
  .m-sp-40 {
    margin: 4rem !important;
  }
  .my-sp-40 {
    margin: 4rem 0 !important;
  }
  .mx-sp-40 {
    margin: 0 4rem !important;
  }
  .mt-sp-40 {
    margin-top: 4rem !important;
  }
  .mb-sp-40 {
    margin-bottom: 4rem !important;
  }
  .ml-sp-40 {
    margin-left: 4rem !important;
  }
  .mr-sp-40 {
    margin-right: 4rem !important;
  }
  .p-sp-40 {
    padding: 4rem !important;
  }
  .py-sp-40 {
    padding: 4rem 0 !important;
  }
  .px-sp-40 {
    padding: 0 4rem !important;
  }
  .pt-sp-40 {
    padding-top: 4rem !important;
  }
  .pb-sp-40 {
    padding-bottom: 4rem !important;
  }
  .pl-sp-40 {
    padding-left: 4rem !important;
  }
  .pr-sp-40 {
    padding-right: 4rem !important;
  }
  .m-sp-45 {
    margin: 4.5rem !important;
  }
  .my-sp-45 {
    margin: 4.5rem 0 !important;
  }
  .mx-sp-45 {
    margin: 0 4.5rem !important;
  }
  .mt-sp-45 {
    margin-top: 4.5rem !important;
  }
  .mb-sp-45 {
    margin-bottom: 4.5rem !important;
  }
  .ml-sp-45 {
    margin-left: 4.5rem !important;
  }
  .mr-sp-45 {
    margin-right: 4.5rem !important;
  }
  .p-sp-45 {
    padding: 4.5rem !important;
  }
  .py-sp-45 {
    padding: 4.5rem 0 !important;
  }
  .px-sp-45 {
    padding: 0 4.5rem !important;
  }
  .pt-sp-45 {
    padding-top: 4.5rem !important;
  }
  .pb-sp-45 {
    padding-bottom: 4.5rem !important;
  }
  .pl-sp-45 {
    padding-left: 4.5rem !important;
  }
  .pr-sp-45 {
    padding-right: 4.5rem !important;
  }
  .m-sp-50 {
    margin: 5rem !important;
  }
  .my-sp-50 {
    margin: 5rem 0 !important;
  }
  .mx-sp-50 {
    margin: 0 5rem !important;
  }
  .mt-sp-50 {
    margin-top: 5rem !important;
  }
  .mb-sp-50 {
    margin-bottom: 5rem !important;
  }
  .ml-sp-50 {
    margin-left: 5rem !important;
  }
  .mr-sp-50 {
    margin-right: 5rem !important;
  }
  .p-sp-50 {
    padding: 5rem !important;
  }
  .py-sp-50 {
    padding: 5rem 0 !important;
  }
  .px-sp-50 {
    padding: 0 5rem !important;
  }
  .pt-sp-50 {
    padding-top: 5rem !important;
  }
  .pb-sp-50 {
    padding-bottom: 5rem !important;
  }
  .pl-sp-50 {
    padding-left: 5rem !important;
  }
  .pr-sp-50 {
    padding-right: 5rem !important;
  }
  .m-sp-55 {
    margin: 5.5rem !important;
  }
  .my-sp-55 {
    margin: 5.5rem 0 !important;
  }
  .mx-sp-55 {
    margin: 0 5.5rem !important;
  }
  .mt-sp-55 {
    margin-top: 5.5rem !important;
  }
  .mb-sp-55 {
    margin-bottom: 5.5rem !important;
  }
  .ml-sp-55 {
    margin-left: 5.5rem !important;
  }
  .mr-sp-55 {
    margin-right: 5.5rem !important;
  }
  .p-sp-55 {
    padding: 5.5rem !important;
  }
  .py-sp-55 {
    padding: 5.5rem 0 !important;
  }
  .px-sp-55 {
    padding: 0 5.5rem !important;
  }
  .pt-sp-55 {
    padding-top: 5.5rem !important;
  }
  .pb-sp-55 {
    padding-bottom: 5.5rem !important;
  }
  .pl-sp-55 {
    padding-left: 5.5rem !important;
  }
  .pr-sp-55 {
    padding-right: 5.5rem !important;
  }
  .m-sp-60 {
    margin: 6rem !important;
  }
  .my-sp-60 {
    margin: 6rem 0 !important;
  }
  .mx-sp-60 {
    margin: 0 6rem !important;
  }
  .mt-sp-60 {
    margin-top: 6rem !important;
  }
  .mb-sp-60 {
    margin-bottom: 6rem !important;
  }
  .ml-sp-60 {
    margin-left: 6rem !important;
  }
  .mr-sp-60 {
    margin-right: 6rem !important;
  }
  .p-sp-60 {
    padding: 6rem !important;
  }
  .py-sp-60 {
    padding: 6rem 0 !important;
  }
  .px-sp-60 {
    padding: 0 6rem !important;
  }
  .pt-sp-60 {
    padding-top: 6rem !important;
  }
  .pb-sp-60 {
    padding-bottom: 6rem !important;
  }
  .pl-sp-60 {
    padding-left: 6rem !important;
  }
  .pr-sp-60 {
    padding-right: 6rem !important;
  }
  .m-sp-65 {
    margin: 6.5rem !important;
  }
  .my-sp-65 {
    margin: 6.5rem 0 !important;
  }
  .mx-sp-65 {
    margin: 0 6.5rem !important;
  }
  .mt-sp-65 {
    margin-top: 6.5rem !important;
  }
  .mb-sp-65 {
    margin-bottom: 6.5rem !important;
  }
  .ml-sp-65 {
    margin-left: 6.5rem !important;
  }
  .mr-sp-65 {
    margin-right: 6.5rem !important;
  }
  .p-sp-65 {
    padding: 6.5rem !important;
  }
  .py-sp-65 {
    padding: 6.5rem 0 !important;
  }
  .px-sp-65 {
    padding: 0 6.5rem !important;
  }
  .pt-sp-65 {
    padding-top: 6.5rem !important;
  }
  .pb-sp-65 {
    padding-bottom: 6.5rem !important;
  }
  .pl-sp-65 {
    padding-left: 6.5rem !important;
  }
  .pr-sp-65 {
    padding-right: 6.5rem !important;
  }
  .m-sp-70 {
    margin: 7rem !important;
  }
  .my-sp-70 {
    margin: 7rem 0 !important;
  }
  .mx-sp-70 {
    margin: 0 7rem !important;
  }
  .mt-sp-70 {
    margin-top: 7rem !important;
  }
  .mb-sp-70 {
    margin-bottom: 7rem !important;
  }
  .ml-sp-70 {
    margin-left: 7rem !important;
  }
  .mr-sp-70 {
    margin-right: 7rem !important;
  }
  .p-sp-70 {
    padding: 7rem !important;
  }
  .py-sp-70 {
    padding: 7rem 0 !important;
  }
  .px-sp-70 {
    padding: 0 7rem !important;
  }
  .pt-sp-70 {
    padding-top: 7rem !important;
  }
  .pb-sp-70 {
    padding-bottom: 7rem !important;
  }
  .pl-sp-70 {
    padding-left: 7rem !important;
  }
  .pr-sp-70 {
    padding-right: 7rem !important;
  }
  .m-sp-75 {
    margin: 7.5rem !important;
  }
  .my-sp-75 {
    margin: 7.5rem 0 !important;
  }
  .mx-sp-75 {
    margin: 0 7.5rem !important;
  }
  .mt-sp-75 {
    margin-top: 7.5rem !important;
  }
  .mb-sp-75 {
    margin-bottom: 7.5rem !important;
  }
  .ml-sp-75 {
    margin-left: 7.5rem !important;
  }
  .mr-sp-75 {
    margin-right: 7.5rem !important;
  }
  .p-sp-75 {
    padding: 7.5rem !important;
  }
  .py-sp-75 {
    padding: 7.5rem 0 !important;
  }
  .px-sp-75 {
    padding: 0 7.5rem !important;
  }
  .pt-sp-75 {
    padding-top: 7.5rem !important;
  }
  .pb-sp-75 {
    padding-bottom: 7.5rem !important;
  }
  .pl-sp-75 {
    padding-left: 7.5rem !important;
  }
  .pr-sp-75 {
    padding-right: 7.5rem !important;
  }
  .m-sp-80 {
    margin: 8rem !important;
  }
  .my-sp-80 {
    margin: 8rem 0 !important;
  }
  .mx-sp-80 {
    margin: 0 8rem !important;
  }
  .mt-sp-80 {
    margin-top: 8rem !important;
  }
  .mb-sp-80 {
    margin-bottom: 8rem !important;
  }
  .ml-sp-80 {
    margin-left: 8rem !important;
  }
  .mr-sp-80 {
    margin-right: 8rem !important;
  }
  .p-sp-80 {
    padding: 8rem !important;
  }
  .py-sp-80 {
    padding: 8rem 0 !important;
  }
  .px-sp-80 {
    padding: 0 8rem !important;
  }
  .pt-sp-80 {
    padding-top: 8rem !important;
  }
  .pb-sp-80 {
    padding-bottom: 8rem !important;
  }
  .pl-sp-80 {
    padding-left: 8rem !important;
  }
  .pr-sp-80 {
    padding-right: 8rem !important;
  }
  .m-sp-85 {
    margin: 8.5rem !important;
  }
  .my-sp-85 {
    margin: 8.5rem 0 !important;
  }
  .mx-sp-85 {
    margin: 0 8.5rem !important;
  }
  .mt-sp-85 {
    margin-top: 8.5rem !important;
  }
  .mb-sp-85 {
    margin-bottom: 8.5rem !important;
  }
  .ml-sp-85 {
    margin-left: 8.5rem !important;
  }
  .mr-sp-85 {
    margin-right: 8.5rem !important;
  }
  .p-sp-85 {
    padding: 8.5rem !important;
  }
  .py-sp-85 {
    padding: 8.5rem 0 !important;
  }
  .px-sp-85 {
    padding: 0 8.5rem !important;
  }
  .pt-sp-85 {
    padding-top: 8.5rem !important;
  }
  .pb-sp-85 {
    padding-bottom: 8.5rem !important;
  }
  .pl-sp-85 {
    padding-left: 8.5rem !important;
  }
  .pr-sp-85 {
    padding-right: 8.5rem !important;
  }
  .m-sp-90 {
    margin: 9rem !important;
  }
  .my-sp-90 {
    margin: 9rem 0 !important;
  }
  .mx-sp-90 {
    margin: 0 9rem !important;
  }
  .mt-sp-90 {
    margin-top: 9rem !important;
  }
  .mb-sp-90 {
    margin-bottom: 9rem !important;
  }
  .ml-sp-90 {
    margin-left: 9rem !important;
  }
  .mr-sp-90 {
    margin-right: 9rem !important;
  }
  .p-sp-90 {
    padding: 9rem !important;
  }
  .py-sp-90 {
    padding: 9rem 0 !important;
  }
  .px-sp-90 {
    padding: 0 9rem !important;
  }
  .pt-sp-90 {
    padding-top: 9rem !important;
  }
  .pb-sp-90 {
    padding-bottom: 9rem !important;
  }
  .pl-sp-90 {
    padding-left: 9rem !important;
  }
  .pr-sp-90 {
    padding-right: 9rem !important;
  }
  .m-sp-95 {
    margin: 9.5rem !important;
  }
  .my-sp-95 {
    margin: 9.5rem 0 !important;
  }
  .mx-sp-95 {
    margin: 0 9.5rem !important;
  }
  .mt-sp-95 {
    margin-top: 9.5rem !important;
  }
  .mb-sp-95 {
    margin-bottom: 9.5rem !important;
  }
  .ml-sp-95 {
    margin-left: 9.5rem !important;
  }
  .mr-sp-95 {
    margin-right: 9.5rem !important;
  }
  .p-sp-95 {
    padding: 9.5rem !important;
  }
  .py-sp-95 {
    padding: 9.5rem 0 !important;
  }
  .px-sp-95 {
    padding: 0 9.5rem !important;
  }
  .pt-sp-95 {
    padding-top: 9.5rem !important;
  }
  .pb-sp-95 {
    padding-bottom: 9.5rem !important;
  }
  .pl-sp-95 {
    padding-left: 9.5rem !important;
  }
  .pr-sp-95 {
    padding-right: 9.5rem !important;
  }
  .m-sp-100 {
    margin: 10rem !important;
  }
  .my-sp-100 {
    margin: 10rem 0 !important;
  }
  .mx-sp-100 {
    margin: 0 10rem !important;
  }
  .mt-sp-100 {
    margin-top: 10rem !important;
  }
  .mb-sp-100 {
    margin-bottom: 10rem !important;
  }
  .ml-sp-100 {
    margin-left: 10rem !important;
  }
  .mr-sp-100 {
    margin-right: 10rem !important;
  }
  .p-sp-100 {
    padding: 10rem !important;
  }
  .py-sp-100 {
    padding: 10rem 0 !important;
  }
  .px-sp-100 {
    padding: 0 10rem !important;
  }
  .pt-sp-100 {
    padding-top: 10rem !important;
  }
  .pb-sp-100 {
    padding-bottom: 10rem !important;
  }
  .pl-sp-100 {
    padding-left: 10rem !important;
  }
  .pr-sp-100 {
    padding-right: 10rem !important;
  }
}
.wid-0 {
  width: 0% !important;
}

.wid-2 {
  width: 2% !important;
}

.wid-4 {
  width: 4% !important;
}

.wid-6 {
  width: 6% !important;
}

.wid-8 {
  width: 8% !important;
}

.wid-10 {
  width: 10% !important;
}

.wid-12 {
  width: 12% !important;
}

.wid-14 {
  width: 14% !important;
}

.wid-16 {
  width: 16% !important;
}

.wid-18 {
  width: 18% !important;
}

.wid-20 {
  width: 20% !important;
}

.wid-22 {
  width: 22% !important;
}

.wid-24 {
  width: 24% !important;
}

.wid-26 {
  width: 26% !important;
}

.wid-28 {
  width: 28% !important;
}

.wid-30 {
  width: 30% !important;
}

.wid-32 {
  width: 32% !important;
}

.wid-34 {
  width: 34% !important;
}

.wid-36 {
  width: 36% !important;
}

.wid-38 {
  width: 38% !important;
}

.wid-40 {
  width: 40% !important;
}

.wid-42 {
  width: 42% !important;
}

.wid-44 {
  width: 44% !important;
}

.wid-46 {
  width: 46% !important;
}

.wid-48 {
  width: 48% !important;
}

.wid-50 {
  width: 50% !important;
}

.wid-52 {
  width: 52% !important;
}

.wid-54 {
  width: 54% !important;
}

.wid-56 {
  width: 56% !important;
}

.wid-58 {
  width: 58% !important;
}

.wid-60 {
  width: 60% !important;
}

.wid-62 {
  width: 62% !important;
}

.wid-64 {
  width: 64% !important;
}

.wid-66 {
  width: 66% !important;
}

.wid-68 {
  width: 68% !important;
}

.wid-70 {
  width: 70% !important;
}

.wid-72 {
  width: 72% !important;
}

.wid-74 {
  width: 74% !important;
}

.wid-76 {
  width: 76% !important;
}

.wid-78 {
  width: 78% !important;
}

.wid-80 {
  width: 80% !important;
}

.wid-82 {
  width: 82% !important;
}

.wid-84 {
  width: 84% !important;
}

.wid-86 {
  width: 86% !important;
}

.wid-88 {
  width: 88% !important;
}

.wid-90 {
  width: 90% !important;
}

.wid-92 {
  width: 92% !important;
}

.wid-94 {
  width: 94% !important;
}

.wid-96 {
  width: 96% !important;
}

.wid-98 {
  width: 98% !important;
}

.wid-100 {
  width: 100% !important;
}

@media screen and (max-width: 480px) {
  .wid-sp-0 {
    width: 0% !important;
  }
  .wid-sp-2 {
    width: 2% !important;
  }
  .wid-sp-4 {
    width: 4% !important;
  }
  .wid-sp-6 {
    width: 6% !important;
  }
  .wid-sp-8 {
    width: 8% !important;
  }
  .wid-sp-10 {
    width: 10% !important;
  }
  .wid-sp-12 {
    width: 12% !important;
  }
  .wid-sp-14 {
    width: 14% !important;
  }
  .wid-sp-16 {
    width: 16% !important;
  }
  .wid-sp-18 {
    width: 18% !important;
  }
  .wid-sp-20 {
    width: 20% !important;
  }
  .wid-sp-22 {
    width: 22% !important;
  }
  .wid-sp-24 {
    width: 24% !important;
  }
  .wid-sp-26 {
    width: 26% !important;
  }
  .wid-sp-28 {
    width: 28% !important;
  }
  .wid-sp-30 {
    width: 30% !important;
  }
  .wid-sp-32 {
    width: 32% !important;
  }
  .wid-sp-34 {
    width: 34% !important;
  }
  .wid-sp-36 {
    width: 36% !important;
  }
  .wid-sp-38 {
    width: 38% !important;
  }
  .wid-sp-40 {
    width: 40% !important;
  }
  .wid-sp-42 {
    width: 42% !important;
  }
  .wid-sp-44 {
    width: 44% !important;
  }
  .wid-sp-46 {
    width: 46% !important;
  }
  .wid-sp-48 {
    width: 48% !important;
  }
  .wid-sp-50 {
    width: 50% !important;
  }
  .wid-sp-52 {
    width: 52% !important;
  }
  .wid-sp-54 {
    width: 54% !important;
  }
  .wid-sp-56 {
    width: 56% !important;
  }
  .wid-sp-58 {
    width: 58% !important;
  }
  .wid-sp-60 {
    width: 60% !important;
  }
  .wid-sp-62 {
    width: 62% !important;
  }
  .wid-sp-64 {
    width: 64% !important;
  }
  .wid-sp-66 {
    width: 66% !important;
  }
  .wid-sp-68 {
    width: 68% !important;
  }
  .wid-sp-70 {
    width: 70% !important;
  }
  .wid-sp-72 {
    width: 72% !important;
  }
  .wid-sp-74 {
    width: 74% !important;
  }
  .wid-sp-76 {
    width: 76% !important;
  }
  .wid-sp-78 {
    width: 78% !important;
  }
  .wid-sp-80 {
    width: 80% !important;
  }
  .wid-sp-82 {
    width: 82% !important;
  }
  .wid-sp-84 {
    width: 84% !important;
  }
  .wid-sp-86 {
    width: 86% !important;
  }
  .wid-sp-88 {
    width: 88% !important;
  }
  .wid-sp-90 {
    width: 90% !important;
  }
  .wid-sp-92 {
    width: 92% !important;
  }
  .wid-sp-94 {
    width: 94% !important;
  }
  .wid-sp-96 {
    width: 96% !important;
  }
  .wid-sp-98 {
    width: 98% !important;
  }
  .wid-sp-100 {
    width: 100% !important;
  }
}
@media screen and (max-width: 980px) {
  .wid-tab-0 {
    width: 0% !important;
  }
  .wid-tab-2 {
    width: 2% !important;
  }
  .wid-tab-4 {
    width: 4% !important;
  }
  .wid-tab-6 {
    width: 6% !important;
  }
  .wid-tab-8 {
    width: 8% !important;
  }
  .wid-tab-10 {
    width: 10% !important;
  }
  .wid-tab-12 {
    width: 12% !important;
  }
  .wid-tab-14 {
    width: 14% !important;
  }
  .wid-tab-16 {
    width: 16% !important;
  }
  .wid-tab-18 {
    width: 18% !important;
  }
  .wid-tab-20 {
    width: 20% !important;
  }
  .wid-tab-22 {
    width: 22% !important;
  }
  .wid-tab-24 {
    width: 24% !important;
  }
  .wid-tab-26 {
    width: 26% !important;
  }
  .wid-tab-28 {
    width: 28% !important;
  }
  .wid-tab-30 {
    width: 30% !important;
  }
  .wid-tab-32 {
    width: 32% !important;
  }
  .wid-tab-34 {
    width: 34% !important;
  }
  .wid-tab-36 {
    width: 36% !important;
  }
  .wid-tab-38 {
    width: 38% !important;
  }
  .wid-tab-40 {
    width: 40% !important;
  }
  .wid-tab-42 {
    width: 42% !important;
  }
  .wid-tab-44 {
    width: 44% !important;
  }
  .wid-tab-46 {
    width: 46% !important;
  }
  .wid-tab-48 {
    width: 48% !important;
  }
  .wid-tab-50 {
    width: 50% !important;
  }
  .wid-tab-52 {
    width: 52% !important;
  }
  .wid-tab-54 {
    width: 54% !important;
  }
  .wid-tab-56 {
    width: 56% !important;
  }
  .wid-tab-58 {
    width: 58% !important;
  }
  .wid-tab-60 {
    width: 60% !important;
  }
  .wid-tab-62 {
    width: 62% !important;
  }
  .wid-tab-64 {
    width: 64% !important;
  }
  .wid-tab-66 {
    width: 66% !important;
  }
  .wid-tab-68 {
    width: 68% !important;
  }
  .wid-tab-70 {
    width: 70% !important;
  }
  .wid-tab-72 {
    width: 72% !important;
  }
  .wid-tab-74 {
    width: 74% !important;
  }
  .wid-tab-76 {
    width: 76% !important;
  }
  .wid-tab-78 {
    width: 78% !important;
  }
  .wid-tab-80 {
    width: 80% !important;
  }
  .wid-tab-82 {
    width: 82% !important;
  }
  .wid-tab-84 {
    width: 84% !important;
  }
  .wid-tab-86 {
    width: 86% !important;
  }
  .wid-tab-88 {
    width: 88% !important;
  }
  .wid-tab-90 {
    width: 90% !important;
  }
  .wid-tab-92 {
    width: 92% !important;
  }
  .wid-tab-94 {
    width: 94% !important;
  }
  .wid-tab-96 {
    width: 96% !important;
  }
  .wid-tab-98 {
    width: 98% !important;
  }
  .wid-tab-100 {
    width: 100% !important;
  }
}
/* LOADING */
.is-loading {
  overflow: hidden;
}

.loading {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at center, rgba(201, 169, 110, 0.1), transparent 34%), var(--black);
  opacity: 1;
  visibility: visible;
  transition: opacity 0.9s cubic-bezier(0.22, 1, 0.36, 1), visibility 0s linear 0s;
}

.loading.is-loaded {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition-delay: 0s, 0.9s;
}

.loading-inner {
  width: min(58vw, 360px);
  display: grid;
  justify-items: center;
  gap: 24px;
  transform: translateY(8px);
}

.loading-mark {
  width: 100%;
  opacity: 0;
  transform: translateY(12px);
  animation: loadingMark 1.2s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.loading-mark img {
  width: 100%;
  height: auto;
  display: block;
  filter: drop-shadow(0 0 28px rgba(201, 169, 110, 0.22));
}

.loading-line {
  position: relative;
  width: min(44vw, 240px);
  height: 1px;
  overflow: hidden;
  background: rgba(201, 169, 110, 0.18);
}

.loading-line::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  transform: translateX(-100%);
  animation: loadingLine 1.4s cubic-bezier(0.65, 0, 0.35, 1) infinite;
}

.loading-text {
  font-family: "Balthazar", serif;
  font-size: 0.875rem;
  letter-spacing: 0.34em;
  color: var(--gold);
  text-transform: uppercase;
}

@keyframes loadingMark {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes loadingLine {
  to {
    transform: translateX(100%);
  }
}
@media (max-width: 768px) {
  .loading-inner {
    width: min(50vw, 300px);
    gap: 20px;
  }
  .loading-text {
    font-size: 0.75rem;
    letter-spacing: 0.24em;
  }
}
/* NAV */
nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: 24px 60px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(8, 8, 8, 0.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(201, 169, 110, 0.12);
  transition: background 0.3s;
}

.nav-logo {
  font-family: "Balthazar", serif;
  font-size: 1.375rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: var(--gold);
  text-decoration: none;
}

.nav-links {
  display: flex;
  gap: 40px;
  list-style: none;
}

.nav-links a {
  font-family: "Balthazar", serif;
  color: var(--white);
  text-decoration: none;
  font-size: 1rem;
  letter-spacing: 0.22em;
  opacity: 0.75;
  transition: color 0.3s, opacity 0.3s;
}

.nav-links a:hover {
  color: var(--gold);
  opacity: 1;
}

/* HAMBURGER */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  background: none;
  border: none;
  cursor: none;
  padding: 4px;
  z-index: 200;
}

.nav-hamburger span {
  display: block;
  width: 100%;
  height: 1px;
  background: var(--white);
  transition: transform 0.35s ease, opacity 0.35s ease, width 0.35s ease;
  transform-origin: center;
}

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

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

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

/* MOBILE DRAWER */
.nav-drawer {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(8, 8, 8, 0.97);
  z-index: 150;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}

.nav-drawer.open {
  opacity: 1;
  pointer-events: auto;
}

.nav-drawer ul {
  list-style: none;
  text-align: center;
}

.nav-drawer ul li {
  padding: 18px 0;
  border-bottom: 1px solid rgba(201, 169, 110, 0.1);
}

.nav-drawer ul li:first-child {
  border-top: 1px solid rgba(201, 169, 110, 0.1);
}

.nav-drawer ul li a {
  font-size: 1rem;
  letter-spacing: 0.35em;
  color: var(--white);
  text-decoration: none;
  transition: color 0.3s;
  display: block;
  padding: 0 60px;
  font-family: "Balthazar", serif;
}

.nav-drawer ul li a:hover {
  color: var(--gold);
}

.nav-drawer-logo {
  text-align: center;
  font-family: "Balthazar", serif;
  font-size: 1.5rem;
  letter-spacing: 0.1em;
  color: var(--gold);
  margin-bottom: 0px;
}
.nav-drawer-logo img {
  width: 50%;
  max-width: 400px;
}

.nav-drawer-close {
  position: absolute;
  top: 24px;
  right: 24px;
  width: 44px;
  height: 44px;
  background: none;
  border: 1px solid rgba(201, 169, 110, 0.25);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: none;
  transition: border-color 0.3s, background 0.3s;
}

.nav-drawer-close:hover {
  border-color: var(--gold);
  background: rgba(201, 169, 110, 0.08);
}

.nav-drawer-close svg {
  width: 16px;
  height: 16px;
  stroke: var(--white);
  transition: stroke 0.3s;
}

.nav-drawer-close:hover svg {
  stroke: var(--gold);
}

.nav-drawer-sns {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-top: 48px;
}

.nav-drawer-sns a {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.72;
  transition: opacity 0.3s, transform 0.3s;
}

.nav-drawer-sns img {
  display: block;
  width: 22px;
  height: 22px;
  -o-object-fit: contain;
     object-fit: contain;
}

.nav-drawer-sns a:hover {
  opacity: 1;
  transform: translateY(-2px);
}

/* HERO */
.hero {
  position: relative;
  height: calc(100vh - var(--header-height, 78px));
  overflow: hidden;
  margin-top: var(--header-height, 78px);
}
@media screen and (max-width: 980px) {
  .hero {
    height: 70vh;
  }
}

.photo-frame {
  position: relative;
  margin-top: 0;
}

.photo-placeholder {
  width: 100%;
  height: calc(100vh - var(--header-height, 78px));
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 980px) {
  .photo-placeholder {
    height: 70vh;
  }
}

.photo-placeholder img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.photo-placeholder img.mainimg01 {
  -o-object-position: center center;
     object-position: center center;
}
@media screen and (max-width: 980px) {
  .photo-placeholder img.mainimg01 {
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 60% center;
       object-position: 60% center;
  }
}
@media screen and (max-width: 480px) {
  .photo-placeholder img.mainimg01 {
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 68% center;
       object-position: 68% center;
  }
}

.photo-corner {
  position: absolute;
  width: 30px;
  height: 30px;
  border-color: var(--gold);
  border-style: solid;
  opacity: 0.6;
}

.photo-corner.tl {
  top: -8px;
  left: -8px;
  border-width: 1px 0 0 1px;
}

.photo-corner.tr {
  top: -8px;
  right: -8px;
  border-width: 1px 1px 0 0;
}

.photo-corner.bl {
  bottom: -8px;
  left: -8px;
  border-width: 0 0 1px 1px;
}

.photo-corner.br {
  bottom: -8px;
  right: -8px;
  border-width: 0 1px 1px 0;
}

.hero-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 65%;
  background: linear-gradient(to top, var(--black) 0%, var(--black) 20%, transparent 100%);
}

.hero-content {
  position: relative;
  z-index: 2;
  padding: 0 60px 70px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: flex-end;
  gap: 40px;
}

.hero-year-badge {
  font-size: 0.75rem;
  letter-spacing: 0.35em;
  color: var(--gold);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 16px;
}

.hero-year-badge::before {
  content: "";
  display: block;
  width: 40px;
  height: 1px;
  background: var(--gold);
}

.hero-title {
  font-family: "Balthazar", serif;
  font-size: clamp(3.25rem, 7vw, 5.625rem);
  font-weight: 400;
  line-height: 0.9;
  letter-spacing: 0.05em;
  color: var(--white);
  margin-bottom: 6px;
}

.hero-subtitle {
  font-size: 0.8125rem;
  letter-spacing: 0.4em;
  color: var(--gold);
  margin-top: 20px;
}

.hero-anniversary {
  font-family: "Balthazar", serif;
  font-size: clamp(5rem, 11vw, 8.75rem);
  font-weight: 400;
  color: transparent;
  -webkit-text-stroke: 1px rgba(201, 169, 110, 0.25);
  letter-spacing: -0.02em;
  line-height: 1;
  align-self: flex-end;
  padding-bottom: 5px;
}

.scroll-hint {
  position: absolute;
  bottom: 10px;
  right: 0px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  font-size: 0.75rem;
  letter-spacing: 0.35em;
  color: var(--text-dim);
  z-index: 2;
}
.scroll-hint span {
  transform: rotate(90deg);
  margin-bottom: 10px;
}
@media screen and (max-width: 980px) {
  .scroll-hint {
    bottom: 10px;
    right: inherit;
    left: -15px;
  }
}

.scroll-line {
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, transparent, var(--gold-dim));
  animation: scrollAnim 2s ease-in-out infinite;
}

@keyframes scrollAnim {
  0% {
    transform: scaleY(0);
    transform-origin: top;
    opacity: 0;
  }
  50% {
    transform: scaleY(1);
    transform-origin: top;
    opacity: 1;
  }
  100% {
    transform: scaleY(1);
    transform-origin: bottom;
    opacity: 0;
  }
}
.bnr {
  position: absolute;
}
.bnr.bnr_35th {
  width: 26%;
  max-width: 400px;
  top: 50%;
  left: 50%;
  transform: translate(-130%, -50%);
}
@media screen and (max-width: 980px) {
  .bnr.bnr_35th {
    left: 3%;
    transform: translate(0%, -50%);
    width: 30%;
  }
}
@media screen and (max-width: 480px) {
  .bnr.bnr_35th {
    width: 48%;
    top: inherit;
    left: 50%;
    bottom: 2%;
    transform: translate(-50%, 0%);
  }
}

.mainbnr {
  position: absolute;
  top: 50%;
  right: 20px;
  z-index: 1;
  width: 14%;
  max-width: 300px;
  transform: translate(0, -50%);
}
@media screen and (max-width: 980px) {
  .mainbnr {
    right: 10px;
    width: 23%;
    max-width: 300px;
  }
}

/* SECTION BASE */
.section {
  padding: 100px 60px;
  position: relative;
  z-index: 1;
}

.section-label {
  font-size: 0.75rem;
  letter-spacing: 0.4em;
  color: var(--gold);
  margin-bottom: 50px;
  display: flex;
  align-items: center;
  gap: 20px;
  font-weight: 600;
  font-family: "Balthazar", serif;
}

.section-label::after {
  content: "";
  flex: 1;
  max-width: 60px;
  height: 1px;
  background: var(--gold-dim);
}

.section-title {
  font-family: "Balthazar", serif;
  font-size: clamp(2rem, 4vw, 2.6rem);
  font-weight: 400;
  color: var(--white);
  letter-spacing: 0.04em;
  line-height: 1.1;
  margin-bottom: 60px;
}

/* GOLD DIVIDER */
.divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold-dim) 30%, var(--gold-dim) 70%, transparent);
  margin: 0;
}

/* CONTENT BANNERS */
#contents {
  background: rgba(14, 14, 14, 0.3);
}

.banners-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
}
@media screen and (max-width: 1280px) {
  .banners-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 480px) {
  .banners-grid {
    grid-template-columns: repeat(1, 1fr);
  }
}

.banner {
  display: block;
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  cursor: none;
  background: var(--surface);
  color: inherit;
  text-decoration: none;
}

.banner.is-coming-soon::before {
  content: "COMING SOON";
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(8, 8, 8, 0.62);
  color: var(--white);
  font-family: "Balthazar", serif;
  font-size: 1.25rem;
  letter-spacing: 0.3em;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}

.banner.is-coming-soon:hover::before {
  opacity: 1;
}

.banner-bg {
  position: absolute;
  inset: 0;
  transition: transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.banner:hover .banner-bg {
  transform: scale(1.06);
}

.banner-gradient {
  width: 100%;
  height: 100%;
}

.banner-gradient img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
  filter: brightness(0.55) saturate(0.7);
  transition: filter 0.7s ease;
}

.banner:hover .banner-gradient img {
  filter: brightness(0.65) saturate(0.85);
}

.banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(8, 8, 8, 0.9) 0%, rgba(8, 8, 8, 0.3) 60%, transparent 100%);
}

.banner-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 30px 28px;
}
@media screen and (max-width: 980px) {
  .banner-content {
    padding: 20px 18px;
  }
}

.banner-tag {
  font-size: 0.75rem;
  letter-spacing: 0.35em;
  color: var(--gold);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: "Balthazar", serif;
}

.banner-tag::before {
  content: "";
  display: block;
  width: 20px;
  height: 1px;
  background: var(--gold);
}

.banner-title {
  font-family: "Balthazar", serif;
  font-size: 1.375rem;
  font-weight: 400;
  color: var(--white);
  line-height: 1.2;
}

.banner-arrow {
  position: absolute;
  top: 28px;
  right: 28px;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(201, 169, 110, 0.3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
}

.banner:hover .banner-arrow {
  background: var(--gold);
  border-color: var(--gold);
}

.banner-arrow svg {
  width: 12px;
  height: 12px;
  stroke: var(--gold);
  transition: stroke 0.3s;
}

.banner:hover .banner-arrow svg {
  stroke: var(--black);
}

/* gradient fills per banner */
.banner-1 .banner-gradient {
  background: linear-gradient(135deg, #1a1208 0%, #0d1a14 100%);
}

.banner-2 .banner-gradient {
  background: linear-gradient(135deg, #0e0e1a 0%, #1a0e14 100%);
}

.banner-3 .banner-gradient {
  background: linear-gradient(135deg, #1a1208 0%, #141a0e 100%);
}

.banner-overlay::after {
  content: "";
  position: absolute;
  top: 20px;
  left: 20px;
  right: 20px;
  bottom: 20px;
  border: 1px solid rgba(201, 169, 110, 0.06);
}

/* decorative elements in banners */
.banner-deco {
  position: absolute;
  pointer-events: none;
}

.banner-1 .banner-deco {
  top: 0;
  right: 0;
  width: 40%;
  height: 60%;
  background: radial-gradient(ellipse at top right, rgba(201, 169, 110, 0.08) 0%, transparent 70%);
}

/* LYRIC SECTION */
#lyrics {
  background: rgba(8, 8, 8, 0.5);
  min-height: 60vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.lyric-stage {
  text-align: center;
  padding: 60px 20px;
  position: relative;
}

.lyric-quote-mark {
  font-family: "Balthazar", serif;
  font-size: 7.5rem;
  font-weight: 400;
  color: rgba(201, 169, 110, 0.08);
  line-height: 0.5;
  margin-bottom: 20px;
  display: block;
}

.lyric-text {
  font-family: "Balthazar", serif;
  font-size: clamp(1.375rem, 3.5vw, 2.5rem);
  font-weight: 400;
  font-style: italic;
  color: var(--white);
  line-height: 1.65;
  max-width: 800px;
  margin: 0 auto 24px;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.lyric-text.visible {
  opacity: 1;
  transform: translateY(0);
}

.lyric-source {
  font-size: 0.8125rem;
  letter-spacing: 0.35em;
  color: var(--gold-dim);
  opacity: 0;
  transition: opacity 0.8s ease 0.3s;
}

.lyric-source.visible {
  opacity: 1;
}

.lyric-dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 40px;
}

.lyric-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--text-dim);
  cursor: none;
  transition: background 0.3s, transform 0.3s;
}

.lyric-dot.active {
  background: var(--gold);
  transform: scale(1.4);
}

.lyric-nav-btn {
  background: none;
  border: 1px solid rgba(201, 169, 110, 0.2);
  color: var(--gold-dim);
  padding: 12px 32px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 0.75rem;
  letter-spacing: 0.3em;
  cursor: none;
  margin-top: 30px;
  transition: all 0.3s;
  display: inline-block;
}

.lyric-nav-btn:hover {
  background: rgba(201, 169, 110, 0.08);
  color: var(--gold);
  border-color: var(--gold-dim);
}

.lyric-nav-area {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-top: 20px;
}

/* melody */
#melody {
  background: rgba(20, 20, 20, 0.3);
}

.melody-header {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: flex-end;
  margin-bottom: 50px;
}

.melody-link-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--gold);
  letter-spacing: 0.25em;
  text-decoration: none;
  border-bottom: 1px solid rgba(201, 169, 110, 0.3);
  padding-bottom: 4px;
  transition: border-color 0.3s;
}

.melody-link-btn:hover {
  border-color: var(--gold);
}

.melody-link-btn svg {
  width: 14px;
  height: 14px;
  stroke: var(--gold);
}

.melody-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media screen and (max-width: 1280px) {
  .melody-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 980px) {
  .melody-grid {
    grid-template-columns: 1fr;
  }
}

.melody-card {
  background: var(--surface2);
  border: 1px solid rgba(201, 169, 110, 0.08);
  padding: 28px;
  transition: border-color 0.4s, transform 0.4s;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

.melody-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold-dim), transparent);
  transform: scaleX(0);
  transition: transform 0.5s;
}

.melody-card:hover {
  border-color: rgba(201, 169, 110, 0.2);
  transform: translateY(-3px);
}

.melody-card:focus-visible {
  outline: 1px solid var(--gold);
  outline-offset: 4px;
}

.melody-card:hover::before {
  transform: scaleX(1);
}

.melody-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}

.melody-user {
  display: flex;
  align-items: center;
  gap: 10px;
}

.melody-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8125rem;
  letter-spacing: 0;
  font-weight: 400;
  color: var(--gold);
  border: 1px solid rgba(201, 169, 110, 0.3);
}

.melody-name {
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

.melody-user-detail {
  font-size: 0.6875rem;
  letter-spacing: 0.08em;
  color: var(--text-dim);
  white-space: nowrap;
}

.melody-date {
  font-size: 0.75rem;
  color: var(--text-dim);
  letter-spacing: 0.1em;
}

.melody-song {
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  color: var(--gold);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.melody-song::before {
  content: "♪";
  font-size: 0.8125rem;
}

.melody-text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 0.8125rem;
  line-height: 1.85;
  color: var(--text-muted);
  font-weight: 400;
}

.melody-more-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 180px;
  height: 48px;
  margin: 40px auto 0;
  border: 1px solid rgba(201, 169, 110, 0.35);
  background: transparent;
  color: var(--gold);
  font-family: "Balthazar", serif;
  font-size: 1rem;
  letter-spacing: 0.22em;
  cursor: pointer;
  transition: border-color 0.3s, background 0.3s, transform 0.3s;
}

.melody-more-btn:hover {
  border-color: var(--gold);
  background: rgba(201, 169, 110, 0.08);
  transform: translateY(-2px);
}

.melody-more-btn:focus-visible {
  outline: 1px solid var(--gold);
  outline-offset: 4px;
}

.is-melody-modal-open {
  overflow: hidden;
}

.melody-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.melody-modal.is-open {
  display: flex;
}

.melody-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
}

.melody-modal__dialog {
  position: relative;
  width: min(720px, 100%);
  max-height: min(78vh, 720px);
  overflow-y: auto;
  background: var(--surface2);
  border: 1px solid rgba(201, 169, 110, 0.22);
  padding: 34px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45);
}

.melody-modal__close {
  position: absolute;
  top: 12px;
  right: 14px;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(201, 169, 110, 0.25);
  background: transparent;
  color: var(--gold);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
}

.melody-modal__close:focus-visible {
  outline: 1px solid var(--gold);
  outline-offset: 3px;
}

.melody-modal__meta {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-right: 46px;
  margin-bottom: 18px;
  color: var(--text-dim);
  font-size: 0.8125rem;
  letter-spacing: 0.08em;
}

.melody-modal__user {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.melody-modal__name {
  color: var(--text-muted);
}

.melody-modal__detail {
  color: var(--text-dim);
  font-size: 0.75rem;
  white-space: nowrap;
}

.melody-modal__song {
  color: var(--gold);
  font-size: 0.875rem;
  letter-spacing: 0.18em;
  margin-bottom: 18px;
}

.melody-modal__text {
  margin: 0;
  color: var(--text-muted);
  font-family: "Noto Sans JP", sans-serif;
  font-size: 0.9375rem;
  line-height: 2;
  white-space: pre-wrap;
}

@media screen and (max-width: 480px) {
  .melody-modal {
    padding: 14px;
  }
  .melody-modal__dialog {
    padding: 28px 22px;
    max-height: 82vh;
  }
  .melody-modal__meta {
    display: grid;
    gap: 6px;
  }
}
#release .release-card {
  position: relative;
  overflow: hidden;
  margin-bottom: 2rem;
  padding: 2rem;
  border: 1px solid rgba(201, 169, 110, 0.45);
  background: rgba(20, 20, 20, 0.72);
}
#release .release-card::before {
  position: absolute;
  top: -1px;
  left: -1px;
  width: 5rem;
  height: 3px;
  background: var(--gold);
  content: "";
}
#release .release-card::after {
  position: absolute;
  right: 1rem;
  bottom: -2rem;
  color: rgba(201, 169, 110, 0.08);
  content: attr(data-release-number);
  font-family: "DM Serif Display", serif;
  font-size: clamp(8rem, 19vw, 15rem);
  font-style: italic;
  line-height: 1;
  pointer-events: none;
}
#release .release-card h3 {
  position: relative;
  z-index: 1;
  margin-bottom: 1.2rem;
  line-height: 1.75;
}
#release .release-card p {
  position: relative;
  z-index: 1;
  margin-bottom: 1rem;
  line-height: 2;
}
#release .release-card p:last-child {
  margin-bottom: 0;
}
#release .release-card__type {
  position: relative;
  z-index: 1;
  display: inline-block;
  margin-bottom: 1rem;
  padding: 0.35rem 0.8rem;
  border: 1px solid var(--gold-dim);
  color: var(--gold-light);
  font-family: "Balthazar", serif;
  font-size: 0.85rem;
  letter-spacing: 0.14em;
  line-height: 1;
}
#release .release-card__type--digital {
  border-color: rgba(232, 213, 163, 0.65);
}
#release .release-card__type--album {
  border-color: rgba(201, 169, 110, 0.85);
  background: rgba(201, 169, 110, 0.12);
}
#release .release-card__details {
  position: relative;
  z-index: 2;
  display: flex;
  gap: 1.8rem;
  align-items: flex-start;
}
#release .release-card__details-body {
  flex: 1;
  min-width: 0;
}
#release .release-card__details-body a {
  overflow-wrap: anywhere;
}
#release .release-card__jacket {
  flex: 0 0 min(38%, 17.5rem);
  order: 2;
  margin: 0;
  border: 1px solid rgba(201, 169, 110, 0.65);
  box-shadow: 0 0.7rem 1.8rem rgba(0, 0, 0, 0.35);
}
#release .release-card__jacket img {
  display: block;
  width: 100%;
}
#release .release-card .release-card__date {
  margin-bottom: 0.55rem;
  color: var(--gold);
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.12em;
}
#release .release-card .release-card__date::before {
  margin-right: 0.45rem;
  content: "■";
  font-size: 0.65em;
  vertical-align: 0.12em;
}
#release .release-card .release-card__title {
  margin-bottom: 1.4rem;
  color: var(--white);
  font-size: 1.25rem;
  letter-spacing: 0.06em;
}
#release .release-note {
  margin-top: 3rem;
  padding: 1.5rem 1.8rem;
  border-top: 1px solid rgba(201, 169, 110, 0.4);
  border-bottom: 1px solid rgba(201, 169, 110, 0.4);
  background: rgba(20, 20, 20, 0.35);
}
#release .release-note .release-note__title {
  margin-bottom: 1rem;
  color: var(--gold-light);
  font-size: 1rem;
  letter-spacing: 0.1em;
}
#release .release-note .release-note__icon {
  margin-right: 0.35rem;
  color: var(--gold);
}
#release .release-note p {
  margin-bottom: 0.7rem;
  font-size: 0.9rem;
  line-height: 1.9;
}
#release .release-note p:last-child {
  margin-bottom: 0;
  color: var(--text-muted);
  font-size: 0.8rem;
}

@media screen and (max-width: 480px) {
  #release .release-card {
    margin-bottom: 1.5rem;
    padding: 1.4rem 1.1rem;
  }
  #release .release-card h3 {
    line-height: 1.65;
  }
  #release .release-card .release-card__date {
    font-size: 0.95rem;
  }
  #release .release-card .release-card__title {
    font-size: 1.08rem;
  }
  #release .release-card p {
    line-height: 1.85;
  }
  #release .release-card .release-card__details {
    gap: 1.3rem;
    flex-direction: column;
  }
  #release .release-card .release-card__jacket {
    width: min(100%, 17.5rem);
    margin: 0 auto;
    flex-basis: auto;
    order: 0;
  }
  #release .release-note {
    margin-top: 2rem;
    padding: 1.2rem 1rem;
  }
}
#playlist .playlist-header {
  margin-bottom: 3.5rem;
}
#playlist .playlist-header__eyebrow {
  margin-bottom: 0.5rem;
  color: var(--gold);
  font-family: "Balthazar", serif;
  font-size: 0.9rem;
  letter-spacing: 0.22em;
}
#playlist .playlist-header__title {
  margin-bottom: 1rem;
  color: var(--white);
  font-family: "DM Serif Display", serif;
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  font-style: italic;
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 1;
}
#playlist .playlist-header__lead {
  margin-bottom: 0;
  color: var(--text-muted);
  line-height: 2;
}
#playlist .playlist-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}
#playlist .playlist-card {
  position: relative;
  display: flex;
  min-height: 10.5rem;
  overflow: hidden;
  border: 1px solid rgba(201, 169, 110, 0.38);
  background: rgba(20, 20, 20, 0.78);
  color: var(--text);
  text-decoration: none;
  transition: border-color 0.35s ease, background 0.35s ease, transform 0.35s ease;
}
#playlist .playlist-card::before {
  position: absolute;
  top: -1px;
  left: -1px;
  width: 4rem;
  height: 3px;
  background: var(--gold);
  content: "";
}
#playlist a.playlist-card:hover {
  border-color: rgba(201, 169, 110, 0.85);
  background: rgba(26, 26, 26, 0.95);
  transform: translateY(-5px);
}
#playlist a.playlist-card:hover .playlist-card__visual img {
  transform: scale(1.06);
}
#playlist a.playlist-card:hover .playlist-card__link {
  color: var(--gold-light);
}
#playlist .playlist-card__visual {
  position: relative;
  z-index: 1;
  display: flex;
  flex: 0 0 9rem;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-right: 1px solid rgba(201, 169, 110, 0.2);
  background: linear-gradient(145deg, rgba(201, 169, 110, 0.14), rgba(8, 8, 8, 0.4));
}
#playlist .playlist-card__visual img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  transition: transform 0.45s ease;
}
#playlist .playlist-card__placeholder {
  color: rgba(232, 213, 163, 0.6);
  font-family: "DM Serif Display", serif;
  font-size: 3rem;
  font-style: italic;
  line-height: 1;
}
#playlist .playlist-card__placeholder small {
  font-size: 0.38em;
}
#playlist .playlist-card__body {
  position: relative;
  z-index: 1;
  display: flex;
  min-width: 0;
  padding: 1.25rem 1rem;
  flex-direction: column;
  justify-content: center;
}
#playlist .playlist-card .playlist-card__label,
#playlist .playlist-card .playlist-card__name,
#playlist .playlist-card .playlist-card__name-en {
  margin-bottom: 0;
}
#playlist .playlist-card__label {
  color: var(--gold);
  font-family: "Balthazar", serif;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
}
#playlist .playlist-card__name {
  margin-top: 0.45rem;
  color: var(--white);
  font-size: 1.02rem;
  line-height: 1.5;
}
#playlist .playlist-card__name-en {
  margin-top: 0.25rem;
  color: var(--text-muted);
  font-family: "Balthazar", serif;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  line-height: 1.3;
}
#playlist .playlist-card__link,
#playlist .playlist-card__status {
  margin-top: 1rem;
  color: var(--gold);
  font-family: "Balthazar", serif;
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  transition: color 0.3s ease;
}
#playlist .playlist-card--coming-soon {
  opacity: 0.7;
}
#playlist .playlist-card--coming-soon::before {
  background: var(--gold-dim);
}
#playlist .playlist-card__status {
  color: var(--text-muted);
}

@media screen and (max-width: 1280px) {
  #playlist .playlist-grid {
    grid-template-columns: repeat(2, minmax(0, 2fr));
  }
}
@media screen and (max-width: 980px) {
  #playlist .playlist-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
}
@media screen and (max-width: 480px) {
  #playlist .playlist-header {
    margin-bottom: 2.5rem;
  }
  #playlist .playlist-header__lead {
    font-size: 0.9rem;
  }
  #playlist .playlist-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  #playlist .playlist-card {
    min-height: 8.5rem;
  }
  #playlist .playlist-card__visual {
    flex-basis: 7.5rem;
  }
  #playlist .playlist-card__body {
    padding: 1rem 0.85rem;
  }
}
#gogoblc_re h2.title.tour {
  text-align: center;
  font-family: "Balthazar", serif;
  font-size: clamp(2rem, 4vw, 2.6rem);
  font-weight: normal;
  margin-bottom: 4rem;
}
@media screen and (max-width: 480px) {
  #gogoblc_re h2.title.tour {
    font-size: clamp(1.8rem, 2.8vw, 2rem);
    margin-bottom: 2rem;
  }
}
#gogoblc_re .gogoreturn {
  font-family: "Balthazar", serif;
  font-size: clamp(2rem, 4vw, 2.6rem);
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 1.1;
}
#gogoblc_re .livecon {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  font-size: 0.9rem;
  line-height: 2;
  flex-direction: column;
}
@media screen and (max-width: 1280px) {
  #gogoblc_re .livecon {
    flex-direction: column;
  }
}
@media screen and (max-width: 980px) {
  #gogoblc_re .livecon {
    font-size: 0.8rem;
  }
}
#gogoblc_re .livecon h4 {
  font-size: 1.25rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 980px) {
  #gogoblc_re .livecon h4 {
    font-size: 1rem;
  }
}
#gogoblc_re .schedulebox {
  width: 100%;
  /*width: calc(60% - 2rem);*/
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 1rem;
}
@media screen and (max-width: 1280px) {
  #gogoblc_re .schedulebox {
    width: 100%;
  }
}
#gogoblc_re .schedulebox .tourBox {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-areas: "date date" "area place" "time time" "info info";
  align-content: start;
  -moz-column-gap: 12px;
       column-gap: 12px;
  width: calc((100% - 3rem) / 4);
  padding: 24px;
  border: 1px solid rgba(201, 169, 110, 0.18);
  border-radius: 8px;
  background: var(--surface2);
  overflow: hidden;
}
#gogoblc_re .schedulebox .tourBox div {
  float: none;
  width: auto;
  box-sizing: border-box;
  padding: 0;
}
#gogoblc_re .schedulebox .tourdate {
  grid-area: date;
  color: var(--gold-light);
  font-size: 1.125rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1.45;
}
#gogoblc_re .schedulebox .tourdate .day {
  display: block;
}
#gogoblc_re .schedulebox .tourdate .big {
  color: var(--gold-light);
  font-size: 1.5rem;
  line-height: 1;
}
#gogoblc_re .schedulebox .tourarea {
  grid-area: area;
  align-self: center;
  margin-top: 14px;
  line-height: 1;
  text-align: left;
  background: none;
}
#gogoblc_re .schedulebox .tourarea span {
  display: inline-block;
  padding: 5px 9px;
  border: 1px solid rgba(201, 169, 110, 0.35);
  border-radius: 999px;
  background: rgba(201, 169, 110, 0.06);
  color: var(--gold);
  font-size: 0.75rem;
  letter-spacing: 0.14em;
}
#gogoblc_re .schedulebox .tourplace {
  grid-area: place;
  align-self: center;
  margin-top: 14px;
  color: var(--white);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.6;
}
#gogoblc_re .schedulebox .tourplace a {
  color: inherit;
}
#gogoblc_re .schedulebox .tourtime {
  grid-area: time;
  margin-top: 16px;
  color: var(--text-muted);
  font-size: 0.8125rem;
  letter-spacing: 0.12em;
  line-height: 1.7;
}
#gogoblc_re .schedulebox .tourinfo {
  grid-area: info;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(201, 169, 110, 0.12);
  color: var(--text-muted);
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  line-height: 1.7;
}
#gogoblc_re .schedulebox .tourinfo span {
  line-height: inherit;
}
#gogoblc_re .schedulebox .tourinfo .contactline {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.5em;
  padding-top: 8px;
}
#gogoblc_re .schedulebox .tourinfo .contactline span {
  margin-left: inherit;
  padding-left: inherit;
  text-indent: inherit;
}
#gogoblc_re .ticketbox {
  display: flex;
  gap: 3rem;
  /*width: 40%;*/
}
@media screen and (max-width: 980px) {
  #gogoblc_re .ticketbox {
    width: 100%;
    display: block;
  }
}
#gogoblc_re .ticketbox-price {
  width: calc((100% - 1.5rem) / 2);
  border: solid 1px;
  padding: 2rem;
  align-self: flex-start;
}
@media screen and (max-width: 980px) {
  #gogoblc_re .ticketbox-price {
    width: 100%;
    padding: 1.5rem;
    margin-bottom: 2rem;
  }
}
#gogoblc_re .ticketbox-schedule {
  align-self: flex-start;
  width: calc((100% - 1.5rem) / 2);
}
@media screen and (max-width: 980px) {
  #gogoblc_re .ticketbox-schedule {
    width: 100%;
  }
}
@media screen and (max-width: 1280px) {
  #gogoblc_re .schedulebox .tourBox {
    width: calc((100% - 2rem) / 3);
  }
}
@media screen and (max-width: 980px) {
  #gogoblc_re .schedulebox .tourBox {
    width: calc((100% - 1rem) / 2);
    padding: 20px;
  }
}
@media screen and (max-width: 480px) {
  #gogoblc_re .schedulebox {
    display: block;
  }
  #gogoblc_re .schedulebox .tourBox {
    width: 100%;
    padding: 16px;
  }
  #gogoblc_re .schedulebox .tourBox + .tourBox {
    margin-top: 14px;
  }
  #gogoblc_re .schedulebox .tourdate {
    font-size: 1rem;
  }
  #gogoblc_re .schedulebox .tourplace {
    font-size: 0.9375rem;
  }
}

/* SUBMIT CTA */
.submit-cta {
  margin-top: 60px;
  text-align: center;
  padding: 60px;
  border: 1px solid rgba(201, 169, 110, 0.1);
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 480px) {
  .submit-cta {
    padding: 32px;
  }
}

.submit-cta::before {
  content: "35";
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
  font-family: "Balthazar", serif;
  font-size: 12.5rem;
  font-weight: 400;
  line-height: 1;
  color: rgba(201, 169, 110, 0.04);
  pointer-events: none;
}

.submit-cta-title {
  font-family: "Balthazar", serif;
  font-size: 2rem;
  font-weight: 400;
  color: var(--white);
  margin-bottom: 12px;
}

.submit-cta-sub {
  font-size: 0.8125rem;
  letter-spacing: 0.2em;
  color: var(--text-muted);
  margin-bottom: 36px;
  line-height: 1.8;
}

.cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: none;
  border: 1px solid var(--gold-dim);
  color: var(--gold);
  font-family: "Noto Sans JP", sans-serif;
  font-size: 0.8125rem;
  letter-spacing: 0.3em;
  padding: 16px 48px;
  cursor: none;
  text-decoration: none;
  transition: all 0.4s;
}
@media screen and (max-width: 480px) {
  .cta-btn {
    padding: 16px 24px;
  }
}

.cta-btn:hover {
  background: rgba(201, 169, 110, 0.08);
  border-color: var(--gold);
}

.cta-btn svg {
  width: 14px;
  height: 14px;
  stroke: var(--gold);
}

/* FOOTER */
footer {
  background: rgba(8, 8, 8, 0.82);
  margin-top: auto;
  padding: 60px;
  border-top: 1px solid rgba(201, 169, 110, 0.1);
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 980px) {
  footer {
    padding: 30px;
  }
}

.footer-inner {
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: 40px;
  place-content: space-between;
}
@media screen and (max-width: 480px) {
  .footer-inner {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
    gap: 0px;
  }
}

.footer-logo {
  font-family: "Balthazar", serif;
  font-size: 1.75rem;
  font-weight: 400;
  letter-spacing: 0.2em;
  color: var(--gold);
  width: 120px;
}

.footer-copy {
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  color: var(--text);
  text-align: center;
}

.footer-sns {
  display: flex;
  align-items: center;
  gap: 14px;
}
@media screen and (max-width: 480px) {
  .footer-sns {
    margin: 0px 0 40px 0;
  }
}

.footer-sns a {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.72;
  transition: opacity 0.3s, transform 0.3s;
}

.footer-sns img {
  display: block;
  width: 20px;
  height: 20px;
  -o-object-fit: contain;
     object-fit: contain;
}

.footer-sns a:hover {
  opacity: 1;
  transform: translateY(-2px);
}

/* WING BG */
.wing-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.wing-bg svg {
  width: 90vw;
  max-width: 1200px;
  height: auto;
  opacity: 0.13;
  filter: drop-shadow(0 0 40px rgba(201, 169, 110, 0.15));
}

.wing-left {
  transform-origin: 846.65px 547.75px;
  transition: transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
}

.wing-right {
  transform-origin: 846.65px 547.75px;
  transition: transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
}

/* FADE IN */
.fade-up {
  opacity: 0;
  transform: translateY(36px);
  transition: opacity 0.85s cubic-bezier(0.22, 1, 0.36, 1), transform 0.85s cubic-bezier(0.22, 1, 0.36, 1);
}

.fade-up.in {
  opacity: 1;
  transform: translateY(0);
}

.fade-left {
  opacity: 0;
  transform: translateX(-32px);
  transition: opacity 0.85s cubic-bezier(0.22, 1, 0.36, 1), transform 0.85s cubic-bezier(0.22, 1, 0.36, 1);
}

.fade-left.in {
  opacity: 1;
  transform: translateX(0);
}

.fade-right {
  opacity: 0;
  transform: translateX(24px);
  transition: opacity 0.85s cubic-bezier(0.22, 1, 0.36, 1), transform 0.85s cubic-bezier(0.22, 1, 0.36, 1);
}

.fade-right.in {
  opacity: 1;
  transform: translateX(0);
}

.fade-in {
  opacity: 0;
  transition: opacity 1s cubic-bezier(0.22, 1, 0.36, 1);
}

.fade-in.in {
  opacity: 1;
}

.delay-1 {
  transition-delay: 0.1s;
}

.delay-2 {
  transition-delay: 0.2s;
}

.delay-3 {
  transition-delay: 0.3s;
}

.delay-4 {
  transition-delay: 0.45s;
}

.delay-5 {
  transition-delay: 0.6s;
}

/* SWIPER */
.swiper-button-prev {
  color: var(--gold-dim);
  height: 24px;
  width: 24px;
}

.swiper-button-next {
  color: var(--gold-dim);
  height: 24px;
  width: 24px;
}

.swiper-pagination-bullet-active {
  background: var(--gold-dim);
}

@media screen and (max-width: 980px) {
  nav {
    padding: 18px 24px;
  }
  .nav-links {
    display: none;
  }
  .nav-hamburger {
    display: flex;
  }
  .nav-drawer {
    display: flex;
  }
  .section {
    padding: 70px 24px;
  }
  .hero-content {
    padding: 0 24px 50px;
    grid-template-columns: 1fr;
  }
  .hero-anniversary {
    display: none;
  }
  .melody-header {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .cursor, .cursor-ring {
    display: none;
  }
  .fade-right {
    transform: translateX(12px);
  }
}/*# sourceMappingURL=style.css.map */