/*
Theme Name: JASSMEP
Theme URI: https://jassmep.org
Description: 日本学校音楽教育実践学会 公式WordPressテーマ
Version: 1.0.0
Author: JASSMEP
Author URI: https://jassmep.org
Text Domain: jassmep
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/

/* ==========================================================
   style.css - 全ページ共通スタイル
   日本学校音楽教育実践学会（JASSMEP）ホームページ

   【テーマカラー】
   メインカラー: #C9788A（ローズピンク）
   ホバーカラー: #E8A0B0（明るいピンク）
   フッターカラー: #6BA896（グリーン）
   ボーダーカラー: #f0d8de（淡いピンク）
   背景ピンク:   #fdf0f3（極淡ピンク）
   ========================================================== */

/* ==========================================================
   リセット・ベーススタイル
   - ページ全体のフォント・余白・背景色を初期化
   - リンクの基本スタイルを設定
   ========================================================== */
body {
    font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    color: #333;
    margin: 0;
    padding: 0;
    background: #fff;
}
/* リンク: 通常時は黒、ホバー時はテーマカラー */
a { color: #333; text-decoration: none; }
a:hover { color: #C9788A; }

/* ==========================================================
   PCヘッダーバー（.top-header）
   - PC表示時のみ表示されるヘッダー
   - ロゴ・学会名・Englishボタンなどを横並びに配置
   - SP表示時は display:none になる（レスポンシブ参照）
   ========================================================== */
.top-header {
    display: flex;
    align-items: center;
    padding: 15px 30px;
    background: #fff;
    border-bottom: 1px solid #f0d8de; /* 下線: 淡いピンク */
}
/* ヘッダーロゴ: 固定サイズ80x60px */
.top-header .header-logo {
    display: inline-block;
    width: 80px;
    height: 60px;
    flex-shrink: 0;
    margin-right: 15px;
}
.top-header .header-logo img {
    width: 80px;
    height: 60px;
    display: block;
}
/* ヘッダー情報エリア: ロゴの右側に伸縮して配置 */
.top-header .header-info {
    flex: 1;
}
/* 英語名（小さく灰色で表示） */
.top-header .header-info .lab-name-en {
    font-size: 12px;
    color: #888;
    letter-spacing: 0.5px;
    line-height: 1.3;
}
/* 日本語の学会名（大きく太字で表示） */
.top-header .header-info .lab-name {
    font-size: 32px;
    font-weight: bold;
    line-height: 1.4;
}
/* ヘッダー右側: お問い合わせ・Englishボタンなどを横並び */
.top-header .header-right {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-shrink: 0;
}
.top-header .header-right a {
    font-size: 16px;
    color: #333;
}
/* アイコンとテキストの間隔 */
.top-header .header-right a i {
    margin-right: 4px;
}
/* Englishボタン: テーマカラーの枠線付きボタン */
.top-header .header-right .btn-english {
    display: inline-block;
    border: 1px solid #C9788A;
    padding: 4px 14px;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 1px;
    color: #C9788A;
}
/* Englishボタン ホバー時: 背景をテーマカラーに、文字を白に反転 */
.top-header .header-right .btn-english:hover {
    background: #C9788A;
    color: #fff;
}

/* ==========================================================
   SPヘッダー（.sp-top-header）
   - スマートフォン表示時のみ表示されるヘッダー
   - ロゴ・学会名・ハンバーガーメニューボタンを横並びに配置
   - PC表示時は display:none（デフォルト）
   ========================================================== */
.sp-top-header {
    display: none; /* デフォルトは非表示、SP時にflex表示 */
    align-items: center;
    padding: 10px 15px;
    background: #fff;
    border-bottom: 1px solid #f0d8de;
}
/* SPロゴ: PCより小さい53x40px */
.sp-top-header .sp-logo-box {
    width: 53px;
    height: 40px;
    flex-shrink: 0;
    margin-right: 10px;
}
.sp-top-header .sp-logo-box img {
    width: 53px;
    height: 40px;
    display: block;
}
/* SP学会名エリア: ロゴの右側に伸縮配置 */
.sp-top-header .sp-header-info {
    flex: 1;
}
/* SP英語名（かなり小さめ） */
.sp-top-header .sp-header-info .sp-lab-en {
    font-size: 8px;
    color: #888;
    letter-spacing: 0.3px;
    line-height: 1.3;
}
/* SP日本語学会名 */
.sp-top-header .sp-header-info .sp-lab {
    font-size: 20px;
    font-weight: bold;
}
/* ハンバーガーメニューボタン */
.sp-top-header .sp-menu-btn {
    background: none;
    border: none;
    cursor: pointer;
    text-align: center;
    padding: 2px 5px;
}
/* メニューアイコン（テーマカラーで大きく表示） */
.sp-top-header .sp-menu-btn .menu-icon { display: block; font-size: 24px; color: #C9788A; }
/* 「MENU」テキスト（アイコンの下に小さく表示） */
.sp-top-header .sp-menu-btn .menu-text { display: block; font-size: 10px; letter-spacing: 1px; }

/* ==========================================================
   SPサブバー（.sp-sub-bar）
   - SPヘッダーの直下に表示されるリンクバー
   - お問い合わせ・Englishなどを横並びに配置
   - 背景はテーマカラー、文字は白
   ========================================================== */
.sp-sub-bar {
    display: none; /* デフォルトは非表示、SP時にblock表示 */
    background: #C9788A;
}
/* サブバー内のリンクを均等配置 */
.sp-sub-bar-inner {
    display: flex;
}
.sp-sub-bar-inner a {
    flex: 1; /* 各リンクを均等幅に */
    text-align: center;
    color: #fff;
    font-size: 14px;
    padding: 10px 5px;
    border-right: 1px solid #D4889A; /* 区切り線: やや明るいピンク */
}
.sp-sub-bar-inner a:last-child { border-right: none; }
.sp-sub-bar-inner a i { margin-right: 4px; }
/* SP版Englishリンク */
.sp-sub-bar-inner .btn-en-sp {
    font-weight: bold;
    letter-spacing: 1px;
    color: #fff;
}

/* ==========================================================
   PCメインナビゲーション（.main-nav）
   - テーマカラー背景の横並びナビゲーション
   - 各メニュー項目を均等幅で配置
   - ドロップダウンメニュー対応
   - SP表示時は display:none になる（レスポンシブ参照）
   ========================================================== */
.main-nav {
    background: #C9788A;
}
.main-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: center;
}
/* 各メニュー項目: 均等幅・中央揃え */
.main-nav li { flex: 1; text-align: center; }
/* 項目間の区切り線 */
.main-nav li + li { border-left: 1px solid #D4889A; }
/* メニューリンク: 白文字、ホバー時に背景色変化 */
.main-nav a {
    display: block;
    color: #fff;
    font-size: 16px;
    padding: 14px 10px;
    transition: background 0.2s;
    letter-spacing: 1px;
}
.main-nav a:hover { background: #E8A0B0; color: #fff; }
/* 英語サブテキスト（メニュー項目の下に小さく表示） */
.main-nav > ul > li > a .nav-en {
    display: block;
    font-size: 10px;
    font-weight: normal;
    letter-spacing: 1px;
    opacity: 0.7;
    margin-top: 2px;
}

/* --- ドロップダウンメニュー --- */
/* 親メニュー項目にposition:relativeを設定 */
.main-nav .has-dropdown {
    position: relative;
}
/* ドロップダウン本体: デフォルト非表示、ホバー時に表示 */
.main-nav .dropdown-menu-custom {
    display: none;
    position: absolute;
    top: 100%; /* 親メニューの直下に配置 */
    left: 0;
    width: 100%;
    /* min-width: 260px; */
    min-width: 300px;
    background: #fff;
    border: 1px solid #f0d8de;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    z-index: 100;
    flex-direction: column;
    padding: 0;
    margin: 0;
}
/* ホバー時にドロップダウンを表示 */
.main-nav .has-dropdown:hover .dropdown-menu-custom {
    display: flex;
}
/* ドロップダウン内の項目: 左寄せ・縦並び */
.main-nav .dropdown-menu-custom li {
    flex: none;
    text-align: left;
    border-left: none;
}
/* ドロップダウン内の区切り線: 上線で区切り */
.main-nav .dropdown-menu-custom li + li {
    border-left: none;
    border-top: 1px solid #f0d8de;
}
/* ドロップダウン内のリンク: 黒文字・小さめフォント */
.main-nav .dropdown-menu-custom a {
    color: #333;
    font-size: 14px;
    padding: 10px 16px;
    letter-spacing: 0;
    white-space: nowrap;
}
/* ドロップダウンリンク ホバー時: 淡いピンク背景 */
.main-nav .dropdown-menu-custom a:hover {
    background: #fdf0f3;
    color: #C9788A;
}

/* ==========================================================
   ヒーローマーキースライダー（.hero-marquee）
   - トップページ上部の無限スクロール書影スライダー
   - 2行構成: 上段は左方向、下段は右方向にスクロール
   - 中央にキャッチコピーを袋文字でオーバーレイ
   - 左右にフェードマスク、上下に装飾ラインを配置
   ========================================================== */
.hero-marquee {
    position: relative;
    width: 100%;
    overflow: hidden;
    background: linear-gradient(160deg, #1a1a2e 0%, #16213e 40%, #0f3460 100%);
    padding: 36px 0;
}

/* 中央オーバーレイテキスト */
.hero-marquee-overlay {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 10;
    pointer-events: none;
    text-align: center;
    padding: 0 20px;
}
/* キャッチコピー: 袋文字（黒縁取り + 多重シャドウ） */
.hero-marquee-overlay .hero-catch {
    font-size: 40px;
    font-weight: 900;
    color: #fff;
    letter-spacing: 12px;
    -webkit-text-stroke: 2px rgba(0,0,0,0.7);
    paint-order: stroke fill;
    text-shadow:
        0 0 12px rgba(0,0,0,0.8),
        0 0 30px rgba(0,0,0,0.5),
        0 4px 20px rgba(0,0,0,0.6);
    margin-bottom: 12px;
    line-height: 1.5;
}
/* サブテキスト: 袋文字（細めの縁取り） */
.hero-marquee-overlay .hero-sub {
    font-size: 15px;
    color: #fff;
    letter-spacing: 4px;
    -webkit-text-stroke: 1px rgba(0,0,0,0.5);
    paint-order: stroke fill;
    text-shadow:
        0 0 8px rgba(0,0,0,0.8),
        0 0 20px rgba(0,0,0,0.5);
}

/* マーキートラック（各行の画像列） */
.marquee-track {
    display: flex;
    width: max-content;
    gap: 20px;
    padding: 10px 0;
}
/* 左から右方向へスクロール */
.marquee-track.row-1 {
    animation: marquee-right 60s linear infinite;
}
@keyframes marquee-right {
    0%   { transform: translateX(-50%); }
    100% { transform: translateX(0); }
}

/* マーキー内の各画像カード（書影＝縦長に最適化） */
.marquee-card {
    flex-shrink: 0;
    width: 180px;
    border-radius: 12px;
    overflow: hidden;
    position: relative;
    box-shadow: 0 8px 32px rgba(0,0,0,0.3);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.marquee-card:hover {
    transform: scale(1.05) translateY(-4px);
    box-shadow: 0 16px 48px rgba(201,120,138,0.4);
}
.marquee-card img {
    width: 100%;
    height: auto;
    display: block;
}
/* 画像上のグラデーションオーバーレイ */
.marquee-card::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(201,120,138,0.15) 100%);
    border-radius: 12px;
}

/* マーキー左右のフェードアウトマスク */
.hero-marquee::before,
.hero-marquee::after {
    content: '';
    position: absolute;
    top: 0; bottom: 0;
    width: 120px;
    z-index: 5;
    pointer-events: none;
}
.hero-marquee::before {
    left: 0;
    background: linear-gradient(90deg, #1a1a2e 0%, transparent 100%);
}
.hero-marquee::after {
    right: 0;
    background: linear-gradient(-90deg, #0f3460 0%, transparent 100%);
}

/* 上下の装飾ライン（テーマカラーのグラデーション） */
.marquee-line-top,
.marquee-line-bottom {
    height: 3px;
    background: linear-gradient(90deg, transparent, #C9788A, #E8A0B0, #C9788A, transparent);
    position: relative;
    z-index: 6;
}

/* ==========================================================
   フィーチャーカード（.feature-section）
   - トップページのコンテンツカード（4列グリッド）
   - 各カードは画像＋キャプションで構成
   - SP表示時は2列に変更（レスポンシブ参照）
   ========================================================== */
.feature-section {
    padding: 20px 40px 40px;
}
/* 4列グリッドレイアウト */
.feature-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
.feature-card {
    overflow: hidden;
}
/* カード画像エリア: アスペクト比4:3、テーマカラー枠線 */
.feature-card .feature-img {
    width: 100%;
    aspect-ratio: 4/3;
    border: 1px solid #C9788A;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
/* 画像: 枠内に収まるようcontainで表示 */
.feature-card .feature-img img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    display: block;
}
/* 画像上の光沢オーバーレイ */
.feature-card .feature-img::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: radial-gradient(ellipse at 60% 50%, rgba(255,255,255,0.15) 0%, transparent 55%);
}
/* カードキャプション: 画像下に中央揃えで表示 */
.feature-card .feature-caption {
    padding: 10px 2px;
    font-size: 16px;
    color: #333;
    text-align: center;
}

/* ==========================================================
   学会紹介セクション（.about-section）
   - トップページの学会紹介テキストエリア
   - テーマカラーの下線付きタイトルと本文で構成
   ========================================================== */
.about-section {
    padding: 40px 40px 40px;
}
/* セクションタイトル: 太字、下線はテーマカラー3px */
.about-title {
    font-size: 22px;
    font-weight: bold;
    color: #333;
    padding-bottom: 12px;
    margin: 0 0 20px;
    border-bottom: 3px solid #C9788A;
}
/* タイトル横の英語表記 */
.about-title .about-title-en {
    font-size: 13px;
    font-weight: normal;
    color: #C9788A;
    margin-left: 10px;
    letter-spacing: 1px;
}
/* 本文エリア: 読みやすい行間1.9 */
.about-body {
    font-size: 15px;
    line-height: 1.9;
    color: #444;
}
.about-body p {
    margin: 0 0 14px;
}

/* ==========================================================
   タブセクション（.tab-section）
   - お知らせ・ニュースをタブで切り替え表示するエリア
   - タブナビゲーション + コンテンツエリアで構成
   - アクティブタブの下線を白にしてコンテンツと一体化
   ========================================================== */
.tab-section {
    padding: 0 40px 50px;
}
/* タブナビゲーション: 横並びで中央配置 */
.tab-nav {
    display: flex;
    justify-content: center;
    gap: 0;
    margin-bottom: 0;
}
/* 各タブ: 淡いピンク背景、下線テーマカラー */
.tab-nav .tab-item {
    padding: 14px 60px;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    cursor: pointer;
    border: 1px solid #e0c0c8;
    border-bottom: 2px solid #C9788A;
    background: #fdf0f3;
    color: #333;
    transition: all 0.2s;
    position: relative;
}
/* アクティブなタブ: 白背景、下線を白にしてコンテンツと繋がる */
.tab-nav .tab-item.active {
    background: #fff;
    border-bottom: 2px solid #fff;
    z-index: 1;
}
/* タブ内の英語表記 */
.tab-nav .tab-item .tab-en {
    display: block;
    font-size: 12px;
    font-weight: normal;
    color: #C9788A;
    margin-top: 2px;
}
/* タブコンテンツエリア: タブの下に繋がるボーダー付きボックス */
.tab-content-area {
    border: 1px solid #e0c0c8;
    border-top: 2px solid #C9788A;
    padding: 10px 25px 25px;
    margin-top: -2px; /* タブとの隙間をなくす */
}

/* --- ニュース一覧アイテム --- */
/* 各ニュース: 日付・バッジ・テキストを横並びに配置 */
.news-item {
    display: flex;
    align-items: flex-start;
    padding: 18px 0;
    border-bottom: 1px solid #f0d8de;
    gap: 15px;
}
.news-item:last-child { border-bottom: none; }
/* 日付: 灰色・固定幅で揃える */
.news-date {
    font-size: 16px;
    color: #888;
    white-space: nowrap;
    flex-shrink: 0;
    min-width: 90px;
}
/* カテゴリバッジ: テーマカラーの枠線ラベル */
.news-badge {
    display: inline-block;
    border: 1px solid #C9788A;
    padding: 1px 10px;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 1px;
    flex-shrink: 0;
    white-space: nowrap;
    color: #C9788A;
}
/* ニュース本文: 残りのスペースを使って表示 */
.news-text {
    font-size: 16px;
    line-height: 1.8;
    color: #444;
    flex: 1;
}
/* ニュース本文内のリンク: テーマカラー＋下線付き */
.news-text a {
    text-decoration: underline;
    color: #C9788A;
}
/* 学会紹介本文内のリンク: 同上 */
.about-body a {
    text-decoration: underline;
    color: #C9788A;
}
/* 「もっと見る」ボタン: 中央配置、テーマカラー枠線 */
.news-more {
    text-align: center;
    padding-top: 20px;
}
.news-more a {
    display: inline-block;
    font-size: 16px;
    color: #C9788A;
    border: 1px solid #e0c0c8;
    padding: 6px 20px;
}
.news-more a:hover { background: #fdf0f3; }
.news-more a i { margin-left: 5px; }

/* ==========================================================
   バナーセクション（.banner-section）
   - 外部リンクやサブページへのバナーリンク（4列グリッド）
   - テーマカラー枠線の矩形ボタンとして表示
   - SP表示時は2列に変更（レスポンシブ参照）
   ========================================================== */
.banner-section {
    padding: 30px 40px 40px;
}
/* 4列グリッドレイアウト */
.banner-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
/* 各バナー: テーマカラー枠線、中央揃えテキスト */
.banner-item {
    height: 70px;
    border: 2px solid #C9788A;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 3px;
    color: #C9788A;
}
.banner-item:hover { background: #fdf0f3; }

/* ==========================================================
   PAGE TOPボタン（PC版）
   - ページ最下部の「ページトップへ戻る」ボタン
   - 半円形（上部のみ角丸）のテーマカラーボタン
   ========================================================== */
.page-top {
    text-align: center;
    padding: 20px 40px 0;
}
.page-top a {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100px;
    height: 50px;
    background: #C9788A;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 1px;
    border-radius: 100px 100px 0 0; /* 上部のみ角丸で半円形に */
    transition: background 0.3s;
}
.page-top a:hover { background: #b5687a; color: #fff; }
.page-top a i { font-size: 16px; margin-bottom: 2px; }

/* ==========================================================
   PAGE TOPボタン（SP版）
   - SP表示時のみ表示される「ページトップへ戻る」ボタン
   - PC版と同じデザインだがパディングが異なる
   ========================================================== */
.sp-page-top {
    display: none; /* デフォルトは非表示、SP時にblock表示 */
    text-align: center;
    padding: 0;
}
.sp-page-top a {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100px;
    height: 50px;
    background: #C9788A;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 1px;
    border-radius: 100px 100px 0 0;
}
.sp-page-top a i { font-size: 16px; margin-bottom: 2px; }

/* ==========================================================
   フッター（.site-footer）
   - ページ最下部のフッターエリア
   - 緑色（#6BA896）背景、白文字
   - 左側: ロゴ・学会名・住所
   - 右側: フッターナビゲーション（4列グリッド）+ コピーライト
   - SP表示時は右側を非表示にし、SPフッターナビに切り替え
   ========================================================== */
.site-footer {
    background: #6BA896;
    color: #fff;
    padding: 30px 40px 20px;
}
/* フッター内部: 左右を横並びに配置 */
.footer-inner {
    display: flex;
    gap: 40px;
    align-items: flex-start;
}

/* --- フッター左側: ロゴ・学会名・住所 --- */
.footer-left {
    flex-shrink: 0;
}
.footer-left a { color: #fff; }
/* ロゴと学会名を横並びに */
.footer-left .footer-logo-row {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
}
/* フッターロゴ: 64x48px */
.footer-left .footer-logo-box {
    width: 64px;
    height: 48px;
    flex-shrink: 0;
}
.footer-left .footer-logo-box img {
    width: 64px;
    height: 48px;
    display: block;
}
/* フッター学会名 */
.footer-left .footer-lab {
    font-size: 20px;
    font-weight: bold;
}
/* フッター住所 */
.footer-left .footer-address {
    font-size: 14px;
    color: #fff;
    line-height: 1.8;
    margin-top: 5px;
}

/* --- フッター右側: ナビゲーション + コピーライト --- */
.footer-right {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
/* フッターナビ: 4列グリッドでリンクグループを配置 */
.footer-nav {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 15px;
}
/* 各ナビグループ */
.footer-nav-group {
    margin-bottom: 12px;
}
.footer-nav-group:last-child {
    margin-bottom: 0;
}
/* グループタイトル: 太字 */
.footer-nav-group .footer-nav-title {
    font-size: 14px;
    font-weight: bold;
    color: #fff;
    display: block;
    margin-bottom: 5px;
}
/* グループ内リンク */
.footer-nav-group a {
    font-size: 13px;
    color: #fff;
    display: block;
    padding: 1px 0;
}
/* リンクの先頭に「>」マークを付与 */
.footer-nav-group a::before {
    content: '>';
    margin-right: 4px;
}
/* タイトルには「>」マークを付けない */
.footer-nav-group .footer-nav-title::before {
    content: none;
}
.footer-nav-group a:hover { color: #fff; }
/* コピーライト: 右寄せ */
.footer-copyright {
    font-size: 14px;
    color: #fff;
    text-align: right;
}

/* ==========================================================
   SPフッターナビ（.sp-footer-nav）
   - SP表示時のみ表示されるフッターナビゲーション
   - 3列グリッドでリンクを配置
   - 緑色系の背景（PCフッターより少し明るい）
   ========================================================== */
.sp-footer-nav {
    display: none; /* デフォルトは非表示、SP時にblock表示 */
    background: #7CB8A6;
    padding: 15px 20px;
}
/* 3列グリッドレイアウト */
.sp-footer-nav-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px 15px;
}
.sp-footer-nav-grid a {
    font-size: 14px;
    color: #e8f5f0;
    padding: 4px 0;
}
/* リンクの先頭に「>」マーク */
.sp-footer-nav-grid a::before {
    content: '>';
    margin-right: 4px;
    color: #b0d8cc;
}

/* ==========================================================
   ハンバーガーメニュー（Offcanvas）
   - SP表示時にメニューボタンで開くサイドメニュー
   - Bootstrapのoffcanvasコンポーネントを利用
   - メニュー項目を縦一列に表示
   - サブメニューはインデント＋「>」マーク付き
   ========================================================== */
/* メニュー項目リストのリセット */
.offcanvas-menu .offcanvas-body ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
/* 各メニュー項目: 下線で区切り */
.offcanvas-menu .offcanvas-body li { border-bottom: 1px solid #f0d8de; }
/* メニューリンク: 大きめフォントで押しやすく */
.offcanvas-menu .offcanvas-body a {
    display: block;
    padding: 15px 10px;
    font-size: 18px;
    color: #333;
}
/* サブメニュー（入れ子のul） */
.offcanvas-menu .offcanvas-body ul ul {
    padding: 0 0 10px;
}
.offcanvas-menu .offcanvas-body ul ul li {
    border-bottom: none;
}
/* サブメニューリンク: やや小さめ、左にインデント */
.offcanvas-menu .offcanvas-body ul ul a {
    font-size: 15px;
    padding: 6px 10px 6px 25px;
    color: #666;
}
/* サブメニューリンクの先頭に「>」マーク */
.offcanvas-menu .offcanvas-body ul ul a::before {
    content: '>';
    margin-right: 6px;
    color: #C9788A;
}

/* ==========================================================
   レスポンシブ対応（991.98px以下 = タブレット・スマートフォン）
   - PC専用要素を非表示、SP専用要素を表示に切り替え
   - レイアウトを小さい画面に最適化
   ========================================================== */
@media (max-width: 991.98px) {
    /* PC用ヘッダー・ナビを非表示 → SP用に切り替え */
    .top-header { display: none; }
    .main-nav { display: none; }
    .sp-top-header { display: flex; }
    .sp-sub-bar { display: block; }

    /* ヒーローマーキー: パディング縮小、テキスト・カードサイズ縮小 */
    .hero-marquee { padding: 20px 0; }
    .hero-marquee-overlay .hero-catch { font-size: 24px; letter-spacing: 6px; }
    .hero-marquee-overlay .hero-sub { font-size: 12px; letter-spacing: 2px; }
    .marquee-card { width: 130px; border-radius: 8px; }
    .marquee-track { gap: 12px; }
    .hero-marquee::before,
    .hero-marquee::after { width: 50px; }

    /* セクション余白を縮小 */
    .feature-section { padding: 15px 15px 25px; }
    .about-section { padding: 25px 15px 30px; }
    /* フィーチャーカード: 4列→2列に変更 */
    .feature-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }

    /* タブセクション: 余白縮小、タブを均等幅に */
    .tab-section { padding: 0 15px 30px; }
    .tab-nav .tab-item {
        padding: 12px 15px;
        font-size: 17px;
        flex: 1;
    }
    /* タブ内の英語表記を非表示 */
    .tab-nav .tab-item .tab-en { display: none; }
    .tab-content-area { padding: 5px 15px 20px; }

    /* ニュースアイテム: 横並び→縦並びに変更 */
    .news-item {
        flex-direction: column;
        gap: 4px;
        padding: 14px 0;
    }
    .news-date { min-width: auto; }
    .news-badge { margin-left: 8px; }
    .news-text { font-size: 16px; }

    /* バナー: 4列→2列に変更、ボーダーを1pxに */
    .banner-section { padding: 15px; }
    .banner-row {
        grid-template-columns: repeat(2, 1fr);
        gap: 0;
    }
    .banner-item {
        border: 1px solid #C9788A;
        margin: -0.5px; /* ボーダーの重なりを調整 */
        height: 60px;
        font-size: 14px;
    }

    /* PAGE TOPボタン: PC版→SP版に切り替え */
    .page-top { display: none; }
    .sp-page-top { display: block; }

    /* フッター: SP用ナビは非表示、footer-rightをSP対応レイアウトで表示 */
    .sp-footer-nav { display: none; }
    .footer-inner { flex-direction: column; gap: 20px; }
    .footer-nav { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .footer-nav-group .footer-nav-title { font-size: 13px; }
    .footer-nav-group a { font-size: 12px; }
    .site-footer { padding: 20px 20px 15px; }
    .footer-copyright {
        margin-top: 15px;
        text-align: center; /* SP時は中央揃え */
    }
}