.book-layout {

    width: 100vw; /* ビューポート幅いっぱい */
    margin-left: calc(-50vw + 50%); /* 画面中央から左端まで広げる */
    margin-right: calc(-50vw + 50%); /* 画面中央から右端まで広げる */
}

/* グレーの背景を持つコンテンツ部分 */
.book-content {
    position: relative; /* 子要素の配置の基準点となる */
    padding: 20px;
    padding-top: 60px;
    /* border-top: 1px solid #ddd;
    border-bottom: 1px solid #ddd; */
    background-color: #f5f5f5; /* 画像がない場合のデフォルト背景色 */
    overflow: hidden; /* はみ出た背景画像を隠す */
}

/* 背景画像用のスタイル */
.background-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover; /* 画像をコンテナにフィット */
    background-position: center; /* 画像を中央に配置 */
    filter: blur(5px); /* 画像をぼかす */
    transform: scale(1.1); /* ブラーによる端のずれを補正 */
    z-index: 1;
}

/* 暗めのオーバーレイ */
.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6); /* 暗めの半透明オーバーレイ */
    z-index: 2;
}

.overlay-home {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.6); /* 暗めの半透明オーバーレイ */
    z-index: 2;
}


/* 実際のコンテンツを中央に配置するためのラッパー */
.content-wrapper {
    position: relative;
    z-index: 3; /* 最前面に配置 */
    max-width: 800px;
    margin: 0 auto;
    padding: 0 20px;
    color: white; /* 画像背景の場合は白文字 */
}

/* 画像がない場合のスタイル調整 */
.book-content:not(:has(.background-image)) .content-wrapper {
    color: inherit; /* デフォルトの文字色に戻す */
}

.title-section {
    display: flex;
    gap: 20px;
    margin-bottom: 20px;
}

.book-image {
    flex: 0 0 190px;
    max-width: 190px; /* 最大サイズを設定 */
    width: 100%; /* 親要素に合わせて幅を自動調整 */
    /* border: 1px solid #ddd; */
    /* filter: drop-shadow(5px 5px 5px #202020); 影を追加 */
}

/* 大画面対応 */
@media (min-width: 1200px) {
    .book-image {
        flex: 0 0 250px;
        max-width: 250px;
    }
}

@media (min-width: 1400px) {
    .book-image {
        flex: 0 0 280px;
        max-width: 280px;
    }
}

@media (min-width: 1600px) {
    .book-image {
        flex: 0 0 320px;
        max-width: 320px;
    }
}

/* デスクトップ */
@media (min-width: 992px) and (max-width: 1199px) {
    .book-image {
        flex: 0 0 220px;
        max-width: 220px;
    }
}

@media (max-width: 768px) { /* タブレットサイズ以下の場合 */
    .book-image {
        flex: 0 0 190px; /* スマホサイズの場合の幅を指定 */
    }
}

@media (max-width: 435px) {
    .book-image {
        flex: 0 0 180px;
    }
}

@media (max-width: 420px) {
    .book-image {
        flex: 0 0 165px;
    }
}

@media (max-width: 380px) {
    .book-image {
        flex: 0 0 150px;
    }
}

@media (max-width: 370px) {
    .book-image {
        flex: 0 0 140px;
    }
}

