/* 管理画面(/setting/**) 共通追加スタイル
   base.css の茶屋カラー(:root変数)に準拠・フラット。
   ・admin-cat-jump : TOP(お知らせ)の大カテゴリ ワンタッチ列
   ・admin-rellinks : 大カテゴリ内の関連ページ(サブ)リンク
   ・admin-gear     : 右下固定「各種設定TOPへ」 */

/* 大カテゴリ ワンタッチ列（TOPページ） */
.admin-cat-jump {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    max-width: 620px;     /* 常に3列（PC/スマホとも） */
    margin: 12px auto 4px;
}
.admin-cat-jump a {
    font-size: .875rem;     /* btn-sm 相当 */
    padding: .25rem .5rem;  /* btn-sm 相当の厚み */
    border-radius: 8px;
    border: 1px solid #212529;
    background: #212529;   /* btn-dark と同じ黒 */
    color: #fff;
    text-decoration: none;
    display: flex;          /* グリッドセルいっぱいに広げて幅を揃える */
    align-items: center;
    justify-content: flex-start;   /* アイコン頭で左揃え */
    gap: 6px;
}
.admin-cat-jump a i { font-size: 13px; color: #fff; width: 16px; text-align: center; }   /* 白アイコン・頭揃え */
.admin-cat-jump a:hover { background: #2c3034; color: #fff; }

/* 大カテゴリ内の関連ページ(サブ)リンク */
.admin-rellinks {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    /* 上の隙間は padding-top で持つ。margin-top だと手前要素とmargin相殺し、
       ページの入れ子構造次第で隙間が消えたり(ナビ密着)詰まったりするため。
       padding は相殺しない＝どのページでも必ず同一の隙間になる。 */
    margin: 0 auto 16px;
    padding-top: 12px;
    max-width: 450px;         /* small-container相当。どのページでもボタン帯を中央450幅に固定し座標を一致させる */
}
.admin-rellinks a {
    font-size: .875rem;     /* btn-sm 相当 */
    padding: .25rem .5rem;  /* btn-sm 相当の厚み */
    border-radius: 8px;
    border: 1px solid #212529;
    background: #212529;
    color: #fff;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.admin-rellinks a i { font-size: 13px; color: #fff; width: 16px; text-align: center; }   /* アイコンサイズ・頭揃えをcat-jumpに統一 */
.admin-rellinks a:hover { background: #2c3034; color: #fff; }

/* 子カテゴリ帯を3列固定(2行×3列など)で並べたいページ用モディファイア（例:イベント設定）。
   cat-jump と同じ3列グリッド挙動を rellinks(450幅) に適用する。 */
.admin-rellinks.cols3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
}
.admin-rellinks.cols3 a { display: flex; justify-content: flex-start; }

/* 右下固定：各種設定TOPへワンタッチ */
.admin-gear {
    position: fixed;
    right: 16px;
    bottom: 16px;
    z-index: 1030;   /* Bootstrapのfixed相当。モーダルbackdrop(1040+)より下げ、モーダル中は覆われて押せないようにする */
    display: inline-flex;
    align-items: center;
    gap: 8px;
    height: 48px;
    padding: 0 16px;
    background: #212529;   /* btn-dark と同じ黒で管理系ボタンに統一 */
    color: #fff;
    border: 1px solid #212529;
    border-radius: 8px;
    text-decoration: none;
    font-size: 14px;
}
.admin-gear:hover { background: #2c3034; color: #fff; }
.admin-gear i { font-size: 17px; }

@media screen and (max-width: 767px) {
    .admin-gear { padding: 0; width: 50px; justify-content: center; }
    .admin-gear .admin-gear-lab { display: none; }
    /* スマホでも3列を維持するため詰める（cat-jump と cols3 の rellinks 共通） */
    .admin-cat-jump { gap: 6px; }
    .admin-rellinks.cols3 { gap: 6px; }
    .admin-cat-jump a,
    .admin-rellinks.cols3 a {
        font-size: .72rem;
        padding: .3rem .35rem;
        gap: 4px;
        justify-content: center;
        text-align: center;
        line-height: 1.25;
    }
    .admin-cat-jump a i,
    .admin-rellinks.cols3 a i { width: 13px; font-size: 11px; }
}
