@charset "UTF-8";

/* --- レイアウトの基本：ここを書き換え --- */
.top-contents {
    display: flex;
    justify-content: space-between;
    padding: 20px 0;
    align-items: flex-start;
}

.side-left { width: 250px; }    /* 180pxから250pxへ */
.main-column { width: 680px; }  /* 750pxから680pxへ（合計調整） */
.side-right { width: 250px; }   /* 240pxから250pxへ（右も合わせると綺麗です） */

/* --- 共通：グレー枠（コンテンツボックス） --- */
.content-box {
    border: 1px solid #ddd; /* 薄いグレーの枠線 */
    margin-bottom: 20px;
    background-color: #fff;
}

/* --- 共通：見出しの青い帯 --- */
.section-title {
    background-color: #E6ECFC; /* 全コンテンツ共通の青帯 */
    color: #19358E;
    font-size: 15px;
    padding: 6px 10px;
    font-weight: bold;
}

/* --- 左ナビ（これだけ見出しがないため枠線を調整） --- */
.side-nav ul li {
    border-bottom: 1px solid #ddd;
}
.side-nav ul li:last-child { border-bottom: none; }
.side-nav a {
    display: block;
    padding: 8px 12px;
    background-color: #f0faff;
    color: #0066cc;
    font-weight: bold;
    font-size: 13px;
}
.side-nav a:hover { background-color: #3ec6f0; color: #fff; }

/* --- 中央：プレイ内容 --- */
.course-tab-bar {
    background-color: #f0faff;
    display: flex;
    border-bottom: 1px solid #ddd;
}
.course-tab-bar span {
    padding: 5px 12px;
    font-size: 12px;
    color: #0066cc;
    border-right: 1px solid #ddd;
    cursor: pointer;
}
.course-main { display: flex; padding: 15px; gap: 15px; }
.course-main img { width: 240px; border: 1px solid #eee; }
.course-desc h3 { color: #ff6dae; margin-bottom: 10px; border-bottom: 1px dotted #ff6dae; }

/* タブバー全体の調整 */
.course-tab-bar {
    background-color: #f0faff;
    display: flex;
    border-bottom: 1px solid #ddd;
    width: 100%; /* 親の750pxいっぱいにする */
}

/* 1つあたりの幅を 100% / 8 = 12.5% に設定 */
.course-tab-bar .tab-item {
    flex: 0 0 12.5%; 
    text-align: center;
    padding: 8px 0;
    font-size: 11px; /* 8個並ぶので文字サイズを微調整 */
    color: #0066cc;
    border-right: 1px solid #ddd;
    cursor: pointer;
    box-sizing: border-box;
    transition: background-color 0.3s;
}

.course-tab-bar .tab-item:last-child {
    border-right: none;
}

/* 選択されているタブのスタイル */
.course-tab-bar .tab-item.active {
    background-color: #ff6dae; /* ピンク */
    color: #fff;
    font-weight: bold;
}

/* コンテンツの表示・非表示切り替え */
.tab-content {
    display: none; /* 基本は非表示 */
}

.tab-content.active {
    display: flex; /* activeクラスがついたものだけ表示 */
}

/* ==========================================================================
   遊び方コンテンツ専用スタイル
   ========================================================================== */

/* 全体を囲むグレーの枠 */
.main-howto-section {
    width: 100%;
    border: 1px solid #ddd;
    background-color: #fff;
    margin-bottom: 20px;
}

/* 「遊び方」タイトル帯（薄いブルー） */
.main-howto-title {
    background-color: #e6ecf7;
    color: #333366;
    font-size: 16px;
    padding: 6px 15px;
    font-weight: bold;
    border-bottom: 1px solid #ddd;
    text-align: left; /* 画像に合わせて左寄せ */
}

/* 各コースの外枠 */
.howto-course-box {
    margin: 15px;
    border: 1px solid #ddd;
    display: flex;
    flex-direction: column;
}

/* 高さ指定（ご指定の数値） */
.box-290 { height: 300px; }
.box-495 { height: 545px; }
.box-560 { height: 625px; }

/* コース名見出し（左にピンクの縦棒） */
.howto-course-name {
    font-size: 18px;
    color: #f180ba; /* ピンク */
    padding: 10px 15px;
    border-left: 5px solid #f180ba; /* 左の縦線 */
    background-color: #fff;
    font-weight: bold;
}

/* コース内容のスクロールエリア */
.howto-scroll-inner {
    flex: 1;
    padding: 0 15px 15px;
}

/* テキストのスタイル */
.howto-scroll-inner p {
    font-size: 14px;
    line-height: 1.8;
    color: #333;
    margin-bottom: 1.5em;
}

/* このエリア専用のスクロールバー */
.howto-scroll-inner::-webkit-scrollbar {
    width: 6px;
}
.howto-scroll-inner::-webkit-scrollbar-thumb {
    background-color: #ddd;
    border-radius: 10px;
}

/* ==========================================================================
   本日の出勤専用スタイル (左+中央の2カラム分)
   ========================================================================== */

   .today-cast-area {
    /* margin-left と width の calc を削除してリセット */
    margin-left: 0; 
    width: 100%;
    border: 1px solid #ddd;
    background-color: #fff;
    margin-top: 20px;
}

/* タイトル帯（薄いブルー） */
.today-cast-title {
    background-color: #e6ecf7;
    color: #333366;
    font-size: 16px;
    padding: 6px 15px;
    font-weight: bold;
    border-bottom: 1px solid #ddd;
}

/* キャストを並べるコンテナ（7列グリッド） */
.today-cast-container {
    display: grid;
    /* 680pxの幅なら、4〜5列が画像サイズ的に限界です */
    grid-template-columns: repeat(4, 1fr); 
    gap: 10px;
    padding: 15px;
}

/* キャストカード（画像にある薄いグレーの背景） */
.cast-card {
    background-color: #f5f5f5; /* カードの背景色 */
    border-radius: 8px;
    padding: 10px 5px;
    text-align: center;
}

/* 画像の枠線 */
.cast-img-wrap img {
    width: 100px;
    height: auto;
    border: 1px solid #ddd;
    background-color: #fff;
    padding: 2px;
}

/* 名前（ピンク） */
.cast-name {
    color: #f180ba; /* ピンク */
    font-weight: bold;
    font-size: 14px;
    margin-top: 5px;
}

/* 出勤時間（黒） */
.cast-time {
    font-size: 12px;
    color: #333;
    margin-top: 2px;
}

/* --- 右：道案内リスト --- */
.guide-list { padding: 10px; }
.guide-item { margin-bottom: 15px; border-bottom: 1px dotted #ccc; padding-bottom: 10px; }
.guide-item:last-child { border-bottom: none; }
.guide-item img { width: 100%; border: 1px solid #eee; margin-bottom: 5px; }
.guide-item p { font-size: 11px; line-height: 1.5; color: #333; }

/* --- 左カラム共通：スクロールエリア --- */
.side-scroll-area {
    overflow-y: scroll;
    padding: 10px;
}

/* スクロールバーのデザイン（右側と統一） */
.side-scroll-area::-webkit-scrollbar { width: 5px; }
.side-scroll-area::-webkit-scrollbar-thumb { border-radius: 10px; }

.side-banner {
    margin-bottom: 25px;
}

/* --- 新人情報 (高さ 670px) --- */
.new-cast-sidebar {
    height: 815px;
    display: flex;
    flex-direction: column;
}
.new-cast-sidebar .side-scroll-area { flex: 1; }

.side-entry {
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: 1px solid #c8e6c9; /* 薄い緑の線 */
}
.green-bg { background-color: #69D871 !important; } /* 画像に合わせた緑のバナー */

/* --- コスチューム (高さ 305px) --- */

/* 外枠（薄いグレーの枠線） */
.custom-costume-section {
    width: 100%;
    height: 290px; /* 指定の高さ */
    border: 1px solid #ddd;
    background-color: #fff;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    margin-bottom: 20px;
}

/* タイトル帯（薄いブルー） */
.custom-costume-title {
    background-color: #e6ecf7; /* 画像に基づいた薄い青 */
    color: #333366;
    font-size: 15px;
    padding: 6px 0;
    text-align: center;
    font-weight: bold;
    border-bottom: 1px solid #ddd;
}

/* スクロールエリア */
.custom-costume-scroll {
    flex: 1;
    overflow-y: scroll;
    padding: 10px;
}

/* 各アイテムの区切り */
.custom-costume-entry {
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 1px dotted #ccc;
    text-align: center;
}

/* ピンクの角丸ネーム帯 */
.custom-costume-banner {
    background-color: #ff6dae;; /* ピンク色 */
    color: #fff;
    font-size: 14px;
    font-weight: bold;
    padding: 4px 0;
    border-radius: 20px; /* 綺麗な角丸 */
    width: 90%;
    margin: 0 auto 10px;
}

/* 画像の枠 */
.custom-costume-img img {
    width: 180px; /* 画像サイズ調整 */
    height: auto;
    border: 1px solid #ddd;
    padding: 2px;
    background-color: #fff;
}

/* このエリア専用のスクロールバー設定 */
.custom-costume-scroll::-webkit-scrollbar {
    width: 6px;
}
.custom-costume-scroll::-webkit-scrollbar-thumb {
    border-radius: 10px;
}

/* プロフィール周りの微調整（右側と共通化） */
.entry-date { font-size: 12px; margin-bottom: 3px; font-weight: bold; }
.entry-main { display: flex; gap: 8px; margin-bottom: 8px; }
.entry-img { width: 70px; height: auto; border: 1px solid #eee; }
.entry-profile { font-size: 11px; line-height: 1.4; text-align: left; }
.entry-text { font-size: 11px; line-height: 1.5; text-align: left; }

/* --- 右カラム：新着情報の修正 --- */

/* 枠と高さの制御 */
.news-sidebar {
    height: 670px; /* 指定の高さ */
    display: flex;
    flex-direction: column;
    overflow: hidden; /* 親ははみ出し禁止 */
}

/* スクロールエリア */
.news-scroll-area {
    flex: 1;
    overflow-y: scroll; /* 縦スクロールを有効に */
    padding: 10px;
}

/* 各エントリー（1件ごとの枠） */
.news-entry {
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 1px solid #ff99cc; /* ピンクの区切り線 */
}
.news-entry:last-child {
    border-bottom: none;
}

.entry-date {
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 5px;
}

/* 名前バナー（ピンクの角丸） */
.cast-name-banner {
    background-color: #ff6dae;
    color: #fff;
    text-align: center;
    font-weight: bold;
    border-radius: 15px;
    padding: 3px 0;
    margin-bottom: 10px;
}

/* 写真とプロフィールの並び */
.entry-main {
    display: flex;
    gap: 10px;
    margin-bottom: 10px;
}
.entry-img {
    width: 100px;
    height: auto;
    border: 1px solid #ddd;
}
.entry-profile {
    font-size: 13px;
    line-height: 1.5;
}

/* 紹介文 */
.entry-text {
    font-size: 13px;
    line-height: 1.6;
    color: #333;
}

/* スクロールバーのカスタマイズ（任意：細くして見た目を整える） */
.news-scroll-area::-webkit-scrollbar {
    width: 6px;
}
.news-scroll-area::-webkit-scrollbar-thumb {
    border-radius: 10px;
}