@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300..700;1,300..700&family=Libre+Baskerville:ital,wght@0,400..700;1,400..700&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap');
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
ol, ul {  list-style: none; }
blockquote, q {  quotes: none; }
blockquote:before, blockquote:after, q:before, q:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}
img {
vertical-align: bottom;
max-width: 100%;
height:auto;
}
* {
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
:root {
--white-color: #FFFFFF;
--Key-color: #4a3f35;
--sub-color: #8a7a6a;
--accent-color: #c8a063;
--accent-color: #ccac00;
--bg-color: #fdfaf6;
--btn:#ca9b53;
--btnhover:#f7e891;
--product:#ebddb9;
}
html {
font-size: 62.5%;
scroll-behavior: smooth;
}
body {
position: relative;
color: var(--Key-color);
text-align: left;
line-height: 1.6;
-webkit-text-size-adjust: 100%;
-ms-text-size-adjust: 100%;
text-size-adjust: 100%;
background: var(--white-color);
background-color:#fefdfc;
font-family: "Noto Serif JP", serif;
font-optical-sizing: auto;
font-weight: 400;
overflow-x: clip;
font-size: clamp(16px, 3vw, 1rem);
animation: fadeIn 2s ease 0s 1 normal forwards;
}
@keyframes fadeIn {
0% {opacity: 0;}
100% {opacity: 1;}
}
a {
color: var(--accent-color);
text-decoration: none;
transition: color 0.3s;
}
a:hover {
color: var(--accent-color);
transition: color .5s;
}
#wrapper{  
position: relative;
overflow-x: hidden;
width: 100%;
margin: 0 auto;
}
.mainContents{
width: min(1180px, 96%);
margin-inline: auto;
padding:clamp(40px, 5vw, 80px) 0px;
text-align: center;
}
h2{
display: flex;
flex-direction: column;
align-items: center;
color: var(--accent-color);
font-family: "Libre Baskerville", serif;
font-optical-sizing: auto;
font-weight: 400;
font-size: clamp(30px, 5vw, 42px);
line-height: 1;
margin-bottom: clamp(20px, 5vw, 40px) ;
}
.sub-title {
font-size: 0.45em;
font-family: "Noto Serif JP", serif;
font-optical-sizing: auto;
font-weight: 700;
line-height: 1.6;
color: var(--Key-color);
}
h2::after {
content: "";
display: block;
width: 100%; 
height: clamp(20px, 2.5vw + 10px, 40px);
background:url(../../images/anniversary/common/h2-sm.webp) no-repeat center center;
background-size: contain;
}
@media screen and (min-width:899px) {
h2::after {
background:url(../../images/anniversary/common/h2.webp) no-repeat center center;
background-size: contain;
}
}
h3{
font-family: "Noto Serif JP", serif;
font-optical-sizing: auto;
font-weight: 600;
font-size: clamp(22px, 3vw, 26px);
margin-bottom: 10px;
}
p {
font-size: clamp(14px, 3vw, 16px);
}
.notes{
font-size: 12px;
line-height: 1.8;
margin:.4em auto;
}
dl {
line-height: 1.8;
margin: 1vw auto;
}
dl > div {
padding-bottom: 15px;
}
dt {
color: var(--accent-color);
font-weight: 700;
font-size: clamp(16px, 3vw, 18px);
}
.sm{
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 400;
font-size: clamp(12px, 3vw, 14px);
}

