/* =========================================================================
   Spaces — feuille de style (DA pop minimaliste, accent périwinkle #707FFE)
   ========================================================================= */

@font-face {
    font-family: 'Archivo Black';
    src: url('fonts/ArchivoBlack-Regular.ttf') format('truetype');
    font-weight: 400 900;
    font-display: swap;
}

:root {
    --bg: #ffffff;
    --bg-soft: #f6f7fb;
    --ink: #11121a;
    --ink-soft: #3a3c49;
    --muted: #8a8d9c;
    --line: #ececf2;
    --accent: #707ffe;          /* périwinkle — couleur du logo */
    --accent-press: #5563f5;
    --accent-2: #ff2e63;        /* rose pop secondaire */
    --radius: 16px;
    --radius-sm: 10px;
    --shadow: 0 10px 30px rgba(17, 18, 26, .07);
    --shadow-hover: 0 16px 44px rgba(17, 18, 26, .13);
    --container: 1120px;
    --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    --font-display: 'Archivo Black', var(--font);
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: var(--font);
    color: var(--ink);
    background: var(--bg);
    line-height: 1.65;
    font-size: 17px;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }

.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: 22px; }

.screen-reader-text { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px); white-space: nowrap; }
.skip-link:focus { position: fixed; left: 12px; top: 12px; z-index: 999; width: auto; height: auto; clip: auto; background: var(--ink); color: #fff; padding: 10px 14px; border-radius: 10px; }

/* ---- Header ---- */
.site-header {
    position: sticky; top: 0; z-index: 50;
    background: rgba(255,255,255,.85);
    backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--line);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; min-height: 68px; gap: 16px; }
.site-logo { display: inline-flex; align-items: center; gap: 11px; }
.site-logo-icon { width: 38px; height: 38px; border-radius: 50%; box-shadow: 0 4px 12px rgba(112,127,254,.35); }
.site-logo-text { font-family: var(--font-display); font-size: 23px; letter-spacing: -.03em; color: var(--ink); line-height: 1; }

.site-nav .nav-list { display: flex; gap: 6px; list-style: none; margin: 0; padding: 0; font-weight: 600; font-size: 14.5px; }
.site-nav .nav-list a { color: var(--ink-soft); padding: 8px 13px; border-radius: 999px; transition: background .15s, color .15s; }
.site-nav .nav-list a:hover { background: var(--accent); color: #fff; }

.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--ink); margin: 5px 0; border-radius: 2px; }

.site-main { padding-block: 36px 64px; min-height: 60vh; }

