/* --- 全体リセット & 共通スタイル --- */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}
html {
    scroll-behavior: smooth;
}
body {
    font-family: "Noto Sans JP", sans-serif;
    background-color: #d60011;
    background-image: url("https://s3-ap-northeast-1.amazonaws.com/pf-web/fanclubs/174/assets/259/statics/yoshiki2026/images/bg.jpg");
    background-size: cover;
    background-attachment: fixed;
    color: #333333;
    line-height: 1.6;
    padding: 40px 20px;
}
.container {
    max-width: 800px;
    margin: 0 auto;
}

/* --- ヒーローイメージ --- */
.hero-wrapper {
    max-width: 1240px;
    width: 100%;
    margin: 0 auto 40px auto;
    text-align: center;
}
.hero-image {
    width: 100%;
    max-width: 1240px;
height: auto;
aspect-ratio: 1240 / 700;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    font-weight: bold;
    border-radius: 8px;
}
.hero-image img {
    width: 100%;
}

/* --- ヘッダー領域 --- */
header {
    text-align: center;
    color: #ffffff;
    margin-bottom: 30px;
    padding: 20px 10px;
}
.main-title {
    font-family: "Noto Serif JP", serif;
    font-size: 2.2rem;
    font-weight: 700;
    letter-spacing: 2px;
    line-height: 1.45;
    margin-bottom: 32px;
}
.lead-text {
    font-size: 0.9rem;
    line-height: 1.8;
    max-width: 640px;
    margin: 0 auto;
    color: #ffffff;
}
.lead-text p {
    margin-bottom: 15px;
}

/* --- CONTENTS (目次ナビゲーション) --- */
.contents-section {
    text-align: center;
    margin-bottom: 40px;
}
.contents-headline {
    font-family: "Noto Serif JP", serif;
    color: #ffffff;
    font-size: 1.2rem;
    font-weight: bold;
    letter-spacing: 2px;
    margin-bottom: 20px;
}
.contents-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-width: 760px;
    margin: 0 auto;
}
.contents-item {
    background-color: #ffffff;
    border-radius: 6px;
    padding: 12px 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    text-decoration: none;
    color: #333333;
    transition: opacity 0.2s;
    text-align: left;
}
.contents-item:hover {
    opacity: 0.9;
}
.contents-text-group {
    flex-grow: 1;
}
.contents-title-ja {
    font-weight: 900;
    font-size: 1.1rem;
    color: #AC8630;
}
.contents-title-en {
    font-size: 0.8rem;
    color: #AC8630;
    font-weight: bold;
    margin-top: 2px;
}

/* プランバッジの共通スタイル */
.badge-group {
    display: flex;
    gap: 6px;
    margin-right: 15px;
    align-items: center;
}
.badge {
    display: inline-block;
  width: 100%;
  height: 100%;
    min-width: 75px;
aspect-ratio: 125 / 34;
    padding: 0;
}
.badge img {
    width: 100%;
}
.badge.standard {
    background-color: #0066cc; /* スタンダード用の青 */
}
.badge.premium {
    background-color: #cc0033; /* プレミアム用の赤 */
}

.contents-list .badge {
    width: 124px;
}

section.card  .badge {
    width: 84px;
}


/* 右側の矢印アイコン */
.arrow-icon {
    color: #AC8630;
    font-weight: bold;
    font-size: 1.2rem;
}

/* --- コンテンツカード共通 --- */
.card {
    background-color: #ffffff;
    border-radius: 12px;
    padding: 50px 40px;
    margin-bottom: 40px;
    /* ページ内リンクでジャンプした際のトブ先の余白確保（ヘッダー等の被り防止用） */
    scroll-margin-top: 20px;
}

.h3_bg {
    padding-top: 32px;
    padding-bottom: 20px;
    padding-left: 20px;
    padding-right: 20px;
    margin-bottom: 44px;
    margin-left: auto;
    margin-right: auto;
    border-image-slice: 71 66 71 66;
    border-image-width: 72px 72px 72px 72px;
    border-image-outset: 0px 0px 0px 0px;
    border-image-repeat: round round;
    border-image-source: url("https://s3-ap-northeast-1.amazonaws.com/pf-web/fanclubs/174/assets/259/statics/yoshiki2026/images/h3_bg.svg");
    border-style: solid;
    margin-bottom: 30px;
    max-width: 682px;
    width: 100%;
}