.book-image img {
    width: 100%;
    height: auto;
    filter: drop-shadow(5px 5px 5px #202020); /* 影を追加 */
}

.no-image {
    width: 100%;
    height: 280px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #eee;
    text-align: center;
}

.book-info {
    flex: 1;
    /* writing-mode: vertical-rl; */
    overflow-x: hidden; /* 横方向のはみ出しを防ぐ */
}

.book-info h1 {
    margin: 0 0 15px 0;
    font-size: 135%;
    font-family: 'Times New Roman' , '游明朝' , 'Yu Mincho' , '游明朝体' , 'YuMincho' , 'ヒラギノ明朝 Pro W3' , 'Hiragino Mincho Pro' , 'HiraMinProN-W3' , 'HGS明朝E' , 'ＭＳ Ｐ明朝' , 'MS PMincho' , serif;
}

.book-info p {
    margin: 5px 0;
    font-size: 100%;
    font-family: 'Times New Roman' , '游明朝' , 'Yu Mincho' , '游明朝体' , 'YuMincho' , 'ヒラギノ明朝 Pro W3' , 'Hiragino Mincho Pro' , 'HiraMinProN-W3' , 'HGS明朝E' , 'ＭＳ Ｐ明朝' , 'MS PMincho' , serif;
}

.description-section {
    margin-bottom: 20px;
    padding-top: 2%;
    padding-bottom: 0.5%;
    padding-right: 15%;  /* デフォルトで15% */
    padding-left: 15%;
    background-color: white;
    border-radius: 3px;
    font-size: 100%;
}

/* 大画面対応 - 画像とテキストサイズを連動 */
@media (min-width: 1600px) {
    .book-image {
        flex: 0 0 320px;
        max-width: 320px;
    }
    .book-info h1 {
        font-size: 170%;
    }
    .book-info p {
        font-size: 115%;
    }
}

@media (min-width: 1400px) and (max-width: 1599px) {
    .book-image {
        flex: 0 0 280px;
        max-width: 280px;
    }
    .book-info h1 {
        font-size: 155%;
    }
    .book-info p {
        font-size: 110%;
    }
}

@media (min-width: 1200px) and (max-width: 1399px) {
    .book-image {
        flex: 0 0 250px;
        max-width: 250px;
    }
    .book-info h1 {
        font-size: 145%;
    }
    .book-info p {
        font-size: 110%;
    }
}

/* デスクトップ */
@media (min-width: 992px) and (max-width: 1199px) {
    .book-image {
        flex: 0 0 220px;
        max-width: 220px;
    }
    .book-info h1 {
        font-size: 140%;
    }
    .book-info p {
        font-size: 105%;
    }
}

/* タブレットサイズ */
@media (max-width: 768px) {
    .description-section {
        padding-right: 10%;
        padding-left: 10%;
        padding-top: 4%;
    }
    .book-image {
        flex: 0 0 190px;
    }
    .book-info h1 {
        font-size: 135%;
    }
    .book-info p {
        font-size: 105%;
    }
}

@media (max-width: 435px) {
    .book-image {
        flex: 0 0 180px;
    }
    .book-info h1 {
        font-size: 125%;
    }
    .book-info p {
        font-size: 100%;
    }
}

@media (max-width: 420px) {
    .book-image {
        flex: 0 0 165px;
    }
    .book-info h1 {
        font-size: 120%;
    }
    .book-info p {
        font-size: 100%;
    }
}

@media (max-width: 380px) {
    .book-image {
        flex: 0 0 150px;
    }
    .book-info h1 {
        font-size: 115%;
    }
    .book-info p {
        font-size: 100%;
    }
}

@media (max-width: 370px) {
    .book-image {
        flex: 0 0 140px;
    }
    .book-info h1 {
        font-size: 110%;
    }
    .book-info p {
        font-size: 100%;
    }
}

/* スマートフォンサイズ */
@media (max-width: 480px) {
    .description-section {
        padding-right: 9%;
        padding-left: 9%;
        padding-top: 5%;
    }
    .book-info {
        writing-mode: vertical-rl;
        overflow-wrap: break-word; /* 単語の途中で改行 */
        max-height: 20em; /* 表示領域の高さを制限 */
        line-height: 1em; /* 行の高さを設定 */
    }
    .book-info h1 {
        margin-left: 0.5rem; /* タイトル横に余白 */
        font-size: 120%; /* 縦書き時のサイズ */
    }
    .book-info p {
        display: flex;
        justify-content: flex-end; /* タイトル以外の要素を下に下げる */
        margin-left: 0.1rem;
        font-size: 100%; /* 縦書き時のサイズ */
    }
}

/* 横並び配置のためのコンテナ - シームレスなレスポンシブ対応 */
#book-author-container {
    display: flex !important;
    flex-wrap: nowrap;
    gap: 15px; /* 固定値に変更 */
    justify-content: center;
    align-items: flex-end;
    margin-top: 1.5%;
    margin-bottom: 3%;
    border-bottom: 7px solid #8d8d8d;
    filter: drop-shadow(5px 5px 5px #aaa);
    padding: 0 10px; /* 固定値に変更 */
    overflow-x: auto;
    
    /* CSS変数で基準値を設定 */
    --min-book-width: 80px;
    --max-book-width: 200px;
    --optimal-book-width: clamp(var(--min-book-width), 15vw, var(--max-book-width));
}

.book-card-author {
    flex: 0 0 auto;
    text-align: center;
    box-sizing: border-box;
    filter: drop-shadow(5px 5px 5px #aaa);
    transition: transform 0.2s ease, width 0.3s ease;
    
    /* シームレスな幅調整 */
    width: var(--optimal-book-width);
    min-width: var(--min-book-width);
    max-width: var(--max-book-width);
}

/* 画面サイズ別の微調整 */
/* 大画面 */
@media screen and (min-width: 1200px) {
    #book-author-container {
        --optimal-book-width: clamp(150px, 12vw, 200px);
        gap: 15px; /* 固定値 */
    }
}

/* 中画面 */
@media screen and (max-width: 1199px) and (min-width: 768px) {
    #book-author-container {
        --optimal-book-width: clamp(150px, 18vw, 180px);
        gap: 10px; /* 固定値 */
    }
}

