@charset "UTF-8";
@font-face {
  font-family: "Raiden-Italic";
  src:
    url("../../images/fan/fan_new/Raiden-Italic.otf") format("italic"),
    url("../../images/fan/fan_new/Raiden-Regular.otf") format("regular");
}
a{
	transition: all 0.2s ease-out;
}
a:hover{
	opacity: 0.6;
}
body.lower.fan_new main{
	padding: 0;
}

/* 追加特典テキスト */
.fan_new .fan_new_cnt .additional-benefits-text {
	text-align: center;
	font-size: 36px;
	font-weight: 700;
	color: #fff;
	
	margin: 40px 0;
}

.fan_new .fan_new_cnt .additional-benefits-text .pc-text {
	display: inline;
}

.fan_new .fan_new_cnt .additional-benefits-text .sp-text {
	display: none;
}

@media screen and (max-width: 767px) {
	.fan_new .fan_new_cnt .additional-benefits-text {
		font-size: 24px;
		margin: 30px 0;
	}
	
	.fan_new .fan_new_cnt .additional-benefits-text .pc-text {
		display: none;
	}
	
	.fan_new .fan_new_cnt .additional-benefits-text .sp-text {
		display: inline;
		line-height: 1.5;
	}
}

.fan_new .fan_new_cnt .btn-fanclub a{
	width: 700px;
	max-width: 700px;
	height: 88px;
	margin: 0 auto;
	display: block;
	background: url("../../images/fan/fan_new/btn_bg.png");
	background-position: center;
	background-size: contain;
	border-radius: 10px;
	border:solid 2px #fff;
	padding: 0;
	position: relative;
}

@media screen and (max-width: 767px) {
	.fan_new .fan_new_cnt .btn-fanclub {
		width: 100%;
		max-width: 100%;
	}
	.fan_new .fan_new_cnt .btn-fanclub a{
		width: 100%;
		max-width: 100%;
		height: 66px;
	}
}
.fan_new .fan_new_cnt .btn a.nolink{
	cursor: none;
	opacity: 1;
}
.fan_new .fan_new_cnt .btn a.nolink > div{
	display: flex;
	justify-content: center;
	align-items: baseline;
}
.fan_new .fan_new_cnt .btn a.nolink > div.sp{
	display: none;
}
.fan_new .fan_new_cnt .btn a.nolink{
	background: none;
	background: red;
	border:solid 2px #fff;
	padding: 25px 0px;
}
.fan_new .fan_new_cnt .btn a.nolink p:first-child{
	font-size: 2rem;
	margin-right: 10px;
}
.fan_new .fan_new_cnt .btn a.nolink p:nth-child(2){
	font-size: 2.8rem;
	margin-right: 10px;
}
.fan_new .fan_new_cnt .btn a.nolink p:nth-child(2) span{
	font-size: 3.6rem;
}
.fan_new .fan_new_cnt .btn a.nolink p:last-child{
	font-size: 3rem;
}
.fan_new .fan_new_cnt .btn a.nolink p::before{
	display: none;
}
.fan_new .fan_new_cnt .btn a.nolink:hover{
	opacity: 1;
}
.fan_new .fan_new_cnt .btn-fanclub p{
	font-size: 2.6rem;
	line-height: 88px;
	text-align: center;
	color: white;
	font-weight: bold;
	margin: 0;
	height: 88px;
}
.fan_new .fan_new_cnt .btn-fanclub a::before{
	content: "";
	width: 32px;
	height: 32px;
	background-image: url("../../images/fan/fan_new/btn_icon.svg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	position: absolute;
	left: 30px;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
}

@media screen and (max-width: 767px) {
	.fan_new .fan_new_cnt .btn-fanclub p{
		font-size: 1.6rem;
		line-height: 17px;
		height: 66px;
	}
	.fan_new .fan_new_cnt .btn-fanclub a::before{
		width: 20px;
		height: 20px;
		left: 15px;
		background-image: url("../../images/fan/fan_new/btn_icon.svg");
		background-repeat: no-repeat;
		background-position: center;
		background-size: contain;
	}
}

.fan_new .fan_new_cnt .main_vi{
	background: url("../../images/fan/fan_2025/main_bg.png");
	background-size: cover;
	background-position: center bottom;
	height: 640px;
}
.fan_new .fan_new_cnt .main_vi .vi_info{
	text-align: right;
}
.fan_new .fan_new_cnt .content1{
	background: url("../../images/fan/fan_new/cnt1_bg.png");
	background-size: cover;
	background-position: center bottom;
	padding: 40px 0px 80px;
}
.fan_new .fan_new_cnt .content1 .fan_cnt{
	max-width: 900px;
	margin: 0 auto;
	text-align: center;
}
.fan_new .fan_new_cnt .content1 .fan_cnt > img{
	max-width: 607px;
	width: 100%;
	margin: 62px auto 15px;
	text-align: center;
}
.fan_new .fan_new_cnt .content1 .fan_cnt .list{
	text-align: left;
	position: relative;
}
.fan_new .fan_new_cnt .content1 .fan_cnt .list::after{
	content: "";
	background: url("../../images/fan/fan_new/img.png");
	background-size: 100%;
    width: 192px;
    height: 264px;
    position: absolute;
    bottom: -20px;
    right: -100px;
}
.fan_new .fan_new_cnt .content1 .fan_cnt .list dl{
	background: #fff;
	padding: 21px 22px;
	border-radius: 10px;
	margin-bottom: 8px;
	display: flex;
	align-items: center;
}
.fan_new .fan_new_cnt .content1 .fan_cnt .list dl dd{
	color: #111111;
	font-size: 2.2rem;
	line-height: 1;
	font-weight: bold;
	margin-left: 18px;
	margin-top: 10px;
}
.fan_new .fan_new_cnt .content1 .fan_cnt .list dl dd a{
	position: relative;
	color: #111111;
}
.fan_new .fan_new_cnt .content1 .fan_cnt .list dl dd a::after{
	content: "";
	width: 22px;
	height: 22px;
	background: url("../../images/fan/fan_new/btn_icon2.svg");
	position: absolute;
	top: -2px;
    right: -40px;
}

/* PC版content1完璧実装 */
/* 特典カードセクション */
.fan_new .fan_new_cnt .content1 .reward_cards_section {
    padding: 60px 40px !important;
}

.fan_new .fan_new_cnt .content1 .reward_cards_container {
    display: flex !important;
    gap: 20px !important;
    justify-content: center !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
}

.fan_new .fan_new_cnt .content1 .reward_card {
    background: white !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1) !important;
    width: calc(25% - 15px) !important;
    min-width: 260px !important;
    text-align: center !important;
    aspect-ratio: 293.25/436.25 !important;
    display: flex !important;
    flex-direction: column !important;
}

.fan_new .fan_new_cnt .content1 .reward_header {
    margin: 15px 24px 0 !important;
    padding: 0 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

.fan_new .fan_new_cnt .content1 .reward_header img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
}

.fan_new .fan_new_cnt .content1 .reward_image {
    padding: 10px 24px 0 !important;
    display: flex !important;
    align-items: flex-start !important;
}

.fan_new .fan_new_cnt .content1 .reward_image img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1/1 !important;
    object-fit: cover !important;
    border-radius: 0 !important;
}

.fan_new .fan_new_cnt .content1 .reward_content {
    padding: 12px 24px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    flex: 1 !important;
}

.fan_new .fan_new_cnt .content1 .reward_content h3 {
    font-family: 'Noto Sans JP', sans-serif !important;
    font-size: 24px !important;
    font-weight: bold !important;
    color: #005C30 !important;
    margin-bottom: 5px !important;
    line-height: 1.2 !important;
}

.fan_new .fan_new_cnt .content1 .reward_note {
    font-family: 'Noto Sans JP', sans-serif !important;
    font-size: 10px !important;
    font-weight: normal !important;
    color: #005C30 !important;
    line-height: 1.3 !important;
    margin-top: 5px !important;
}

/* チェックリストセクション */
.fan_new .fan_new_cnt .content1 .fanclub_checklist_section {
    position: relative !important;
    padding: 0 40px 60px !important;
}

.fan_new .fan_new_cnt .content1 .checklist_message {
    text-align: center !important;
    margin-bottom: 40px !important;
}

.fan_new .fan_new_cnt .content1 .checklist_subtitle {
    display: none !important;
}

.fan_new .fan_new_cnt .content1 .checklist_title {
    display: none !important;
}

.fan_new .fan_new_cnt .content1 .checklist_content {
    display: flex !important;
    margin: 0 auto !important;
    position: relative !important;
}

.fan_new .fan_new_cnt .content1 .checklist_items {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    max-width: 980px !important;
    margin: 0 auto !important;
    position: relative !important;
    z-index: 1 !important;
}

.fan_new .fan_new_cnt .content1 .checklist_item {
    background: white !important;
    border-radius: 10px !important;
    padding: 24px 26px !important;
    display: flex !important;
    align-items: center !important;
    position: relative !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1) !important;
}

.fan_new .fan_new_cnt .content1 .checklist_icon {
    margin-right: 20px !important;
    flex-shrink: 0 !important;
}

.fan_new .fan_new_cnt .content1 .checklist_icon img {
    width: 28px !important;
    height: 28px !important;
}

.fan_new .fan_new_cnt .content1 .checklist_item p {
    color: #111 !important;
    font-size: 2rem !important;
    font-weight: bold !important;
    line-height: 1.4 !important;
    margin: 0 !important;
}

.fan_new .fan_new_cnt .content1 .checklist_item .inline_icon {
    width: 24px !important;
    height: 24px !important;
    vertical-align: middle !important;
    margin-left: 8px !important;
}

.fan_new .fan_new_cnt .content1 .mascot_character {
    position: absolute !important;
    right: 20px !important;
    bottom: 0 !important;
    z-index: 2 !important;
}

.fan_new .fan_new_cnt .content1 .mascot_character img {
    width: 180px !important;
    height: auto !important;
    max-width: 100% !important;
}

/* 料金カードセクション */
.fan_new .fan_new_cnt .price_cards_section {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding: 80px 20px;
	gap: 40px;
	background: #FFFFFF;
	flex: none;
	order: 3;
	align-self: stretch;
	flex-grow: 0;
	overflow-x: hidden;
}

/* ボタンコンテナの幅を確保 */
.fan_new .fan_new_cnt .btn-fanclub {
	width: 100%;
	max-width: 700px;
	margin: 0 auto 20px;
}

.fan_new .fan_new_cnt .price_cards_container {
	/* オートレイアウト */
	display: flex;
	flex-direction: row;
	align-items: flex-start;
	padding: 0px;
	gap: 20px;

	width: 100%;
	max-width: 1233px;
	height: 274px;


	/* オートレイアウト内部 */
	flex: none;
	order: 0;
	flex-grow: 0;

}

/* 箱の中共通のスタイル */
.fan_new .fan_new_cnt .price_card {
    
    text-align: center;
    overflow: hidden;

	/* オートレイアウト */
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;

	width: 397.67px;
	height: 274px;
	min-height: 274px; 
	border: 4px solid;
	/* オートレイアウト内部 */
	flex: none;
	order: 0;
	align-self: stretch;
	flex-grow: 1;
}
/* 枠 */
.fan_new .fan_new_cnt .price_card.gold_card {
    border-color: #B79831;
}
/* 枠 */
.fan_new .fan_new_cnt .price_card.regular_card {
    border-color: #005C30;
}
/* 枠 */
.fan_new .fan_new_cnt .price_card.junior_card {
    border-color: #A9C31A;
}
/* グレードもじ */
.fan_new .fan_new_cnt .price_header {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 24px;
	line-height: 120%;
	/* ボックスの高さと同一、または29px */
	display: flex;
	align-items: center;
	text-align: center;
	color: #FFFFFF;
	padding: 16px 0px;
	gap: 10px;
}

.fan_new .fan_new_cnt .price_card.gold_card .price_header {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	gap: 10px;

	width: 397.67px;
	height: 61px;
    background: #B79831;
	/* オートレイアウト内部 */
	flex: none;
	order: 0;
	align-self: stretch;
	flex-grow: 0;

}

.fan_new .fan_new_cnt .price_card.regular_card .price_header {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	gap: 10px;

	width: 397.67px;
	height: 61px;
    background: #005C30;
	/* オートレイアウト内部 */
	flex: none;
	order: 0;
	align-self: stretch;
	flex-grow: 0;

}

.fan_new .fan_new_cnt .price_card.junior_card .price_header {
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	gap: 10px;

	width: 397.67px;
	height: 61px;
    background: #A9C31A;
	/* オートレイアウト内部 */
	flex: none;
	order: 0;
	align-self: stretch;
	flex-grow: 0;

}

