/* /custom-assets/blog-pages/list-style.css */

/* --- メンバー一覧 (アコーディオン) --- */
.bml-wrapper { margin-bottom: 30px; }
.bml-accordion { border: 1px solid #e0e0e0; border-radius: 8px; overflow: hidden; }
.bml-accordion > summary { padding: 15px 20px; font-size: 1.1em; font-weight: bold; cursor: pointer; user-select: none; }
.bml-accordion > summary:hover { background-color: #f9f9f9; }
.bml-content { padding: 20px; border-top: 1px solid #e0e0e0; }
.bml-overall-link { text-align: center; margin-bottom: 20px; }
.bml-overall-link .button {
    background: linear-gradient(136deg, var(--nogizaka-color) 0%, var(--sakurazaka-color) 50%, var(--hinatazaka-color) 100%);
    transition: filter 0.2s ease;
    color: white !important;
}
.bml-overall-link .button:hover { filter: brightness(1.15); }
.bml-groups-container { display: grid; grid-template-columns: 1fr; gap: 20px; }
.bml-group-column { border-radius: 8px; overflow: hidden; }
.bml-group-column.group-nogizaka46 { --theme-color: var(--nogizaka-color); }
.bml-group-column.group-sakurazaka46 { --theme-color: var(--sakurazaka-color); }
.bml-group-column.group-hinatazaka46 { --theme-color: var(--hinatazaka-color); }
.bml-group-column { border: 2px solid var(--theme-color); }
.bml-group-column > summary { padding: 12px 15px; background-color: var(--theme-color); color: white; font-size: 1em; font-weight: bold; cursor: pointer; user-select: none; }
.bml-group-column > summary:hover { filter: brightness(1.1); }
.bml-group-column > summary::-webkit-details-marker { display: none; }
.bml-group-column > summary { list-style: none; }
.bml-group-content { padding: 15px; }
.bml-group-button { margin-bottom: 15px; }
.bml-generation h4 { font-size: 0.9em; margin: 10px 0 5px; border-bottom: 1px solid #eee; padding-bottom: 5px; }
.bml-member-list { display: flex; flex-wrap: wrap; gap: 8px; list-style: none; padding: 0; margin: 0; }
.bml-member-list li { margin: 0; }
.bml-member-list a, .bml-current-member { display: block; padding: 6px 12px; border-radius: 15px; text-decoration: none; transition: all 0.2s; }
.bml-current-member { font-weight: bold; background-color: var(--theme-color); color: white; border: 1px solid var(--theme-color); }

@media (min-width: 1000px) {
  .bml-groups-container { grid-template-columns: repeat(3, 1fr); }
  .bml-group-column > summary { cursor: default; }
  .bml-group-column > summary:hover { filter: none; }
}

/* --- ブログ一覧カード --- */
.bl-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}
.bl-card { border: 1px solid #e0e0e0; border-radius: 8px; overflow: hidden; display: flex; flex-direction: column; cursor: pointer; transition: box-shadow 0.2s; }
.bl-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.bl-card.group-nogizaka46 { --theme-color: var(--nogizaka-color); }
.bl-card.group-sakurazaka46 { --theme-color: var(--sakurazaka-color); }
.bl-card.group-hinatazaka46 { --theme-color: var(--hinatazaka-color); }
.bl-thumbnail { position: relative; width: 100%; }
.bl-thumbnail img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 1 / 1; }
.bl-blog-num { position: absolute; top: 0; left: 0; background: var(--theme-color); color: white; padding: 4px 10px; font-size: 0.8em; border-bottom-right-radius: 8px; font-weight: bold; }
.bl-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to top, rgba(0,0,0,0.7), transparent 60%); display: flex; align-items: flex-end; padding: 10px; }
.bl-header { display: flex; justify-content: space-between; align-items: center; width: 100%; gap: 10px; }
.bl-header a { padding: 5px 12px; border-radius: 12px; font-size: 0.85em; font-weight: bold; text-decoration: none; }
.bl-header-mobile { display: none; }
.bl-content { padding: 15px; flex-grow: 1; display: flex; flex-direction: column; }
.bl-title { font-size: 1.1em; margin: 0 0 10px; line-height: 1.4; flex-grow: 1; overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }
.bl-date { font-size: 0.9em; color: #777; margin-bottom: 15px; }
.bl-actions { display: flex; gap: 5px; }
.bl-action-link.button { flex: 1; font-size: clamp(0.6rem, -1.078rem + 7.8vw, 0.8rem); }

@media (max-width: 611px) {
    .bl-card { flex-direction: row; }
    .bl-thumbnail { width: 120px; flex-shrink: 0; }
    .bl-thumbnail img { aspect-ratio: auto; }
    .bl-content { flex-grow: 1; padding: 12px; }
    .bl-overlay { display: none; }
    .bl-header-mobile { display: flex; justify-content: space-between; margin-bottom: 10px; flex-wrap: wrap; gap: 8px; }
    .bl-header-mobile a { padding: 5px 12px; border-radius: 12px; font-size: 0.85em; font-weight: bold; text-decoration: none; }
    .bl-actions .bl-action-link.button { padding: 10px; }
}

/* --- ページネーション --- */
.bl-pagination { text-align: center; margin-top: 40px; }
.bl-pagination ul { list-style: none; padding: 0; display: inline-flex; flex-wrap: wrap; justify-content: center; gap: 5px; }
.bl-pagination li span, .bl-pagination li a { padding: 8px 12px; border: 1px solid #ddd; text-decoration: none; color: #555; border-radius: 4px; display: block; font-weight: bold; transition: all 0.2s ease; }
.bl-pagination li span.current { background: #555; color: white; border-color: #555; }
.bl-pagination li a:hover { background: #f0f0f0 !important; color: #333 !important; }
.bl-pagination.pagination-group-nogizaka46 li span.current { background-color: var(--nogizaka-color); border-color: var(--nogizaka-color); }
.bl-pagination.pagination-group-nogizaka46 li a:hover { background-color: var(--nogizaka-color) !important; color: white !important; border-color: var(--nogizaka-color) !important; }
.bl-pagination.pagination-group-sakurazaka46 li span.current { background-color: var(--sakurazaka-color); border-color: var(--sakurazaka-color); }
.bl-pagination.pagination-group-sakurazaka46 li a:hover { background-color: var(--sakurazaka-color) !important; color: white !important; border-color: var(--sakurazaka-color) !important; }
.bl-pagination.pagination-group-hinatazaka46 li span.current { background-color: var(--hinatazaka-color); border-color: var(--hinatazaka-color); }
.bl-pagination.pagination-group-hinatazaka46 li a:hover { background-color: var(--hinatazaka-color) !important; color: white !important; border-color: var(--hinatazaka-color) !important; }

/* --- ポップアップモーダル --- */
.blog-popup-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 9999; display: none; align-items: center; justify-content: center; }
.blog-popup-modal.active { display: flex; }
.blog-popup-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.7); cursor: pointer; }
.blog-popup-container { position: relative; width: 95%; max-width: 1200px; height: 90vh; background-color: #fff; border-radius: 8px; box-shadow: 0 5px 15px rgba(0,0,0,0.3); display: flex; flex-direction: column; }
.blog-popup-container.group-nogizaka46 { --theme-color: var(--nogizaka-color); }
.blog-popup-container.group-sakurazaka46 { --theme-color: var(--sakurazaka-color); }
.blog-popup-container.group-hinatazaka46 { --theme-color: var(--hinatazaka-color); }
.blog-popup-close { position: absolute; top: -15px; right: -15px; width: 35px; height: 35px; border-radius: 50%; background-color: #333; color: white; border: 2px solid white; font-size: 24px; line-height: 1; cursor: pointer; z-index: 10; }
.blog-popup-content { padding: 20px 20px 0; overflow-y: auto; flex-grow: 1; }
.report-close-btn { width: 100%; margin-top: 15px; }

/* --- 一括設定ボタン --- */
.global-settings-btn-wrapper { margin-bottom: 20px; }
#open-settings-popup-btn { width: 100%; --theme-color: #666; }
#open-settings-popup-btn.group-nogizaka46 { --theme-color: var(--nogizaka-color); }
#open-settings-popup-btn.group-sakurazaka46 { --theme-color: var(--sakurazaka-color); }
#open-settings-popup-btn.group-hinatazaka46 { --theme-color: var(--hinatazaka-color); }

/* --- 設定ポップアップモーダル --- */
#settings-popup-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 10000; display: none; align-items: center; justify-content: center; }
#settings-popup-modal.active { display: flex; }
.settings-popup-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.7); cursor: pointer; }
.settings-popup-container { position: relative; width: 95%; max-width: 600px; background-color: #fff; border-radius: 8px; box-shadow: 0 5px 15px rgba(0,0,0,0.3); display: flex; flex-direction: column; }
.settings-popup-container.group-nogizaka46 { --theme-color: var(--nogizaka-color); }
.settings-popup-container.group-sakurazaka46 { --theme-color: var(--sakurazaka-color); }
.settings-popup-container.group-hinatazaka46 { --theme-color: var(--hinatazaka-color); }
.settings-popup-header { padding: 15px 20px; border-bottom: 1px solid #eee; display: flex; justify-content: space-between; align-items: center; gap: 15px; }
.settings-popup-header h2 { margin: 0; font-size: 1.2em; flex-grow: 1; }
.settings-popup-header .button { padding: 6px 12px; font-size: 0.8em; }
.settings-popup-close { background: none; border: none; font-size: 24px; cursor: pointer; color: #888; padding: 0 5px; }
.settings-popup-content { padding: 20px; max-height: 70vh; overflow-y: auto; }
.settings-group { margin-bottom: 25px; }
.settings-group h3 { font-size: 1.1em; margin: 0 0 15px; border-bottom: 2px solid #f0f0f0; padding-bottom: 10px; }
.setting-item { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; }
.setting-item-label { font-size: 0.95em; }
.settings-popup-footer { padding: 15px 20px; border-top: 1px solid #eee; text-align: center; }
#settings-popup-footer-close { width: 100%; }
.setting-structure-toggles { display: flex; gap: 8px; flex-wrap: wrap; }
.setting-structure-toggle { background-color: #ccc; color: #555; border: none; padding: 6px 12px; border-radius: 15px; font-size: 0.85em; font-weight: bold; cursor: pointer; transition: all 0.2s ease; }
.setting-structure-toggle.active { background-color: var(--theme-color); color: white; }
.setting-structure-preview { font-size: 0.9em; color: #666; background-color: #f9f9f9; border: 1px solid #ddd; padding: 8px 12px; border-radius: 4px; overflow-wrap: break-word; margin-top: 10px; }
.setting-structure-preview .path-part { font-weight: bold; color: #333; }