/**
 * Single Exhibit Page Styles
 *
 * Aligns with museemontrealjuif.ca design language.
 * Overrides Bootstrap defaults for exhibit pages.
 */

:root {
    --mjm-primary: #e84d21;
    --mjm-primary-hover: #c93d15;
    --mjm-text: #3C3950;
    --mjm-text-muted: #99A9B5;
    --mjm-bg-light: #FDF0EC;
    --mjm-bg-dark: #38393D;
    --mjm-shadow: 6px 6px 9px rgba(0, 0, 0, 0.2);
}

/* ── Page layout ── */

.single-exhibit,
article.type-exhibit {
    background-color: #fff;
}

/* Override Visual Composer/WPBakery row backgrounds on exhibit pages */
.single-exhibit .vc_row,
.single-exhibit .vc_row-fluid,
.single-exhibit .vc_column-inner,
.single-exhibit .wpb_wrapper,
.single-exhibit [class*="vc_custom_"] {
    background-color: #fff !important;
}

.single-exhibit .container-fluid {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 2rem;
    padding-right: 2rem;
}

/* ── Typography ── */

.single-exhibit .display-4 {
    color: var(--mjm-text);
    font-family: 'Libre Baskerville', Georgia, 'Times New Roman', serif;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-weight: 700;
    font-size: 2.2rem;
}

.single-exhibit .entry-header .h4.text-muted {
    color: var(--mjm-text-muted) !important;
    font-weight: 400;
    letter-spacing: 0.02em;
}

.single-exhibit .entry-content,
.single-exhibit .card-body {
    font-size: 15px;
    line-height: 1.7;
    color: var(--mjm-text);
}

.single-exhibit .card-header .h4 {
    font-weight: 600;
    font-family: 'Libre Baskerville', Georgia, 'Times New Roman', serif;
}

.single-exhibit .sources-content {
    font-size: 14px;
    color: var(--mjm-text-muted);
}

.single-exhibit .sources-content p {
    margin-bottom: 0.5rem;
}

/* ── Links ── */

.single-exhibit a {
    color: var(--mjm-primary);
    transition: color 0.2s ease;
}

.single-exhibit a:hover,
.single-exhibit a:focus {
    color: var(--mjm-primary-hover);
}

.single-exhibit .entry-content a,
.single-exhibit .card-body a {
    text-decoration: none;
}

.single-exhibit .entry-content a:hover,
.single-exhibit .card-body a:hover {
    text-decoration: underline;
}

/* ── Cards ── */

.single-exhibit .card {
    border: none;
    border-radius: 8px;
    box-shadow: var(--mjm-shadow);
    overflow: hidden;
}

.single-exhibit .card-header {
    background: var(--mjm-primary);
    border-bottom: 2px solid var(--mjm-bg-light);
}

.single-exhibit .card-header .h4 {
    color: #fff;
}

/* ── Category badges ── */

.single-exhibit .badge.bg-secondary {
    background-color: var(--mjm-primary) !important;
    color: #fff !important;
    border-radius: 9999px;
    font-weight: 500;
    padding: 0.6em 1.3em;
    font-size: 1.23rem;
}

.single-exhibit .badge.bg-secondary:hover {
    background-color: var(--mjm-primary-hover) !important;
}

/* ── Image carousel ── */

.single-exhibit .location-image-container {
    position: relative;
    overflow: hidden;
}

.single-exhibit .location-image-trigger {
    display: block;
    width: 100%;
    border: 0;
    padding: 0;
    background: none;
    text-align: left;
    cursor: pointer;
}

.single-exhibit .location-image-trigger:focus {
    outline: 2px solid var(--mjm-primary);
    outline-offset: 2px;
    border-radius: 6px;
}

.single-exhibit .location-image-trigger:focus:not(:focus-visible) {
    outline: none;
}

.single-exhibit .location-image {
    width: 100%;
    height: 300px;
    object-fit: cover;
    border-radius: 4px;
}

.single-exhibit .location-image-title,
.single-exhibit .location-image-caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(60, 57, 80, 0.75);
    color: white;
    padding: 8px;
    text-align: center;
    font-size: 14px;
    font-weight: normal;
    margin: 0;
}

/* ── Map container ── */

.single-exhibit #single-exhibit-map {
    border-radius: 8px;
    border: 1px solid #dee2e6;
}

/* ── Edit button (footer) ── */

.single-exhibit .entry-footer .btn-outline-secondary {
    border-radius: 9999px;
    border-color: var(--mjm-text);
    color: var(--mjm-text);
    padding: 0.45em 1.5em;
    transition: all 0.2s ease;
}

.single-exhibit .entry-footer .btn-outline-secondary:hover,
.single-exhibit .entry-footer .btn-outline-secondary:focus {
    background-color: var(--mjm-primary);
    border-color: var(--mjm-primary);
    color: #fff;
}

/* ── Horizontal rule ── */

.single-exhibit hr {
    border-color: var(--mjm-bg-light);
    opacity: 1;
}

/* ── Modal refinements ── */

.single-exhibit .modal-content {
    border-radius: 8px;
    border: none;
    box-shadow: var(--mjm-shadow);
}

.single-exhibit .modal-header {
    background: var(--mjm-primary);
    border-bottom: 2px solid var(--mjm-bg-light);
}

.single-exhibit .modal-title {
    color: #fff;
    font-family: 'Libre Baskerville', Georgia, 'Times New Roman', serif;
}

.single-exhibit .modal-header .btn-close {
    filter: invert(1);
}

/* ── Responsive ── */

@media (max-width: 991.98px) {
    .single-exhibit .display-4 {
        font-size: 1.6rem;
    }
}
