/*!
 * YLS - Établissement
 * Feuille de style centralisée pour les shortcodes :
 *   - [fiche_etablissement]    (préfixe .yls-fiche)
 *   - [liste_etablissements]   (préfixe .yls-liste)
 *
 * Variables CSS partagées (préfixe --yls-etb-*) : surcharge possible
 * depuis le thème enfant pour personnaliser couleurs/radius/etc.
 */

/* =========================================================================
 *  VARIABLES PARTAGÉES
 * ========================================================================= */
.yls-fiche,
.yls-liste {
    --yls-etb-primary: #2c5282;
    --yls-etb-accent: #38a169;
    --yls-etb-text: #2d3748;
    --yls-etb-muted: #718096;
    --yls-etb-bg: #ffffff;
    --yls-etb-border: #e2e8f0;
    --yls-etb-block-bg: #f7fafc;
    --yls-etb-hover-bg: #f7fafc;
    --yls-etb-radius: 8px;

    box-sizing: border-box;
    max-width: 100%;
    color: var(--yls-etb-text);
    font-family: inherit;
    line-height: 1.5;
}
.yls-fiche *,
.yls-fiche *::before,
.yls-fiche *::after,
.yls-liste *,
.yls-liste *::before,
.yls-liste *::after { box-sizing: border-box; }

/* État vide partagé */
.yls-etb__empty {
    padding: 1.25rem;
    background: #f7fafc;
    border: 1px dashed #cbd5e0;
    border-radius: 8px;
    color: #718096;
    font-style: italic;
    text-align: center;
}


/* =========================================================================
 *  FICHE ÉTABLISSEMENT
 * ========================================================================= */
.yls-fiche {
    background: var(--yls-etb-bg);
    border: 1px solid var(--yls-etb-border);
    border-radius: var(--yls-etb-radius);
    padding: 1.75rem;
}

/* Header */
.yls-fiche__header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: 1rem;
    margin-bottom: 1.5rem;
    border-bottom: 2px solid var(--yls-etb-border);
}
.yls-fiche__title {
    margin: 0;
    font-size: clamp(1.25rem, 2.2vw, 1.75rem);
    line-height: 1.2;
    color: var(--yls-etb-primary);
    font-weight: 700;
}
.yls-fiche__subtitle {
    margin: .35rem 0 0;
    color: var(--yls-etb-muted);
    font-size: .9rem;
    text-transform: uppercase;
    letter-spacing: .5px;
    font-weight: 600;
}
.yls-fiche__badges {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    flex-shrink: 0;
}
.yls-fiche__badge {
    display: inline-block;
    padding: .3rem .8rem;
    font-size: .78rem;
    font-weight: 600;
    border-radius: 999px;
    line-height: 1.4;
    color: #fff;
    white-space: nowrap;
}
.yls-fiche__badge--primary { background: var(--yls-etb-primary); }
.yls-fiche__badge--accent  { background: var(--yls-etb-accent); }

/* Grille des blocs */
.yls-fiche__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
}
.yls-fiche__block {
    background: var(--yls-etb-block-bg);
    border-radius: var(--yls-etb-radius);
    padding: 1.25rem;
}
.yls-fiche__block-title {
    margin: 0 0 .85rem;
    font-size: .85rem;
    font-weight: 700;
    color: var(--yls-etb-primary);
    text-transform: uppercase;
    letter-spacing: .5px;
}

/* Adresse */
.yls-fiche__address {
    font-style: normal;
    display: flex;
    flex-direction: column;
    gap: .15rem;
}
.yls-fiche__line { display: block; }
.yls-fiche__line--site {
    font-weight: 700;
    color: var(--yls-etb-primary);
    font-size: 1rem;
    margin-bottom: .35rem;
    padding-bottom: .35rem;
    border-bottom: 1px solid var(--yls-etb-border);
}
.yls-fiche__line--strong { font-weight: 600; margin-top: .15rem; }
.yls-fiche__line--muted {
    color: var(--yls-etb-muted);
    font-size: .88rem;
    margin-top: .4rem;
}

/* Listes de définitions */
.yls-fiche__dl {
    margin: 0;
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: .45rem 1rem;
    font-size: .94rem;
}
.yls-fiche__dl dt {
    font-weight: 600;
    color: var(--yls-etb-muted);
}
.yls-fiche__dl dd {
    margin: 0;
    word-break: break-word;
}

/* Lien vers le support GHT (dans le bloc administratif) */
.yls-fiche__ght-support-link {
    color: var(--yls-etb-primary);
    font-weight: 600;
    text-decoration: none;
    border-bottom: 1px dashed var(--yls-etb-primary);
}
.yls-fiche__ght-support-link:hover,
.yls-fiche__ght-support-link:focus-visible {
    color: var(--yls-etb-accent);
    border-bottom-color: var(--yls-etb-accent);
    text-decoration: none;
}


/* =========================================================================
 *  BLOC "ÉTABLISSEMENTS DU GHT" (uniquement sur l'établissement support)
 * ========================================================================= */