/* TOP */
#top {
width: 100%;;
background: url(../../images/anniversary/top/background2.png?) repeat;
background-size: 100px auto;
}
#top .mainContents{
padding: 10px 0 clamp(40px, 5vw, 80px);
margin: 0 auto 0;
line-height: 1.6;
}
@media screen and (min-width:899px) {
#top .mainContents{
background: 
url('../../images/anniversary/background/top-right.webp') left -10px top -15px / 300px auto no-repeat,
url('../../images/anniversary/background/bottom-left.webp') right -10px bottom  / 300px auto no-repeat;
}
}
#top .mainContents .kvArea{
background: url(../../images/anniversary/top/bg.webp) no-repeat center 130px;
background-size: 95vw auto;
}
#top .mainContents .kv{
margin: 0 auto;
animation: slide-up-anim 0.8s ease-out 1 forwards;
opacity: 0;
position: relative;
display: grid;
place-items: center;
width: min(840px, 100%);
aspect-ratio: 3 / 4; 
background: url('../../images/anniversary/top/kv_bg.webp') no-repeat center / contain;
padding: 0 0 0 .7%;
box-sizing: border-box;
}
#top .mainContents .kv::after {
content: "";
position: absolute;
inset: 0;
background: url('../../images/anniversary/top/kv_parts.webp') no-repeat center / contain;
z-index: 2;
pointer-events: none; 
}
#top .mainContents .kv .main-photo {  
position: relative;
width: 100%;  
height: 88%;
object-fit: contain; 
z-index: 1;
}
@keyframes slide-up-anim {
0% { transform: translateY(-30px); }
100% {opacity: 1;transform: translateY(0); }
}
h1{
font-size: clamp(15px, 3vw, 18px);
font-weight: 500;
text-align: left;
margin: 3%;
}
.catch{
font-size: clamp(20px, 3vw, 24px);
font-weight: 600;
text-align: center;
text-align: left;
margin: 0 3%;
}
@media screen and (min-width:899px) {
#top .mainContents{
width: 100%;
padding: 0 0 40px;
line-height: 2;
}
h1{
text-align: center;
margin: .5em auto 0;
line-height: 2;
}
.catch{
text-align: center;
margin: 0 auto;
}
.catch::before {
content: "★";
display: block;
color:var(--accent-color);
font-size: clamp(22px, 3vw, 26px);
line-height: 1.6;
}
}
/* MENU */
.menu-trigger {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
position: fixed;
top: 4px;
right: 4px;
width: 60px; 
height: 80px;
background: url(../../images/anniversary/menu/menu-bg.webp) no-repeat center top;
background-size: contain;
background-color: transparent;
z-index: 200; 
cursor: pointer;
border: 0;
padding-bottom: 20px;
}
.menu-trigger .bar {
width: 23px;
height: 2px;
margin: 2px 0;
background: var(--accent-color);
background: #b8860b;
transition: all 0.3s ease;
border-radius: 2px;
display: block;
}
.menu-trigger.is-active .bar:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.menu-trigger.is-active .bar:nth-child(2) { opacity: 0; }
.menu-trigger.is-active .bar:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
.menu {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100dvh;
display: grid;
place-items: center;
background: var(--bg-color) url(../../images/anniversary/top/background.png) repeat;
background-size: 100px auto;
border-top: solid 3px var(--accent-color);
border-bottom: solid 3px var(--accent-color);
opacity: 0;
visibility: hidden;
transition: opacity 0.4s ease, visibility 0.4s;
z-index: 150;
}
.menu.is-active {
opacity: 1;
visibility: visible;
}
.nav-container {
text-align: center;
}
.nav-list {
display: flex;
justify-content: center;
align-items: center;
flex-direction: column;
gap: 2rem;
}
.nav-list li:not(:last-child)::after {
display: none;
}
.nav-list li a {
color:var(--accent-color);
font-family: "Libre Baskerville", serif;
font-optical-sizing: auto;
font-weight: 400;
letter-spacing: -0.01em;
font-size: clamp(16px, 3vw, 18px);
letter-spacing: 0.05em;
font-weight: 500;
}
.nav-list li a {
font-size: 24px;
}
.nav-list li a:hover {
color:var(--Key-color);
}

/* EVENT */
#event{
padding:clamp(40px, 5vw, 80px) 0px;
}
#event .mainContents{
margin: 0 auto;
padding: clamp(20px, 5vw, 30px) 0px;
width: min(830px, 90%);
box-sizing: border-box;
border: clamp(20px, 3vw, 40px) solid transparent;
border-image-source: url('../../images/anniversary/event/frame.webp');
border-image-slice: 100; 
border-image-width: 40px;
background-color: var(--white-color);
}
#event .mainContents dl{
margin: clamp(10px, 5vw, 15px) auto clamp(5px, 5vw, 10px);
}
#event .mainContents dd{
font-weight: 600;
line-height: 1.6em;
}
.seating-chart{
display: inline-block;
background-color: #faf6f0;
margin: clamp(5px, 5vw, 10px) auto;
padding: 1em;
text-align: center;
line-height: 1.5;
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 400;
}
.seating-chart .text{
font-size: clamp(13px, 5vw, 15px);
font-weight: 500;
margin: 0 auto .3em;
}
.seating-chart p a{
color:var(--accent-color);
}
.seating-chart p a:hover{
color:var(--Key-color);
}
.map-container {
position: relative;
width: 100%;
padding-top: 40%;
}
.map-container iframe {
position: absolute;
top: 0;
left: 0;
width: 100% !important;
height: 100% !important;
}
.my-map {
width: 100%;
height: 50vh;
border: solid 3px var(--bg-color) !important;
}

