/* Page qualite_de_vie ClimaScore. Externalise depuis qualite_de_vie.html
   pour cache navigateur + crawl plus rapide. Statique, tokens via _tokens.css. */
    /* --- Qualite de vie SEO page (charte editoriale unifiee) --- */

    .qv-hero {
        background: var(--ed-paper);
        background-image: var(--ed-noise);
        background-size: 160px 160px;
        border-bottom: 1px solid var(--ed-line);
        padding: var(--space-12) var(--space-4) var(--space-10);
    }
    .qv-hero__inner {
        max-width: 920px;
        margin: 0 auto;
        display: grid;
        grid-template-columns: 1.5fr 1fr;
        gap: var(--space-10);
        align-items: center;
    }
    @media (max-width: 768px) {
        .qv-hero__inner { grid-template-columns: 1fr; gap: var(--space-6); }
    }
    .qv-hero__title {
        font-family: var(--font-display);
        font-size: var(--text-display);
        line-height: var(--leading-tight);
        letter-spacing: var(--tracking-display);
        color: var(--ed-graphite);
        font-weight: 700;
        margin: var(--space-3) 0 var(--space-4);
        max-width: 22ch;
    }
    .qv-hero__lead {
        font-size: var(--text-lead);
        line-height: var(--leading-normal);
        color: var(--ed-mute);
        max-width: 52ch;
        margin: 0 0 var(--space-5);
    }

    .qv-note {
        background: var(--ed-paper-2);
        border: 1px solid var(--ed-line);
        border-radius: var(--radius-lg);
        padding: var(--space-6);
        text-align: center;
        position: relative;
        overflow: hidden;
    }
    .qv-note::before {
        content: '';
        position: absolute;
        top: 0; left: 0; right: 0;
        height: 3px;
        background: var(--ed-saffron);
    }
    .qv-note__letter {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 96px;
        height: 96px;
        border-radius: var(--radius);
        font-family: var(--font-display);
        font-weight: 700;
        font-size: 3.5rem;
        color: #fff;
        background: var(--ed-graphite);
        letter-spacing: -0.04em;
        font-variant-numeric: tabular-nums;
        margin-bottom: var(--space-3);
    }
    .qv-note__letter.cl-a { background: var(--dpe-a); }
    .qv-note__letter.cl-b { background: var(--dpe-b); }
    .qv-note__letter.cl-c { background: var(--dpe-c); color: var(--ed-graphite); }
    .qv-note__letter.cl-d { background: var(--dpe-d); color: var(--ed-graphite); }
    .qv-note__letter.cl-e { background: var(--dpe-e); }
    .qv-note__letter.cl-f { background: var(--dpe-f); }
    .qv-note__label {
        font-family: var(--font-display);
        font-weight: 600;
        font-size: 1.25rem;
        color: var(--ed-graphite);
    }
    .qv-note__hint {
        font-size: var(--text-small);
        color: var(--ed-mute);
        margin-top: var(--space-2);
    }

    /* --- Composantes de la note --- */
    .qv-facteurs {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-5);
        margin-top: var(--space-5);
    }
    @media (max-width: 768px) {
        .qv-facteurs { grid-template-columns: 1fr; }
    }
    .qv-facteur {
        background: var(--ed-paper);
        border: 1px solid var(--ed-line);
        border-radius: var(--radius-lg);
        padding: var(--space-5);
        display: flex;
        flex-direction: column;
        gap: var(--space-2);
    }
    .qv-facteur__head {
        display: flex;
        justify-content: space-between;
        align-items: baseline;
        gap: var(--space-3);
    }
    .qv-facteur__name {
        font-family: var(--font-display);
        font-weight: 600;
        font-size: 1.0625rem;
        color: var(--ed-graphite);
    }
    .qv-facteur__pill {
        font-size: var(--text-small);
        background: var(--ed-saffron-soft);
        color: var(--ed-saffron);
        padding: 0.125rem 0.625rem;
        border-radius: 9999px;
        font-weight: 600;
        white-space: nowrap;
    }
    .qv-facteur__pill--ok { background: var(--ed-forest-soft); color: var(--ed-forest-deep); }
    .qv-facteur__pill--alerte { background: var(--ed-terracotta-soft); color: var(--ed-terracotta); }
    .qv-facteur__metric {
        font-family: var(--font-display);
        font-size: var(--text-data-m);
        font-weight: 700;
        color: var(--ed-ink-deep);
        font-variant-numeric: tabular-nums;
        line-height: 1;
    }
    .qv-facteur__unit {
        font-size: 0.875rem;
        color: var(--ed-mute);
        font-weight: 500;
    }
    .qv-facteur__desc {
        color: var(--ed-mute);
        font-size: var(--text-small);
        line-height: var(--leading-normal);
        margin: 0;
    }
    .qv-facteur__nodata {
        color: var(--ed-mute-2);
        font-style: italic;
        font-size: var(--text-small);
    }

    /* --- Tableau voisinage --- */
    .qv-table {
        width: 100%;
        border-collapse: collapse;
        font-size: var(--text-body);
        margin-top: var(--space-4);
    }
    .qv-table th, .qv-table td {
        padding: var(--space-3) var(--space-2);
        text-align: left;
        border-bottom: 1px solid var(--ed-line);
    }
    .qv-table th {
        font-family: var(--font-display);
        font-size: var(--text-eyebrow);
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: var(--tracking-eyebrow);
        color: var(--ed-mute);
    }
    .qv-table td.right {
        text-align: right;
    }
    .qv-table a {
        color: var(--ed-forest);
        text-decoration: none;
        border-bottom: 1px solid transparent;
    }
    .qv-table a:hover { border-bottom-color: var(--ed-forest); }
    .qv-class-mini {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 28px;
        height: 28px;
        border-radius: var(--radius-sm);
        font-family: var(--font-display);
        font-weight: 700;
        font-size: 0.875rem;
        color: #fff;
        background: var(--ed-graphite);
        font-variant-numeric: tabular-nums;
    }
    .qv-class-mini.cl-a { background: var(--dpe-a); }
    .qv-class-mini.cl-b { background: var(--dpe-b); }
    .qv-class-mini.cl-c { background: var(--dpe-c); color: var(--ed-graphite); }
    .qv-class-mini.cl-d { background: var(--dpe-d); color: var(--ed-graphite); }
    .qv-class-mini.cl-e { background: var(--dpe-e); }
    .qv-class-mini.cl-f { background: var(--dpe-f); }
    .qv-class-mini.na { background: var(--ed-mute-2); }
    @media (max-width: 540px) {
        .qv-table th:nth-child(3), .qv-table td:nth-child(3) { display: none; }
    }

    /* --- CTA score --- */
    .qv-cta {
        background: var(--ed-graphite);
        color: var(--ed-paper);
        padding: var(--space-10) var(--space-6);
        border-radius: var(--radius-lg);
        margin-top: var(--space-8);
        text-align: center;
    }
    .qv-cta h2 {
        color: var(--ed-paper);
        margin: 0 0 var(--space-3);
        font-size: 1.625rem;
    }
    .qv-cta p {
        color: rgba(250, 247, 241, 0.8);
        max-width: 56ch;
        margin: 0 auto var(--space-5);
    }
    .qv-cta .cs-btn {
        background: var(--ed-saffron);
        color: #fff;
        border-color: var(--ed-saffron);
    }
    .qv-cta .cs-btn:hover {
        background: #7e4d18;
        border-color: #7e4d18;
    }

    /* --- Maillage --- */
    .qv-maillage {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-8);
        margin-top: var(--space-5);
    }
    @media (max-width: 768px) {
        .qv-maillage { grid-template-columns: 1fr; gap: var(--space-6); }
    }
    .qv-maillage h3 {
        font-size: 1rem;
        font-weight: 600;
        color: var(--ed-graphite);
        margin: 0 0 var(--space-3);
    }
    .qv-maillage ul {
        list-style: none;
        padding: 0;
        margin: 0;
        display: flex;
        flex-direction: column;
        gap: var(--space-2);
    }
    .qv-maillage a {
        color: var(--ed-forest);
        text-decoration: none;
        font-size: var(--text-body);
        border-bottom: 1px solid transparent;
    }
    .qv-maillage a:hover { border-bottom-color: var(--ed-forest); }
