/* === Theatre Power — ツアーレポートページ固有スタイル (tour2025.css) === */
/* 更新: 2026-03-23 */
/* 注意: tr- プレフィックスによる名前空間で他ページと分離されています。 */
/*       デザインのトーンが異なるのは意図的です（雑誌的レイアウト）。 */

/* ============================================================
           BASE & VARIABLES
           ============================================================ */
        :root { 
            /* ツアーページ内の独自コンテンツ（HamletやMelosのタイトル等）で使用するため、変数は維持します */
            --tp-red: #D00000; 
            --tp-dark: #1a1a1a; 
            --tp-darker: #0d0d0d; 
            --tp-gray: #f9f9f9; 
            --font-oswald: 'Oswald', sans-serif; 
            --font-ja: 'Noto Sans JP', sans-serif; 
            --font-serif: 'Noto Serif JP', serif; 
            --font-script: 'Playfair Display', serif; 
        }

        /* ハンバーガーメニュー開閉時に背景を固定する機能のため、これだけは維持します */
        body.menu-open { overflow: hidden; }



        /* ============================================================
           TOUR PAGE LAYOUT & UTILITIES
           ============================================================ */

    
    .tr-container { 
        max-width: 1100px; 
        margin: 0 auto; 
        padding: 0 20px; 
    }
        .tr-main { padding-top: 0; }
        .tr-section-full-width { width: 100%; overflow: hidden; margin-bottom: 120px; }
        .tr-fw-container { display: flex; min-height: 600px; }
        .tr-fw-col-left { flex: 1; }
        .tr-fw-col-right { flex: 1; }
        .tr-pad-large { padding: 60px 40px; display: flex; flex-direction: column; justify-content: center; }
        .flex-col-reverse { flex-direction: column-reverse; justify-content: flex-end; }
        
        .bg-beige { background-color: #E7D5BE; }
        .bg-beige-white { background: linear-gradient(90deg, #E7D5BE 50%, #fff 50%); }
        .bg-black-custom { background-color: #D00000; }
        .bg-black-white-custom { background-color: #fff; }
        .bg-elephant-custom { background-color: #0e77bc; }
        .bg-elephant-white { background: linear-gradient(90deg, #4276B8 50%, #fff 50%); }
        .bg-black { background-color: #1a1a1a; }
        .bg-black-white { background: linear-gradient(90deg, #1a1a1a 50%, #fff 50%); }
        .bg-gray-light { background-color: #fafafa; }
        .bg-darker { background-color: #1a1a1a; }
        
        .text-white { color: #fff !important; }
        .text-brand-red-imp { color: #D00000 !important; }
        .text-dark-gray-imp { color: #333333 !important; }
        .border-white { border-color: #fff !important; }
        .border-none { border: none !important; box-shadow: none !important; }
        .mt-10 { margin-top: 40px; }
        .mt-8 { margin-top: 32px; }
        .mt-6 { margin-top: 24px; }
        .mb-8 { margin-bottom: 32px; }
        .text-center-mb-3 { text-align: center; margin-bottom: 3rem; }
        
        /* Typography */
        .tr-title, .tr-title-mock-01, .tr-title-mock-02, .tr-title-mock-04 { font-family: var(--font-oswald); font-size: 4.5rem; line-height: 0.9; letter-spacing: 2px; margin: 0 0 30px; text-transform: uppercase; font-weight: bold; }
        .tr-title-mock-01, .tr-title-mock-02 { color: var(--tp-red); }
        .tr-title, .tr-title-mock-04, .text-white .tr-title { color: #fff; }
        .tr-number-mock-01, .tr-number-mock-02, .tr-number-mock-03, .tr-number-mock-04 { font-family: var(--font-oswald); font-size: 5.5rem; font-weight: bold; line-height: 1; }
        .tr-number-mock-01, .tr-number-mock-02 { color: var(--tp-red); }
        .tr-number-mock-03, .tr-number-mock-04 { color: #fff; }
        .tr-catch-mock-01, .tr-catch-mock-02, .tr-catch-mock-03, .tr-catch-mock-04 { font-weight: bold; font-size: 0.8rem; line-height: 1.7; }
        .tr-catch-mock-01 { color: #333; }
        .tr-catch-mock-02, .tr-catch-mock-03, .tr-catch-mock-04 { color: #fff; }
        .tr-head-flex-01, .tr-head-flex-02, .tr-head-flex-03, .tr-head-flex-04 { display: flex; align-items: center; gap: 25px; margin-bottom: 10px; }
        
        .tr-sub-head { font-family: var(--font-oswald); color: var(--tp-red); font-size: 1.3rem; margin-bottom: 15px; border-bottom: 2px solid rgba(208,0,0,0.3); padding-bottom: 5px; display: inline-block; font-weight: bold; }
        .text-white .tr-sub-head { color: #fff; border-color: rgba(255,255,255,0.3) !important; }
        .tr-mini-head { color: var(--tp-red); font-weight: bold; font-size: 0.95rem; margin-bottom: 5px; margin-top: 0; }
        .text-white .tr-mini-head { color: #fff; }
        .tr-list-disc { list-style: disc; padding-left: 20px; margin: 0 0 20px 0; font-size: 0.85rem; color: #333; line-height: 1.8; }
        .text-white .tr-list-disc { color: rgba(255,255,255,0.9); }
        .tr-highlight-title { color: var(--tp-red); font-weight: bold; font-size: 0.95rem; margin-bottom: 4px; margin-top: 0; }
        .tr-desc { font-size: 0.85rem; line-height: 1.8; color: #333; text-align: justify; margin: 0; margin-bottom: 12px; }
        
        .tr-red-content { margin-top: 20px; }
        .tr-red-img-area { width: 100%; margin-bottom: 30px; }
        .tr-img-full { width: 100%; box-shadow: 0 10px 20px rgba(0,0,0,0); }

/* ============================================================
           Hero (ツアーレポート冒頭のメインビジュアル)
           ============================================================ */
        .tr-hero-mockup { padding-top: 60px; padding-bottom: 0; position: relative; }
        .tr-hero-header-mock { margin-bottom: 40px; text-align: left; }
        .tr-hero-top-row { display: flex; align-items: baseline; gap: 15px; color: var(--tp-red); margin-bottom: 5px; justify-content: left; }
        .tr-year-mock { font-family: var(--font-oswald); font-size: 3.5rem; font-weight: bold; line-height: 1; }
        .tr-sub-mock { font-family: var(--font-oswald); font-size: 0.9rem; font-weight: bold; letter-spacing: 0.5px; color: var(--tp-red); }
        .tr-report-mock { font-family: var(--font-oswald); font-size: 4rem; color: var(--tp-red); line-height: 1; margin: 0; letter-spacing: 1px; font-weight: bold; text-transform: uppercase; }
        .tr-hero-visual-area { position: relative; width: 100%; padding-bottom: 40px; }
        .tr-hero-red-bg { position: absolute; top: 120px; bottom: 0; left: 0; width: 100%; background-color: var(--tp-red); z-index: 0; }
        .tr-hero-img-box { width: 100%; position: relative; z-index: 10; padding: 0 20px; }
        .tr-hero-img-box img { width: 100%; display: block; box-shadow: 0 0px 0px rgba(0,0,0,0.4); margin: 0 auto; }
        .tr-hero-footer-text { position: relative; z-index: 10; color: #fff; text-align: center; font-family: var(--font-oswald); font-size: 0.8rem; letter-spacing: 1.5px; font-weight: bold; margin-top: 25px; text-transform: uppercase; }


/* Intro (ツアーレポート冒頭の導入メッセージ：維持する項目) */
        .tr-intro-message { padding: 120px 0; text-align: center; background-color: #fff; }
        .tr-intro-text { font-family: "Noto Sans JP", sans-serif; color: var(--tp-red); line-height: 2.0; font-weight: normal; letter-spacing: 0.05em; }
        .tr-intro-main { font-size: 1.3rem; display: block; margin-bottom: 0px; color: #BC221C; }
        .tr-intro-sub { font-size: 1.3rem; display: block; color: #BC221C; }

        

/* ============================================================
           Video Area (ツアーレポート本文の動画表示：維持する項目)
           ============================================================ */
        .tr-video-row { display: flex; justify-content: space-between; gap: 20px; align-items: flex-start; margin-top: 24px; }
        .tr-video-box { width: 48%; position: relative; padding-bottom: 0; background: transparent; box-shadow: none; }
        .tr-ratio-fix { width: 100%; aspect-ratio: 16 / 9; background: #000; border-radius: 0px; overflow: hidden; position: relative; transform: translateZ(0); }
        .tr-ratio-fix iframe, .tr-ratio-fix img, .tr-ratio-fix .tr-thumb-overlay { width: 100%; height: 100%; object-fit: cover; position: absolute; top: 0; left: 0; border: none; }
        .tr-video-thumb-link { display: block; text-decoration: none; cursor: pointer; }
        .tr-thumb-overlay { background: rgba(0, 0, 0, 0.4); display: flex; align-items: center; justify-content: center; transition: background 0.3s ease; z-index: 2; }
        .tr-thumb-content { text-align: center; color: #fff; width: 100%; padding: 5px; }
        .tr-play-icon-wrap { position: relative; display: inline-flex; align-items: center; justify-content: center; width: 50px; height: 50px; background: rgba(0, 0, 0, 0.6); border-radius: 50%; border: 2px solid #fff; margin-bottom: 10px; transition: transform 0.3s ease, background 0.3s ease; }
        .tr-play-icon { font-size: 20px; color: #fff; margin-left: 3px; }
        .tr-lock-badge { position: absolute; top: -10px; right: -25px; background: #c00; color: #fff; font-size: 10px; font-weight: bold; padding: 3px 6px; border-radius: 4px; white-space: nowrap; box-shadow: 0 2px 4px rgba(0,0,0,0.3); }
        .tr-thumb-text { font-family: "Noto Sans JP", sans-serif; font-weight: 700; font-size: 13px; letter-spacing: 0.02em; color: #fff; text-shadow: 0 2px 4px rgba(0,0,0,0.8); margin: 0; line-height: 1.4; }
        .tr-video-thumb-link:hover .tr-thumb-overlay { background: rgba(0, 0, 0, 0.2); }
        .tr-video-thumb-link:hover .tr-ratio-fix img { transform: scale(1.05); transition: transform 0.3s ease; }
        .tr-video-thumb-link:hover .tr-play-icon-wrap { transform: scale(1.1); background: #c00; border-color: #c00; }



        /* Survey & Voices */
        .tr-dark-section { background-color: var(--tp-dark); color: #fff; padding: 80px 0; margin-bottom: 0 !important; padding-bottom: 100px; }
        .tr-section-title-white { font-family: var(--font-oswald); font-size: 2rem; color: #fff; margin-bottom: 40px; text-align: center; border-bottom: 1px solid #333; padding-bottom: 15px; }
        .tr-font-ja { font-family: "Noto Sans JP", sans-serif; font-size: 0.9rem; font-weight: 400; color: #aaa; margin-left: 10px; display: inline-block; vertical-align: middle; }
        .tr-survey-unified-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0px; margin-bottom: 40px; align-items: start; }
        .tr-survey-info-box { text-align: left; padding-top: 80px; }
        .tr-survey-info-box h4 { font-family: "Noto Sans JP", sans-serif; font-size: 0.9rem; font-weight: 700; color: #fff; margin-bottom: 10px; margin-top: 0; }
        .tr-survey-info-box ul { padding-left: 1.2em; margin: 0; list-style: disc; color: #ccc; }
        .tr-survey-info-box li { font-size: 0.75rem; line-height: 1.8; margin-bottom: 4px; }
        .tr-chart-box { background: transparent; border: none; padding: 0; text-align: center; flex: 1; }
        .tr-chart-img { width: 100%; height: auto; display: block; }
        .tr-voices-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; }
        .tr-voice-title { font-family: var(--font-oswald); font-size: 2.2rem; color: #fff; margin-bottom: 10px; }
        .tr-voice-role { color: var(--tp-red); font-weight: bold; font-size: 0.9rem; margin-top: 20px; margin-bottom: 8px; }
        .tr-voice-text, .tr-voice-list li { font-size: 0.85rem; color: #ccc; line-height: 1.8; margin-bottom: 15px; text-align: justify; }
        .tr-voice-list { padding-left: 1em; margin: 0; }
        .tr-voice-list li { list-style: disc; }

        /* ============================================================
           Cast, FAQ (出演者の声とよくある質問：維持)
           ============================================================ */
        .tr-section-white { padding: 80px 0; background: #fff; margin-bottom: 0 !important; }
        .tr-section-title-dark { font-family: var(--font-oswald); font-size: 2rem; color: #333; margin-bottom: 40px; text-align: center; border-bottom: 1px solid #eee; padding-bottom: 15px; }
        .tr-person-block { max-width: 800px; margin: 0 auto 40px; text-align: center; }
        .tr-person-name { font-family: var(--font-playfair); font-size: 1.4rem; font-weight: 700; margin-bottom: 10px; }
        .tr-person-sub { font-size: 0.9rem; font-family: "Noto Sans JP", sans-serif; font-weight: 400; color: #666; margin-left: 15px; display: inline-block; vertical-align: middle; }
        .tr-person-text { text-align: left; line-height: 1.9; }
        .tr-group-photo-full { width: 100%; max-width: 1200px; margin: 0 auto; }
        .tr-group-img { width: 100%; display: block; }
        .tr-faq-wrapper { max-width: 800px; margin: 0 auto; }
        .tr-faq-item { background: #fff; border: 1px solid #e5e5e5; border-radius: 8px; margin-bottom: 1rem; overflow: hidden; transition: box-shadow 0.3s ease; }
        .tr-faq-item:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.05); }
        .tr-faq-question { display: flex; justify-content: space-between; align-items: center; padding: 1.2rem 1.5rem; font-weight: 700; cursor: pointer; list-style: none; position: relative; font-family: "Noto Sans JP", sans-serif; color: #333; }
        .tr-faq-question::-webkit-details-marker { display: none; }
        .tr-q-mark { color: var(--tp-red); font-family: 'Oswald', sans-serif; font-size: 1.2em; margin-right: 10px; }
        .tr-icon-plus { width: 20px; height: 20px; position: relative; flex-shrink: 0; margin-left: 15px; }
        .tr-icon-plus::before, .tr-icon-plus::after { content: ''; position: absolute; background-color: #333; top: 50%; left: 50%; transform: translate(-50%, -50%); transition: transform 0.3s ease; }
        .tr-icon-plus::before { width: 100%; height: 2px; }
        .tr-icon-plus::after { width: 2px; height: 100%; }
        details[open] .tr-icon-plus::after { transform: rotate(90deg); }
        details[open] .tr-icon-plus { transform: rotate(180deg); }
        .tr-faq-answer { padding: 0 1.5rem 1.5rem 3.5rem; color: #555; line-height: 1.8; font-size: 0.95rem; border-top: 1px solid transparent; }
        .tr-faq-item[open] .tr-faq-answer { border-top: 1px solid #f0f0f0; padding-top: 1rem; }
        .tr-faq-sublist { margin-top: 10px; padding-left: 0; list-style: none; }
        .tr-faq-sublist li { margin-bottom: 5px; padding-left: 1rem; position: relative; }
        .tr-faq-sublist li::before { content: "●"; color: #D00000; font-size: 0.6em; position: absolute; left: 0; top: 0.6em; }

        

/* --- 1. ツアーレポート固有：実績と導入校リスト (維持する項目) --- */
        .tr-footer-info { background-color: #1a1a1a; padding: 80px 0; color: #fff; margin-bottom: 0 !important; }
        .tr-footer-grid { display: flex; gap: 60px; align-items: flex-start; }
        .tr-footer-col-left { width: 35%; flex-shrink: 0; }
        .tr-footer-heading { font-family: var(--font-oswald); font-size: 1.8rem; font-weight: bold; color: #fff; margin-bottom: 30px; }
        .tr-numbers-list { list-style: none; padding: 0; margin: 0; }
        .tr-numbers-list li { font-size: 1.1rem; font-weight: bold; margin-bottom: 20px; line-height: 1.4; border-bottom: 1px dotted #555; padding-bottom: 10px; }
        .tr-footer-col-right { flex: 1; }
        .tr-footer-sub { font-family: "Noto Sans JP", sans-serif; font-size: 0.9rem; font-weight: normal; color: #ccc; margin-left: 10px; }
        .tr-adoptions-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; font-size: 0.75rem; }
        .tr-adopt-col { border-right: 1px dotted #555; padding-right: 20px; }
        .tr-adopt-col:last-child { border-right: none; padding-right: 0; }
        .tr-cat-title { color: var(--tp-red); font-family: var(--font-oswald); font-weight: bold; font-size: 0.95rem; margin-bottom: 10px; margin-top: 0; }
        .tr-school-list { list-style: none; padding: 0; margin: 0; color: #ccc; line-height: 1.8; }
        .tr-school-list li { margin-bottom: 0; }


/* ============================================================
           MEDIA QUERIES (MOBILE) - ツアー実績・導入校リストの調整
           ============================================================ */
        @media (max-width: 900px) {
            /* 実績と導入校リストの縦並び調整（ツアーページ固有：維持） */
            .tr-footer-grid { flex-direction: column; gap: 40px; }
            .tr-footer-col-left { width: 100%; border-bottom: 1px dotted #555; padding-bottom: 40px; }
            
            /* 導入校リストを2カラムにする設定（ツアーページ固有：維持） */
            .tr-adoptions-grid { grid-template-columns: 1fr 1fr; gap: 20px; }
            .tr-adopt-col { border-right: none; padding-right: 0; margin-bottom: 20px; }
        }

        @media (max-width: 1024px) {
            /* --- Tour Specific (レポート本文のスマホ調整：維持) --- */
            .tr-hero-header-mock { text-align: left; margin-bottom: 20px; padding: 0 20px; }
            .tr-hero-top-row { flex-direction: row; flex-wrap: wrap; justify-content: flex-start; gap: 10px; margin-bottom: 0; }
            .tr-year-mock { font-size: 3rem; }
            .tr-sub-mock { font-size: 0.8rem; }
            .tr-report-mock { font-size: 3.5rem; text-align: left; line-height: 1; }
            .tr-hero-visual-area { padding-bottom: 0; margin-top: 20px; width: calc(100% + 40px); margin-left: -20px; }
            .tr-hero-red-bg { display: none; }
            .tr-hero-img-box { padding: 0; margin: 0; width: 100%; }
            .tr-hero-img-box img { width: 100%; display: block; }
            .tr-hero-footer-text { position: static; width: 100%; margin-left: 0; padding: 40px 20px; background-color: var(--tp-red); font-size: 1rem; line-height: 1.4; margin-top: 0; text-align: center; color: #fff; }
            
            .tr-fw-container { display: block; }
            .tr-fw-col-left, .tr-fw-col-right { width: 100%; padding: 40px 20px; }
            .bg-beige-white, .bg-black-white, .bg-elephant-white, .bg-white-black { background: #fff; }
            .bg-black-custom { padding-top: 40px; padding-bottom: 40px; }
            .tr-section-full-width { margin-bottom: 80px; }
            
            .tr-head-flex-01, .tr-head-flex-02, .tr-head-flex-03, .tr-head-flex-04 { flex-direction: column; align-items: flex-start; gap: 10px; }
            .tr-title-mock-01, .tr-title-mock-02, .tr-title, .tr-title-mock-04 { font-size: 3rem; }
            .tr-video-row { flex-direction: column; }
            .tr-video-box { width: 100%; margin-bottom: 20px; }
            
            .tr-survey-unified-grid { grid-template-columns: 1fr; gap: 30px; }
            .tr-voices-2col { grid-template-columns: 1fr; }
            
            /* 導入文・モバイル用ヘッダーの調整（ツアーページ固有：維持） */
            .tr-mobile-header-04 { display: block; padding: 40px 20px 0; background-color: #fff; }
            .tr-intro-message { padding: 50px 0 !important; text-align: left; }
            .tr-intro-main, .tr-intro-sub { font-size: 1.0rem; line-height: 1.8; }

            /* --- 以下の 3 項目（ナビ、フッター、CTA）のスマホ用設定は common.css に集約したため削除しました --- */
        }

        @media (max-width: 480px) {
            /* 導入校リストを2列から1列に切り替え（ツアーページ固有：維持） */
            .tr-adoptions-grid { 
                grid-template-columns: 1fr; 
            }
        }

