/* =============================================================================
 * app.css — システム共通デザイン（白・グレー基調 / 汎用テーマ）
 *
 * 読み込み順: Bootstrap5(CDN) → 本ファイル の順でロードされるため、
 * ここでの記述で Bootstrap の見た目を上書きする。
 * Bootstrap クラスをそのまま使う全画面（既存サンプル・今後追加する画面）が
 * 自動的にこのデザインに追従する。色や角丸は (a) のトークンを変えるだけで一括変更可能。
 * ========================================================================== */

/* -----------------------------------------------------------------------------
 * (a) デザイントークン
 * --------------------------------------------------------------------------- */
:root {
    --app-bg: #f6f7f9;          /* ページ背景: 極薄グレー */
    --app-surface: #ffffff;     /* カード/ヘッダー面: 白 */
    --app-surface-2: #fafbfc;   /* 見出し行など極薄面 */
    --app-border: #e6e8eb;      /* 罫線: 薄グレー */
    --app-border-strong: #d6d9dd;
    --app-text: #20242b;        /* 本文: 濃グレー（純黒は避ける） */
    --app-text-muted: #6b7280;  /* 補助テキスト */
    --app-text-invert: #ffffff;
    --app-accent: #2b2f36;      /* アクセント＝濃グレー（選択中/主要ボタン） */
    --app-accent-hover: #3a3f47;
    --app-accent-weak: #eef0f2; /* アクティブ/ホバーのごく薄い背景 */
    --app-danger: #b4453d;      /* 破壊的操作（削除など）: 落ち着いた赤 */
    --app-danger-hover: #9c3a33;
    --app-danger-weak: #f7ecea; /* 危険カードの淡い背景 */
    --app-radius: 12px;         /* カード等の角丸 */
    --app-radius-sm: 7px;       /* ボタン/入力の角丸 */
    --app-shadow: 0 1px 2px rgba(16, 24, 40, .03), 0 4px 16px rgba(16, 24, 40, .05);
    --app-shadow-pop: 0 8px 24px rgba(16, 24, 40, .10), 0 2px 6px rgba(16, 24, 40, .06);
    --app-focus-ring: 0 0 0 .2rem rgba(43, 47, 54, .12);
}

/* -----------------------------------------------------------------------------
 * (b) ベース
 * --------------------------------------------------------------------------- */
body {
    background-color: var(--app-bg);
    color: var(--app-text);
    font-family: 'Nunito', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Helvetica Neue',
        'Hiragino Sans', 'Hiragino Kaku Gothic ProN', 'Noto Sans JP', Meiryo, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a {
    color: var(--app-accent);
    text-decoration: none;
}

a:hover {
    color: var(--app-accent-hover);
    text-decoration: underline;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--app-text);
}

/* -----------------------------------------------------------------------------
 * (c) ヘッダー（共通ナビバー）
 *   レイアウト側で <nav class="navbar app-header"> を付与して使う。
 *   bg-primary / bg-secondary / text-white が付いていても白基調に上書きする。
 * --------------------------------------------------------------------------- */
.app-header.navbar {
    background-color: var(--app-surface) !important;
    border-bottom: 1px solid var(--app-border);
    box-shadow: none;
    padding: .25rem 1rem;
    /* ログイン前（ブランドのみ）／ログイン後（メニューあり）で高さを揃える */
    min-height: 3.5rem;
}

.app-header.navbar > .container-fluid {
    min-height: inherit;
    align-items: center;
}

.app-header .app-header__brand {
    color: var(--app-text) !important;
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: .01em;
    margin: 0;
}

.app-header .app-header__brand:hover {
    color: var(--app-accent) !important;
}

/* ヘッダー内メニュー */
.app-header .navbar-nav .nav-link {
    color: var(--app-text-muted) !important;
    font-weight: 600;
    font-size: .95rem;
    padding: .5rem .85rem;
    border-radius: var(--app-radius-sm);
    transition: background-color .12s ease, color .12s ease;
}

