:root {
    --admin-primary: #1B365C;      /* 濃い紺色 */
    --admin-secondary: #4A78B3;    /* やや明るい紺色 */
    --admin-background: #F5F7FA;   /* 薄いグレー */
    --admin-text: #333333;         /* 濃いグレー */
    --admin-error: #DC3545;        /* エラー用の赤 */
    --admin-success: #28A745;      /* 成功用の緑 */
    --admin-warning: #FFC107;      /* 警告用の黄色 */
    --admin-info: #17A2B8;         /* 情報用の青 */
    --admin-border: #E5E9F0;       /* ボーダー用の色 */
    --admin-title: #2C4F8A;        /* タイトル用の落ち着いた紺色 */
}

/* ログイン画面 */
.admin-login {
    background-color: var(--admin-background);
    min-height: 100vh;
}

.admin-login .system-title {
    color: var(--admin-title);
    font-size: 1.75rem;
    letter-spacing: 0.05em;
}

.admin-login .card {
    border: 1px solid var(--admin-border);
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05); /* シャドウを柔らかく調整 */
}

.admin-login .card-header {
    background-color: var(--admin-primary);
    border-radius: 7px 7px 0 0;
    padding: 1.25rem;
}

.admin-login .btn-primary {
    background-color: var(--admin-primary);
    border-color: var(--admin-primary);
    padding: 0.75rem 1.5rem;
    font-weight: 500;
}

.admin-login .btn-primary:hover {
    background-color: var(--admin-secondary);
    border-color: var(--admin-secondary);
}

.admin-login .form-label {
    color: var(--admin-text);
    font-weight: 500;
}

/* ダッシュボード */
.admin-dashboard {
    background-color: var(--admin-background);
    min-height: 100vh;
}

.admin-navbar {
    background-color: var(--admin-primary);
    border-bottom: 1px solid var(--admin-border);
}

.admin-navbar .navbar-brand {
    color: white;
    font-weight: 500;
}

.admin-navbar .nav-link {
    color: rgba(255, 255, 255, 0.9);
}

.admin-navbar .nav-link:hover {
    color: white;
}

.admin-sidebar {
    background-color: white;
    border-right: 1px solid var(--admin-border);
    min-height: calc(100vh - 56px);
}

.admin-sidebar .nav-link {
    color: var(--admin-text);
    padding: 0.8rem 1rem;
    border-radius: 4px;
    margin-bottom: 0.25rem;
    transition: all 0.3s ease;
}

.admin-sidebar .nav-link:hover {
    background-color: var(--admin-background);
    color: var(--admin-primary);
}

.admin-sidebar .nav-link.active {
    background-color: var(--admin-primary);
    color: white;
}

.admin-sidebar .nav-link i {
    margin-right: 0.5rem;
    width: 20px;
    text-align: center;
}

.admin-content {
    padding: 2rem;
}

.admin-card {
    background-color: white;
    border: 1px solid var(--admin-border);
    border-radius: 8px;
    margin-bottom: 1.5rem;
}

.admin-card .card-header {
    background-color: transparent;
    border-bottom: 1px solid var(--admin-border);
    padding: 1.25rem;
}

.admin-card .card-title {
    color: var(--admin-primary);
    font-weight: 500;
    margin-bottom: 0;
}

.admin-card .card-body {
    padding: 1.25rem;
}

/* 検索フォームの開閉アニメーション */
.collapse {
    transition: all 0.35s ease;
}
.collapsing {
    transition: all 0.35s ease;
}
.card-header button i {
    transition: transform 0.35s ease;
}
.card-header button[aria-expanded="false"] i {
    transform: rotate(180deg);
} 

/* モーダルアニメーション */
.modal.fade {
    transition: opacity 0.3s ease-in-out;
    display: none;
}

.modal.fade.show {
    display: block;
    opacity: 1;
}

.modal-dialog {
    transition: transform 0.3s ease-in-out;
}

/* モーダルのz-index管理 */
.modal {
    z-index: 1055;
}

.modal-backdrop {
    z-index: 1050;
}

/* 非表示モーダルの無効化 */
.modal:not(.show) {
    display: none;
}

/* フォーム要素の操作性確保 */
.form-control,
.form-select,
.form-check-input,
.btn {
    position: relative;
    z-index: 1;
}

/* 検索フォーム領域の操作性確保 */
.search-form {
    position: relative;
    z-index: 2;
}

/* カード内のフォーム要素の操作性確保 */
.card {
    position: relative;
    z-index: 3;
}

.card-body {
    position: relative;
    z-index: 1;
}

/* 詳細画面のスタイル */
.detail-label {
    min-width: 100px;
    background-color: #f8f9fa;
    padding: 0.5rem 1rem;
    margin-bottom: 0;
    border-radius: 4px;
    font-weight: 500;
    color: #495057;
    border: 1px solid #dee2e6;
}
.detail-value {
    flex: 1;
    padding: 0.5rem 1rem;
    margin-left: 1rem;
}
.table-bordered {
    border-color: #dee2e6;
}
.table-light {
    background-color: #f8f9fa;
}
.card-header {
    background-color: #f8f9fa;
    border-bottom: 1px solid #dee2e6;
}
.card-header h6 {
    color: #495057;
    font-weight: 500;
}