/* CAST */
#cast{
width: 100%;;
background: url(../../images/anniversary/background/bg.png) repeat;
background-size: 100px auto;
}
.castlist{
width: min(1050px, 90%);
margin: 0 auto clamp(30px, 5vw, 50px);
}
@media screen and (min-width:400px) {
.castlist{
display: grid;
grid-template-columns: repeat(2, 1fr); 
gap: 16px;
}
}
@media screen and (min-width:600px) {
.castlist{
display: grid;
grid-template-columns: repeat(3, 1fr); 
}
}
@media screen and (min-width:899px) {
.castlist{
grid-template-columns: repeat(4, 1fr); 
}
}
#cast dl {
margin: 0 auto 16px; 
}
@media screen and (min-width:899px) {
#cast dl {
margin: 0 auto; 
}
}
#cast dt {
font-size: clamp(12px, 3vw, 14px);
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 400;
line-height: 1;
}
#cast dd {
font-size: clamp(18px, 3vw, 20px);
font-weight: 600;
}

/* TICKET */
#ticket h3{
margin-bottom: 0;
}
@media screen and (min-width:580px) {
#ticket h3 br{
display: none;
}
}
.seat-types {
display: flex;
gap: 10px;
margin: clamp(15px, 5vw, 30px) auto clamp(10px, 5vw, 20px);
width: min(660px, 96%);
}
.seat-box {
flex: 1;
background-color:var(--sub-color);
color: var(--white-color);
text-align: center;
padding: 15px 5px;
line-height: 1.2;
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 500;
}
.seat-name {
font-size: clamp(16px, 5vw, 18px);
}
.seat-price { 
font-size: clamp(20px, 5vw, 26px);
line-height: 1.4;
}
.seat-price span { 
font-size: clamp(14px, 3vw, 16px);
margin-left: 4px;
display: block;
font-weight: 500;
}
@media screen and (min-width:600px) {
.seat-price span { 
display: inline;
}
}
.info-section {
width: min(660px, 96%);
margin: 30px auto 0;
text-align: left;
}
@media screen and (min-width:899px) {
.info-section {
margin: 50px auto 0;
}
}
#ticket .info-section h4 {
font-size: clamp(16px, 5vw, 20px);
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 500;
color: var(--Key-color);
border-bottom: 2px solid var(--Key-color);
padding-bottom: 4px;
margin-bottom: 10px;
}
#ticket .info-section .details {
color: var(--Key-color);
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
}
#ticket .info-section .details .url{
margin: 10px auto 5px;
font-size: clamp(14px, 3vw, 18px);
font-weight: 600;
}
#ticket .info-section .details .schedule{
margin: 10px auto;
font-size: clamp(16px, 3vw, 18px);
font-weight: 500;
}

/* GOODS */
#goods {
width: 100%;;
background: url(../../images/anniversary/background/bg.png) repeat;
background-size: 100px auto;
}
#goods .goodsContents {
margin:  0 auto;
width: min(880px, 92%);
}
@media screen and (min-width:899px) {
#goods .goodsContents {
width: 94%;
margin: min(3vw, 30px) auto 0;
}
}
#goods h3 {
text-align: left;
}
@media screen and (min-width:899px) {
#goods h3 {
text-align: center;
}
}
#goods .goodsText {
margin: 0 auto;
font-size: clamp(14px, 3vw, 16px);
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 400;
font-style: normal;
line-height: 1.6;
text-align: left;
}
@media screen and (min-width:899px) {
#goods .goodsText {
text-align: center;
}
}
.advance{
background-color:var(--bg-color);
background-color: #faf6f0;
width: min(650px, 100%);
margin: clamp(10px, 5vw, 20px) auto;
padding: 20px;
text-align: left;
line-height: 1.5;
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 400;
}
@media screen and (min-width:899px) {
.advance{
width: min(600px, 95%);
}
}
.advance .text{
font-size: clamp(16px, 5vw, 18px);
font-weight: 600;
margin: 0 auto clamp(5px, 5vw, 7px);
}
.advance p a{
color:var(--Key-color);
}
.advance .advance-title{
margin-top: .5em;
font-weight: 700;
}
.advance .online {
display: flex;
justify-content: center;
align-items: center;
margin: 1em auto 0;
display: block;
text-align: center;
}
a.btn {
font-size: clamp(16px, 3vw, 18px);
font-weight: 600;
position: relative;
display: inline-block;
padding: 1.5rem 4rem;
cursor: pointer;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
-webkit-transition: all 0.3s;
transition: all 0.3s;
text-align: center;
vertical-align: middle;
color:var(--Key-color);
border-radius: 0.5rem;
}
a.btn-radius-solid {
background: var(--accent-color);
background: -webkit-gradient(linear, left top, left bottom, from(var(--btn)), to(var(--btnhover)));
background: -webkit-linear-gradient(top, var(--btn) 0%, var(--btnhover) 100%);
background: linear-gradient(to bottom, var(--btn) 0%, var(--btnhover) 100%);
}
a.btn-radius-solid:hover {
background: -webkit-gradient(linear, left bottom, left top, from(var(--btn)), to(var(--btnhover)));
background: -webkit-linear-gradient(bottom, var(--btn) 0%, var(--btnhover) 100%);
background: linear-gradient(to top, var(--btn) 0%, var(--btnhover) 100%);
}

