/**
 * ARCHIV — Passe production (responsive, a11y, polish — sans nouvelle direction)
 */

/* —— Base & overflow —— */
html {
    scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

body.archiv-site {
    overflow-x: clip;
    min-width: 0;
}

.archiv-page-shell {
    width: min(100%, var(--content-max, 76rem));
    max-width: 100%;
}

/* —— Accessibilité : focus visible —— */
.archiv-skip-link:focus {
    position: fixed;
    top: 0.75rem;
    left: 0.75rem;
    z-index: 2000;
    padding: 0.65rem 1rem;
    background: var(--aged-gold, #b68a3a);
    color: var(--ink, #11100d);
    font-family: var(--font-ui);
    font-size: 14px;
    text-decoration: none;
    outline: none;
    box-shadow: 0 0 0 3px rgba(242, 235, 221, 0.5);
}

body.archiv-site a:focus-visible,
body.archiv-site button:focus-visible,
body.archiv-site .archiv-btn:focus-visible {
    outline: 2px solid var(--aged-gold, #b68a3a);
    outline-offset: 3px;
}

body.archiv-site .archiv-museum-header__toggle:focus-visible {
    outline-color: var(--text-light, #f2ebdd);
}

/* —— Navigation : lisibilité tablette (jamais < 15px) —— */
@media (max-width: 1400px) and (min-width: 1200px) {
    body.archiv-site .archiv-museum-nav__list a {
        font-size: 15px;
        padding: 0 12px;
        letter-spacing: 0.02em;
    }
}

body.archiv-site.archiv-nav-open {
    overflow: hidden;
}

/* —— Boutons & filtres (touch mobile) —— */
@media (max-width: 767px) {
    body.archiv-site .archiv-btn,
    body.archiv-site .archiv-filter-btn,
    body.archiv-site .archiv-museum-header__toggle {
        min-height: 44px;
        min-width: 44px;
    }

    body.archiv-site .archiv-filter-btn {
        font-size: 13px;
        padding: 0.5rem 0.85rem;
    }

    body.archiv-site .archiv-toolbar {
        flex-direction: column;
        align-items: stretch;
        gap: 1rem;
    }

    body.archiv-site .archiv-filters,
    body.archiv-site .archiv-sort-group {
        flex-wrap: wrap;
        gap: 0.5rem;
    }
}

/* —— Grilles & cartes —— */
body.archiv-site .archiv-collection-grid {
    margin-left: 0;
    margin-right: 0;
}

body.archiv-site .archiv-collection-grid > [class*="col-"] {
    min-width: 0;
}

body.archiv-site .archiv-artwork-card,
body.archiv-site .archiv-work-card {
    min-width: 0;
    height: 100%;
}

/* Cartes catalogue : résumé entier, pied de carte (documentation) toujours visible */
body.archiv-site .archiv-artwork-card__cartel,
body.archiv-site .archiv-work-card__body {
    min-height: 0;
    overflow: visible;
}

body.archiv-site .archiv-artwork-card__summary {
    display: block;
    -webkit-line-clamp: unset;
    overflow: visible;
}

body.archiv-site .archiv-artwork-card__institution {
    flex-shrink: 0;
}

body.archiv-site .archiv-source-block,
body.archiv-site .archiv-card-actions {
    flex-shrink: 0;
}

body.archiv-site .archiv-collection-spotlight .archiv-artwork-card--feature {
    display: grid;
    grid-template-columns: 1fr;
}

@media (min-width: 992px) {
    body.archiv-site .archiv-collection-spotlight .archiv-artwork-card--feature {
        grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    }
}

/* —— Compare / prose —— */
.archiv-compare {
    display: grid;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .archiv-compare {
        grid-template-columns: 1fr 1fr;
    }
}

.archiv-prose-block,
.archiv-lead {
    overflow-wrap: break-word;
    word-wrap: break-word;
}

/* —— Table sources —— */
.archiv-table-wrap {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 1rem 0 2rem;
}

.archiv-credits-table {
    width: 100%;
    min-width: 36rem;
    border-collapse: collapse;
    font-size: 0.9375rem;
    line-height: 1.5;
}

.archiv-credits-table th,
.archiv-credits-table td {
    padding: 0.65rem 0.85rem;
    text-align: left;
    border-bottom: 1px solid rgba(74, 56, 40, 0.15);
    vertical-align: top;
}

.archiv-credits-table th {
    font-family: var(--font-ui);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-brown, #4a3828);
}

.archiv-credits-table a {
    color: var(--dark-gold, #8c6728);
}

/* —— Fiche œuvre —— */
body.archiv-site .archiv-oeuvre-layout {
    align-items: start;
}

@media (max-width: 991px) {
    body.archiv-site .archiv-oeuvre-hero {
        min-height: auto;
        max-height: none;
    }
}

/* —— Lightbox mobile —— */
@media (max-width: 767px) {
    .mfp-archiv .mfp-close {
        padding: 12px;
        right: 4px;
        top: 4px;
    }

    .mfp-archiv .mfp-title {
        font-size: 14px;
        line-height: 1.45;
        padding: 12px 16px;
    }
}

/* —— Hero accueil : stabilité layout —— */
.archiv-immersive-hero {
    contain: layout style;
}

/* —— Liens externes : lisibilité —— */
body.archiv-site a[target="_blank"]:not(.archiv-btn)::after {
    content: none;
}

body.archiv-site .archiv-text-link {
    text-underline-offset: 3px;
}

body.archiv-site .archiv-see-also ul {
    list-style: none;
    margin: 0.75rem 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1.25rem;
}

body.archiv-site .archiv-see-also a {
    font-family: var(--font-ui, "Outfit", sans-serif);
    font-size: 0.95rem;
    color: var(--aged-gold, #b68a3a);
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* —— Footer cohérent —— */
.archiv-archive-footer a:hover {
    color: var(--text-light, #f2ebdd);
}

/* —— Navigation regroupée (dropdowns musée) —— */
body.archiv-site .archiv-museum-header,
body.archiv-site .archiv-museum-header__inner,
body.archiv-site .archiv-museum-nav,
body.archiv-site .archiv-museum-nav__list {
    overflow: visible;
}

/* Logo mobile : garder le médaillon (portrait Dürer) lisible */
@media (max-width: 1199px) {
    body.archiv-site .archiv-museum-header__inner {
        gap: 0.65rem;
    }

    body.archiv-site .archiv-museum-header__brand {
        flex: 0 1 auto;
        min-width: 0;
        max-width: calc(100% - 3.25rem);
    }

    body.archiv-site .archiv-museum-header__logo {
        width: auto;
        max-width: min(220px, 56vw);
        height: clamp(50px, 12vw, 56px);
        object-fit: contain;
        object-position: left center;
    }
}

body.archiv-site .archiv-museum-nav-mobile__logo {
    display: block;
    width: auto;
    height: 48px;
    max-width: 100%;
    object-fit: contain;
    object-position: left center;
}

@media (min-width: 1200px) {
    body.archiv-site .archiv-museum-header__inner {
        gap: 0.75rem;
    }

    body.archiv-site .archiv-museum-nav--desktop {
        flex: 1 1 auto;
        min-width: 0;
        display: flex;
        justify-content: flex-end;
    }

    body.archiv-site .archiv-museum-nav__list {
        flex-shrink: 1;
        min-width: 0;
        max-width: 100%;
    }
}

@media (min-width: 1200px) and (max-width: 1399px) {
    body.archiv-site .archiv-museum-nav__list > li > a,
    body.archiv-site .archiv-nav-dropdown__trigger {
        padding-left: 10px;
        padding-right: 10px;
        font-size: 15px;
    }
}

body.archiv-site .archiv-museum-nav__list > li {
    position: relative;
}

body.archiv-site .archiv-nav-dropdown {
    position: relative;
}

body.archiv-site .archiv-nav-dropdown__trigger {
    font-family: var(--font-ui, "Outfit", sans-serif);
    font-size: 15px;
    font-variant-caps: normal;
    text-transform: none;
    letter-spacing: 0.03em;
    font-weight: 400;
    color: var(--archiv-nav-inactive, rgba(230, 216, 191, 0.88));
    background: transparent;
    border: none;
    box-shadow: none;
    cursor: pointer;
    padding: 0 clamp(14px, 1.6vw, 22px);
    line-height: 1.35;
    white-space: nowrap;
    transition: color 0.32s ease, opacity 0.32s ease;
    appearance: none;
    -webkit-appearance: none;
}

body.archiv-site .archiv-nav-dropdown__trigger--oeuvres {
    letter-spacing: 0.02em;
    font-feature-settings: "liga" 0;
}

@media (min-width: 1200px) {
    body.archiv-site .archiv-nav-dropdown__trigger,
    body.archiv-site .archiv-museum-nav__list > li > a {
        font-size: 16px;
    }
}

body.archiv-site .archiv-nav-dropdown__trigger:hover,
body.archiv-site .archiv-nav-dropdown__trigger.active,
body.archiv-site .archiv-nav-dropdown:focus-within .archiv-nav-dropdown__trigger {
    color: var(--archiv-nav-hover, #b68a3a);
}

body.archiv-site .archiv-nav-dropdown__trigger.active {
    color: var(--archiv-nav-active, #e6d8bf);
}

@media (min-width: 1200px) {
    body.archiv-site .archiv-museum-nav--desktop .archiv-nav-dropdown__menu {
        display: block;
        position: absolute;
        top: calc(100% + 6px);
        left: 0;
        right: auto;
        min-width: 11.5rem;
        margin: 0;
        padding: 0.3rem 0;
        list-style: none;
        background: rgba(14, 13, 11, 0.94);
        -webkit-backdrop-filter: blur(10px);
        backdrop-filter: blur(10px);
        border: none;
        border-radius: 3px;
        box-shadow:
            0 10px 28px rgba(0, 0, 0, 0.22),
            0 0 0 1px rgba(182, 138, 58, 0.1);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transform: translateY(-7px);
        transform-origin: top left;
        z-index: 1100;
        transition:
            opacity 0.42s cubic-bezier(0.22, 1, 0.36, 1),
            transform 0.48s cubic-bezier(0.22, 1, 0.36, 1),
            visibility 0s linear 0.48s,
            box-shadow 0.4s ease;
    }

    /* Pont invisible : évite la fermeture entre le bouton et le panneau */
    body.archiv-site .archiv-nav-dropdown__menu::before {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        top: -14px;
        height: 14px;
    }

    body.archiv-site .archiv-nav-dropdown__menu > li {
        opacity: 0;
        transform: translateY(-4px);
        transition:
            opacity 0.36s cubic-bezier(0.22, 1, 0.36, 1),
            transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
    }

    body.archiv-site .archiv-nav-dropdown__menu > li:nth-child(1) { transition-delay: 0.04s; }
    body.archiv-site .archiv-nav-dropdown__menu > li:nth-child(2) { transition-delay: 0.08s; }
    body.archiv-site .archiv-nav-dropdown__menu > li:nth-child(3) { transition-delay: 0.12s; }
    body.archiv-site .archiv-nav-dropdown__menu > li:nth-child(4) { transition-delay: 0.16s; }

    /* Menus de droite : alignés au libellé, sans débordement */
    body.archiv-site .archiv-museum-nav__list > li.archiv-nav-dropdown--align-end .archiv-nav-dropdown__menu {
        left: auto;
        right: 0;
        transform-origin: top right;
    }

    body.archiv-site .archiv-nav-dropdown:hover .archiv-nav-dropdown__menu,
    body.archiv-site .archiv-nav-dropdown:focus-within .archiv-nav-dropdown__menu,
    body.archiv-site .archiv-nav-dropdown.is-open .archiv-nav-dropdown__menu {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: translateY(0);
        box-shadow:
            0 14px 36px rgba(0, 0, 0, 0.26),
            0 0 0 1px rgba(182, 138, 58, 0.14);
        transition:
            opacity 0.38s cubic-bezier(0.22, 1, 0.36, 1),
            transform 0.44s cubic-bezier(0.22, 1, 0.36, 1),
            visibility 0s,
            box-shadow 0.4s ease;
    }

    body.archiv-site .archiv-nav-dropdown:hover .archiv-nav-dropdown__menu > li,
    body.archiv-site .archiv-nav-dropdown:focus-within .archiv-nav-dropdown__menu > li,
    body.archiv-site .archiv-nav-dropdown.is-open .archiv-nav-dropdown__menu > li {
        opacity: 1;
        transform: translateY(0);
    }

    @media (prefers-reduced-motion: reduce) {
        body.archiv-site .archiv-museum-nav--desktop .archiv-nav-dropdown__menu,
        body.archiv-site .archiv-nav-dropdown__menu > li {
            transition-duration: 0.01ms;
            transition-delay: 0s;
        }
    }
}

@media (max-width: 1199px) {
    body.archiv-site .archiv-museum-nav--desktop .archiv-nav-dropdown__menu {
        display: none !important;
    }
}

body.archiv-site .archiv-nav-dropdown__menu a {
    display: block;
    font-family: var(--font-ui, "Outfit", sans-serif);
    font-size: 15px;
    font-variant-caps: normal;
    text-transform: none;
    letter-spacing: 0.02em;
    line-height: 1.45;
    color: rgba(230, 216, 191, 0.92);
    text-decoration: none;
    padding: 0.48rem 1rem;
    white-space: nowrap;
    transition: color 0.28s ease, background 0.32s ease;
}

@media (min-width: 1200px) {
    body.archiv-site .archiv-nav-dropdown__menu a {
        font-size: 15px;
        font-weight: 400;
        padding: 0.44rem 0.95rem;
    }
}

body.archiv-site .archiv-nav-dropdown__menu a:hover,
body.archiv-site .archiv-nav-dropdown__menu a.active {
    color: #b68a3a;
    background: rgba(182, 138, 58, 0.05);
}

body.archiv-site .archiv-nav-dropdown__menu a.active::after {
    display: none;
}

/* Mobile — groupes */
body.archiv-site .archiv-nav-mobile-link {
    font-size: 1.25rem;
    min-height: 52px;
    display: flex;
    align-items: center;
    font-weight: 400;
}

body.archiv-site .archiv-nav-mobile-group {
    margin-top: 0.5rem;
    padding-top: 0.75rem;
    border-top: 1px solid rgba(182, 138, 58, 0.15);
}

body.archiv-site .archiv-nav-mobile-group__label {
    display: block;
    font-family: var(--font-ui, "Outfit", sans-serif);
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: 0.03em;
    color: #e6d8bf;
    margin-bottom: 0.35rem;
    padding: 0.25rem 0;
}

body.archiv-site .archiv-nav-mobile-group__sub {
    list-style: none;
    margin: 0;
    padding: 0 0 0 0.75rem;
}

body.archiv-site .archiv-nav-mobile-sublink {
    font-size: 1.0625rem;
    min-height: 48px;
    display: flex;
    align-items: center;
    padding: 0.35rem 0;
    color: rgba(230, 216, 191, 0.9);
}

body.archiv-site .archiv-nav-mobile-sublink:hover,
body.archiv-site .archiv-nav-mobile-sublink.active,
body.archiv-site .archiv-nav-mobile-link:hover,
body.archiv-site .archiv-nav-mobile-link.active {
    color: #b68a3a;
}

body.archiv-site .archiv-museum-nav-mobile__list > li:first-child {
    border-top: none;
    padding-top: 0;
    margin-top: 0;
}

/* —— Masquer résidus template (sécurité production) —— */
body.archiv-site .progress-wrap,
body.archiv-site .progress-wrap * {
    display: none !important;
}

/* ============================================================
   RAFFINEMENT UI/UX PREMIUM 2026
   Passe de finition (lisibilité, hiérarchie, rythme, contraste)
   sans refonte — surcharge finale.
   ============================================================ */

/* 1. HERO — titre : plus de coupure en plein mot, cadrage maîtrisé */
body.archiv-site .archiv-immersive-hero__inner {
    max-width: 47rem;
    padding: clamp(2.5rem, 6vh, 4rem) clamp(1.4rem, 5vw, 3.5rem);
}

body.archiv-site .archiv-immersive-hero h1.archiv-immersive-hero__title {
    font-size: clamp(2.6rem, 6vw, 5.5rem);
    letter-spacing: 0.035em;
    line-height: 1.06;
    overflow-wrap: normal;
    word-break: normal;
    hyphens: manual;
    text-wrap: balance;
}

body.archiv-site .archiv-immersive-hero .archiv-immersive-hero__subtitle {
    font-size: clamp(1.3rem, 2.6vw, 1.75rem);
    line-height: 1.4;
    margin-bottom: 1.4rem;
}

body.archiv-site .archiv-immersive-hero .archiv-immersive-hero__text {
    font-size: clamp(16px, 1.05vw, 18px);
    line-height: 1.7;
    max-width: 36rem;
    color: #EADCC2;
}

/* 2. SURTITRES / KICKERS — jamais sous 13px, tracking maîtrisé */
body.archiv-site .archiv-kicker,
body.archiv-site .archiv-home-section__kicker,
body.archiv-site .archiv-eyebrow {
    font-size: 13px;
    letter-spacing: 0.16em;
}

/* 3. CARTES ŒUVRES (accueil) — légende institution lisible */
body.archiv-site .archiv-home-work__institution {
    font-size: 0.8125rem;
    line-height: 1.45;
    color: #6A523A;
}

body.archiv-site .archiv-home-work__meta {
    color: var(--text-brown, #4A3828);
}

/* 4. CARTES ÉDITIONS — supprimer le micro-texte (≥ 12px) */
body.archiv-site .archiv-edition-card__category {
    font-size: 0.72rem;
    letter-spacing: 0.13em;
    color: #5C6B5E;
}

body.archiv-site .archiv-edition-card__source {
    font-size: 0.82rem;
    opacity: 1;
    color: #4A3828;
}

body.archiv-site .archiv-edition-card__format,
body.archiv-site .archiv-edition-card__cta .archiv-edition-cta,
body.archiv-site .archiv-edition-status {
    font-size: 0.72rem;
}

body.archiv-site .archiv-editions-disclaimer {
    font-size: 0.8rem;
    line-height: 1.65;
}

/* 5. RYTHME DES SECTIONS — respiration desktop accrue */
@media (min-width: 1024px) {
    body.archiv-site .archiv-home-section,
    body.archiv-site .archiv-museum-section {
        padding-top: clamp(5rem, 8vw, 8.5rem);
        padding-bottom: clamp(5rem, 8vw, 8.5rem);
    }
}

/* 6. LARGEUR DE LECTURE — éviter les lignes trop longues */
body.archiv-site .archiv-prose,
body.archiv-site .archiv-rich-text p,
body.archiv-site .archiv-section__intro {
    max-width: 44rem;
}

/* 7. MICRO-INTERACTIONS — liens éditoriaux : soulignement fin animé */
body.archiv-site .archiv-edition-cta,
body.archiv-site .archiv-home-works__more {
    transition: color 0.18s ease, border-color 0.18s ease;
}

/* 8. IMAGES — garde-fou : vignettes accueil en cover (pas de déformation) */
body.archiv-site .archiv-home-work__frame img {
    object-fit: cover;
}

/* 9. MOBILE — confort de lecture et de touche */
@media (max-width: 767px) {
    body.archiv-site .archiv-home-section,
    body.archiv-site .archiv-museum-section {
        padding-top: clamp(3.5rem, 12vw, 5rem);
        padding-bottom: clamp(3.5rem, 12vw, 5rem);
    }

    body.archiv-site .archiv-immersive-hero h1.archiv-immersive-hero__title {
        font-size: clamp(2.4rem, 13vw, 3.4rem);
    }

    body.archiv-site .archiv-edition-card__category,
    body.archiv-site .archiv-edition-card__source {
        font-size: 0.8rem;
    }
}