/* Price詳しくはこちら */
.fan_new .fan_new_cnt .price_footer {
    font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 16px;
	line-height: 120%;
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    flex-shrink: 0;
	font-family: 'Noto Sans JP';
	padding-bottom: 8px;
	transition: opacity 0.2s;
}
.fan_new .fan_new_cnt .price_footer:hover {
	opacity: 0.8;
}
/* 詳しくはこちらの横のボタン */
.fan_new .fan_new_cnt .price_footer_icon {
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-60%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.fan_new .fan_new_cnt .price_footer_icon svg {
    /* under_arrow */

	width: 24px;
	height: 24px;

	transform: rotate(70g);

	/* オートレイアウト内部 */
	flex: none;
	order: 1;
	flex-grow: 0;

}

.fan_new .fan_new_cnt .price_card.gold_card .price_footer {
    /* More Info Container */

	/* オートレイアウト */
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	gap: 8px;

	width: 397.67px;
	height: 56px;

	background: #B79831;

	/* オートレイアウト内部 */
	flex: none;
	order: 4;
	align-self: stretch;
	flex-grow: 0;
}

.fan_new .fan_new_cnt .price_card.gold_card .price_footer_icon svg path {
    fill: #B79831;
}

.fan_new .fan_new_cnt .price_card.regular_card .price_footer {
    background: #005C30;
	/* More Info Container */

	/* オートレイアウト */
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	/* padding: 16px; */
	gap: 8px;

	width: 397.67px;
	height: 56px;

	/* オートレイアウト内部 */
	flex: none;
	order: 4;
	align-self: stretch;
	flex-grow: 0;
}

.fan_new .fan_new_cnt .price_card.regular_card .price_footer_icon svg path {
    fill: #005C30;
}

.fan_new .fan_new_cnt .price_card.junior_card .price_footer {
    background: #A9C31A;
	/* More Info Container */

	/* オートレイアウト */
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	gap: 8px;

	width: 397.67px;
	height: 56px;
	min-height: 56px;


	/* オートレイアウト内部 */
	flex: none;
	order: 4;
	align-self: stretch;
	flex-grow: 0;
}

.fan_new .fan_new_cnt .price_card.junior_card .price_footer_icon svg path {
    fill: #A9C31A;
}

.fan_new .fan_new_cnt .price_content {
    flex: 1;
    display: flex;
    flex-direction: column;
	align-items: center; 
    justify-content: center;
	background-color: #fff;
	
}

/* 年会費 */
.fan_new .fan_new_cnt .price_label {

	font-size: 0.9rem;

	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 500;
	font-size: 16px;
	line-height: 120%;
	/* または19px */
	display: flex;
	align-items: center;
	text-align: center;
	color: #000000;
	/* オートレイアウト内部 */
	flex: none;
	order: 0;
	flex-grow: 0;
}
/* 金額 */
.fan_new .fan_new_cnt .price_number {
    /* font-size: 3.2rem;
    font-weight: bold;
    color: #000000;
    display: inline-block;
    line-height: 1; */
	/* Fee Amount */

	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 700;
	font-size: 36px;
	line-height: 100%;
	margin: 16px 0px;
	/* ボックスの高さと同一、または36px */
	display: inline-flex;
	align-items: baseline; 
	text-align: center;
	color: #000000;


	/* オートレイアウト内部 */
	flex: none;
	order: 1;
	flex-grow: 0;

}
/* 円(税込) */
.fan_new .fan_new_cnt .price_unit {
    /* font-size: 1.8rem;
    font-weight: bold;
    color: #000000; */
	/* Fee Unit */

	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	font-size: 16px;
	line-height: 120%;
	margin-left: 4px;
	/* または19px */
	
	/* align-items: center;
	text-align: center; */
	/* margin-left: 4px; */
	color: #000000;

	/* オートレイアウト内部 */
	flex: none;
	order: 1;

}
/* 説明 */
.fan_new .fan_new_cnt .price_description {
	font-family: 'Noto Sans JP';
	font-style: normal;
    font-size: 1.4rem;
    color: #000000;
    line-height: 1.4;
    min-height: 40px;
    font-weight: 500;
	display: flex; 
	align-items: center; 
	justify-content: center; 
	/* Membership Benefits */
	width: 397.67px;
	height: 38px;
	/* オートレイアウト内部 */
	flex: none;
	order: 2;
	flex-grow: 0;

}

.fan_new .fan_new_cnt .price_btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: white;
    border: 1px solid #ccc;
    color: #333;
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 1.3rem;
    text-decoration: none;
    transition: all 0.3s ease;
}

.fan_new .fan_new_cnt .price_btn:hover {
    background: #f5f5f5;
}

.fan_new .fan_new_cnt .price_btn .arrow {
    font-size: 1.2rem;
}

.fan_new .fan_new_cnt .main_cta_section {
    text-align: center;
    margin-top: 0;
    padding: 0;
}

.fan_new .fan_new_cnt .main_cta_button {
    margin-bottom: 40px;
}

.fan_new .fan_new_cnt .main_cta_btn {
    display: inline-block;
    text-decoration: none;
    transition: all 0.3s ease;
}

.fan_new .fan_new_cnt .main_cta_btn img {
    width: 706px;
    height: 70px;
    border-radius: 10px;
    display: block;
    object-fit: contain;
}

.fan_new .fan_new_cnt .main_cta_btn:hover {
    opacity: 0.8;
    transform: translateY(-2px);
}

@media (max-width: 768px) {
    .fan_new .fan_new_cnt .main_cta_btn img {
        width: 100%;
        max-width: 400px;
        height: 50px;
        object-fit: contain;
    }
}

.fan_new .fan_new_cnt .guide_btn {
    color: #005C30;
    font-size: 1.6rem;
    text-decoration: underline;
    display: inline-block;
    margin-top: 10px;
}

.fan_new .fan_new_cnt .guide_btn:hover {
    color: #007A40;
}

/* 早期入会特典セクション */
.fan_new .fan_new_cnt .early_bird_section {
    background-image: url('/teams/verblitz/images/fan/fan_2025/early_registration_benefits_bg.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 60px 40px;
    color: white;
}

.fan_new .fan_new_cnt .early_bird_container {
    max-width: 1200px;
    margin: 0 auto;
}

.fan_new .fan_new_cnt .early_bird_container img {
    width: 100%;
    height: auto;
    display: block;
}

.fan_new .fan_new_cnt .early_bird_container img.pcdl {
    display: block;
}

.fan_new .fan_new_cnt .early_bird_container img.sp {
    display: none;
}

@media (max-width: 768px) {
    .fan_new .fan_new_cnt .early_bird_container img.pcdl {
        display: none;
    }
    
    .fan_new .fan_new_cnt .early_bird_container img.sp {
        display: block;
    }
}

.fan_new .fan_new_cnt .early_bird_header {
    background: white;
    color: #005C30;
    text-align: center;
    padding: 15px 40px;
    border-radius: 30px;
    margin: 0 auto 40px auto;
    max-width: 300px;
    position: relative;
}

.fan_new .fan_new_cnt .early_bird_header h2 {
    font-size: 2.4rem;
    font-weight: bold;
    margin: 0;
}

.fan_new .fan_new_cnt .early_bird_header::before,
.fan_new .fan_new_cnt .early_bird_header::after {
    content: "";
    position: absolute;
    top: 50%;
    width: 100px;
    height: 2px;
    background: white;
}

.fan_new .fan_new_cnt .early_bird_header::before {
    left: -120px;
}

.fan_new .fan_new_cnt .early_bird_header::after {
    right: -120px;
}

.fan_new .fan_new_cnt .benefit_cards {
    display: flex;
    gap: 30px;
    justify-content: center;
    margin-bottom: 30px;
}

.fan_new .fan_new_cnt .benefit_card {
    background: white;
    color: #333;
    border-radius: 12px;
    padding: 30px 20px;
    text-align: center;
    flex: 1;
    max-width: 320px;
    position: relative;
}

.fan_new .fan_new_cnt .benefit_icon {
    background: #005C30;
    color: white;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    font-weight: bold;
    margin: 0 auto 15px auto;
}

.fan_new .fan_new_cnt .benefit_title {
    font-size: 1.6rem;
    font-weight: bold;
    color: #005C30;
    margin-bottom: 15px;
    border-bottom: 2px solid #005C30;
    padding-bottom: 8px;
}

.fan_new .fan_new_cnt .benefit_text {
    font-size: 1.4rem;
    line-height: 1.5;
    margin-bottom: 15px;
}

.fan_new .fan_new_cnt .highlight_red {
    color: #E53E3E;
    font-weight: bold;
}

.fan_new .fan_new_cnt .benefit_note {
    font-size: 1.1rem;
    color: #666;
    line-height: 1.3;
}

.fan_new .fan_new_cnt .early_bird_footer {
    text-align: center;
    margin-top: 30px;
}

.fan_new .fan_new_cnt .early_bird_footer p {
    font-size: 1.6rem;
    font-weight: bold;
}

/* 新規セクション3：グレード特典タブ */
.fan_new .fan_new_cnt .grade_benefits_section {
    background: #f8f9fa;
    padding: 80px 0 0 0;
}

.fan_new .fan_new_cnt .grade_benefits_container {
    max-width: 100%;
    margin: 0 auto;
    background: white;
}

.fan_new .fan_new_cnt .grade_benefits_header {
    text-align: center;
    padding: 80px 40px 60px 40px;
    background: #f8f9fa;
    max-width: 100%;
}

.fan_new .fan_new_cnt .grade_benefits_header h2 {
    font-size: 3.6rem;
    font-weight: bold;
    color: #333;
}

.fan_new .fan_new_cnt .grade_tabs {
    display: flex;
    justify-content: center;
    gap: 0;
    margin-bottom: 40px;
}

.fan_new .fan_new_cnt .grade_tab {
    background: #e9ecef;
    border: none;
    padding: 15px 40px;
    font-size: 1.8rem;
    font-weight: bold;
    color: #666;
    cursor: pointer;
    transition: all 0.3s ease;
}

.fan_new .fan_new_cnt .grade_tab.active {
    background: #005C30;
    color: white;
}

.fan_new .fan_new_cnt .grade_tab:hover:not(.active) {
    background: #dee2e6;
}

.fan_new .fan_new_cnt .grade_content {
    position: relative;
}


.fan_new .fan_new_cnt .benefits_list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px;
}