#goods .goodsContents .goodsList {
width: min(1280px, 96%);
margin: min(5vw, 30px) auto 0;
}
@media screen and (min-width:899px) {
#goods .goodsContents .goodsList {
width: min(1280px, 100%);
margin: min(3vw, 30px) auto 0;
}
}
#goods .goodsContents .goodsList ul li {
width: 100%;
margin: 0 auto 5%;
}
@media screen and (min-width: 480px) {
#goods .goodsContents .goodsList ul {
display: flex;
flex-wrap: wrap;
}
#goods .goodsContents .goodsList ul li {
width: calc((100% - 20px* 1) / 2);
margin: 0 20px 2% 0;
}
#goods .goodsContents .goodsList ul li:nth-of-type(2n) {
margin-right: 0;
}
}
@media screen and (min-width: 798px) {
#goods .goodsContents .goodsList ul li {
width: calc((100% - 20px* 2) / 3);
margin-right: 20px;
}
#goods .goodsContents .goodsList ul li:nth-of-type(2n) {
margin-right: 20px;
}
#goods .goodsContents .goodsList ul li:nth-of-type(3n) {
margin-right: 0;
}
}
#goods .goodsContents .goodsList ul li .productImg{
border: solid 1px var(--product);
background-color:var(--white-color);
padding: 1em;
}
@media screen and (min-width: 481px) {
#goods .goodsContents .goodsList ul li:nth-of-type(4) .productImg{
padding-top: 2em;
padding-bottom: 2em;
}
}
@media screen and (min-width: 798px) {
#goods .goodsContents .goodsList ul li:nth-of-type(4) .productImg{
padding-top: 1em;
padding-bottom: 1em;
}
}
#goods .goodsContents .goodsList ul li .goods__contents {
margin: min(1vw, 10px) auto;
text-align: center;
}
@media screen and (min-width: 899px) {
#goods .goodsContents .goodsList ul li .goods__contents {
text-align: left;
}
}
#goods .goodsContents .goodsList ul li .goods__contents .product {
font-size: clamp(17px, 3vw, 18px);
line-height: 1.5;
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 500;
}
#goods .goodsContents .goodsList ul li .goods__contents .price{
color: var(--accent-color);
font-size: clamp(14px, 3vw, 16px);
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 400;
}
@media screen and (min-width: 899px) {
#goods .goodsContents .goodsList ul li .goods__contents {
font-size: 1.55rem;
}
}
.product-card {
background-color:#e9e4dd;
padding: 20px;
}
@media screen and (min-width: 899px) {
.product-card {
display: flex;
align-items: flex-start;
gap: 20px;
}
}
.product-image {
background-color:var(--white-color);
width: 100%;
max-width: 400px;
margin: 0 auto;
margin: 0;
flex: 1; 
min-width: 0;
position: relative;
padding: 1em ; 
box-sizing: border-box;
overflow: hidden; 
}
@media screen and (min-width: 899px) {
.product-image {
padding: 25px 3em; 
}
}
.product-image img {
width: 100%;
height: auto;
display: block;
} 
.product-info {
width: 300px;
text-align: left;
margin-top: 1em;
}
@media (max-width: 600px) {
.product-card {
flex-direction: column;
}
.product-info {
width: 100%;
margin:0 auto;
}
}
.product-info .productname {
font-size: clamp(16px, 3vw, 18px);
line-height: 1.5;
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 400;
}
#goods .goodsContents .product-info .price{
color: var(--accent-color);
font-size: clamp(16px, 3vw, 18px);
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 400;
}
@media screen and (min-width: 899px) {
#goods .goodsContents .product-info .price{
margin-top: 1.2em;
}
}
#goods .PurchaseBonus{
margin: clamp(30px, 5vw, 50px) auto 0;
text-align: left;
}
#goods .PurchaseBonus .PurchaseBonus-title {
font-size: clamp(18px, 5vw, 22px);
background-color: var(--sub-color);
color: var(--white-color);
font-weight: 600;
line-height: 2;
text-align: center;
margin-bottom: 10px ;
}
#goods .PurchaseBonus .PurchaseBonusBox{
margin: clamp(10px, 3vw, 40px)  auto 1em;
}
@media screen and (min-width:899px) {
#goods .PurchaseBonus .PurchaseBonusBox{
display: grid;
grid-template-columns: 1fr 60%; 
/* gap: 20px; */
direction: rtl;
}
#goods .PurchaseBonus .PurchaseBonusBox > * {
direction: ltr; 
}
}
#goods .PurchaseBonus .PurchaseBonusBox .purchaseBonus__text {
margin: 0 auto clamp(10px, 5vw, 20px) 1em;
font-size: clamp(14px, 3vw, 16px);
font-family: "Noto Sans JP", sans-serif;
font-optical-sizing: auto;
font-weight: 500;
font-style: normal;
line-height: 1.6;
color: var(--sub-color);
}