.yls-fiche__ght-block {
    margin-top: 1.5rem;
    background: var(--yls-etb-block-bg);
    border-left: 4px solid var(--yls-etb-primary);
    border-radius: var(--yls-etb-radius);
    padding: 1.5rem;
}
.yls-fiche__ght-title {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .5rem;
    margin: 0 0 1rem;
    font-size: .95rem;
    font-weight: 700;
    color: var(--yls-etb-primary);
    text-transform: uppercase;
    letter-spacing: .5px;
}
.yls-fiche__ght-code {
    display: inline-block;
    padding: .15rem .55rem;
    background: var(--yls-etb-primary);
    color: #fff;
    border-radius: 999px;
    font-size: .78rem;
    letter-spacing: .3px;
}
.yls-fiche__ght-count {
    color: var(--yls-etb-muted);
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0;
    font-size: .9rem;
}
.yls-fiche__ght-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: .5rem;
}
.yls-fiche__ght-item {
    margin: 0;
    padding: 0;
    list-style: none;
}
.yls-fiche__ght-link {
    display: flex;
    flex-direction: column;
    padding: .7rem .9rem;
    background: var(--yls-etb-bg);
    border: 1px solid var(--yls-etb-border);
    border-radius: 6px;
    text-decoration: none;
    color: var(--yls-etb-text);
    transition: border-color .15s, background .15s, transform .15s;
}
.yls-fiche__ght-link:hover,
.yls-fiche__ght-link:focus-visible {
    border-color: var(--yls-etb-primary);
    background: #fff;
    transform: translateY(-1px);
    text-decoration: none;
    color: var(--yls-etb-text);
}
.yls-fiche__ght-link:focus-visible {
    outline: 2px solid var(--yls-etb-primary);
    outline-offset: 2px;
}
.yls-fiche__ght-name {
    font-weight: 600;
    color: var(--yls-etb-primary);
    font-size: .92rem;
    line-height: 1.3;
}
.yls-fiche__ght-ville {
    font-size: .82rem;
    color: var(--yls-etb-muted);
    margin-top: .15rem;
}


/* =========================================================================
 *  LISTE ÉTABLISSEMENTS
 * ========================================================================= */
.yls-liste {
    --yls-etb-cols: 3;
}

.yls-liste__grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(var(--yls-etb-cols), minmax(0, 1fr));
    gap: 1rem;
}

.yls-liste__item {
    margin: 0;
    padding: 0;
    list-style: none;
}

.yls-liste__link {
    position: relative;
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 1.25rem;
    background: var(--yls-etb-bg);
    border: 1px solid var(--yls-etb-border);
    border-radius: var(--yls-etb-radius);
    text-decoration: none;
    color: var(--yls-etb-text);
    transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.yls-liste__link:hover,
.yls-liste__link:focus-visible {
    transform: translateY(-2px);
    background: var(--yls-etb-hover-bg);
    border-color: var(--yls-etb-primary);
    box-shadow: 0 6px 18px rgba(44, 82, 130, .10);
    text-decoration: none;
    color: var(--yls-etb-text);
}
.yls-liste__link:focus-visible {
    outline: 2px solid var(--yls-etb-primary);
    outline-offset: 2px;
}

.yls-liste__badge {
    position: absolute;
    top: .85rem;
    right: .85rem;
    background: var(--yls-etb-primary);
    color: #fff;
    font-size: .7rem;
    font-weight: 600;
    padding: .2rem .55rem;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: .4px;
}

.yls-liste__name {
    margin: 0 0 .5rem;
    padding-right: 3.5rem;
    font-size: 1.1rem;
    line-height: 1.3;
    color: var(--yls-etb-primary);
    font-weight: 700;
}

.yls-liste__site {
    margin: 0 0 .75rem;
    font-size: .92rem;
    color: var(--yls-etb-muted);
    font-style: italic;
}

.yls-liste__location {
    margin: 0 0 1rem;
    font-size: .92rem;
    color: var(--yls-etb-text);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .35rem;
    line-height: 1.4;
}
.yls-liste__sep { color: var(--yls-etb-muted); }
.yls-liste__dep { color: var(--yls-etb-muted); }

.yls-liste__cta {
    margin-top: auto;
    padding-top: .5rem;
    font-size: .82rem;
    font-weight: 600;
    color: var(--yls-etb-primary);
    text-transform: uppercase;
    letter-spacing: .5px;
}


/* =========================================================================
 *  RESPONSIVE
 * ========================================================================= */

/* Tablet */
@media (max-width: 900px) {
    .yls-liste__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Mobile */
@media (max-width: 600px) {
    .yls-fiche { padding: 1.1rem; }
    .yls-fiche__header {
        flex-direction: column;
        align-items: flex-start;
    }
    .yls-fiche__dl {
        grid-template-columns: 1fr;
        gap: .1rem;
    }
    .yls-fiche__dl dt { margin-top: .5rem; }
    .yls-fiche__dl dt:first-child { margin-top: 0; }
    .yls-fiche__ght-block { padding: 1.1rem; }
}

@media (max-width: 560px) {
    .yls-liste__grid { grid-template-columns: 1fr; }
    .yls-liste__name { padding-right: 0; }
    .yls-liste__badge {
        position: static;
        display: inline-block;
        margin-bottom: .6rem;
    }
}