.card-title {
    text-align: center;
    color: #AC8630;
    font-size: 1.8rem;
    font-weight: 900;
    margin-bottom: 5px;
}
.card-subtitle {
    text-align: center;
    color: #AC8630;
    font-size: 1.1rem;
    font-weight: bold;
     margin-bottom: 16px;
}

/* カード内のプランバッジ配置 */
.card-badge-container {
    text-align: center;
    margin-bottom: 20px;
}

/* --- テキスト装飾・リスト --- */
.section-desc {
    text-align: center;
    font-size: 0.95rem;
    margin-bottom: 25px;
    font-weight: 500;
}
.info-list {
    list-style: none;
    max-width: 580px;
    margin: 0 auto 25px auto;
    font-size: 0.9rem;
}
.info-list li {
    margin-bottom: 8px;
    padding-left: 15px;
    position: relative;
}
.info-list li::before {
    content: "・";
    position: absolute;
    left: 0;
    color: #AC8630;
}
.highlight-box {
    margin: 20px auto;
    width: 580px;
    max-width: 100%;
    font-size: 0.9rem;
}
.highlight-title {
    color: #d60011;
    font-weight: bold;
    margin-bottom: 8px;
}
.note {
    font-size: 0.8rem;
    color: #555555;
    max-width: 580px;
    margin: 15px auto 0 auto;
    line-height: 1.5;
}
.en-text {
    border-top: 1px dashed #ddd;
    margin-top: 30px;
    padding-top: 25px;
    color: #555555;
    font-size: 0.85rem;
}

/* --- ボタン --- */
.btn-container {
    text-align: center;
    margin-top: 30px;
}
.btn {
    display: inline-block;
    background-color: #000000;
    color: #ffffff;
    text-decoration: none;
    font-weight: bold;
    padding: 14px 0;
    border-radius: 4px;
    font-size: 1rem;
    transition: background-color 0.3s;
    min-width: 260px;
    margin: 6px;
}
.btn:hover {
    background-color: #333333;
    color: #ffffff;
}
.btn-sub {
    font-size: 0.8rem;
    color: #444;
    margin-top: 10px;
    text-align: center;
}

/* --- スケジュールテーブル --- */
.schedule-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 20px;
    font-size: 0.85rem;
}
.schedule-table th, .schedule-table td {
    border-bottom: 1px solid #eee;
    padding: 12px 10px;
    text-align: left;
}
.schedule-table th {
    background-color: #f9f9f9;
    color: #333;
}
.tag-vip {
    background-color: #dfba6b;
    color: #fff;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 0.75rem;
    font-weight: bold;
}

/* --- フッター --- */
footer {
    text-align: center;
    color: #ffffff;
    font-size: 0.8rem;
    margin-top: 60px;
    opacity: 0.8;
    line-height: 1.6;
}

/* ==========================================================================
   モバイル向けレイアウト (768px以下)
   ========================================================================== */
@media screen and (max-width: 768px) {
    body {
padding: 20px 10px;
    }
    .hero-image {
font-size: 1.2rem;
    }
    .hero-wrapper {
margin-bottom: 25px;
    }
    .main-title {
font-size: 1.5rem;
    }
    .sub-title {
font-size: 1.3rem;
margin-bottom: 20px;
    }
    .lead-text {
font-size: 0.8rem;
    }
    
    /* スマホ時のCONTENTSレイアウト調整 */
    .contents-item {
flex-direction: column;
align-items: flex-start;
padding: 15px;
position: relative;
    }
    .badge-group {
margin-top: 10px;
margin-right: 0;
    }
    .arrow-icon {
position: absolute;
right: 15px;
top: 50%;
transform: translateY(-50%);
    }

    .card {
padding: 30px 15px;
margin-bottom: 25px;
    }
    .card-title {
font-size: 1.4rem;
    }
    .card-subtitle {
font-size: 0.8rem;
margin-bottom: 20px;
    }
.highlight-box {
    padding: 0 8px;
}
    .btn {
/*width: 100%;*/
padding: 12px 20px;
font-size: 0.95rem;
    }
    .schedule-table th, .schedule-table td {
padding: 8px 4px;
font-size: 0.75rem;
    }
}


/*-----------------------------
  fadein
-----------------------------*/
.fadein {
  opacity: 0;
  visibility: hidden;
  transform: translateY(40px);
  transition: all 1s cubic-bezier(.33,.01,.06,.99);
}

.fadein.is-show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0px);
}