#main .main-contents{
	padding:0;
}

#main .main-content{
	margin:30px 0 30px 0;
}

	#main article{
		margin: 0 auto;
		margin-bottom: 30px;
	}
	
	#main article img{
		width:100%;
	}

	#main article span{
		display:block;
		background: rgba(255,0,0,0.5);
		padding:10px;
		border-bottom:solid 1px #BEB141;
	}



  /*
  10th
  */
  
img.tenthImg {
  max-width: 100%;
  height: auto;
  display: block;
}

img.tenthSpImg{
  width: 90%;
}


article { padding: 0 10px; }
p { margin-bottom: 5px; }

br.spBr { display: none; }
br.pcBr { display: block; }

.tenthCon { padding: 0 20px; }
.tenthSTtl{ font-size: 140%; line-height: 2; letter-spacing: 0.05em;}
.tenthSTtl2{ font-size: 140%; line-height: 1.5; letter-spacing: 0.05em; text-align: center; padding-top: 20px; border-top: 1px solid #fff;}

.tenthBox h3 { font-size: 24px; line-height: 1.2; letter-spacing: 0.05em; }
.tenthBox h3 span { margin-left: -0.5em; }
.spec1 { font-size: 12px; line-height: 1.5; }
.spec2 { font-size: 14px; line-height: 1.6; }
.spec2 span { font-size: 85%; }
.spec3 { font-size: 14px; line-height: 1.8; }
.spec3 span { font-size: 14px; }
.specLine { font-size: 18px; padding-bottom: 5px; border-bottom: 1px solid #fff; }

.tenthTxtL{ font-size: 120%;}
.tenthTxtM{ font-size: 110%;}
.tenthTxtS{ font-size: 90%;}
.tenthTxtSS{ font-size: 70%;}

.tenthBox2 .tenthplace {
	padding: 15px;
	background: rgba(190,177,65,0.3);
	line-height: 1.8;
}
.tenthBox2 dl {
	padding: 15px;
	background: rgba(190,177,65,0.3);
	line-height: 1.8;
}
.tenthBox2 dt { float: left; }
.tenthBox2 dd { margin-left: 5em; }
.tenthBox2 dd a{
	text-decoration: underline;
	color:#fff;
	transition: 0.1s linear;
	}  

.tenthBox2 .tenthMidashi {
  padding: 5px;
  border: solid 1px #888;
}

.tenthBox a{
	text-decoration: underline;
	color:#fff;
  overflow-wrap: anywhere;
  word-break: break-word;
	transition: 0.1s linear;
	}
.tenthBox a:hover{ color:#ff0000; }

.tenthBox2 a{
	text-decoration: underline;
	color:#fff;
  overflow-wrap: anywhere;
  word-break: break-word;
	transition: 0.1s linear;
	}
.tenthBox2 a:hover{ color:#ff0000; }


 /*
 * menu
 */
 
.toTop {
  display: block;
  width: 100%;
  padding: 1rem 0 2rem 0;
  text-align: right;
  font-size: 1rem;
}

.tenth-menuBg {
  padding-top: 20px;
  margin-bottom: 20px;
  border-top: 1px dotted #ddd;
}

ul.menu{
	width: 100%;
	max-width: 880px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	gap: 2px;
	box-sizing: border-box;
	background: rgba(255,255,255,0.15);
	padding: 10px;

}

ul.menu li{
	width: calc(50% - 1px);
	text-align: center;
	font-size: 14px;
	line-height: 1.5;
	background: #1b1c1c;
	list-style: none;
	box-sizing: border-box;
	padding: 0;
	margin: 0;
}

ul.menu li a{
	display: block;
	padding: 1.5em 0.5em;
	background: #000;
	color: #fff;
	text-decoration: none;
	transition: 0.1s linear;
	-webkit-transition: 0.1s linear;
	box-sizing: border-box;
}

ul.menu li a:hover{
	background: #A00625;
	color: #fff;
}

ul.menu li.active a{
	color: #fff;
	background: #A00625;
	pointer-events: none;
}



ul.menu li{
	font-size: 12px;
}




/* アコーディオン */
.accordion { width: 100%; text-align: left; font-size: 1rem; }
.accordion2 { color: #131313; text-align: left; }


.accordion h4 span { font-size: 90%; }
.accordion p { line-height: 1.8; }
.accordion .txtRight { text-align: right; }
.accordion .txtCenter { text-align: center; }

.accordion a { text-decoration: none; display: block; }


.accordion h4{
  margin: 0; /* ←念のため */
  padding: 0; 
}

.accordion h4 a{
  display: block;
  padding: 20px 10px;              /* ←元のpaddingをここに移動 */
  background: #a00625;        /* ←背景もaに移す */
  text-align: center;
  font-size: 100%;
  line-height: 1.5;
  color: #fff;                /* ←文字色必要なら */
}

.accordion h4 a:hover{
	background: #c4b540;
	color: #c52c32;
}


/* 画像だけアコーディオン（追加） */
.accordion--imageOnly .accordion2{
	padding: 0;
}

.accordionImage{
	text-align: center;
}

.accordionImage a{
	display: block;
}

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


/* 10thグッズ */
.productCard{
  display: grid;
  grid-template-columns: minmax(220px, 40%) 1fr;
  gap: 12px;
  align-items: start;

  padding: 10px;
  background: rgba(255,255,255,0.7);
}

.productCard__image img{
  display: block;
  width: 100%;
  height: auto;
	transition: opacity 0.3s ease;
}

/* グッズモーダル */
.productCard__image a{
	display: block;
	cursor: pointer;
	border: 1px solid #c4062c;
	transition: opacity 0.3s ease;
}

.productCard__image a:hover img {
	opacity: 0.6;
}


.productCard__content{
  min-width: 0;
}

.productCard__title{
  margin: 0 0 15px;
  padding: 16px 20px;
  font-size: 100%;
  line-height: 1.4;
  font-weight: 500;
  text-align: center;
  background: rgba(255,255,255,0.5);
}

.productCard__title span {
	font-size: 80%;
}

.productCard__desc{
  margin: 0 0 15px;
  font-size: 100%;
  line-height: 1.9;
}

.productCard__desc a{
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.productCard__note{
  display: inline-block;
  margin-top: 12px;
  font-size: 90%;
}

.productCard__spec{
  display: grid;
  grid-template-columns: 4em 1fr;
  gap: 2px;
}

dl.productCard__spec{
	background: rgba(255,255,255,0.1);
  padding: 6px 10px 10px; /* 上だけ小さく */
}

.productCard__spec dt,
.productCard__spec dd{
  margin: 0;
  font-size: 90%;
  line-height: 1.2;
}

.productCard__spec dt{
  font-weight: 700;
}

@media (max-width: 900px){
  .productCard{
    grid-template-columns: 1fr;
  }

  .productCard__title{
    margin-bottom: 20px;
    text-align: left;
  }
}

@media (max-width: 767px){
  .productCard{
    gap: 20px;
    padding: 16px;
  }

  .productCard__title{
    padding: 12px 14px;
  }

  .productCard__spec{
    grid-template-columns: 1fr;
    gap: 4px 0;
  }

  .productCard__spec dt{
    margin-top: 10px;
  }
}




/* ========================================
   10th お祝いコメント
======================================== */
#comment{
	padding: 0 10px;
	margin: 20px 0 0;
}

.commentWrap{
	padding: 20px 0 10px;
	border-top: 1px solid #fff;
}

.commentTtl{
	margin: 0 0 18px;
	font-size: 140%;
	line-height: 1.5;
	letter-spacing: 0.05em;
	text-align: center;
}

.commentBtnList{
	margin: 0;
	padding: 0;
	list-style: none;
	text-align: center;
	background: rgba(255,255,255,0.15);
	padding: 20px 10px 15px 10px;
	margin-bottom: 10px;
}

.commentBtnList li{
	display: inline-block;
	width: calc(80% - 6px);
	margin: 0 3px 8px;
	vertical-align: top;
}

.commentBtn{
	display: block;
	width: 100%;
	padding: 12px 34px 12px 10px;
	background: #000;
	color: #fff;
	text-decoration: none;
	text-align: center;
	line-height: 1.5;
	font-size: 12px;
	position: relative;
	box-sizing: border-box;
	transition: background 0.2s linear, color 0.2s linear;
}

.commentBtn:hover{
	background: #a00625;
	color: #fff;
}

.commentBtn:before,
.commentBtn:after{
	content: "";
	position: absolute;
	box-sizing: border-box;
	width: 10px;
	height: 10px;
	border: 1px solid #fff;
	background: #000;
}

.commentBtn:before{
	right: 16px;
	top: 50%;
	margin-top: -4px;
}

.commentBtn:after{
	right: 12px;
	top: 50%;
	margin-top: -8px;
}

.commentBtn:hover:before,
.commentBtn:hover:after{
	background: #a00625;
	border-color: #fff;
}


/* モーダル */
.commentInlineModal{
	width: 100%;
	background: rgba(255,255,255,0.94);
	color: #131313;
	box-sizing: border-box;
}

.commentInlineModal__head{
	padding: 12px 16px 14px;
	text-align: center;
	border-bottom: 1px solid #8e8e8e;
}

.commentInlineModal__role{
	margin: 0 0 6px;
	font-size: 12px;
	line-height: 1.4;
	color: #333;
}

.commentInlineModal__name{
	margin: 0;
	font-size: 20px;
	line-height: 1.4;
	font-weight: bold;
	color: #131313;
	letter-spacing: 0.1rem;
}

.commentInlineModal__name span {
	font-size: 14px;
	font-weight: 400;
}

.commentInlineModal__body{
	padding: 16px 16px 20px;
	max-height: 70vh;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

.commentInlineModal__text{
	font-size: 0.9rem;
	line-height: 1.9;
	color: #131313;
	word-break: break-word;
}

.commentInlineModal__text img{
  display: block;
  max-width: 100%;
  height: auto;
}



/* ========================================
   10th お祝いコメント ボタン最終上書き（SP）
======================================== */
.comment-inline.commentBtn,
.commentBtn{
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 60px;
	padding: 0 14px;
	background: #000;
	color: #fff;
	text-decoration: none;
	box-sizing: border-box;
	overflow: hidden;
	transition: background 0.2s linear, color 0.2s linear;
}

/* 旧アイコンを完全に無効化 */
.comment-inline.commentBtn::before,
.comment-inline.commentBtn::after,
.commentBtn::before,
.commentBtn::after{
	content: none !important;
	display: none !important;
}

/* 文字＋アイコンを1セットで中央 */
.comment-inline.commentBtn > span,
.commentBtn > span{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	white-space: normal;
	line-height: 1.3;
	font-size: 14px;
	text-align: center;
}

/* アイコン */
.comment-inline.commentBtn > span::after,
.commentBtn > span::after{
	content: "";
	display: block;
	flex: 0 0 11px;
	width: 11px;
	height: 11px;
	margin-left: 0.3em;
	box-sizing: border-box;
	border: 1px solid #fff;
	background: #000;
	position: relative;
	left: 4px;
	top: -2px;

	box-shadow:
		-4px 4px 0 -1px #000,
		-4px 4px 0 0 #fff;

	transition:
		background 0.2s linear,
		box-shadow 0.2s linear,
		border-color 0.2s linear;
}

.comment-inline.commentBtn:hover,
.commentBtn:hover{
	background: #a00625;
	color: #fff;
}

.comment-inline.commentBtn:hover > span::after,
.commentBtn:hover > span::after{
	background: #a00625;
	box-shadow:
		-4px 4px 0 -1px #a00625,
		-4px 4px 0 0 #fff;
}