.fan_new .fan_new_cnt .benefit_item {
    background: white;
    border-radius: 12px;
    padding: 30px;
    text-align: center;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.fan_new .fan_new_cnt .benefit_item img {
    width: 80px;
    height: 80px;
    margin-bottom: 20px;
}

.fan_new .fan_new_cnt .benefit_item h4 {
    font-size: 2rem;
    font-weight: bold;
    color: #333;
    margin-bottom: 15px;
}

.fan_new .fan_new_cnt .benefit_item p {
    font-size: 1.6rem;
    color: #666;
    line-height: 1.5;
}

/* Content2 詳細比較表の改良 */
.fan_new .fan_new_cnt .content2 .detailed_comparison_header {
    text-align: center;
    margin-bottom: 40px;
}

.fan_new .fan_new_cnt .content2 .detailed_comparison_header h2 {
    font-size: 3.2rem;
    font-weight: bold;
    color: #333;
    margin-bottom: 15px;
}

.fan_new .fan_new_cnt .content2 .detailed_comparison_header p {
    font-size: 1.8rem;
    color: #666;
}

.fan_new .fan_new_cnt .content2 .price_small {
    font-size: 1.2rem;
    font-weight: normal;
    color: #666;
}

/* 新しいグレード特典デザイン */
.fan_new .fan_new_cnt .grade_tabs_container {
    display: flex;
    justify-content: center;
    background: #f8f9fa;
    position: relative;
    z-index: 10;
    padding: 0 40px;
}

.fan_new .fan_new_cnt .grade_tab {
    flex: 1;
    max-width: 400px;
    padding: 25px 40px;
    text-align: center;
    font-size: 2.2rem;
    font-weight: bold;
    color: white;
    position: relative;
    cursor: pointer;
    border: 2px solid;
    border-bottom: 2px solid;
    transition: all 0.3s ease;
    margin-bottom: -2px;
}

.fan_new .fan_new_cnt .grade_tab.gold_tab {
    background: #B69832;
    border-color: #B69832;
}

.fan_new .fan_new_cnt .grade_tab.regular_tab {
    background: #005C30;
    border-color: #005C30;
}

.fan_new .fan_new_cnt .grade_tab.junior_tab {
    background: #A9C31A;
    border-color: #A9C31A;
}

.fan_new .fan_new_cnt .grade_tab.active {
    background: white !important;
    position: relative;
    z-index: 20;
}

.fan_new .fan_new_cnt .grade_tab.gold_tab.active {
    color: #B69832 !important;
    border-color: #B69832 !important;
    border-bottom-color: transparent !important;
}

.fan_new .fan_new_cnt .grade_tab.regular_tab.active {
    color: #005C30 !important;
    border-color: #005C30 !important;
    border-bottom-color: transparent !important;
}

.fan_new .fan_new_cnt .grade_tab.junior_tab.active {
    color: #A9C31A !important;
    border-color: #A9C31A !important;
    border-bottom-color: transparent !important;
}

/* コンテンツパネル全体のスタイル */
.fan_new .fan_new_cnt .grade_content_panel {
    background: white;
    position: relative;
    display: none;
}

.fan_new .fan_new_cnt .grade_content_panel.active {
    display: block;
}

.fan_new .fan_new_cnt .grade_content_panel[data-content="gold"] {
    border-top: 2px solid #B69832;
}

.fan_new .fan_new_cnt .grade_content_panel[data-content="regular"] {
    border-top: 2px solid #005C30;
}

.fan_new .fan_new_cnt .grade_content_panel[data-content="junior"] {
    border-top: 2px solid #A9C31A;
}

/* グッズセクション */
.fan_new .fan_new_cnt .grade_goods_section {
    background: white;
    padding: 40px;
    max-width: 1200px;
    margin: 0 auto;
}

.fan_new .fan_new_cnt .goods_items {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

.fan_new .fan_new_cnt .goods_items.single_item {
    grid-template-columns: 1fr;
    padding-top: 20px;
}

.fan_new .fan_new_cnt .goods_item.horizontal_layout {
    display: flex;
    align-items: center;
    gap: 40px;
    padding: 0 0 30px 0;
    background: transparent;
    border-radius: 0;
}

.fan_new .fan_new_cnt .goods_item.horizontal_layout .goods_image {
    flex: 0 0 300px;
    width: 300px;
    height: auto;
}

.fan_new .fan_new_cnt .goods_item.horizontal_layout .goods_content {
    flex: 1;
}

.fan_new .fan_new_cnt .goods_item.horizontal_layout h3 {
    font-size: 1.8rem;
    font-weight: bold;
    color: #000;
    text-align: left;
    margin: 0 0 15px 0;
}

.fan_new .fan_new_cnt .goods_item.horizontal_layout p {
    margin: 0;
}

.fan_new .fan_new_cnt .goods_item {
    background: transparent;
    border-radius: 0;
    padding: 0 0 30px 0;
    text-align: left;
    position: relative;
}

.fan_new .fan_new_cnt .goods_badge {
    position: absolute;
    top: -20px;
    left: 20px;
}

.fan_new .fan_new_cnt .goods_badge img {
    width: 80px;
    height: auto;
}

.fan_new .fan_new_cnt .goods_image {
    width: 100%;
    height: auto;
    margin: 0;
    display: block;
}

.fan_new .fan_new_cnt .goods_image img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
}


.fan_new .fan_new_cnt .goods_item h3 {
    font-size: 1.8rem;
    font-weight: bold;
    color: #000;
    margin: 20px 20px 20px 20px;
    text-align: left;
}

.fan_new .fan_new_cnt .goods_item p {
    font-size: 1.4rem;
    color: #000;
    line-height: 1.6;
    margin: 0 20px 0 20px;
    text-align: left;
}

.fan_new .fan_new_cnt .goods_sizes {
    font-size: 1.2rem;
    color: #000;
    line-height: 1.4;
    margin: 0 20px;
    text-align: left;
}

.fan_new .fan_new_cnt .goods_sizes span {
    display: block;
}

/* グッズタイトル */
.fan_new .fan_new_cnt .goods_title {
    font-size: 2.4rem;
    font-weight: bold;
    color: #333;
    text-align: center;
    margin-bottom: 20px;
    padding-top: 40px;
}

.fan_new .fan_new_cnt .goods_description {
    font-size: 1.6rem;
    color: #000;
    text-align: center;
    line-height: 1.6;
    margin-bottom: 40px;
    padding: 0 20px;
}

.fan_new .fan_new_cnt .goods_description .text-red {
    color: #E60012;
    font-weight: bold;
}

.fan_new .fan_new_cnt .goods_description .pc-br {
    display: block;
}

@media screen and (max-width: 767px) {
    .fan_new .fan_new_cnt .goods_description .pc-br {
        display: none;
    }
}

@media screen and (max-width: 767px) {
    .fan_new .fan_new_cnt .goods_title {
        font-size: 2rem;
        padding-top: 30px;
    }
    
    .fan_new .fan_new_cnt .goods_description {
        font-size: 1.4rem;
        margin-bottom: 30px;
    }
}

/* イベントセクション */
.fan_new .fan_new_cnt .grade_events_section {
    background: white;
    padding: 0 40px 40px 40px;
    max-width: 1200px;
    margin: 0 auto;
}

.fan_new .fan_new_cnt .events_title {
    font-size: 2.4rem;
    font-weight: bold;
    color: #333;
    text-align: center;
    margin-bottom: 60px;
    padding-top: 40px;
    border-top: 2px solid #DBDBDB;
    max-width: 1120px;
    margin-left: auto;
    margin-right: auto;
}

.fan_new .fan_new_cnt .events_grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    margin-bottom: 50px;
}

.fan_new .fan_new_cnt .event_item {
    text-align: left;
}

.fan_new .fan_new_cnt .event_image {
    width: 100%;
    height: 200px;
    margin-bottom: 20px;
    overflow: hidden;
}

.fan_new .fan_new_cnt .event_image img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.fan_new .fan_new_cnt .event_item h4 {
    font-size: 1.8rem;
    font-weight: bold;
    color: #000;
    margin: 0 0 10px 0 !important;
    text-align: left;
    display: block;
    line-height: 1.4;
}

.fan_new .fan_new_cnt .event_item p {
    font-size: 1.4rem;
    color: #000;
    line-height: 1.6;
    text-align: left;
}

/* 追加情報セクション */
.fan_new .fan_new_cnt .events_additional {
    background: white;
    padding: 40px 0;
    border-radius: 0;
    border-top: 2px solid #DBDBDB;
    max-width: 1120px;
    margin-left: auto;
    margin-right: auto;
}

.fan_new .fan_new_cnt .events_additional h4 {
    font-size: 1.8rem;
    font-weight: bold;
    color: #333;
    margin-bottom: 15px;
}

.fan_new .fan_new_cnt .events_additional p {
    font-size: 1.4rem;
    color: #000 !important;
    line-height: 1.6;
    margin-bottom: 0;
}

.fan_new .fan_new_cnt .events_additional .note {
    font-size: 1.2rem;
    color: #999;
}

.fan_new .fan_new_cnt .coupon_section,
.fan_new .fan_new_cnt .ticket_section,
.fan_new .fan_new_cnt .visitor_section {
    margin-bottom: 30px;
    padding-bottom: 30px;
    border-bottom: 2px solid #DBDBDB;
}

.fan_new .fan_new_cnt .visitor_section {
    border-bottom: 2px solid #DBDBDB;
}

/* 入会ボタンセクション */
.fan_new .fan_new_cnt .join_button_section {
    text-align: center;
    padding: 40px 0;
}

.fan_new .fan_new_cnt .join_button {
    display: inline-block;
    margin-bottom: 20px;
}

.fan_new .fan_new_cnt .join_button img {
    width: 400px;
    height: auto;
}

.fan_new .fan_new_cnt .grade_benefits_section .guide_link {
    display: block;
    color: #0066cc;
    font-size: 1.6rem;
    text-decoration: underline;
}


/* イベント参加権のスタイル */


.fan_new .fan_new_cnt .event-notes {
    list-style: none;
    margin: 10px 0 0;
    padding: 0;
    font-size: 0.85em;
    font-weight: normal;
}

.fan_new .fan_new_cnt .event-notes li {
    margin: 5px 0;
    text-align: center;
}

/* Content4 FAQ スタイル */
.fan_new .fan_new_cnt .content4 .faq_container {
    max-width: 900px;
    margin: 0 auto;
}

.fan_new .fan_new_cnt .content4 .faq_item {
    background: white;
    border-radius: 12px;
    margin-bottom: 20px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

.fan_new .fan_new_cnt .content4 .faq_question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 25px 30px;
    background: #f8f9fa;
    cursor: pointer;
    transition: background-color 0.3s ease;
}

.fan_new .fan_new_cnt .content4 .faq_question:hover {
    background: #e9ecef;
}

.fan_new .fan_new_cnt .content4 .faq_question h3 {
    font-size: 1.8rem;
    font-weight: bold;
    color: #333;
    margin: 0;
    flex: 1;
}

.fan_new .fan_new_cnt .content4 .faq_toggle {
    font-size: 2.4rem;
    font-weight: bold;
    color: #005C30;
    transition: transform 0.3s ease;
}

.fan_new .fan_new_cnt .content4 .faq_item.active .faq_toggle {
    transform: rotate(45deg);
}

.fan_new .fan_new_cnt .content4 .faq_answer {
    padding: 0 30px;
    max-height: 0;
    overflow: hidden;
    transition: all 0.3s ease;
}

.fan_new .fan_new_cnt .content4 .faq_item.active .faq_answer {
    padding: 25px 30px;
    max-height: 500px;
}

.fan_new .fan_new_cnt .content4 .faq_answer p {
    font-size: 1.6rem;
    color: #666;
    line-height: 1.6;
    margin: 0;
}

.fan_new .fan_new_cnt .cnt{
	max-width: 1260px;
	width: 100%;
	margin: 0 auto;
	font-size: 1.6rem;
	line-height: 1.6;
	padding: 80px 20px;
}
.fan_new .fan_new_cnt .cnt p.ttl{
	font-size: 4.2rem;
	line-height: 1.2;
	font-weight: bold;
	color: #fff;
	text-align: center;
	margin-bottom: 51px;
}

.fan_new .fan_new_cnt .content2{
	background: #F2F4F3;
}
.fan_new .fan_new_cnt .content2 .table{
	margin-bottom: 12px;
}
.fan_new .fan_new_cnt .content2 .table table{
	width: 100%;
	border-collapse: collapse;
}
.fan_new .fan_new_cnt .content2 .table th, .fan_new .fan_new_cnt .content2 .table td {
	border: 2px solid #DBDBDB;
	border-left: none;
	border-bottom: none;
	padding: 24px;
	text-align: center;
}

.fan_new .fan_new_cnt .content2 .table .price_row {
	border-top: 2px solid #DBDBDB;
}

.fan_new .fan_new_cnt .content2 .table tr:nth-child(2) th,
.fan_new .fan_new_cnt .content2 .table tr:nth-child(2) td {
	border-top: 2px solid #DBDBDB;
}
.fan_new .fan_new_cnt .content2 .table thead th{
	padding: 45px 24px;
	border-top: none;
}
.fan_new .fan_new_cnt .content2 .table thead th:first-child{
	font-weight: normal;
}
.fan_new .fan_new_cnt .content2 .table thead th:last-child{
	border-right: none;
}
.fan_new .fan_new_cnt .content2 .table thead th.h_gold{
	background-color: #B79831;
	font-size: 2rem;
	font-weight: bold;
}
.fan_new .fan_new_cnt .content2 .table thead th.h_regular{
	background-color: #005C30;
	font-size: 2rem;
	font-weight: bold;
}
.fan_new .fan_new_cnt .content2 .table thead th.h_jr{
	background-color: #A9C31A;
	font-size: 2rem;
	font-weight: bold;
}
.fan_new .fan_new_cnt .content2 .table thead th.h_jr span{
	border:solid 1px;
	font-size: 1.4rem;
	line-height: 1;
	font-weight: bold;
	padding: 5px 5px 3px;
}
.fan_new .fan_new_cnt .content2 .table th{
	background-color: #444444;
	color: white;
	font-weight: normal;
}
.fan_new .fan_new_cnt .content2 .table td{
	background: #fff;
	font-size: 1.8rem;
}
.fan_new .fan_new_cnt .content2 .table td:last-child{
	border-right: none;
}
.fan_new .fan_new_cnt .content2 .table td.gold{
	color: #B79831;
	font-size: 2.2rem;
}
.fan_new .fan_new_cnt .content2 .table td.regular{
	color: #005C30;
	font-size: 2.2rem;
}
.fan_new .fan_new_cnt .content2 .table td.jr{
	color: #A9C31A;
	font-size: 2.2rem;
}
.fan_new .fan_new_cnt .content2 .note dl{
	display: flex;
	margin-bottom: 11px;
}
.fan_new .fan_new_cnt .content2 .note dl dt{
	margin-right: 10px;
}
.fan_new .fan_new_cnt .content2 .note dl dd a{
	text-decoration: underline;
	color: #272727;
}

.fan_new .fan_new_cnt .content3 .cnt{
	padding: 77px 0px;
}
.fan_new .fan_new_cnt .content3{
	background: url("../../images/fan/fan_new/g_bg.png");
	background-size: cover;
	background-position: center;
	background-repeat: repeat-y;
}
.fan_new .fan_new_cnt .content3 .cnt .goods_list{
	display: flex;
	flex-wrap: wrap;
    gap: 0px 20px;
    justify-content: space-between;
    margin-bottom: 20px;
}
.fan_new .fan_new_cnt .content3 .cnt .goods_list .goods{
	width: 32%;
	font-size: 1.6rem;
	font-weight: 300;
	line-height: 1.6;
	color: #fff;
}
.fan_new .fan_new_cnt .content3 .cnt .goods_list .goods img{
	width: 100%;
	margin-bottom: 12px;
}
.fan_new .fan_new_cnt .content3 .cnt .goods_list .goods p.g_ttl{
	font-size: 2.4rem;
	font-weight: bold;
	margin-bottom: 24px;
}
.fan_new .fan_new_cnt .content3 .cnt .goods_list .goods .list_note{
	margin-top: 10px;
}
.fan_new .fan_new_cnt .content3 .cnt .goods_list .goods .list_note a{
	color: white;
	text-decoration: underline;
}
.fan_new .fan_new_cnt .content3 .cnt .goods_list .goods .list_note p.ind{
	text-indent: -12px;
    margin-left: 12px;
}

