html {
	background: url(../../common/imgs/bg1.jpg)  no-repeat top center;
	background-size:cover;
	background-attachment: fixed;
}

body::before{
	content:"";
	position:fixed;
	inset:0;
	background:url(../../common/imgs/bg2.png) repeat;
	pointer-events:none;
	z-index:-1;
}

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

	#main article{
		width:640px;
		margin: 0 auto;
		margin-bottom: 20px;
	}

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



/*
  10th Anniversary
*/

#main-wrap{
  float:left;
  width:880px;
  height:100%;
  background: url(../../common/imgs/title_bg.png) no-repeat;
}
  
img.tenthImg {
  max-width: 100%;
  height: auto;
  display: block;
}

article {
	width: 880px;
	margin: 30px auto 0 auto;
	border-top:solid 2px #c4062c;
}

article .tenthBox {
	width: 880px;
	border-top:solid 1px #beb141;
}

article .tenthBox2 {
	width: 880px;
	border-top:solid 1px #beb141;
  padding-top: 20px;
}

.tenthBox2 .tenthplace {
	padding: 15px;
	background: rgba(0,0,0,0.4);
	line-height: 1.8;
}


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

.tenthBox2 dl {
	padding: 15px;
	background: rgba(0,0,0,0.4);
	line-height: 1.8;
}
.tenthBox2 dt { float: left; }

.tenthBox2 dd { margin-left: 5em; }
.tenthBox2 dd.tenthIG { margin-left: 13em; }

.tenthBox2 dd a{
	text-decoration: underline;
	color:#fff;
	transition: 0.1s linear;
	}
.tenthBox2 dd a:hover{ color:#ff0000; }

.tenthCon { padding: 0 20px; }
.tenthSTtl{ font-size: 24.4px; line-height: 2; letter-spacing: 0.05em;}
.tenthSTtl2{ font-size: 24px; line-height: 1.5; letter-spacing: 0.05em; text-align: center; }

.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: 16px; line-height: 1.8; }
.spec3 span { font-size: 14px; }
.specLine { font-size: 18px; padding-bottom: 5px; border-bottom: 1px solid #fff; }

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

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

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

.rightBox a{
	text-decoration: underline;
	color:#fff;
	transition: 0.1s linear;
	}
.rightBox a:hover{ color:#ff0000; }


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

.accordion p { line-height: 1.8; }
.accordion .txtRight { text-align: right; }
.accordion .txtCenter { text-align: center; }

.accordion h4 a{
  display: block;

	padding: 20px 10px;              /* ←元のpaddingをここに移動 */
  background: #a00625;        /* ←背景もaに移す */
  text-align: center;
  font-size: clamp(12px, 2.2vw, 18px);
  line-height: 1.5;
  color: #fff;
	text-decoration: none;
}

.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: clamp(12px, 4vw, 24px);
  align-items: start;

  padding: clamp(10px, 3vw, 20px);
  background: rgba(255,255,255,0.5);
	font-size: 1rem;
}

.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: clamp(12px, 2.2vw, 18px);
  line-height: 1.4;
  font-weight: 500;
  text-align: center;
  background: rgba(255,255,255,0.2);
}

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

.productCard__desc{
  margin: 0 0 15px;
  font-size: 110%;
  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: 8px 0px;
  margin: 0;
  padding-top: 24px;
}

dl.productCard__spec{
	padding: 0;
	padding-top: 15px;
	border-top: 1px solid #131313;
	background: rgba(0,0,0,0);
}

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

.productCard__spec dt{
  font-weight: 700;
}



/*
 * menu
 */
br.spBr { display: block; }
br.pcBr { display: none; }

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

.tenth-menuBg {
  padding-top: 30px;
  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;
	padding: 0;
}

ul.menu li{
	width: calc((100% - 4px) / 3);
	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;
}

.topBtn {
  pointer-events: auto;
  cursor: pointer;
}


footer {
	margin: 30px 0 0 0;
}