/* ATTENTION */
#attention .mainContents{
font-size: clamp(14px, 3vw, 16px);
text-align: left;
padding-bottom: 40px;
line-height: 1.6;
}
.attentionContents{
margin: 0 auto ;
width: 94%;
}
#attention dl  {
margin: 2em auto 0;
}

#attention dl dd ul li {
  list-style-type: none; /* デフォルトの丸を消す */
  position: relative;
  padding-left: 1em;     /* 記号の分の余白 */
  margin-left: 5px;
}

#attention dl dd ul li::before {
  content: "・";         /* 好きな記号を入れる */
  position: absolute;
  left: 0;
  font-size: 0.8em;      /* ここで大きさを微調整 */
  font-weight: bold;     /* 必要なら太くする */
}

#attention dl dd strong {
color: var(--accent-color);
font-weight: 700; 
font-size: clamp(16px, 3vw, 18px);
}
#attention dl dd .identity{
background-color:var(--bg-color);
margin: 15px auto 0;
padding:20px 25px;
line-height: 1.6;
}
#attention dl dd .identity-title{
border-bottom: solid 1px var(--sub-color);
padding-bottom: 4px;
margin: .5em auto ;
font-weight: 600; 
}
#attention dl dd ol{
margin: .5em auto 1em;
}

/* INFO */
#info .mainContents{
padding: 0 ;
font-weight: 600; 
font-size: clamp(16px, 3vw, 18px);
}
#info .title {
position: relative;
padding: 0 55px;
text-align: center;
color: var(--accent-color);
font-size: clamp(18px, 3vw, 20px);
font-weight: 600;
margin: 0 auto 1em;
}
#info .title:before {
position: absolute;
top: calc(50% - 1px);
left: 0;
width: 100%;
height: 1px;
content: '';
background:var(--accent-color);
}
#info .title span {
position: relative;
padding: 0 1em;
background:var(--white-color);
}

/* FOOTER */
.offical{
margin: 30px auto 20px;
margin-bottom: 20px;
}
.offical img{
/* min-width:90%;*/
width:210px; 
height:auto;
}
#footer {
margin: 0 auto;
text-align: center;
}
@media screen and (min-width:899px) {
#footer {
padding: 30px 0 0;
}
}
#footer .copy{
font-size: clamp(10px, 3vw, 12px);
font-family: "Noto Serif JP", serif;
font-optical-sizing: auto;
font-weight: 600;
}
.back-to-top {
display: none;
position: fixed;
right: .5%;
bottom: .5%;
display: inline-block;
text-decoration: none;
}
.back-to-top img {
width: 70px;
height: auto;
}
[data-aos="fade-up"] { transform: translate3d(0, 60px, 0) !important;}
[data-aos="fade-down"] { transform: translate3d(0, -60px, 0) !important;}
.aos-animate {transform: translate3d(0, 0, 0) !important;}

figure { margin: 0 0 0 !important;}

@media screen and (max-width: 897px) {
.seating-chart{
overflow-wrap: break-word;
word-break: break-all; 
text-align: left;
}
}
@media screen and (min-width:500px) {
.hall br{
display:none;
}
}