.fan_new .fan_new_cnt .content4{
	background: url("../../images/fan/fan_new/v_bg.png");
	background-size: cover;
	background-position: center;
	text-align: center;
}

.fan_new .fan_new_cnt .content4 .content4_inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    max-width: 1200px;
    margin: 0 auto;
}

.fan_new .fan_new_cnt .content4 .line_qr_img {
    width: 150px;
    height: auto;
}

.fan_new .fan_new_cnt .content4 .content4_text {
    text-align: left;
    color: white;
}

.fan_new .fan_new_cnt .content4 .content4_text p {
    color: white;
}

.fan_new .fan_new_cnt .content4 .content4_text .sub_ttl {
    font-size: 2.8rem;
    font-weight: bold;
    margin-bottom: 15px;
}

@media (max-width: 768px) {
    .fan_new .fan_new_cnt .content4 .content4_inner {
        flex-direction: column;
        gap: 20px;
    }
    
    .fan_new .fan_new_cnt .content4 .content4_text {
        text-align: center;
    }
}
.fan_new .fan_new_cnt .content4 img{
	max-width: 910px;
	width: 100%;
}
.fan_new .fan_new_cnt .content4 .txt{
	max-width: 910px;
    text-align: left;
    margin: 0 auto;
    color: white;
}
.fan_new .fan_new_cnt .content4 .txt{
	margin-bottom: 10px;
}
.fan_new .fan_new_cnt .content4 .txt p.ind{
	text-indent: -18px;
	margin-left: 18px;
}

.fan_new .fan_new_cnt .content5 .event_list{
	display: flex;
	flex-wrap: wrap;
    gap: 0px 20px;
	justify-content: space-between;
	margin-bottom: 80px;
}
.fan_new .fan_new_cnt .content5 .event_list .event{
	background: #fff;
	padding: 24px 30px;
	width: 49%;
}
.fan_new .fan_new_cnt .content5 .event_list .event img{
	width: 100%;
}
.fan_new .fan_new_cnt .content5 .event_list .event .cat_list{
	display: flex;
	flex-wrap: wrap;
	align-content: center;
    gap: 0px 10px;
	margin-bottom: 15px;
}
.fan_new .fan_new_cnt .content5 .event_list .event .cat_list p{
	padding: 10px 10px 5px;
	text-align: center;
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 1;
	color: #fff;
	border-radius: 5px;
}
.fan_new .fan_new_cnt .content5 .event_list .event .cat_list p.e_gold{
	background: #B69832;
}
.fan_new .fan_new_cnt .content5 .event_list .event .cat_list p.e_regular{
	background: #005C30;
}
.fan_new .fan_new_cnt .content5 .event_list .event .cat_list p.e_jr{
	background: #A9C31A;
}
.fan_new .fan_new_cnt .content5 .event_list .event .cat_list p.e_lottery{
	color: #E51616;
	border:solid 1px #E51616;
	border-radius: 0px;
}
.fan_new .fan_new_cnt .content5 .event_list .event p{
	font-size: 1.6rem;
	line-height: 1.6;
}
.fan_new .fan_new_cnt .content5 .event_list .event p.e_ttl{
	font-size: 2.4rem;
	font-weight: bold;
	color: #005C30;
	margin-bottom: 15px;
}

/* フローチャートセクション */
.fan_new .fan_new_cnt .flowchart_section {
	background: white;
	padding: 60px 40px;
	text-align: center;
}

.fan_new .fan_new_cnt .flowchart_header h2 {
	font-size: 3.2rem;
	font-weight: bold;
	color: #005C30;
	margin-bottom: 40px;
	font-family: 'Noto Sans JP', sans-serif;
}

.fan_new .fan_new_cnt .flowchart_content {
	max-width: 800px;
	margin: 0 auto;
	position: relative;
}

.fan_new .fan_new_cnt .flowchart_start {
	background: #005C30;
	color: white;
	border-radius: 50px;
	padding: 15px 40px;
	font-size: 2rem;
	font-weight: bold;
	margin-bottom: 40px;
	display: inline-block;
}

.fan_new .fan_new_cnt .flowchart_decision {
	background: #F5F5F5;
	border: 2px solid #CCCCCC;
	border-radius: 12px;
	padding: 30px;
	margin: 20px auto;
	max-width: 400px;
	font-size: 1.8rem;
	color: #333;
	position: relative;
}

.fan_new .fan_new_cnt .flowchart_arrow {
	width: 0;
	height: 0;
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-top: 15px solid #CCCCCC;
	margin: 0 auto 20px auto;
}

.fan_new .fan_new_cnt .flowchart_result {
	display: flex;
	justify-content: space-around;
	gap: 20px;
	margin-top: 40px;
}

.fan_new .fan_new_cnt .flowchart_grade {
	background: white;
	border: 2px solid;
	border-radius: 12px;
	padding: 20px;
	flex: 1;
	text-align: center;
	font-weight: bold;
}

.fan_new .fan_new_cnt .flowchart_grade.gold {
	border-color: #B79831;
	color: #B79831;
}

.fan_new .fan_new_cnt .flowchart_grade.regular {
	border-color: #005C30;
	color: #005C30;
}

.fan_new .fan_new_cnt .flowchart_grade.junior {
	border-color: #A9C31A;
	color: #A9C31A;
}

/* 来場者特典セクション */
.fan_new .fan_new_cnt .visitor_benefits_section {
	background: #005C30;
	padding: 60px 40px;
	text-align: center;
	color: white;
}

.fan_new .fan_new_cnt .visitor_benefits_header h2 {
	font-size: 3.2rem;
	font-weight: bold;
	color: white;
	margin-bottom: 20px;
	font-family: 'Noto Sans JP', sans-serif;
}

.fan_new .fan_new_cnt .visitor_benefits_header p {
	font-size: 1.8rem;
	color: white;
	margin-bottom: 40px;
}

.fan_new .fan_new_cnt .visitor_qr_code {
	background: white;
	border-radius: 12px;
	padding: 30px;
	max-width: 400px;
	margin: 0 auto;
	text-align: center;
}

.fan_new .fan_new_cnt .visitor_qr_code img {
	width: 200px;
	height: 200px;
	margin-bottom: 20px;
}

.fan_new .fan_new_cnt .visitor_qr_code p {
	font-size: 1.6rem;
	color: #333;
	font-weight: bold;
}

/* グッズセクション（更新） */
.fan_new .fan_new_cnt .goods_section {
	background: #005C30;
	padding: 60px 40px;
}

.fan_new .fan_new_cnt .goods_header {
	text-align: center;
	margin-bottom: 40px;
}

.fan_new .fan_new_cnt .goods_header h2 {
	font-size: 3.2rem;
	font-weight: bold;
	color: white;
	margin-bottom: 20px;
	font-family: 'Noto Sans JP', sans-serif;
}

.fan_new .fan_new_cnt .goods_header p {
	font-size: 1.8rem;
	color: white;
}

.fan_new .fan_new_cnt .goods_grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px;
	max-width: 1200px;
	margin: 0 auto;
}

.fan_new .fan_new_cnt .goods_item {
	background: white;
	border-radius: 12px;
	padding: 20px;
	text-align: center;
}

.fan_new .fan_new_cnt .goods_item img {
	width: 100%;
	height: auto;
	object-fit: contain;
	border-radius: 0;
	margin-bottom: 0;
}

/* .fan_new .fan_new_cnt .goods_item h3 {
	font-size: 1.8rem;
	font-weight: bold;
	color: #000;
	margin-bottom: 10px;
	text-align: left;
} */

.fan_new .fan_new_cnt .goods_item p {
	font-size: 1.4rem;
	color: #000;
	line-height: 1.5;
	text-align: left;
}