/* ========================================
   10th お祝いコメント
======================================== */
#comment{
	width: 100%;
	max-width: 1920px;
	margin: 30px auto 0;
	border-top: solid 2px #c4062c;
}

.commentWrap{
	border-top: solid 1px #beb141;
	padding: 24px 40px 10px;
}

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

.commentBtnList{
	max-width: 1620px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 18px 18px;
	align-items: stretch;
}

/* 共通 */
.commentBtnList li{
	margin: 0;
	list-style: none;
}

/* 1段目：中央1個 */
.commentBtnList li:nth-child(1){
	grid-column: 3 / 5;
}

/* 2段目：3個 */
.commentBtnList li:nth-child(2){
	grid-column: 1 / 3;
}
.commentBtnList li:nth-child(3){
	grid-column: 3 / 5;
}
.commentBtnList li:nth-child(4){
	grid-column: 5 / 7;
}

/* 3段目：中央2個 */
.commentBtnList li:nth-child(5){
	grid-column: 2 / 4;
}
.commentBtnList li:nth-child(6){
	grid-column: 4 / 6;
}










.commentBtn{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 72px;
	padding: 0 24px;
	background: #000;
	color: #fff;
	text-decoration: none;
	font-size: 18px;
	line-height: 1;
	box-sizing: border-box;
	transition: background 0.2s linear, color 0.2s linear;
	overflow: hidden;
}

/* 以前の擬似要素を無効化 */
.commentBtn:before,
.commentBtn:after{
	content: none !important;
}

/* 文字＋アイコンを1セット化 */
.commentBtn > span{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55em;
	white-space: nowrap;
	line-height: 1;
}

/* アイコン */
.commentBtn > span:after{
	content: "";
	display: block;
	width: 18px;
	height: 18px;
	flex: 0 0 18px;
	box-sizing: border-box;
	border: 2px solid #fff;
	background: #000;
	position: relative;
	top: 1px;
	box-shadow:
		6px -6px 0 -2px #000,
		6px -6px 0 0 #fff;
	transition:
		background 0.2s linear,
		box-shadow 0.2s linear,
		border-color 0.2s linear;
}

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

.commentBtn:hover > span:after{
	background: #a00625;
	box-shadow:
		6px -6px 0 -2px #a00625,
		6px -6px 0 0 #fff;
}




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

.commentInlineModal__head{
	padding: 10px 30px 20px;
	text-align: center;
	border-bottom: 1px solid #8e8e8e;
}

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

.commentInlineModal__name{
	margin: 0;
	font-size: 26px;
	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: 28px 34px 30px;
	max-height: 65vh;
	overflow-y: auto;
}

.commentInlineModal__text{
	font-size: 16px;
	line-height: 2;
	color: #131313;
	word-break: break-word;
}

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

.comment-inline{
	display: inline-block;
}




/* 三輪士郎だけモーダル全体を広げる */
#comment-miwa{
	width: 1300px;
}

#comment-miwa .commentInlineModal__text img{
	display: block;
	width: 100%;
	height: auto;
}






/* ========================================
   10th お祝いコメント ボタン最終上書き
======================================== */
.comment-inline.commentBtn,
.commentBtn{
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 72px;
	padding: 0 24px;
	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: nowrap;
	line-height: 1;
	font-size: 16px;
}

/* アイコン */
.comment-inline.commentBtn > span::after,
.commentBtn > span::after{
	content: "";
	display: block;
	flex: 0 0 14px;
	width: 14px;
	height: 14px;
	margin-left: 0.35em;
	box-sizing: border-box;
	border: 1px solid #fff;
	background: #000;
	position: relative;
	left: 6px;   /* ← 右に戻す */
	top: -3px;   /* ← 少し上に戻す */

	box-shadow:
		-5px 5px 0 -1px #000,
		-5px 5px 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:
		-5px 5px 0 -1px #a00625,
		-5px 5px 0 0 #fff;
}



/* ========================================
   10th お祝いコメント ボタン最終上書き（SP流用-調整）
======================================== */
.comment-inline.commentBtn,
.commentBtn{
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 70px;
	padding: 0 20px;
	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;
}