.app-header .navbar-nav .nav-link:hover {
    color: var(--app-text) !important;
    background-color: var(--app-accent-weak);
    text-decoration: none;
}

/* アクティブ（現在ページ） */
.app-header .navbar-nav .nav-link.is-active {
    color: var(--app-text) !important;
    background-color: var(--app-accent-weak);
    font-weight: 700;
}

/* ヘッダー内アイコンボタン（ハンバーガー等） */
.app-header .btn-outline-light {
    color: var(--app-text) !important;
    border-color: var(--app-border-strong) !important;
}

.app-header .btn-outline-light:hover {
    color: var(--app-text) !important;
    background-color: var(--app-accent-weak) !important;
    border-color: var(--app-border-strong) !important;
}

/* ヘッダー内のドロップダウン（ユーザー名） */
.app-header .dropdown-toggle {
    color: var(--app-text) !important;
}

/* モバイル時に縦並びになる領域の見切り線 */
.app-header .app-header__mobile {
    border-top: 1px solid var(--app-border);
    margin-top: .25rem;
    padding-top: .25rem;
}

.app-header .app-header__mobile .nav-link,
.app-header .app-header__mobile .app-header__user {
    color: var(--app-text) !important;
}

/* -----------------------------------------------------------------------------
 * (d) ボタン（原色を排除し、テーマに合わせた配色へ）
 *   - 主要アクション（primary/secondary/success/info/warning/dark）: 濃グレー
 *   - 破壊的アクション（danger）: 落ち着いた赤のみ例外
 *   - ホバー時のアンダーラインは出さない
 * --------------------------------------------------------------------------- */
.btn {
    border-radius: var(--app-radius-sm);
    font-weight: 600;
    padding: .45rem 1.1rem;
    transition: background-color .12s ease, border-color .12s ease, color .12s ease, box-shadow .12s ease;
}

.btn:hover {
    text-decoration: none;
}

.btn:focus,
.btn.focus {
    box-shadow: var(--app-focus-ring);
}

/* 主要・肯定アクションはすべて濃グレーに統一 */
.btn-primary,
.btn-secondary,
.btn-success,
.btn-info,
.btn-warning,
.btn-dark {
    background-color: var(--app-accent);
    border-color: var(--app-accent);
    color: var(--app-text-invert);
}

.btn-primary:hover, .btn-primary:focus,
.btn-secondary:hover, .btn-secondary:focus,
.btn-success:hover, .btn-success:focus,
.btn-info:hover, .btn-info:focus,
.btn-warning:hover, .btn-warning:focus,
.btn-dark:hover, .btn-dark:focus {
    background-color: var(--app-accent-hover);
    border-color: var(--app-accent-hover);
    color: var(--app-text-invert);
}

/* アウトライン系は中立グレーに */
.btn-outline-primary,
.btn-outline-secondary,
.btn-outline-success,
.btn-outline-info,
.btn-outline-dark {
    color: var(--app-text);
    border-color: var(--app-border-strong);
    background-color: var(--app-surface);
}

.btn-outline-primary:hover,
.btn-outline-secondary:hover,
.btn-outline-success:hover,
.btn-outline-info:hover,
.btn-outline-dark:hover {
    color: var(--app-text);
    background-color: var(--app-accent-weak);
    border-color: var(--app-border-strong);
}

/* 破壊的操作のみ落ち着いた赤を維持（削除など） */
.btn-danger {
    background-color: var(--app-danger);
    border-color: var(--app-danger);
    color: var(--app-text-invert);
}

.btn-danger:hover,
.btn-danger:focus {
    background-color: var(--app-danger-hover);
    border-color: var(--app-danger-hover);
    color: var(--app-text-invert);
}

.btn-outline-danger {
    color: var(--app-danger);
    border-color: var(--app-danger);
    background-color: var(--app-surface);
}