/* ---- Grille d'articles ---- */
.post-grid { display: grid; gap: 28px; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.card {
    background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius);
    overflow: hidden; box-shadow: var(--shadow);
    transition: transform .2s ease, box-shadow .2s ease;
    display: flex; flex-direction: column;
}
.card:hover { transform: translateY(-5px); box-shadow: var(--shadow-hover); }
.card-media { position: relative; display: block; aspect-ratio: 1200/630; background: var(--bg-soft); overflow: hidden; }
.card-media img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.card:hover .card-media img { transform: scale(1.05); }
.card-media-fallback { display: block; width: 100%; height: 100%; background: linear-gradient(135deg, var(--accent), #4a59e0); }
.card-cat {
    position: absolute; left: 12px; top: 12px;
    background: var(--accent); color: #fff;
    font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em;
    padding: 6px 11px; border-radius: 999px;
}
.card-body { padding: 17px 19px 21px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.card-title { font-family: var(--font-display); font-size: 18.5px; line-height: 1.22; margin: 0; letter-spacing: -.02em; }
.card-title a { color: var(--ink); }
.card-title a:hover { color: var(--accent); }
.card-excerpt { color: var(--muted); font-size: 14.5px; margin: 0; }
.card-meta { color: var(--muted); font-size: 12.5px; margin-top: auto; padding-top: 6px; }

/* ---- Headers d'archive ---- */
.archive-header { margin-bottom: 30px; }
.archive-title { font-family: var(--font-display); font-size: 34px; margin: 0 0 6px; letter-spacing: -.03em; }
.archive-desc { color: var(--muted); }

/* ---- Article ---- */
.single { max-width: 760px; margin-inline: auto; }
.single-header { margin-bottom: 22px; }
.single-cat {
    display: inline-block; background: var(--accent); color: #fff;
    font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em;
    padding: 6px 13px; border-radius: 999px; margin-bottom: 16px;
}
.single-cat:hover { background: var(--accent-2); }
.single-title { font-family: var(--font-display); font-size: clamp(30px, 5vw, 46px); line-height: 1.08; letter-spacing: -.035em; margin: 0 0 14px; }
.single-meta { color: var(--muted); font-size: 14px; display: flex; align-items: center; gap: 8px; }
.single-meta .dot { opacity: .5; }
.single-featured { margin: 0 0 32px; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.single-featured img { width: 100%; }

.single-content { font-size: 18.5px; line-height: 1.78; color: var(--ink-soft); }
.single-content > p:first-of-type { font-size: 21px; line-height: 1.6; color: var(--ink); font-weight: 500; }
.single-content p { margin: 0 0 1.25em; }
.single-content h2 { font-size: 27px; font-weight: 800; letter-spacing: -.02em; margin: 1.9em 0 .55em; color: var(--ink); }
.single-content h3 { font-size: 21px; font-weight: 700; margin: 1.5em 0 .5em; color: var(--ink); }
.single-content a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.single-content ul, .single-content ol { margin: 0 0 1.25em; padding-left: 1.3em; }
.single-content li { margin-bottom: .4em; }
.single-content blockquote { margin: 1.5em 0; padding: 4px 0 4px 22px; border-left: 4px solid var(--accent); font-style: italic; color: var(--ink); }
.single-content img { border-radius: var(--radius-sm); margin: 1.5em 0; }

/* ---- Articles liés ---- */
.related { max-width: var(--container); margin: 60px auto 0; }
.related-title { font-family: var(--font-display); font-size: 24px; letter-spacing: -.02em; margin: 0 0 22px; position: relative; padding-left: 15px; }
.related-title::before { content: ""; position: absolute; left: 0; top: 5px; bottom: 5px; width: 6px; border-radius: 3px; background: var(--accent); }

/* ---- Publicité ---- */
.ad-slot { margin: 30px auto; text-align: center; }
.ad-slot .ad-label { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: .12em; color: var(--muted); margin-bottom: 6px; }
.ad-leaderboard { margin: 18px auto; min-height: 90px; }
.ad-sticky-mobile { display: none; }

/* ---- Pagination ---- */
.pagination { margin-top: 48px; }
.pagination .nav-links { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.pagination .page-numbers {
    display: inline-flex; align-items: center; justify-content: center; min-width: 44px; height: 44px;
    padding: 0 14px; border: 1px solid var(--line); border-radius: 12px; font-weight: 700; color: var(--ink-soft); background: var(--bg);
}
.pagination .page-numbers:hover { border-color: var(--accent); color: var(--accent); }
.pagination .page-numbers.current { background: var(--accent); border-color: var(--accent); color: #fff; }

.empty { text-align: center; color: var(--muted); padding: 80px 0; font-size: 18px; }

/* ---- Footer ---- */
.site-footer { border-top: 1px solid var(--line); margin-top: 64px; background: var(--bg-soft); }
.footer-inner { padding-block: 44px; text-align: center; }
.footer-brand { display: inline-flex; align-items: center; gap: 10px; }
.footer-brand .site-logo-icon { width: 32px; height: 32px; }
.footer-brand .site-logo-text { font-family: var(--font-display); font-size: 20px; letter-spacing: -.03em; color: var(--ink); }
.footer-tagline { color: var(--muted); margin: 10px 0 18px; }
.footer-nav ul { list-style: none; display: flex; flex-wrap: wrap; gap: 18px; justify-content: center; padding: 0; margin: 0 0 18px; }
.footer-nav a { color: var(--ink-soft); font-weight: 600; font-size: 14px; }
.footer-nav a:hover { color: var(--accent); }
.footer-legal-nav { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; margin: 0 0 14px; }
.footer-legal-nav a { color: var(--muted); font-size: 13px; }
.footer-legal-nav a:hover { color: var(--accent); }
.footer-legal { color: var(--muted); font-size: 13px; margin: 0; }

/* ---- Fil d'Ariane ---- */
.breadcrumb { font-size: 13px; color: var(--muted); margin-bottom: 16px; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.breadcrumb a { color: var(--muted); }
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb .bc-sep { opacity: .5; }
.breadcrumb .bc-current { color: var(--ink-soft); }

/* ---- Hero accueil ---- */
.home-hero { margin: 0 0 32px; }
.home-h1 { font-family: var(--font-display); font-size: clamp(28px, 4.5vw, 40px); letter-spacing: -.03em; margin: 0 0 6px; line-height: 1.05; }
.home-sub { color: var(--muted); font-size: 16px; margin: 0; max-width: 640px; }

/* ---- Bandeau breaking news ---- */
.breaking-banner { background: var(--ink); }
.breaking-banner a { display: flex; align-items: center; gap: 12px; max-width: var(--container); margin-inline: auto; padding: 11px 22px; color: #fff; }
.breaking-tag { display: inline-flex; align-items: center; gap: 7px; background: var(--accent-2); color: #fff; font-weight: 800; font-size: 11.5px; text-transform: uppercase; letter-spacing: .06em; padding: 5px 12px; border-radius: 999px; white-space: nowrap; flex: 0 0 auto; }
.breaking-tag::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: #fff; animation: breaking-pulse 1.2s infinite; }
.breaking-title { font-weight: 600; font-size: 14.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.breaking-banner a:hover .breaking-title { text-decoration: underline; }
@keyframes breaking-pulse { 0%, 100% { opacity: 1; } 50% { opacity: .25; } }

/* ---- Responsive ---- */
@media (max-width: 860px) {
    body { font-size: 16px; }
    .nav-toggle { display: block; }
    .site-nav { position: absolute; top: 68px; left: 0; right: 0; background: #fff; border-bottom: 1px solid var(--line); max-height: 0; overflow: hidden; transition: max-height .25s ease; }
    .site-nav.is-open { max-height: 75vh; }
    .site-nav .nav-list { flex-direction: column; gap: 0; padding: 10px 20px 18px; }
    .site-nav .nav-list li { padding: 4px 0; }
    .single-content { font-size: 17.5px; }
    .ad-sticky-mobile { display: block; position: fixed; left: 0; right: 0; bottom: 0; z-index: 60; background: #fff; border-top: 1px solid var(--line); padding: 4px 0; min-height: 54px; }
    .ad-sticky-mobile .ad-slot { margin: 0; }
    body { padding-bottom: 58px; }
}

@media (prefers-reduced-motion: reduce) { * { scroll-behavior: auto !important; transition: none !important; animation: none !important; } }