/* 小画面 */
@media screen and (max-width: 767px) and (min-width: 481px) {
    #book-author-container {
        --optimal-book-width: clamp(120px, 20vw, 160px);
        gap: 8px; /* 固定値 */
    }
}

/* 極小画面 */
@media screen and (max-width: 480px) {
    #book-author-container {
        --optimal-book-width: clamp(100px, 25vw, 130px);
        gap: 5px; /* 固定値 */
        padding: 0 5px; /* 固定値 */
    }
}

/* 画像コンテナも連動 */
.book-image-container-author {
    aspect-ratio: 3/4;
    width: 100%;
    position: relative;
    overflow: hidden;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
}

.search-section {
    padding: 15px;
    background-color: white;
    border-radius: 3px;
}

/* 検索フォームのスタイル */
#geocode-form {
    display: flex;
    gap: 10px;
    align-items: center;
}

#keyword-input {
    flex: 1;
    padding: 8px;
    border: 2px solid #ddd;
    border-radius: 3px;
}
 
.input-group {
    display: flex;
    align-items: stretch; /* 高さを揃える */
    width: 100%;
    max-width: 300px;
    margin: 0 auto;
    gap: 0; /* 隙間をなくす */
}

.input-group input.form-control {
    flex: 1;
    min-width: 0;
    border-right: none; /* 右側のボーダーを削除 */
    border-top-right-radius: 0; /* 右側の角を四角に */
    border-bottom-right-radius: 0;
}

.input-group-append {
    display: flex;
    margin-left: -1px; /* ボーダーの重なりを調整 */
}

.custom-btn {
    background-color: white !important;
    border: 1px solid #32CD32 !important;  /* 常に枠線を表示 */
    color: #32CD32;
    padding: 8px 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.3s, border-color 0.3s, background-color 0.3s;
}

.custom-btn i.fas.fa-search {
    color: #32CD32;
}

.custom-btn:hover {
    color: #236e44;
    border-color: #236e44 !important;
    background-color: #f8f8f8 !important;
}

.custom-btn:hover i.fas.fa-search {
    color: #236e44;
}

 /* スマートフォン向けの調整 */
 @media screen and (max-width: 480px) {
    #search-form {
        max-width: 100%;
        padding: 0 10px;
    }
 
    .custom-btn {
        padding: 6px 10px; /* スマホ向けに少しコンパクトに */
    }
    
    .input-group {
        padding: 0 10px;
    }
 }
 
 /* 極小画面向け */
 @media screen and (max-width: 320px) {
    .custom-btn {
        padding: 6px 8px;
        border-width: 1px; /* ボーダーの幅を修正 */
    }
 }

 /* 検索フォーム全体のスタイル */
#search-form {
    margin-top: 20px;
    width: 100%;
}

/* 基本ボタンスタイル */
button {
    padding: 8px 15px;
    background-color: #007bff;
    color: white;
    border: none;
    border-radius: 3px;
    cursor: pointer;
}

button:hover {
    background-color: #0056b3;
}