/**
 * Page Catégorie — Layout "Sommaire numéroté sticky + grille 3 colonnes"
 *
 * Chargée conditionnellement sur les pages category via wp_enqueue + is_category().
 * Sélecteurs scopés body.category pour zéro impact ailleurs.
 * Source : mockup v1-sommaire-numero-grille.html (validé user 2026-05-20).
 *
 * @package Guide-Expat-Theme
 * @since 1.4.0
 */

/* =============================================
   OVERRIDE LAYOUT CONTAINER WP
   ============================================= */
body.category #content.site-content,
body.category #content.site-content > .container {
    padding: 0;
    max-width: none;
    margin: 0;
}

/* Le thème force margin-left 300px desktop pour le totem pub. Sur category
   on garde cette réserve (le slot pub Mediavine peut afficher). Si le slot
   est vide, c'est juste du whitespace. */

/* =============================================
   BODY BACKGROUND
   ============================================= */
body.category {
    font-family: var(--sans, 'Manrope', sans-serif);
    background: var(--bg, #FEF3E2);
    color: var(--ink, #2A1D0D);
    font-size: 16px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    background-image:
        radial-gradient(ellipse 80% 60% at 50% 0%, rgba(194, 65, 12, .06), transparent 70%),
        repeating-linear-gradient(45deg, transparent 0 60px, rgba(194, 65, 12, .018) 60px 61px);
}

/* =============================================
   BREADCRUMB
   ============================================= */
body.category .ge-cat-breadcrumb {
    max-width: var(--content-max, 1400px);
    margin: 0 auto;
    padding: 1.2rem var(--side-pad, 4rem) 0;
    font-size: .82rem;
    color: var(--ink-muted, #7A5C36);
    font-family: var(--display, 'Crimson Pro', serif);
    font-style: italic;
    display: flex;
    align-items: center;
    gap: .4rem;
    flex-wrap: wrap;
}
body.category .ge-cat-breadcrumb a {
    color: var(--ink-muted, #7A5C36);
    text-decoration: none;
    transition: color .15s;
}
body.category .ge-cat-breadcrumb a:hover { color: var(--terra, #C2410C); }
body.category .ge-cat-breadcrumb .sep {
    color: var(--terra, #C2410C);
    font-style: normal;
    opacity: .6;
}
body.category .ge-cat-breadcrumb .curr {
    color: var(--ink, #2A1D0D);
    font-weight: 500;
    font-style: normal;
}

/* =============================================
   HERO
   ============================================= */
body.category .ge-cat-hero {
    max-width: var(--content-max, 1400px);
    margin: 0 auto;
    padding: 2rem var(--side-pad, 4rem) 1.5rem;
}
body.category .ge-cat-kicker {
    font-family: var(--hand, 'Caveat', cursive);
    font-size: 1.6rem;
    color: var(--terra, #C2410C);
    transform: rotate(-2deg);
    display: inline-block;
    margin-bottom: .4rem;
}
body.category .ge-cat-hero h1 {
    font-family: var(--display, 'Crimson Pro', serif);
    font-weight: 500;
    font-style: italic;
    font-size: clamp(2.2rem, 4.5vw, 3.8rem);
    line-height: 1.08;
    letter-spacing: -.02em;
    margin: 0 0 .9rem;
    color: var(--ink, #2A1D0D);
}
body.category .ge-cat-hero h1 strong {
    font-weight: 700;
    font-style: normal;
    color: var(--terra, #C2410C);
}
body.category .ge-cat-lede {
    font-size: 1.05rem;
    color: var(--ink-muted, #7A5C36);
    max-width: 72ch;
    line-height: 1.6;
    margin: 0;
    font-family: var(--sans, 'Manrope', sans-serif);
}
body.category .ge-cat-meta {
    display: flex;
    align-items: center;
    gap: 1.4rem;
    margin-top: 1rem;
    font-size: .82rem;
    color: var(--ink-muted, #7A5C36);
    font-family: var(--sans, 'Manrope', sans-serif);
    flex-wrap: wrap;
}
body.category .ge-cat-meta span { display: flex; align-items: center; gap: .35rem; }
body.category .ge-cat-meta .dot {
    width: 4px; height: 4px; border-radius: 50%;
    background: var(--terra, #C2410C); opacity: .5;
}

/* =============================================
   PAGE BODY : Sommaire + Grille
   ============================================= */
body.category .ge-cat-body {
    max-width: var(--content-max, 1400px);
    margin: 0 auto;
    padding: 1.5rem var(--side-pad, 4rem) 4rem;
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 3rem;
    align-items: start;
}
body.category .ge-cat-aside { min-width: 0; }

/* =============================================
   SOMMAIRE STICKY
   ============================================= */
body.category .ge-cat-sommaire {
    position: sticky;
    top: 88px;
    background: var(--bg-paper, #FDEAC2);
    border: 1px solid var(--rule, #E8D5A5);
    border-radius: 14px;
    padding: 1.4rem 1.5rem 1.6rem;
    box-shadow: 0 8px 24px -12px rgba(194, 65, 12, .18);
}
body.category .ge-cat-sommaire-header {
    display: flex;
    align-items: baseline;
    gap: .6rem;
    border-bottom: 1px solid var(--rule, #E8D5A5);
    padding-bottom: .8rem;
    margin-bottom: 1rem;
}
body.category .ge-cat-sommaire-label {
    font-family: var(--hand, 'Caveat', cursive);
    font-size: 1.3rem;
    color: var(--terra, #C2410C);
    transform: rotate(-1.5deg);
    display: inline-block;
}
body.category .ge-cat-sommaire-count {
    font-family: var(--sans, 'Manrope', sans-serif);
    font-size: .78rem;
    color: var(--ink-muted, #7A5C36);
    font-weight: 500;
}
body.category .ge-cat-sommaire-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: .25rem;
}
body.category .ge-cat-si {
    display: block;
    padding: 0;
    border-radius: 8px;
    transition: background .15s;
}
body.category .ge-cat-si:hover { background: rgba(194, 65, 12, .07); }
body.category .ge-cat-si a {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    width: 100%;
    text-decoration: none;
    color: inherit;
    padding: .45rem .5rem;
}
body.category .ge-cat-si:hover .ge-cat-si-title { color: var(--terra, #C2410C); }
body.category .ge-cat-si-num {
    font-family: var(--hand, 'Caveat', cursive);
    font-size: 1.15rem;
    color: var(--terra, #C2410C);
    transform: rotate(-2deg);
    display: inline-block;
    line-height: 1.1;
    min-width: 2rem;
    text-align: right;
    flex-shrink: 0;
    margin-top: .05rem;
}
body.category .ge-cat-si-content { flex: 1; min-width: 0; }
body.category .ge-cat-si-title {
    font-family: var(--display, 'Crimson Pro', serif);
    font-weight: 600;
    font-size: .88rem;
    color: var(--ink, #2A1D0D);
    line-height: 1.3;
    display: block;
    transition: color .15s;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
body.category .ge-cat-si-meta {
    font-family: var(--sans, 'Manrope', sans-serif);
    font-size: .72rem;
    color: var(--ink-muted, #7A5C36);
    margin-top: .1rem;
    display: block;
}

/* =============================================
   SECTION HEAD (titre grille)
   ============================================= */
body.category .ge-cat-section-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    border-bottom: 1px solid var(--rule, #E8D5A5);
    padding-bottom: .75rem;
    margin-bottom: 1.5rem;
}
body.category .ge-cat-section-title {
    font-family: var(--display, 'Crimson Pro', serif);
    font-weight: 600;
    font-size: 1.25rem;
    color: var(--ink, #2A1D0D);
    margin: 0;
}
body.category .ge-cat-section-kicker {
    font-family: var(--hand, 'Caveat', cursive);
    font-size: 1.1rem;
    color: var(--terra, #C2410C);
    transform: rotate(-1.5deg);
    display: inline-block;
}

/* =============================================
   ARTICLE GRID (3 cols)
   ============================================= */
body.category .ge-cat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}
body.category .ge-cat-card {
    background: var(--bg-card, #FFFAF0);
    border: 1px solid var(--rule, #E8D5A5);
    border-radius: 12px;
    overflow: hidden;
    transition: transform .25s, box-shadow .25s, border-color .25s;
}
body.category .ge-cat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 28px -10px rgba(194, 65, 12, .22);
    border-color: var(--terra, #C2410C);
}
body.category .ge-cat-card:hover .ge-cat-card-title { color: var(--terra, #C2410C); }
body.category .ge-cat-card-link {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    height: 100%;
}
body.category .ge-cat-card-img {
    width: 100%;
    aspect-ratio: 1 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
}
body.category .ge-cat-card-img.visa    { background: linear-gradient(135deg, #FDEAC2 0%, #F5D5A0 100%); }
body.category .ge-cat-card-img.doc     { background: linear-gradient(135deg, #E8F5F0 0%, #D4EDE5 100%); }
body.category .ge-cat-card-img.permis  { background: linear-gradient(135deg, #EEF0FD 0%, #DCE0F8 100%); }
body.category .ge-cat-card-img.admin   { background: linear-gradient(135deg, #FDE8E8 0%, #F5D0D0 100%); }
body.category .ge-cat-card-emoji {
    font-size: 2.8rem;
    line-height: 1;
}
body.category .ge-cat-card-num-badge {
    position: absolute;
    top: .5rem;
    left: .5rem;
    font-family: var(--hand, 'Caveat', cursive);
    font-size: 1rem;
    color: var(--terra-deep, #9A2D08);
    transform: rotate(-2deg);
    background: rgba(254, 243, 226, .85);
    padding: .1rem .4rem;
    border-radius: 4px;
    line-height: 1.2;
}
body.category .ge-cat-card-body {
    padding: .85rem .95rem 1rem;
    display: flex;
    flex-direction: column;
    gap: .35rem;
    flex: 1;
}
body.category .ge-cat-card-title {
    font-family: var(--display, 'Crimson Pro', serif);
    font-weight: 600;
    font-size: .98rem;
    color: var(--ink, #2A1D0D);
    line-height: 1.3;
    margin: 0;
    transition: color .15s;
}
body.category .ge-cat-card-meta {
    font-family: var(--sans, 'Manrope', sans-serif);
    font-size: .74rem;
    color: var(--ink-muted, #7A5C36);
    display: flex;
    align-items: center;
    gap: .5rem;
}
body.category .ge-cat-card-meta .sep { opacity: .4; }

/* =============================================
   BACK TO TOP BUTTON
   ============================================= */
body.category .ge-back-btn {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    background: var(--terra, #C2410C);
    color: #FFF6E5;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    text-decoration: none;
    box-shadow: 0 6px 20px rgba(194, 65, 12, .35);
    z-index: 90;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s, background .15s, transform .15s;
}
body.category .ge-back-btn.visible {
    opacity: 1;
    pointer-events: auto;
}
body.category .ge-back-btn:hover {
    background: var(--terra-deep, #9A2D08);
    transform: scale(1.08);
}

/* =============================================
   EMPTY STATE
   ============================================= */
body.category .ge-cat-empty {
    max-width: var(--content-max, 1400px);
    margin: 0 auto;
    padding: 3rem var(--side-pad, 4rem) 5rem;
    text-align: center;
}
body.category .ge-cat-empty h2 {
    font-family: var(--display, 'Crimson Pro', serif);
    font-style: italic;
    font-size: 2rem;
    color: var(--ink, #2A1D0D);
    margin: 0 0 1rem;
}
body.category .ge-cat-empty p {
    color: var(--ink-muted, #7A5C36);
    max-width: 48ch;
    margin: 0 auto 1.5rem;
    font-family: var(--sans, 'Manrope', sans-serif);
}
body.category .ge-cat-empty-btn {
    display: inline-block;
    background: var(--terra, #C2410C);
    color: #FFF6E5;
    padding: .6rem 1.4rem;
    border-radius: 999px;
    font-family: var(--sans, 'Manrope', sans-serif);
    font-weight: 600;
    font-size: .9rem;
    text-decoration: none;
    transition: background .15s;
}
body.category .ge-cat-empty-btn:hover {
    background: var(--terra-deep, #9A2D08);
    color: #FFF6E5;
}

/* =============================================
   REVEAL ANIMATION
   ============================================= */
body.category .reveal {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity .5s ease, transform .5s ease;
}
body.category .reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 1024px) {
    body.category .ge-cat-body {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    body.category .ge-cat-sommaire {
        position: static;
    }
    body.category .ge-cat-sommaire-list {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: .2rem;
    }
}
@media (max-width: 768px) {
    body.category .ge-cat-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    body.category .ge-cat-hero h1 { font-size: 2rem; }
    body.category .ge-cat-sommaire-list { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
    body.category .ge-cat-grid { grid-template-columns: 1fr; }
    body.category .ge-back-btn { bottom: 1.2rem; right: 1.2rem; }
}