.fan_new .fan_new_cnt .content6{
	background: #F2F4F3;
}
.fan_new .fan_new_cnt .content6 .cnt{
	text-align: center;
}
.fan_new .fan_new_cnt .content6 .cnt p{
	font-size: 1.6rem;
	color: #005C30;
	font-weight: bold;
}
.fan_new .fan_new_cnt .content6 .cnt p.faq_ttl{
	font-size: 5.8rem;
	line-height: 1;
	font-family: "Raiden-Italic";
	margin-bottom: 10px;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_btn{
	margin: 60px 0px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-content: center;
    gap: 0px 10px;
	overflow: hidden;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_btn a{
	width: 24%;
	background: #005C30;
	padding: 22px;
	text-align: center;
	color: #fff;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1;
	border-radius: 10px;
	position: relative;
	
}
.fan_new .fan_new_cnt .content6 .cnt .faq_btn a::before{
	content: '';
	width: 10px;
	height: 10px;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	position: absolute;
	right: 25px;
	top: 50%;
	transition: top 0.5s;
	transform: translateY(-50%)rotate(135deg);
	opacity: 1;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_btn a::after{
	content: '';
	position: absolute;
	width: 10px;
	height: 10px;
	border-top: solid 2px #fff;
	border-right: solid 2px #fff;
	right: 25px;
	top: 30%;
	transition: top 0.5s;
	transform: translateY(-50%)rotate(135deg);
	opacity: 0;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_btn a:hover::before {
	top: 50%;
	opacity: 0;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_btn a:hover::after {
	top: 50%;
	opacity: 1;
}

.fan_new .fan_new_cnt .content6 .cnt .faq_btn a p{
	color: #fff;
}
.fan_new .fan_new_cnt .content6 .cnt .faq{
	text-align: left;
}
.fan_new .fan_new_cnt .content6 .cnt .faq p.faq_cat{
	font-size: 2.4rem;
	font-weight: bold;
	margin-bottom: 20px;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list{
	margin-bottom: 60px;
	cursor: pointer;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list{
	background: #fff;
	padding: 19px 80px 19px 20px;
	border-radius: 10px;
	margin-bottom: 10px;
	position: relative;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list::before,.fan_new .fan_new_cnt .content6 .cnt .faq_list .list::after {
	content: '';
    display: inline-block;
    width: 20px;
    height: 2px;
    background-color: #fff;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    transition: opacity 1s;
    background-color: #005C30;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list::after {
    transform: translateY(-50%) rotate(90deg);
    transition: transform 0.5s;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list.show::before {
    opacity: 0;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list.show::after {
    transform: translateY(-50%) rotate(180deg);
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list dl{
	display: flex;
	align-items: flex-start;
	font-size: 1.6rem;
	line-height: 1;
	font-weight: bold;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list dl dt{
	font-family: "Raiden-Italic";
	color: #005C30;
	font-size: 2.6rem;
	margin-right: 20px;
	font-weight: normal;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list dl dd{
	margin-top: 6px;
	line-height: 1.6;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list dl a{
	text-decoration: underline;
	color: #005C30;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list .q{
	cursor: pointer;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list .a{
	display: none;
	margin-top: 20px;
}
.fan_new .fan_new_cnt .content6 .cnt .faq_list .list .a dl dt{
	color: #111111;
}
.fan_new .fan_new_cnt .content6 .cnt .fan_inq{
	display: flex;
	justify-content: center;
	align-content: center;
	max-width: 860px;
	margin: 0 auto;
}
.fan_new .fan_new_cnt .content6 .cnt .fan_inq p{
	width: 50%;
	padding: 30px 30px 25px;
	text-align: center;
	font-size: 1.8rem;
	line-height: 1;
}
.fan_new .fan_new_cnt .content6 .cnt .fan_inq p:first-child{
	background: #005C30;
	color: #fff;
	border-radius: 10px 0px 0px 10px;
}
.fan_new .fan_new_cnt .content6 .cnt .fan_inq p:last-child{
	border: solid 2px #005C30;
	border-radius: 0px 10px 10px 0px;
}
.fan_new .fan_new_cnt .content6 .cnt .fan_inq p:last-child a{
	color: #005C30;
	text-decoration: underline;
}

.pc{
	display: block;
}
.pcdl{
	display: inline-block;
}
.sp{
	display: none;
}

/*タブレット*/
@media (max-width: 1260px) {
	.fan_new .fan_new_cnt .main_vi{
		height: 500px;
	}
	.fan_new .fan_new_cnt .main_vi .vi_info img{
		height: 500px;
	}
	.fan_new .fan_new_cnt .cnt,.fan_new .fan_new_cnt .content3 .cnt{
		padding: 80px 20px;
	}
	.fan_new .fan_new_cnt .content1 .fan_cnt .list::after{
		background: url(../../images/fan/fan_new/img.png);
        background-size: 100%;
        background-repeat: no-repeat;
        width: 160px;
        height: 260px;
        right: -60px;
	}
	.fan_new .fan_new_cnt .content5 .event_list .event{
		width: 48%;
	}
	
	.fan_new .fan_new_cnt .btn a.nolink > div.pc{
		display: none;
	}
	.fan_new .fan_new_cnt .btn a.nolink > div.sp{
		display: block;
	}
	.fan_new .fan_new_cnt .btn a.nolink > div.sp .day{
		display: flex;
		justify-content: center;
		align-items: baseline;
		margin-bottom: 10px;
	}
	.fan_new .fan_new_cnt .btn a.nolink > div.sp .day span.sp_txts{
		font-size: 3rem;
	}
}
@media (max-width: 1060px) {
	.fan_new .fan_new_cnt .content3 .cnt .goods_list .goods{
		width: 30%;
	}
}
@media (max-width: 1024px) {
	.fan_new .fan_new_cnt .content1 .fan_cnt{
		max-width: 800px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_btn a{
		width: 48%;
		margin-bottom: 10px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_btn a:hover::before{
		opacity: 1;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_btn a:hover::after{
		opacity: 0;
	}
	
	.fan_new .fan_new_cnt .content2 .table thead th.h_gold,.fan_new .fan_new_cnt .content2 .table thead th.h_regular,.fan_new .fan_new_cnt .content2 .table thead th.h_jr{
		font-size: 1.2rem;
	}
	
	/* レスポンシブ対応：タブレット */
	.fan_new .fan_new_cnt .content1 .reward_card {
		width: calc(50% - 10px) !important;
	}
	
	.fan_new .fan_new_cnt .content1 .checklist_content {
		flex-direction: column !important;
	}
	
	.fan_new .fan_new_cnt .content1 .mascot_character {
		margin-left: 0 !important;
		text-align: center !important;
		margin-top: 30px !important;
	}
	
	/* price_cards_containerのレスポンシブ対応 */
	.fan_new .fan_new_cnt .price_cards_container {
		padding: 0 20px;
		box-sizing: border-box;
	}
}
@media (max-width: 820px) {
	.fan_new .fan_new_cnt .content1 .fan_cnt{
		max-width: 700px;
	}
	.fan_new .fan_new_cnt .content1 .fan_cnt > img{
		margin: 62px 0px 15px;
	}
	.fan_new .fan_new_cnt .content1 .fan_cnt .list::after{
		background: url(../../images/fan/fan_new/img.png);
        background-size: 100%;
        background-repeat: no-repeat;
        width: 110px;
        height: 260px;
		top: -39%;
        right: -26px;
	}
}
@media (max-width: 768px) {
	body.lower.fan_new main {
	}
}
/*sp*/
@media (max-width: 767px) {
	/* Prevent horizontal scroll */
	body {
		overflow-x: hidden !important;
	}
	
	/* Fix early_bird_header pseudo elements */
	.fan_new .fan_new_cnt .early_bird_header::before,
	.fan_new .fan_new_cnt .early_bird_header::after {
		display: none !important;
	}
	
	.pc{
		display: none;
	}
	.pcdl{
		display: none;
	}
	.sp{
		display: block;
	}
	body.lower.fan_new main {
	}
	.fan_new .fan_new_cnt .main_vi{
		background: url(../../images/fan/fan_2025/main_bg_sp.png);
		background-size: contain;
        background-position: top;
        min-height: 640px;
		height: auto;
        position: relative;
	}
	.fan_new .fan_new_cnt .main_vi .vi_info{
		bottom: 0;
    	position: absolute;
		width: 100%;
	}
	.fan_new .fan_new_cnt .main_vi .vi_info img{
		width: 100%;
		height: auto;
	}
	
	.fan_new .fan_new_cnt .cnt{
		padding: 40px 17px 53px;
	}
	.fan_new .fan_new_cnt .cnt p.ttl{
		font-size: 2.8rem;
		margin-bottom: 18px;
	}
	
	.fan_new .fan_new_cnt .btn-fanclub p{
		font-size: 2rem;
	}
	.fan_new .fan_new_cnt .btn-fanclub a{
		padding: 25px 0px 20px 20px;
	}
	.fan_new .fan_new_cnt .btn-fanclub p::before{
		transform: translate(-130px, -9px);
	}
	
	.fan_new .fan_new_cnt .content1{
		padding: 20px 18px 47px;
	}
	.fan_new .fan_new_cnt .content1 .fan_cnt > img{
		margin-top: 28px;
		position: relative;
        z-index: 9;
	}
	.fan_new .fan_new_cnt .content1 .fan_cnt .list{
		margin-top: -30px;
	}
	.fan_new .fan_new_cnt .content1 .fan_cnt .list dl{
		padding: 13px;
		position: relative;
	}
	.fan_new .fan_new_cnt .content1 .fan_cnt .list dl dd{
		font-size: 1.6rem;
		line-height: 1.6;
		margin-left: 13px;
	}
	.fan_new .fan_new_cnt .content1 .fan_cnt .list dl dd a::after{
		display: none;
	}
	.fan_new .fan_new_cnt .content1 .fan_cnt .list dl.link::after{
		content: "";
		width: 22px;
		height: 22px;
		background: url(../../images/fan/fan_new/btn_icon2.svg);
		position: absolute;
		top: 50%;
		right: 0;
		transform: translate(-50%,-50%);
	}
	.fan_new .fan_new_cnt .content1 .fan_cnt .list::after{
		display: none;
	}
	
	/* モバイル対応：特典カードとチェックリスト */
	.fan_new .fan_new_cnt .content1 .reward_cards_section {
		padding: 40px 0 !important;
	}
	
	.fan_new .fan_new_cnt .content1 .reward_cards_container {
		flex-direction: column !important;
		align-items: center !important;
		gap: 15px !important;
	}
	
	.fan_new .fan_new_cnt .content1 .reward_card {
		width: 100% !important;
		min-width: auto !important;
		aspect-ratio: auto !important;
		border-radius: 0 !important;
	}
	
	.fan_new .fan_new_cnt .content1 .reward_header {
		margin: 24px 24px 0 !important;
		padding: 0 !important;
		display: flex !important;
		justify-content: center !important;
		align-items: center !important;
	}
	
	.fan_new .fan_new_cnt .content1 .reward_header img {
		width: 100% !important;
		height: auto !important;
		max-width: 100% !important;
	}
	
	.fan_new .fan_new_cnt .content1 .reward_image {
		padding: 16px 24px 0 !important;
		display: flex !important;
		align-items: flex-start !important;
	}
	
	.fan_new .fan_new_cnt .content1 .reward_image img {
		width: 100% !important;
		height: auto !important;
		aspect-ratio: 1/1 !important;
		object-fit: cover !important;
		border-radius: 0 !important;
	}
	
	.fan_new .fan_new_cnt .content1 .reward_content {
		padding: 12px 16px 20px !important;
		display: flex !important;
		flex-direction: column !important;
		justify-content: center !important;
		flex: 1 !important;
	}
	
	.fan_new .fan_new_cnt .content1 .reward_content h3 {
		font-family: 'Noto Sans JP', sans-serif !important;
		font-size: 20px !important;
		font-weight: bold !important;
		color: #005C30 !important;
		margin-bottom: 8px !important;
		line-height: 1.2 !important;
		text-align: center !important;
	}
	
	.fan_new .fan_new_cnt .content1 .reward_note {
		font-family: 'Noto Sans JP', sans-serif !important;
		font-size: 10px !important;
		font-weight: normal !important;
		color: #005C30 !important;
		line-height: 1.3 !important;
		margin-top: 5px !important;
		text-align: center !important;
	}
	
	.fan_new .fan_new_cnt .content1 .fanclub_checklist_section {
		padding: 0 0 60px !important;
	}
	
	.fan_new .fan_new_cnt .content1 .checklist_message {
		text-align: center !important;
		margin: 0 auto 40px auto !important;
		position: relative !important;
		display: flex !important;
		justify-content: center !important;
	}
	
	/* SP版：ドット装飾の位置調整（SVG画像に含まれているため削除） */
	
	.fan_new .fan_new_cnt .content1 .checklist_content {
		flex-direction: column !important;
		margin-bottom: -16px !important;
		z-index: 10 !important;
	}
	
	.fan_new .fan_new_cnt .content1 .checklist_items {
		gap: 12px !important;
		margin: 0 0 40px 0 !important;
		max-width: 100% !important;
	}
	
	.fan_new .fan_new_cnt .content1 .checklist_item {
		padding: 18px 16px !important;
		border-radius: 12px !important;
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
		display: flex !important;
		align-items: center !important;
		position: relative !important;
	}
	
	.fan_new .fan_new_cnt .content1 .checklist_icon {
		margin-right: 12px !important;
		margin-left: 4px !important;
		flex-shrink: 0 !important;
		align-self: flex-start !important;
		margin-top: 2px !important;
	}
	
	.fan_new .fan_new_cnt .content1 .checklist_icon img {
		width: 20px !important;
		height: 20px !important;
	}
	
	.fan_new .fan_new_cnt .content1 .checklist_item p {
		font-size: 1.7rem !important;
		line-height: 1.6 !important;
		font-weight: 600 !important;
		color: #333 !important;
		flex: 1 !important;
		margin: 0 !important;
		padding-right: 35px !important;
	}
	
	.fan_new .fan_new_cnt .content1 .checklist_item .inline_icon {
		width: 20px !important;
		height: 20px !important;
		position: absolute !important;
		right: 16px !important;
		top: 50% !important;
		transform: translateY(-50%) !important;
	}
	
	
	.fan_new .fan_new_cnt .content1 .mascot_character img {
		width: 120px !important;
		height: auto !important;
	}
	
	/* 新規セクション1：料金カード+ボタン（SP版） */
	.fan_new .fan_new_cnt .price_cards_section {
		padding: 60px 20px !important;
	}
	
	.fan_new .fan_new_cnt .price_cards_container {
		flex-direction: column !important;
		gap: 20px !important;
		margin-bottom: 40px !important;
		width: 100% !important;
		height: auto !important;
		max-width: 100% !important;
	}
	
	.fan_new .fan_new_cnt .price_card {
		width: 100% !important;
		max-width: 397.67px !important;
		margin: 0 !important;
		height: auto !important;
		min-height: auto !important;
		overflow: visible !important;
	}
	
	.fan_new .fan_new_cnt .price_card.gold_card {
		transform: none !important;
	}
	
	/* Fix header widths for mobile */
	.fan_new .fan_new_cnt .price_card .price_header {
		width: 100% !important;
	}
	
	.fan_new .fan_new_cnt .price_header h3 {
		font-size: 2rem !important;
	}
	
	/* Fix content alignment */
	.fan_new .fan_new_cnt .price_content {
		width: 100% !important;
		padding: 20px !important;
	}
	
	/* Fix price_footer width for mobile */
	.fan_new .fan_new_cnt .price_footer {
		width: 100% !important;
		padding: 16px !important;
	}
	
	.fan_new .fan_new_cnt .price_card.gold_card .price_footer,
	.fan_new .fan_new_cnt .price_card.regular_card .price_footer,
	.fan_new .fan_new_cnt .price_card.junior_card .price_footer {
		width: 100% !important;
	}
	
	.fan_new .fan_new_cnt .price_number {
		font-size: 3.6rem !important;
	}
	
	.fan_new .fan_new_cnt .price_unit {
		font-size: 1.8rem !important;
	}
	
	.fan_new .fan_new_cnt .cta_button {
		padding: 15px 40px !important;
		font-size: 1.8rem !important;
	}
	
	/* 新規セクション2：早期入会特典（SP版） */
	.fan_new .fan_new_cnt .early_bird_section {
		padding: 60px 20px !important;
	}
	
	.fan_new .fan_new_cnt .early_bird_header h2 {
		font-size: 2.8rem !important;
	}
	
	.fan_new .fan_new_cnt .early_bird_subtitle {
		font-size: 1.6rem !important;
	}
	
	.fan_new .fan_new_cnt .early_bird_content {
		flex-direction: column !important;
		gap: 30px !important;
		padding: 40px 20px !important;
	}
	
	.fan_new .fan_new_cnt .early_bird_details h3 {
		font-size: 2.4rem !important;
	}
	
	.fan_new .fan_new_cnt .early_bird_details p {
		font-size: 1.6rem !important;
	}
	
	/* 新規セクション3：グレード特典タブ（SP版） */
	.fan_new .fan_new_cnt .grade_benefits_section {
		padding: 60px 0 !important;
	}
	
	.fan_new .fan_new_cnt .grade_benefits_header h2 {
		font-size: 2.2rem !important;
		padding: 0 20px !important;
		line-height: 1.3 !important;
	}
	
	.fan_new .fan_new_cnt .grade_tabs_container {
		/* タブのデザインはそのまま維持 */
	}
	
	.fan_new .fan_new_cnt .grade_tab {
		width: 112px !important;
		height: 67px !important;
		padding: 10px 15px !important;
		font-size: 1.2rem !important;
		line-height: 1.2 !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
	}
	
	.fan_new .fan_new_cnt .benefits_list {
		grid-template-columns: 1fr !important;
		gap: 20px !important;
	}
	
	.fan_new .fan_new_cnt .benefit_item {
		padding: 20px !important;
	}
	
	.fan_new .fan_new_cnt .benefit_item img {
		width: 60px !important;
		height: 60px !important;
	}
	
	.fan_new .fan_new_cnt .benefit_item h4 {
		font-size: 1.8rem !important;
	}
	
	.fan_new .fan_new_cnt .benefit_item p {
		font-size: 1.4rem !important;
	}
	
	/* フローチャートセクション（SP版） */
	.fan_new .fan_new_cnt .flowchart_section {
		padding: 60px 20px !important;
	}
	
	.fan_new .fan_new_cnt .flowchart_header h2 {
		font-size: 2.8rem !important;
	}
	
	.fan_new .fan_new_cnt .flowchart_start {
		padding: 12px 30px !important;
		font-size: 1.8rem !important;
	}
	
	.fan_new .fan_new_cnt .flowchart_decision {
		padding: 20px !important;
		font-size: 1.6rem !important;
	}
	
	.fan_new .fan_new_cnt .flowchart_result {
		flex-direction: column !important;
		gap: 15px !important;
	}
	
	.fan_new .fan_new_cnt .flowchart_grade {
		padding: 15px !important;
		font-size: 1.6rem !important;
	}
	
	/* 来場者特典セクション（SP版） */
	.fan_new .fan_new_cnt .visitor_benefits_section {
		padding: 60px 20px !important;
	}
	
	.fan_new .fan_new_cnt .visitor_benefits_header h2 {
		font-size: 2.8rem !important;
	}
	
	.fan_new .fan_new_cnt .visitor_benefits_header p {
		font-size: 1.6rem !important;
	}
	
	.fan_new .fan_new_cnt .visitor_qr_code {
		padding: 20px !important;
	}
	
	.fan_new .fan_new_cnt .visitor_qr_code img {
		width: 150px !important;
		height: 150px !important;
	}
	
	.fan_new .fan_new_cnt .visitor_qr_code p {
		font-size: 1.4rem !important;
	}
	
	/* グッズセクション（SP版） */
	.fan_new .fan_new_cnt .goods_section {
		padding: 60px 20px !important;
	}
	
	.fan_new .fan_new_cnt .goods_header h2 {
		font-size: 2.8rem !important;
	}
	
	.fan_new .fan_new_cnt .goods_header p {
		font-size: 1.6rem !important;
	}
	
	.fan_new .fan_new_cnt .goods_grid {
		grid-template-columns: 1fr !important;
		gap: 20px !important;
	}
	
	.fan_new .fan_new_cnt .goods_item {
		padding: 15px !important;
	}
	
	.fan_new .fan_new_cnt .goods_item img {
		height: 150px !important;
	}
	
	.fan_new .fan_new_cnt .goods_item h3 {
		font-size: 1.6rem !important;
	}
	
	.fan_new .fan_new_cnt .goods_item p {
		font-size: 1.3rem !important;
	}
	
	/* グレード別グッズセクション（SP版） */
	.fan_new .fan_new_cnt .grade_goods_section {
		padding: 20px !important;
	}
	
	.fan_new .fan_new_cnt .goods_items {
		grid-template-columns: 1fr !important;
		gap: 20px !important;
	}
	
	.fan_new .fan_new_cnt .goods_item {
		padding: 0 0 20px 0 !important;
	}
	
	.fan_new .fan_new_cnt .goods_image img {
		width: 100% !important;
		height: auto !important;
		max-width: none !important;
	}
	
	.fan_new .fan_new_cnt .goods_item.horizontal_layout {
		flex-direction: column !important;
		gap: 20px !important;
	}
	
	.fan_new .fan_new_cnt .goods_item.horizontal_layout .goods_image {
		flex: initial !important;
		width: 100% !important;
	}
	
	/* グレード別イベントセクション（SP版） */
	.fan_new .fan_new_cnt .grade_events_section {
		padding: 0 20px 40px 20px !important;
	}
	
	.fan_new .fan_new_cnt .events_grid {
		grid-template-columns: 1fr !important;
		gap: 30px !important;
	}
	
	.fan_new .fan_new_cnt .events_title {
		font-size: 2rem !important;
		padding-top: 30px !important;
		margin-bottom: 30px !important;
	}
	
	/* 入会ガイドリンク（SP版） */
	.fan_new .fan_new_cnt .guide_link a,
	.fan_new .fan_new_cnt .guide_btn {
		font-size: 32px !important;
	}
	
	/* Content2 詳細比較表（SP版） */
	.fan_new .fan_new_cnt .content2 .detailed_comparison_header h2 {
		font-size: 2.4rem !important;
	}
	
	.fan_new .fan_new_cnt .content2 .detailed_comparison_header p {
		font-size: 1.4rem !important;
	}
	
	/* Content4 FAQ（SP版） */
	.fan_new .fan_new_cnt .content4 .faq_question {
		padding: 20px !important;
	}
	
	.fan_new .fan_new_cnt .content4 .faq_question h3 {
		font-size: 1.6rem !important;
	}
	
	.fan_new .fan_new_cnt .content4 .faq_toggle {
		font-size: 2rem !important;
	}
	
	.fan_new .fan_new_cnt .content4 .faq_item.active .faq_answer {
		padding: 20px !important;
	}
	
	.fan_new .fan_new_cnt .content4 .faq_answer p {
		font-size: 1.4rem !important;
	}

/* モバイル@media内の重複を削除しました */

	.fan_new .fan_new_cnt .content2 .cnt{
		padding: 40px 10px;
	}
	.fan_new .fan_new_cnt .content2 .table table{
		width: 100%;
		margin: 0 auto;
	}
	.fan_new .fan_new_cnt .content2 .table thead th{
		padding: 34px 2vw;
	}
	.fan_new .fan_new_cnt .content2 .table thead th.h_jr span{
		font-size: 1rem;
	}
	.fan_new .fan_new_cnt .content2 .table th, .fan_new .fan_new_cnt .content2 .table td{
		padding: 20px 9px;
	}
	.fan_new .fan_new_cnt .content2 .table,.fan_new .fan_new_cnt .content2 .table td{
		font-size: 1.2rem;
	}
	.fan_new .fan_new_cnt .content2 .table td.gold,.fan_new .fan_new_cnt .content2 .table td.regular,.fan_new .fan_new_cnt .content2 .table td.jr{
		font-size: 1.6rem;
	}
	.fan_new .fan_new_cnt .content2 .table td span{
		font-size: 1rem;
	}
	.fan_new .fan_new_cnt .content2 .table tbody tr th:first-child{
		max-width: 32px;
		padding: 10px;
	}
	.fan_new .fan_new_cnt .content2 .table tbody tr th:nth-child(2){
		width: 120px;
	}
	.fan_new .fan_new_cnt .content2 .table tbody tr td{
		width:90px;
	}
	.fan_new .fan_new_cnt .content2 .note{
		padding: 0px 10px;
		font-size: 1.2rem;
	}
	
	.fan_new .fan_new_cnt .content3{
		background: url(../../images/fan/fan_new/g_bg_sp.png);
		background-size: cover;
		background-position: center;
	}
	.fan_new .fan_new_cnt .content3 .cnt{
		padding: 40px 17px;
	}
	.fan_new .fan_new_cnt .content3 .cnt .goods_list .goods{
		width: 100%;
	}
	.fan_new .fan_new_cnt .content3 .cnt .goods_list .goods{
		font-size: 1.4rem;
		margin-bottom: 30px;
	}
	.fan_new .fan_new_cnt .content3 .cnt .goods_list .goods p.g_ttl{
		margin-bottom: 10px;
		font-size: 2rem;
	}
	
	.fan_new .fan_new_cnt .content5 .cnt{
		padding-bottom: 52px;
	}
	.fan_new .fan_new_cnt .content5 .event_list{
		margin-bottom: 24px;
	}
	.fan_new .fan_new_cnt .content5 .event_list .event{
		width: 100%;
		margin-bottom: 12px;
	}
	.fan_new .fan_new_cnt .content5 .event_list .event .cat_list p{
		font-size: 1.2rem;
	}
	.fan_new .fan_new_cnt .content5 .event_list .event p.e_ttl{
		font-size: 2rem;
		margin-bottom: 10px;
	}
	.fan_new .fan_new_cnt .content5 .event_list .event p{
		font-size: 1.4rem;
	}
	
	.fan_new .fan_new_cnt .content6 .cnt{
		padding: 40px 10px 80px;
	}
	.fan_new .fan_new_cnt .content6 .cnt p.faq_ttl{
		font-size: 4.8rem;
	}
	.fan_new .fan_new_cnt .content6 .cnt p{
		font-size: 1.4rem;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_btn{
		margin: 25px 0px 38px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_btn a{
		width: 48%;
		margin-bottom: 10px;
		text-align: left;
		font-size: 1.4rem;
		padding: 18px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_btn a::before {
		content: '';
		width: 9px;
		height: 9px;
		border-top: solid 2px #fff;
		border-right: solid 2px #fff;
		position: absolute;
		right: 13px;
		top: 50%;
		transition: top 0.5s;
		transform: translateY(-71%) rotate(135deg);
		opacity: 1;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq p.faq_cat{
		font-size: 1.8rem;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_list{
		margin-bottom: 30px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_list .list dl{
		font-size: 1.4rem;
		align-items: flex-start;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_list .list::before, .fan_new .fan_new_cnt .content6 .cnt .faq_list .list::after{
		top: 27px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_list .list dl dd{
		margin-top: 0px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_list .list dl dt{
		font-size: 1.8rem;
		margin-right: 15px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .faq_list .list .a{
		margin-top: 12px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .fan_inq{
		display: block;
	}
	.fan_new .fan_new_cnt .content6 .cnt .fan_inq p{
		width: 100%;
		padding: 20px 20px 15px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .fan_inq p:first-child{
		border-radius: 10px 10px 0px 0px;
	}
	.fan_new .fan_new_cnt .content6 .cnt .fan_inq p:last-child{
		border-radius: 0px 0px 10px 10px;
	}
	
	.fan_new .fan_new_cnt .btn a.nolink{
		padding: 17px 0px;
	}
	.fan_new .fan_new_cnt .btn a.nolink .day p:first-child{
		font-size: 1.4rem;
	}
	.fan_new .fan_new_cnt .btn a.nolink p:last-child{
		font-size: 3rem;
		margin-left: 10px;
	}
	.fan_new .fan_new_cnt .btn a.nolink .day p{
		font-size: 2.1rem;
	}
	.fan_new .fan_new_cnt .btn a.nolink .day p:last-child{
		margin-left: 0px;
	}
	.fan_new .fan_new_cnt .btn a.nolink p:nth-child(2) span{
		font-size: 2.5rem;
	}
	.fan_new .fan_new_cnt .btn a.nolink > div.sp .day span.sp_txts{
		font-size: 1.8rem;
	}
}

@media (max-width: 414px) {
	.fan_new .fan_new_cnt .main_vi{
		min-height: 580px;
	}
}
@media (max-width: 375px) {
	.fan_new .fan_new_cnt .main_vi{
		min-height: 550px;
	}
	.fan_new .fan_new_cnt .content2 .table thead th.h_jr span{
		padding: 5px 3px 3px;
	}
}


.title {
position: relative;
line-height: 120%;
}
.p {
margin: 0;
}
.question-text {
position: relative;
line-height: 120%;
z-index: 0;
}
.arrow-green-vertical-long-icon {
width: 12px;
position: absolute;
margin: 0 !important;
top: calc(50% - 1.34px);
left: 412px;
height: 251px;
object-fit: contain;
z-index: 0;
}
.arrow-red-vertical-icon {
width: 11px;
position: relative;
height: 56px;
object-fit: contain;
z-index: 0;

}
.yes {
width: 30px;
position: absolute;
margin: 0 !important;
top: 10px;
left: 16px;
line-height: 120%;
display: inline-block;
z-index: 1;
}
.yes-container {
margin: 0 !important;
position: absolute;
bottom: -58.66px;
left: 120px;
display: flex;
flex-direction: row;
align-items: flex-start;
justify-content: flex-start;
gap: 16px;
z-index: 2;
text-align: left;
color: #e51616;
}
/* .arrow-green-horizontal-long-icon {
width: 182px;
position: relative;
max-height: 100%;
z-index: 0;
} */
.no {
width: 25px;
position: absolute;
margin: 0 !important;
top: -32px;
left: 17.5px;
line-height: 120%;
display: inline-block;
z-index: 1;
}
.no-container {
margin: 0 !important;
position: absolute;
top: 43px;
left: 239.5px;
display: flex;
flex-direction: column;
align-items: center;
justify-content: flex-start;
gap: 16px;
z-index: 3;
color: #005c30;
}
.no-container img {
position: relative;
top: -2px;

}
.question {
position: absolute;
top: 46.34px;
left: 0px;
background-color: #fff;
border: 1px solid #005c30;
box-sizing: border-box;
width: 240px;
display: flex;
flex-direction: row;
align-items: center;
justify-content: center;
padding: 24px;
gap: 10px;
}
.question-text1 {
position: relative;
line-height: 120%;
text-align: center;
z-index: 0;
}
.arrow-green-horizontal-short-icon {
width: 60px;
position: absolute;
margin: 0 !important;
top: calc(50% - 0px);
left: 240px;
max-height: 100%;
z-index: 1;
}
.no1 {
width: 25px;
position: absolute;
margin: 0 !important;
top: 12.66px;
left: 257px;
line-height: 120%;
display: inline-block;
color: #005c30;
z-index: 2;
}
.yes-container1 {
margin: 0 !important;
position: absolute;
bottom: -58.66px;
left: 120px;
display: flex;
flex-direction: row;
align-items: flex-start;
justify-content: flex-start;
gap: 16px;
z-index: 3;
color: #e51616;
}
.question1 {
position: absolute;
top: 338.34px;
left: 0px;
background-color: #fff;
border: 1px solid #005c30;
box-sizing: border-box;
width: 240px;
display: flex;
flex-direction: row;
align-items: center;
justify-content: center;
padding: 24px;
gap: 10px;
text-align: left;
}
.arrow5-icon {
width: 182px;
position: absolute;
margin: 0 !important;
top: calc(50% + 0.16px);
left: 240px;
max-height: 100%;
z-index: 0;
}
.arrow-green-vertical-short-icon {
width: 12px;
position: absolute;
margin: 0 !important;
top: calc(50% + 0.16px);
left: 415px;

height: 103px;
object-fit: contain;
z-index: 1;
}
.question-text2 {
position: relative;
line-height: 120%;
text-align: center;
z-index: 2;
}
.no2 {
width: 25px;
position: absolute;
margin: 0 !important;
top: 14.16px;
left: 257px;
line-height: 120%;
display: inline-block;
color: #005c30;
z-index: 3;
}
.yes-container2 {
margin: 0 !important;
position: absolute;
bottom: -58.66px;
left: 120px;
display: flex;
flex-direction: row;
align-items: flex-start;
justify-content: flex-start;
gap: 16px;
z-index: 4;
color: #e51616;
}
.question2 {
position: absolute;
top: 338.34px;
left: 300px;
background-color: #fff;
border: 1px solid #005c30;
box-sizing: border-box;
width: 240px;
display: flex;
flex-direction: row;
align-items: center;
justify-content: center;
padding: 24px;
gap: 10px;
text-align: left;
}
.membership-option {
position: absolute;
top: 484.34px;
left: 0px;
border-radius: 10px;
background-color: #b79831;
width: 240px;
display: flex;
flex-direction: row;
align-items: center;
justify-content: center;
padding: 24px;
box-sizing: border-box;
font-size: 24px;
color: #fff;
cursor: pointer;
transition: transform 0.2s, box-shadow 0.2s;
}
.membership-option:hover {
transform: translateY(-2px);
box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}
.membership-option1 {
position: absolute;
top: 484.34px;
left: 300px;
border-radius: 10px;
background-color: #005c30;
width: 240px;
display: flex;
flex-direction: row;
align-items: center;
justify-content: center;
padding: 24px;
box-sizing: border-box;
font-size: 24px;
color: #fff;
cursor: pointer;
transition: transform 0.2s, box-shadow 0.2s;
}
.membership-option1:hover {
transform: translateY(-2px);
box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}
.membership-option2 {
position: absolute;
top: 484.34px;
left: 600px;
border-radius: 10px;
background-color: #a9c31a;
width: 240px;
display: flex;
flex-direction: row;
align-items: center;
justify-content: center;
padding: 24px;
box-sizing: border-box;
font-size: 24px;
color: #fff;
cursor: pointer;
transition: transform 0.2s, box-shadow 0.2s;
}
.membership-option2:hover {
transform: translateY(-2px);
box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}
.question-text3 {
position: relative;
line-height: 120%;
text-align: center;
z-index: 3;
}
.arrow-green-horizontal-long-icon1 {
width: 179px;
position: absolute;
margin: 0 !important;
top: calc(50% + 0.16px);
left: 240px;
max-height: 100%;
z-index: 2;
}
.no3 {
width: 25px;
position: absolute;
margin: 0 !important;
top: 14.16px;
left: 257px;
line-height: 120%;
display: inline-block;
color: #005c30;
z-index: 1;
}
.yes-container3 {
margin: 0 !important;
position: absolute;
bottom: -58.66px;
left: 120px;
display: flex;
flex-direction: row;
align-items: flex-start;
justify-content: flex-start;
gap: 16px;
z-index: 0;
color: #e51616;
}
.question3 {
position: absolute;
top: 192.34px;
left: 0px;
background-color: #fff;
border: 1px solid #005c30;
box-sizing: border-box;
width: 240px;
display: flex;
flex-direction: row;
align-items: center;
justify-content: center;
padding: 24px;
gap: 10px;
text-align: left;
}
.start {
position: absolute;
top: 0px;
left: 54px;
font-size: 32px;
line-height: 120%;
color: #005c30;
}

/* Arrow Legend Styles */
.arrow-legend {
position: absolute;
right: 0px;
top: 0px;
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 20px;
}

.legend-item {
display: flex;
align-items: center;
gap: 10px;
width: 100px;
justify-content: flex-end;
}

.legend-yes {
font-family: 'Noto Sans JP';
font-weight: 700;
font-size: 16px;
line-height: 120%;
color: #E51616;
}

.legend-no {
font-family: 'Noto Sans JP';
font-weight: 700;
font-size: 16px;
line-height: 120%;
color: #005C30;
}

.legend-arrow-red {
width: 8px;
height: 30px;
}

.legend-arrow-green {
width: 40px;
height: 8px;
}
.flowchart {
width: 840px;
position: relative;
height: 561.3px;
text-align: center;
font-size: 16px;
}
.member-grade-chart {
width: 100%;
position: relative;
background-color: #f2f4f3;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 80px 10px;
box-sizing: border-box;
gap: 40px;
text-align: left;
font-size: 42px;
color: #000;
font-family: 'Noto Sans JP';
}

/* Responsive styles for member-grade-chart */
@media (max-width: 767px) {
    .member-grade-chart {
        padding: 40px 15px;
        font-size: 24px;
        gap: 20px;
    }
    
    /* Reset PC absolute positioning for most elements */
    .member-grade-chart .flowchart > *:not(.arrow-legend) {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        bottom: auto !important;
        transform: none !important;
        margin: 0 !important;
    }
    
    /* Also reset specific elements to ensure override */
    .member-grade-chart .question,
    .member-grade-chart .question1,
    .member-grade-chart .question2,
    .member-grade-chart .question3,
    .member-grade-chart .membership-option,
    .member-grade-chart .membership-option1,
    .member-grade-chart .membership-option2 {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        bottom: auto !important;
        transform: none !important;
        margin: 0 !important;
    }
    
    .member-grade-chart .yes-container,
    .member-grade-chart .yes-container1,
    .member-grade-chart .yes-container2,
    .member-grade-chart .yes-container3,
    .member-grade-chart .no-container,
    .member-grade-chart .no1,
    .member-grade-chart .no2,
    .member-grade-chart .yes,
    .member-grade-chart .no {
        position: static !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        bottom: auto !important;
        transform: none !important;
        margin: 0 !important;
    }
    
    .member-grade-chart .title {
        font-size: 24px;
        line-height: 1.4;
        text-align: center;
        margin-bottom: 30px;
        font-weight: bold;
    }
    
    /* Flowchart container for mobile with gradient overlay */
    .member-grade-chart {
        position: relative !important;
    }
    
    /* Ensure position relative on mobile too */
    @media (max-width: 767px) {
        .member-grade-chart {
            position: relative !important;
        }
    }
    
    .member-grade-chart .flowchart {
        transition: max-height 0.5s ease;
    }
    
    .member-grade-chart.collapsed .flowchart {
        max-height: 400px;
        overflow: hidden;
        position: relative;
    }
    
    .member-grade-chart:not(.collapsed) .flowchart {
        max-height: none;
        overflow: visible;
    }
    
    /* White gradient overlay */
    .member-grade-chart.collapsed::after {
        content: "";
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 700px;
        background: linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(255,255,255,0.6) 20%, rgba(255,255,255,0.9) 40%, rgba(255,255,255,1) 50%);
        pointer-events: none;
        z-index: 50;
    }
    
    /* Show more button - hidden by default on PC */
    @media (min-width: 768px) {
        .show-more-btn {
            display: none !important;
        }
    }
    
    /* Ensure button is hidden on PC with higher specificity */
    @media (min-width: 768px) {
        body .show-more-btn,
        .fan_new .show-more-btn,
        .member-grade-chart .show-more-btn {
            display: none !important;
        }
    }
    
    /* Show button only on mobile */
    @media (max-width: 767px) {
        .member-grade-chart .show-more-btn {
            display: block !important;
            position: absolute !important;
            bottom: 220px !important;
            left: 50% !important;
            transform: translateX(-50%) !important;
            padding: 12px 20px;
            background: transparent;
            color: #005C30;
            border: none;
            font-size: 20px;
            font-weight: bold;
            cursor: pointer;
            z-index: 100;
            transition: all 0.3s ease;
            font-family: 'Noto Sans JP', sans-serif;
            text-decoration: none;
            white-space: nowrap;
            top: auto !important;
            right: auto !important;
            position: absolute !important;
        }
        
        /* Ensure the container has min-height for button positioning */
        .member-grade-chart {
            position: relative !important;
            overflow: visible !important;
        }
        
        .member-grade-chart.collapsed {
            min-height: 450px;
            position: relative !important;
            overflow: visible !important;
        }
        
        .show-more-btn:hover {
            opacity: 0.7;
            transform: translateX(-50%) scale(1.05);
        }
    }
    
    .show-more-btn:hover {
        opacity: 0.7;
        transform: translateX(-50%) scale(1.05);
    }
    
    /* Hide button when expanded on mobile */
    @media (max-width: 767px) {
        .member-grade-chart:not(.collapsed) .show-more-btn {
            display: none !important;
            visibility: hidden !important;
            opacity: 0 !important;
            pointer-events: none !important;
        }
    }
    
    /* Hide gradient when expanded */
    .member-grade-chart:not(.collapsed)::after {
        display: none;
    }
    
    
    /* Remove this duplicate rule as it's now included above */
    
    /* Hide show more button on PC */
    @media (min-width: 768px) {
        .show-more-btn,
        .member-grade-chart .show-more-btn,
        .member-grade-chart.collapsed .show-more-btn {
            display: none !important;
        }
        .member-grade-chart.collapsed .flowchart {
            max-height: none !important;
            overflow: visible !important;
        }
        .member-grade-chart.collapsed::after {
            display: none !important;
        }
    }
    
    .flowchart {
        width: 100% !important;
        height: auto !important;
        min-height: 560px !important;
        position: relative;
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto auto auto auto;
        column-gap: 30px;
        row-gap: 5px;
        align-items: start;
        padding: 0 15px;
        box-sizing: border-box;
    }
    
    /* Debug: show grid areas */
    .member-grade-chart .flowchart > * {
        /* border: 1px dashed #ccc; */
    }
    
    /* Hide START button on mobile */
    .start {
        display: none !important;
    }
    
    /* Questions positioning - Left column */
    .member-grade-chart .flowchart .question {
        grid-column: 1 / 2;
        grid-row: 1;
        position: relative !important;
        top: auto !important;
        left: auto !important;
    }
    
    .member-grade-chart .flowchart .question3 {
        grid-column: 1 / 2;
        grid-row: 2;
        position: relative !important;
        top: auto !important;
        left: auto !important;
    }
    
    .member-grade-chart .flowchart .question1 {
        grid-column: 1 / 2;
        grid-row: 3;
        position: relative !important;
        top: auto !important;
        left: auto !important;
    }
    
    /* Question positioning - Right column */
    .member-grade-chart .flowchart .question2 {
        grid-column: 2 / 3;
        grid-row: 3;
        position: relative !important;
        top: auto !important;
        left: auto !important;
    }
    
    /* Questions common styling */
    .question,
    .question1,
    .question2,
    .question3 {
        width: 100% !important;
        padding: 12px !important;
        margin: 0 !important;
        height: 86px !important;
        background-color: #fff;
        border: 1px solid #005c30;
        box-sizing: border-box;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
    }
    
    .question-text,
    .question-text1,
    .question-text2,
    .question-text3 {
        font-size: 14px !important;
        line-height: 120% !important;
        text-align: center;
        font-weight: 700;
        font-family: 'Noto Sans JP', sans-serif;
    }
    
    .question-text p,
    .question-text1 p,
    .question-text2 p,
    .question-text3 p,
    .member-grade-chart .flowchart .question-text,
    .member-grade-chart .flowchart .question-text1,
    .member-grade-chart .flowchart .question-text2,
    .member-grade-chart .flowchart .question-text3 {
        margin: 0 !important;
        font-size: 14px !important;
    }
    
    /* Membership options positioning */
    .member-grade-chart .flowchart .membership-option {
        grid-column: 1 / 2;
        grid-row: 4;
        position: relative !important;
        top: auto !important;
        left: auto !important;
        margin-top: 0 !important;
    }
    
    .member-grade-chart .flowchart .membership-option1 {
        grid-column: 2 / 3;
        grid-row: 2;
        position: relative !important;
        top: auto !important;
        left: auto !important;
        align-self: start;
        margin-top: 5px !important;
    }
    
    .member-grade-chart .flowchart .membership-option2 {
        grid-column: 2 / 3 !important;
        grid-row: 4 !important;
        position: relative !important;
        top: auto !important;
        left: auto !important;
        align-self: start !important;
        margin: 0 !important;
    }
    
    /* Membership options styling */
    .membership-option,
    .membership-option1,
    .membership-option2 {
        width: 100% !important;
        padding: 24px !important;
        margin: 0 !important;
        height: 72px !important;
        font-size: 20px !important;
        font-weight: 700 !important;
        border-radius: 10px !important;
        cursor: pointer;
        text-align: center;
        color: white !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-family: 'Noto Sans JP', sans-serif;
    }
    
    .membership-option .title,
    .membership-option1 .title,
    .membership-option2 .title {
        font-size: 14px !important;
        margin: 0 !important;
        line-height: 120% !important;
    }
    
    /* Reduce all text size in cards on mobile */
    .member-grade-chart .flowchart .question *,
    .member-grade-chart .flowchart .question1 *,
    .member-grade-chart .flowchart .question2 *,
    .member-grade-chart .flowchart .question3 *,
    .member-grade-chart .flowchart .membership-option *,
    .member-grade-chart .flowchart .membership-option1 *,
    .member-grade-chart .flowchart .membership-option2 * {
        font-size: 14px !important;
    }
    
    /* More specific selectors to ensure font size is applied */
    .member-grade-chart .flowchart .question .question-text,
    .member-grade-chart .flowchart .question1 .question-text1,
    .member-grade-chart .flowchart .question2 .question-text2,
    .member-grade-chart .flowchart .question3 .question-text3,
    .member-grade-chart .flowchart .question .question-text p,
    .member-grade-chart .flowchart .question1 .question-text1 p,
    .member-grade-chart .flowchart .question2 .question-text2 p,
    .member-grade-chart .flowchart .question3 .question-text3 p {
        font-size: 14px !important;
    }
    
    /* Hide ALL desktop arrows on mobile */
    .member-grade-chart .flowchart .arrow-green-vertical-long-icon,
    .member-grade-chart .flowchart .arrow-green-horizontal-long-icon,
    .member-grade-chart .flowchart .arrow-green-horizontal-long-icon1,
    .member-grade-chart .flowchart .arrow-green-horizontal-short-icon,
    .member-grade-chart .flowchart .arrow-green-vertical-short-icon,
    .member-grade-chart .flowchart .arrow5-icon,
    .member-grade-chart .flowchart .arrow-red-vertical-icon {
        display: none !important;
    }
    
    /* YES/NO positioning in grid */
    .member-grade-chart .flowchart .yes-container {
        grid-column: 1 / 2 !important;
        grid-row: 2 !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        margin-top: -15px !important;
    }
    
    .member-grade-chart .flowchart .yes-container3 {
        grid-column: 1 / 2 !important;
        grid-row: 3 !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        margin-top: -15px !important;
    }
    
    .member-grade-chart .flowchart .yes-container1 {
        grid-column: 1 / 2 !important;
        grid-row: 4 !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        margin-top: -15px !important;
    }
    
    .member-grade-chart .flowchart .yes-container2 {
        grid-column: 2 / 3 !important;
        grid-row: 2 !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        margin-top: -15px !important;
    }
    
    .member-grade-chart .flowchart .no-container {
        grid-column: 2 / 3 !important;
        grid-row: 1 !important;
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 8px !important;
        margin-left: -30px !important;
    }
    
    /* Hide NO1 and NO2 on mobile */
    .member-grade-chart .flowchart .no1,
    .member-grade-chart .flowchart .no2 {
        display: none !important;
    }
    
    /* Hide arrow images inside containers */
    .member-grade-chart .flowchart .yes-container img,
    .member-grade-chart .flowchart .yes-container1 img,
    .member-grade-chart .flowchart .yes-container2 img,
    .member-grade-chart .flowchart .yes-container3 img,
    .member-grade-chart .flowchart .no-container img {
        display: none !important;
    }
    
    /* Hide YES/NO text in flowchart */
    .member-grade-chart .flowchart .yes, 
    .member-grade-chart .flowchart .no, 
    .member-grade-chart .flowchart .no1, 
    .member-grade-chart .flowchart .no2, 
    .member-grade-chart .flowchart .no3 {
        display: none !important;
    }
    
    /* Keep YES/NO visible in legend */
    .member-grade-chart .flowchart .legend-yes {
        color: #E51616 !important;
        font-size: 12px !important;
        font-weight: 700 !important;
        font-family: 'Noto Sans JP', sans-serif;
    }
    
    .member-grade-chart .flowchart .legend-no {
        color: #005C30 !important;
        font-size: 12px !important;
        font-weight: 700 !important;
        font-family: 'Noto Sans JP', sans-serif;
    }
    
    /* Arrow legend at top right */
    .member-grade-chart .flowchart .arrow-legend {
        position: absolute !important;
        top: 0 !important;
        right: 15px !important;
        left: auto !important;
        bottom: auto !important;
        width: 120px !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        z-index: 100 !important;
        padding: 10px;
    }
    
    .member-grade-chart .flowchart .legend-item {
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
        gap: 5px !important;
        font-size: 12px !important;
    }
    
    /* Right align NO in legend */
    .member-grade-chart .flowchart .legend-item:last-child {
        justify-content: flex-end !important;
    }
    
    .member-grade-chart .flowchart .legend-yes,
    .member-grade-chart .flowchart .legend-no {
        width: auto !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    /* Mobile arrows - red dotted vertical arrows for left column questions (except first one) */
    .member-grade-chart .flowchart .question3::after,
    .member-grade-chart .flowchart .question1::after {
        content: "";
        position: absolute;
        bottom: -60px;
        left: 50%;
        transform: translateX(-50%);
        width: 12px;
        height: 60px;
        background-image: url("data:image/svg+xml,%3Csvg width='12' height='60' viewBox='0 0 12 60' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 60L11.7735 50L0.226499 50L6 60ZM5 4.37114e-08L5 1.875L7 1.875L7 -4.37114e-08L5 4.37114e-08ZM5 5.625L5 9.375L7 9.375L7 5.625L5 5.625ZM5 13.125L5 16.875L7 16.875L7 13.125L5 13.125ZM5 20.625L5 24.375L7 24.375L7 20.625L5 20.625ZM5 28.125L5 31.875L7 31.875L7 28.125L5 28.125ZM5 35.625L5 39.375L7 39.375L7 35.625L5 35.625ZM5 43.125L5 46.875L7 46.875L7 43.125L5 43.125ZM5 50.625L5 54.375L7 54.375L7 50.625L5 50.625ZM6 60L11.7735 50L0.226499 50L6 60ZM5 4.37114e-08L5 1.875L7 1.875L7 -4.37114e-08L5 4.37114e-08ZM5 5.625L5 9.375L7 9.375L7 5.625L5 5.625ZM5 13.125L5 16.875L7 16.875L7 13.125L5 13.125ZM5 20.625L5 24.375L7 24.375L7 20.625L5 20.625ZM5 28.125L5 31.875L7 31.875L7 28.125L5 28.125ZM5 35.625L5 39.375L7 39.375L7 35.625L5 35.625ZM5 43.125L5 46.875L7 46.875L7 43.125L5 43.125ZM5 50.625L5 54.375L7 54.375L7 50.625L5 50.625Z' fill='%23E51616'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
    }
    
    /* For first question, combine red arrow below with green vertical line */
    .member-grade-chart .flowchart .question::after {
        content: "";
        position: absolute;
        bottom: -60px;
        left: 50%;
        transform: translateX(-50%);
        width: 12px;
        height: 60px;
        background-image: url("data:image/svg+xml,%3Csvg width='12' height='60' viewBox='0 0 12 60' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 60L11.7735 50L0.226499 50L6 60ZM5 4.37114e-08L5 1.875L7 1.875L7 -4.37114e-08L5 4.37114e-08ZM5 5.625L5 9.375L7 9.375L7 5.625L5 5.625ZM5 13.125L5 16.875L7 16.875L7 13.125L5 13.125ZM5 20.625L5 24.375L7 24.375L7 20.625L5 20.625ZM5 28.125L5 31.875L7 31.875L7 28.125L5 28.125ZM5 35.625L5 39.375L7 39.375L7 35.625L5 35.625ZM5 43.125L5 46.875L7 46.875L7 43.125L5 43.125ZM5 50.625L5 54.375L7 54.375L7 50.625L5 50.625ZM6 60L11.7735 50L0.226499 50L6 60ZM5 4.37114e-08L5 1.875L7 1.875L7 -4.37114e-08L5 4.37114e-08ZM5 5.625L5 9.375L7 9.375L7 5.625L5 5.625ZM5 13.125L5 16.875L7 16.875L7 13.125L5 13.125ZM5 20.625L5 24.375L7 24.375L7 20.625L5 20.625ZM5 28.125L5 31.875L7 31.875L7 28.125L5 28.125ZM5 35.625L5 39.375L7 39.375L7 35.625L5 35.625ZM5 43.125L5 46.875L7 46.875L7 43.125L5 43.125ZM5 50.625L5 54.375L7 54.375L7 50.625L5 50.625Z' fill='%23E51616'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
    }
    
    /* Red arrow going UP from question2 (right column) */
    .member-grade-chart .flowchart .question2::before {
        content: "";
        position: absolute;
        top: -69px;
        left: 50%;
        transform: translateX(-50%) rotate(180deg);
        width: 12px;
        height: 69px;
        background-image: url("data:image/svg+xml,%3Csvg width='12' height='69' viewBox='0 0 12 69' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 69L11.7735 59L0.226499 59L6 69ZM5 0L5 1.875L7 1.875L7 0L5 0ZM5 5.625L5 9.375L7 9.375L7 5.625L5 5.625ZM5 13.125L5 16.875L7 16.875L7 13.125L5 13.125ZM5 20.625L5 24.375L7 24.375L7 20.625L5 20.625ZM5 28.125L5 31.875L7 31.875L7 28.125L5 28.125ZM5 35.625L5 39.375L7 39.375L7 35.625L5 35.625ZM5 43.125L5 46.875L7 46.875L7 43.125L5 43.125ZM5 50.625L5 54.375L7 54.375L7 50.625L5 50.625ZM5 58.125L5 61.875L7 61.875L7 58.125L5 58.125Z' fill='%23E51616'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
    }
    
    /* Remove extra margins as we use grid gap */
    .member-grade-chart .flowchart .question,
    .member-grade-chart .flowchart .question3,
    .member-grade-chart .flowchart .question1 {
        margin-bottom: 0 !important;
    }
    
    /* Add top margin to question2 for upward arrow */
    .member-grade-chart .flowchart .question2 {
        margin-top: 0px !important;
    }
    
    /* Green arrow from first question to right */
    .member-grade-chart .flowchart .question::before {
        content: "";
        position: absolute;
        top: 50%;
        right: -15px; /* Start from edge of card */
        transform: translateY(-50%);
        width: 15px;
        height: 2px;
        background: #005C30;
    }
    
    /* Vertical green line in the middle of the gap between columns */
    .member-grade-chart .flowchart::after {
        content: "";
        position: absolute;
        top: 42px;
        left: 50%;
        transform: translateX(-50%);
        width: 2px;
        height: 291px;
        background: #005C30;
    }
    
    /* Green line from question3 (second row) to right */
    .member-grade-chart .flowchart .question3::before {
        content: "";
        position: absolute;
        top: 50%;
        right: -15px; /* Start from edge of card */
        transform: translateY(-50%);
        width: 15px;
        height: 2px;
        background: #005C30;
    }
    
    /* Green arrow from question1 (third row) to question2 */
    .member-grade-chart .flowchart .question1::before {
        content: "";
        position: absolute;
        top: 50%;
        right: -30px;
        transform: translateY(-50%);
        width: 30px;
        height: 12px;
        background-image: url("data:image/svg+xml,%3Csvg width='30' height='12' viewBox='0 0 30 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 6L20 0.226497V11.7735L30 6ZM0 6V7H21V6V5H0V6Z' fill='%23005C30'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
    }
    
    /* Green arrow for question2 */
    .question2::after {
        content: "";
        position: absolute;
        bottom: -60px;
        left: 50%;
        transform: translateX(-50%);
        width: 12px;
        height: 60px;
        background-image: url("data:image/svg+xml,%3Csvg width='12' height='60' viewBox='0 0 12 60' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 60L11.7735 50L0.226499 50L6 60ZM6 0L5 4.37114e-08L5 51L6 51L7 51L7 -4.37114e-08L6 0Z' fill='%23005C30'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
    }
    
}
/* Hide show-more button on PC screens */
@media (min-width: 768px) {
    .show-more-btn {
        display: none \!important;
        visibility: hidden \!important;
    }
}


/* Visitor Button */
.visitor-button {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 16px 20px;
    gap: 24px;
    width: 347px;
    height: 56px;
    background: #FFFFFF;
    border: 2px solid #005C30;
    border-radius: 8px;
    flex: none;
    order: 2;
    align-self: stretch;
    flex-grow: 0;
    cursor: pointer;
    transition: all 0.3s ease;
    margin-top: 20px;
}

.visitor-button span {
    margin: 0 auto;
    width: 180px;
    height: 24px;
    font-family: "Noto Sans JP", sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 20px;
    line-height: 120%;
    display: flex;
    align-items: center;
    text-align: center;
    justify-content: center;
    color: #005C30;
    flex: none;
    order: 0;
    flex-grow: 0;
}

.visitor-button:hover {
    background: #005C30;
}

.visitor-button:hover span {
    color: #FFFFFF;
}

/* Hide button on PC */
@media (min-width: 768px) {
    .visitor-button {
        display: none !important;
    }
}

/* Mobile adjustments */
@media (max-width: 767px) {
    .visitor-button {
        width: 100%;
        max-width: 347px;
        margin: 20px auto 0;
    }
}