.btn-outline-danger:hover,
.btn-outline-danger:focus {
    color: var(--app-text-invert);
    background-color: var(--app-danger);
    border-color: var(--app-danger);
}

.btn-light {
    background-color: var(--app-surface);
    border-color: var(--app-border-strong);
    color: var(--app-text);
}

.btn-light:hover {
    background-color: var(--app-accent-weak);
    border-color: var(--app-border-strong);
    color: var(--app-text);
}

.btn-link {
    color: var(--app-accent);
}

.btn-link:hover {
    color: var(--app-accent-hover);
    text-decoration: none;
}

.btn-danger:focus,
.btn-outline-danger:focus {
    box-shadow: 0 0 0 .2rem rgba(180, 69, 61, .15);
}

/* -----------------------------------------------------------------------------
 * (e) カード — 白面・薄い境界・柔らかい影・余白広めで端正に
 * --------------------------------------------------------------------------- */
.card {
    background-color: var(--app-surface);
    border: 1px solid var(--app-border);
    border-radius: var(--app-radius);
    box-shadow: var(--app-shadow);
}

.card-header {
    background-color: transparent !important;
    border-bottom: 1px solid var(--app-border);
    color: var(--app-text) !important;
    font-weight: 600;
    padding: 1rem 1.35rem;
}

.card-header h1, .card-header h2, .card-header h3,
.card-header h4, .card-header h5, .card-header h6 {
    font-weight: 600;
    letter-spacing: .01em;
}

/* ヘッダー内アイコンはやや控えめに */
.card-header .fas,
.card-header .far,
.card-header .fa {
    color: var(--app-text-muted);
    margin-right: .15rem;
}

.card-body {
    padding: 1.35rem;
}

/* 先頭/末尾の角丸をヘッダー・フッターにも追従させる */
.card > .card-header:first-child {
    border-radius: calc(var(--app-radius) - 1px) calc(var(--app-radius) - 1px) 0 0;
}

/* card-header に bg-* / text-white が付いていても白基調へ中立化 */
.card-header.bg-primary,
.card-header.bg-secondary,
.card-header.bg-dark,
.card-header.bg-info,
.card-header.bg-light,
.card-header.bg-success,
.card-header.bg-warning {
    background-color: transparent !important;
}

.card-header.bg-primary,
.card-header.bg-secondary,
.card-header.bg-dark,
.card-header.bg-info,
.card-header.bg-primary *,
.card-header.bg-secondary *,
.card-header.bg-dark *,
.card-header.bg-info * {
    color: var(--app-text) !important;
}

/* 入れ子カードは影を外し、線だけのフラットな見た目で軽く */
.card .card {
    box-shadow: none;
    border-color: var(--app-border);
}

/* 危険操作カード（border-danger）— 落ち着いた赤の細い境界＋淡い見出し */
.card.border-danger {
    border-color: rgba(180, 69, 61, .35) !important;
}

.card.border-danger > .card-header {
    background-color: var(--app-danger-weak) !important;
    border-bottom-color: rgba(180, 69, 61, .25);
}

.text-danger {
    color: var(--app-danger) !important;
}

/* text-danger 内のアイコンは赤を維持（控えめグレー化の例外） */
.card-header .text-danger .fas,
.card-header .text-danger .far,
.card-header .text-danger .fa {
    color: var(--app-danger);
}

/* -----------------------------------------------------------------------------
 * (f) テーブル
 * --------------------------------------------------------------------------- */
.table {
    color: var(--app-text);
    border-color: var(--app-border);
}

.table > thead {
    background-color: var(--app-surface-2);
}

.table > thead th {
    border-bottom: 1px solid var(--app-border-strong);
    color: var(--app-text-muted);
    font-weight: 700;
    font-size: .9rem;
}

.table > tbody td,
.table > tbody th {
    border-top: 1px solid var(--app-border);
    vertical-align: middle;
}

