/* =========================================================
   Indigo カラーパレット
   ========================================================= */
:root {
    --indigo:        #4B0082;
    --indigo-dark:   #3a0066;
    --indigo-light:  #efe6f7;
    --indigo-border: #bfa3d9;
}

body {
    background-color: #faf8ff;
    color: #1a1a2e;
}

/* =========================================================
   ナビバー
   ========================================================= */
.navbar-indigo {
    background-color: var(--indigo);
}

.navbar-indigo .nav-link,
.navbar-indigo .navbar-brand {
    color: #fff !important;
    font-weight: 600;
}

.navbar-indigo .nav-link:hover {
    color: #dcd0ff !important;
}

/* ハンバーガーアイコン（スマホ） */
.navbar-indigo .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.7);
}

.navbar-indigo .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 1)' stroke-width='2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

/* =========================================================
   カード
   ========================================================= */
.card-indigo {
    border: 1px solid var(--indigo-border);
}

.card-indigo .card-header {
    background-color: var(--indigo-light);
    border-bottom: 1px solid var(--indigo-border);
    font-weight: bold;
}

/* =========================================================
   検索フォーム（search-box）
   ========================================================= */
.search-box {
    padding: 1.2rem;
    background: #fff;
    border-radius: 0.75rem;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    max-width: 600px;
    margin: 1rem auto;
}

@media (min-width: 768px) {
    .search-box {
        margin-top: 2rem;
        margin-bottom: 2rem;
    }
}

.input-group .form-control,
.input-group .btn {
    padding-top: 0.6rem;
    padding-bottom: 0.6rem;
}

.form-control::placeholder {
    color: #aaa;
}

.form-control:focus {
    border-color: var(--indigo);
    box-shadow: 0 0 0 0.2rem rgba(75, 0, 130, 0.25);
}

/* =========================================================
   ボタン
   ========================================================= */
.btn-primary {
    border-radius: 0.5rem;
    background-color: var(--indigo);
    border-color: var(--indigo-dark);
    color: #fff;
}

.btn-primary:hover {
    background-color: var(--indigo-dark);
    border-color: var(--indigo-dark);
}

/* =========================================================
   モーダル
   ========================================================= */
.modal-header {
    background-color: var(--indigo);
    color: #fff;
    border-bottom: none;
}

.modal-title {
    font-weight: 600;
}

.modal-content {
    border-radius: 0.75rem;
    border: 1px solid var(--indigo-border);
}

.modal-body {
    background-color: var(--indigo-light);
    color: #1a1a2e;
}

.modal-footer {
    background-color: #f5f0fa;
    border-top: none;
}

/* 閉じるボタン（×） */
.btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

/* モーダル内のボタン */
.modal-footer .btn-secondary {
    background-color: var(--indigo);
    border-color: var(--indigo-dark);
    color: #fff;
}

.modal-footer .btn-secondary:hover {
    background-color: var(--indigo-dark);
    border-color: var(--indigo-dark);
}

/* =========================================================
   上へ戻るボタン
   ========================================================= */
#backToTop {
    position: fixed;
    bottom: 20px;
    right: 20px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s ease-in-out;
    z-index: 1050;
    background-color: var(--indigo);
    border-color: var(--indigo-dark);
    color: #fff;
}

#backToTop.show {
    opacity: 0.9;
    pointer-events: auto;
}

#backToTop:hover {
    background-color: var(--indigo-dark);
    opacity: 1;
}

/* =========================================================
   フッター
   ========================================================= */
footer {
    background-color: var(--indigo);
    color: #fff;
}

footer a {
    color: #fff;
}