.table-hover > tbody > tr:hover > * {
    background-color: var(--app-accent-weak);
}

.table-bordered,
.table-bordered > :not(caption) > * > * {
    border-color: var(--app-border);
}

/* -----------------------------------------------------------------------------
 * (g) フォーム（フォーカスリングを中立グレーへ）
 * --------------------------------------------------------------------------- */
.form-control,
.form-select {
    border-radius: var(--app-radius-sm);
    border-color: var(--app-border-strong);
    color: var(--app-text);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--app-accent);
    box-shadow: var(--app-focus-ring);
}

.form-check-input:checked {
    background-color: var(--app-accent);
    border-color: var(--app-accent);
}

.form-check-input:focus {
    border-color: var(--app-accent);
    box-shadow: var(--app-focus-ring);
}

.form-label,
.col-form-label {
    color: var(--app-text);
    font-weight: 600;
}

/* select2 をフォームコントロールへ寄せる（CDN読み込み時のみ適用） */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
    border-color: var(--app-border-strong);
    border-radius: var(--app-radius-sm);
}

.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--multiple {
    border-color: var(--app-accent);
}

/* -----------------------------------------------------------------------------
 * (h) アラート（フラッシュメッセージ）— 彩度を落とし左罫線でアクセント
 * --------------------------------------------------------------------------- */
.alert {
    border: 1px solid var(--app-border);
    border-left-width: 3px;
    border-radius: var(--app-radius-sm);
    background-color: var(--app-surface);
    color: var(--app-text);
}

.alert-success { border-left-color: #3f8f5b; }
.alert-danger  { border-left-color: #c0524b; }
.alert-warning { border-left-color: #c08a2e; }
.alert-info    { border-left-color: #3f6f9f; }

/* -----------------------------------------------------------------------------
 * (i) バッジ（必須/任意など）
 * --------------------------------------------------------------------------- */
.badge {
    border-radius: var(--app-radius-sm);
    font-weight: 600;
    letter-spacing: .02em;
}

.badge.bg-danger  { background-color: #c0524b !important; }
.badge.bg-secondary { background-color: var(--app-text-muted) !important; }

/* -----------------------------------------------------------------------------
 * (j) ドロップダウン
 * --------------------------------------------------------------------------- */
.dropdown-menu {
    border: 1px solid var(--app-border);
    border-radius: var(--app-radius);
    box-shadow: var(--app-shadow-pop);
    padding: .35rem;
}

.dropdown-item {
    border-radius: var(--app-radius-sm);
    color: var(--app-text);
    padding: .45rem .75rem;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--app-accent-weak);
    color: var(--app-text);
    text-decoration: none;
}

.dropdown-item.is-active,
.dropdown-item.active {
    background-color: var(--app-accent);
    color: var(--app-text-invert);
}

.dropdown-divider {
    border-top-color: var(--app-border);
}

/* -----------------------------------------------------------------------------
 * (k) フッター（bg-primary 等が付いていても中立化）
 * --------------------------------------------------------------------------- */
footer.bg-primary,
footer.bg-secondary {
    background-color: var(--app-surface) !important;
    border-top: 1px solid var(--app-border);
}

footer.bg-primary a,
footer.bg-secondary a,
footer.bg-primary .text-white,
footer.bg-secondary .text-white {
    color: var(--app-text-muted) !important;
}

footer.bg-primary a:hover,
footer.bg-secondary a:hover {
    color: var(--app-text) !important;
}

/* -----------------------------------------------------------------------------
 * (l) 汎用ユーティリティ
 * --------------------------------------------------------------------------- */
.app-surface {
    background-color: var(--app-surface);
    border: 1px solid var(--app-border);
    border-radius: var(--app-radius);
    box-shadow: var(--app-shadow);
}

/* メインコンテンツの上下余白（レイアウトで利用） */
.app-content {
    padding-top: 1.75rem;
    padding-bottom: 2.5rem;
}
