/* =====================================================================
   SIMANDOU NEWS — Feuille de style principale
   Design industriel sobre : ocre, bleu marine, gris métal, blanc.
   ===================================================================== */

:root {
	--sn-navy:        #1a2d5e;  /* bleu royal du monogramme S */
	--sn-navy-2:      #1f3572;  /* variante légèrement plus claire */
	--sn-navy-deep:   #0d1840;  /* profond — dégradé footer */
	--sn-gold:        #c8900a;  /* ambre chaud du N doré et « NEWS » */
	--sn-gold-dark:   #a47208;  /* ambre foncé — survol / actif */
	--sn-steel:       #5b6573;
	--sn-steel-light: #9aa3af;
	--sn-line:        #e3e6ea;
	--sn-bg:          #f3f4f6;
	--sn-card:        #ffffff;
	--sn-text:        #1d2733;
	--sn-muted:       #5b6472;
	--sn-text-light:  #cdd6e4; /* texte clair sur fond marine */
	--sn-gold-text:   #2a1e00; /* texte sur aplat doré */
	--sn-radius:      8px;
	--sn-shadow:      0 1px 3px rgba(16,29,54,.08), 0 1px 2px rgba(16,29,54,.06);
	--sn-shadow-lg:   0 8px 28px rgba(16,29,54,.14);
	--sn-maxw:        1200px;
	--sn-head:        'Barlow Condensed', 'Arial Narrow', sans-serif;
	--sn-body:        'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;

	/* Couleurs des rubriques (badges, accents) — modifiables ici en un seul endroit. */
	--sn-cat-simandou:        #0e7490;
	--sn-cat-mines:           #a9601f;
	--sn-cat-infrastructures: #1565c0;
	--sn-cat-environnement:   #2e7d32;
	--sn-cat-economie:        #c0392b;
	--sn-cat-simandou2040:    #7a5b16;
	--sn-cat-communautes:     #6d28d9;
	--sn-cat-portraits:       #b8860b;
	--sn-cat-videos:          #b91c1c;

	/* Couleurs de partage social. */
	--sn-social-facebook: #1877f2;
	--sn-social-x:        #111111;
	--sn-social-linkedin: #0a66c2;
	--sn-social-whatsapp: #25d366;

	/* Couleurs des moyens de paiement (souvent dictées par les partenaires). */
	--sn-pay-orange:  #ff7900;
	--sn-pay-mobile:  #ffcc00;
	--sn-pay-paycard: #0a7cff;
}

*, *::before, *::after { box-sizing: border-box; }

body {
	margin: 0;
	font-family: var(--sn-body);
	font-size: 16px;
	line-height: 1.6;
	color: var(--sn-text);
	background: var(--sn-bg);
	-webkit-font-smoothing: antialiased;
}

a { color: var(--sn-navy-2); text-decoration: none; }
a:hover { color: var(--sn-gold-dark); }
img, svg { max-width: 100%; height: auto; display: block; }
h1, h2, h3, h4 { font-family: var(--sn-head); font-weight: 700; line-height: 1.15; margin: 0 0 .5em; color: var(--sn-navy); }

.sn-container { max-width: var(--sn-maxw); margin: 0 auto; padding: 0 16px; }

.screen-reader-text {
	position: absolute !important; width: 1px; height: 1px;
	overflow: hidden; clip: rect(1px,1px,1px,1px); white-space: nowrap;
}
.sn-skip { position: absolute; left: -999px; top: 0; z-index: 1000; background: var(--sn-gold); color: var(--sn-navy); padding: 8px 14px; }
.sn-skip:focus { left: 8px; }

.sn-icon { vertical-align: middle; }
.sn-img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ---------------------------------------------------------------------
   Boutons
   --------------------------------------------------------------------- */
.sn-btn {
	display: inline-block; font-family: var(--sn-head); font-weight: 600;
	letter-spacing: .04em; text-transform: uppercase; font-size: 15px;
	padding: 10px 20px; border-radius: 4px; border: 0; cursor: pointer;
	transition: transform .12s ease, background .15s ease; line-height: 1.2;
}
.sn-btn--gold { background: var(--sn-gold); color: var(--sn-gold-text); }
.sn-btn--gold:hover { background: var(--sn-gold-dark); color: #fff; transform: translateY(-1px); }
.sn-btn--sm { font-size: 13px; padding: 8px 14px; }
.sn-btn--lg { font-size: 17px; padding: 13px 26px; }

/* =====================================================================
   EN-TÊTE
   ===================================================================== */
.sn-topbar { background: #fff; border-top: 3px solid var(--sn-gold); border-bottom: 1px solid var(--sn-line); }
.sn-topbar__inner {
	display: grid; grid-template-columns: auto 1fr auto; align-items: center;
	gap: 22px; padding-top: 12px; padding-bottom: 12px;
}

/* Logo / marque */
.sn-brand { display: flex; flex-direction: column; gap: 2px; }
.sn-logo { display: inline-flex; align-items: center; gap: 10px; }
.sn-logo__mark { width: 46px; height: 38px; flex: none; }
.sn-logo__text { font-family: var(--sn-head); font-size: 30px; line-height: .9; color: var(--sn-navy); }
.sn-logo__text strong { font-weight: 700; }
.sn-logo__text em { font-style: normal; font-weight: 700; color: var(--sn-gold-dark); }
.sn-logo__img { display: block; height: 72px; width: auto; object-fit: contain; }
.sn-logo__img--footer { height: 60px; }
.sn-brand__tagline { margin: 0; font-family: var(--sn-head); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--sn-gold); font-weight: 600; }

/* Bandeau SIMANDOU 2040 */
.sn-headbanner {
	position: relative; overflow: hidden;
	display: flex; align-items: center; justify-content: space-between; gap: 16px;
	background: linear-gradient(105deg, var(--sn-navy-deep) 0%, var(--sn-navy-2) 58%, var(--sn-navy) 100%);
	background-size: cover; background-position: center;
	color: #fff; border-radius: var(--sn-radius); padding: 12px 18px; min-height: 64px;
	border-left: 3px solid var(--sn-gold);
	transition: box-shadow .2s ease, transform .2s ease;
}
.sn-headbanner::after { /* fine trame industrielle */
	content: ''; position: absolute; inset: 0; pointer-events: none;
	background: repeating-linear-gradient(115deg, rgba(255,255,255,.045) 0 14px, transparent 14px 30px);
}
.sn-headbanner > * { position: relative; z-index: 1; }
.sn-headbanner:hover { color: #fff; transform: translateY(-1px); box-shadow: 0 8px 22px rgba(16,29,54,.28); }
.sn-headbanner__title { display: block; font-family: var(--sn-head); font-size: 22px; color: var(--sn-gold); letter-spacing: .03em; }
.sn-headbanner__text { display: block; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--sn-text-light); }
.sn-headbanner__cta { flex: none; background: var(--sn-gold); color: var(--sn-gold-text); font-family: var(--sn-head); font-size: 12px; font-weight: 600; padding: 7px 12px; border-radius: 3px; text-transform: uppercase; letter-spacing: .04em; transition: background .15s ease, color .15s ease; }
.sn-headbanner:hover .sn-headbanner__cta { background: var(--sn-gold-dark); color: #fff; }
.sn-headbanner__body { flex: 1 1 auto; min-width: 0; }
/* Scène de train : à ras bord, pleine hauteur, sur le côté droit (comme la maquette). */
.sn-headbanner__art { flex: none; align-self: stretch; width: 210px; margin: -12px -18px -12px 12px; border-radius: 0 var(--sn-radius) var(--sn-radius) 0; overflow: hidden; position: relative; }
.sn-headbanner__art svg { display: block; width: 100%; height: 100%; }
.sn-headbanner__art::before { content: ''; position: absolute; inset: 0; z-index: 1; background: linear-gradient(90deg, var(--sn-navy-deep) 0%, rgba(15,29,54,.45) 28%, transparent 62%); }

/* Variante image (bannière leaderboard publicitaire) */
.sn-headbanner--img { padding: 0; background: transparent; border-left: 0; min-height: 0; overflow: hidden; }
.sn-headbanner--img:hover { transform: none; box-shadow: none; }
.sn-headbanner--img img { display: block; width: 100%; height: 90px; object-fit: cover; object-position: center; border-radius: var(--sn-radius); }

/* Bloc droit : social + recherche */
.sn-topbar__right { display: flex; align-items: center; gap: 14px; }
.sn-social { list-style: none; margin: 0; padding: 0; display: flex; gap: 6px; }
.sn-social__link {
	display: inline-flex; align-items: center; justify-content: center;
	width: 32px; height: 32px; border-radius: 50%; background: var(--sn-navy-2); color: #fff;
	transition: background .15s ease, color .15s ease, transform .15s ease;
}
.sn-social__link:hover { background: var(--sn-gold); color: var(--sn-navy); transform: translateY(-2px); }

.sn-search { display: flex; align-items: center; background: #fff; border: 1px solid var(--sn-line); border-radius: 4px; overflow: hidden; }
.sn-search__field { border: 0; padding: 8px 12px; font-size: 14px; width: 150px; outline: none; }
.sn-search__btn { border: 0; background: var(--sn-navy-2); color: #fff; padding: 8px 10px; cursor: pointer; display: flex; }
.sn-search__btn:hover { background: var(--sn-gold); color: var(--sn-navy); }

/* Barre de navigation */
.sn-nav { background: var(--sn-navy); }
.sn-nav__inner { display: flex; align-items: stretch; }
.sn-menu { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; flex: 1; min-width: 0; }

/* Icône maison devant « Accueil » (conforme à la maquette). */
.sn-menu .menu-item-home > a::before {
	content: ''; display: inline-block; width: 15px; height: 15px; margin-right: 7px; flex: none;
	background-color: currentColor;
	-webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M12%203%202%2011h2v9h6v-6h4v6h6v-9h2z'/%3E%3C/svg%3E") center / contain no-repeat;
	        mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M12%203%202%2011h2v9h6v-6h4v6h6v-9h2z'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* Bloc ☰ « Plus de rubriques » à droite de la barre. */
.sn-nav__more-wrap { position: relative; margin-left: auto; display: flex; align-items: stretch; }
/* Hamburger : caché en desktop, affiché en mobile (voir media query 680). */
.sn-nav__toggle { display: none; align-items: center; background: transparent; border: 0; color: #e7ecf4; cursor: pointer; padding: 12px 16px; }
.sn-nav__toggle:hover { background: var(--sn-navy-2); color: #fff; }
.sn-nav__more { display: none; position: absolute; right: 0; top: 100%; background: var(--sn-navy-2); min-width: 220px; z-index: 40; margin: 0; padding: 0; list-style: none; box-shadow: var(--sn-shadow-lg); border-top: 3px solid var(--sn-gold); border-radius: 0 0 6px 6px; overflow: hidden; }
.sn-nav__more-wrap:hover .sn-nav__more,
.sn-nav__more-wrap:focus-within .sn-nav__more { display: block; }
.sn-nav__more a { display: block; color: #e7ecf4; font-family: var(--sn-head); font-weight: 600; text-transform: uppercase; letter-spacing: .03em; font-size: 14px; padding: 11px 16px; border-top: 1px solid rgba(255,255,255,.06); white-space: nowrap; transition: background .15s ease, color .15s ease; }
.sn-nav__more li:first-child a { border-top: 0; }
.sn-nav__more a:hover { background: var(--sn-navy); color: #fff; }
.sn-nav__more .current-menu-item > a { background: var(--sn-gold); color: var(--sn-navy); }
.sn-menu > li.sn-menu__extra { display: none; }
.sn-menu li { position: relative; }
.sn-menu > li { display: flex; }
.sn-menu a {
	color: #e7ecf4; font-family: var(--sn-head); font-weight: 600;
	letter-spacing: .03em; text-transform: uppercase; font-size: 14.5px; padding: 13px 15px;
	line-height: 1.1; transition: background .15s ease, color .15s ease; white-space: nowrap;
}
.sn-menu > li > a { display: inline-flex; align-items: center; }
.sn-menu a:hover { background: var(--sn-navy-2); color: #fff; }
.sn-menu .current-menu-item > a,
.sn-menu .current_page_item > a,
.sn-menu .current-menu-ancestor > a { background: var(--sn-gold); color: var(--sn-navy); }
.sn-menu .sub-menu { display: none; position: absolute; left: 0; top: 100%; background: var(--sn-navy-2); min-width: 220px; z-index: 30; box-shadow: var(--sn-shadow-lg); margin: 0; padding: 0; list-style: none; border-top: 3px solid var(--sn-gold); border-radius: 0 0 6px 6px; overflow: hidden; }
.sn-menu li:hover > .sub-menu,
.sn-menu li:focus-within > .sub-menu { display: block; }
.sn-menu .sub-menu a { display: block; padding: 11px 16px; font-size: 14px; border-top: 1px solid rgba(255,255,255,.06); }
.sn-menu .sub-menu li:first-child > a { border-top: 0; }
.sn-menu .sub-menu .current-menu-item > a { background: var(--sn-gold); color: var(--sn-navy); }

/* Chevron : triangle CSS net (auto sur les onglets à sous-menu), pivote à l'ouverture. */
.sn-menu .menu-item-has-children > a::after {
	content: ''; display: inline-block; width: 0; height: 0; margin-left: 7px;
	border-left: 4px solid transparent; border-right: 4px solid transparent;
	border-top: 5px solid currentColor; opacity: .75;
	transition: transform .2s ease, opacity .2s ease;
}
.sn-menu .menu-item-has-children:hover > a::after,
.sn-menu .menu-item-has-children:focus-within > a::after { transform: rotate(180deg); opacity: 1; }

/* Ticker breaking news */
.sn-breaking { display: flex; align-items: stretch; background: #fff; border-bottom: 1px solid var(--sn-line); }
.sn-breaking__tag {
	flex: none; background: var(--sn-gold); color: var(--sn-navy); font-family: var(--sn-head);
	font-weight: 700; letter-spacing: .05em; font-size: 14px; padding: 10px 16px;
	display: flex; align-items: center; text-transform: uppercase;
}
.sn-breaking__viewport { flex: 1; overflow: hidden; position: relative; }
.sn-breaking__track { list-style: none; margin: 0; padding: 0; display: flex; white-space: nowrap; will-change: transform; animation: sn-marquee 38s linear infinite; }
.sn-breaking__track li { padding: 10px 28px 10px 0; }
.sn-breaking__track li::after { content: '•'; color: var(--sn-gold); margin-left: 28px; }
.sn-breaking__track a { color: var(--sn-text); font-size: 14px; font-weight: 500; }
.sn-breaking__track a:hover { color: var(--sn-gold-dark); }
.sn-breaking:hover .sn-breaking__track { animation-play-state: paused; }
.sn-breaking__nav { flex: none; display: flex; }
.sn-breaking__btn { border: 0; border-left: 1px solid var(--sn-line); background: #fff; color: var(--sn-navy); width: 34px; cursor: pointer; font-size: 20px; }
.sn-breaking__btn:hover { background: var(--sn-bg); }
@keyframes sn-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* =====================================================================
   MISE EN PAGE GÉNÉRALE
   ===================================================================== */
.sn-main { padding: 22px 0 40px; }
.sn-main > .sn-container { display: block; }
.sn-row { margin: 0 0 22px; }
.sn-row--ad { display: flex; justify-content: center; }

/* Carte générique */
.sn-card { background: var(--sn-card); border: 1px solid var(--sn-line); border-radius: var(--sn-radius); box-shadow: var(--sn-shadow); padding: 16px; margin-bottom: 22px; }
.sn-section-title { font-family: var(--sn-head); font-weight: 700; font-size: 17px; text-transform: uppercase; letter-spacing: .04em; color: var(--sn-navy); margin: 0 0 12px; padding-bottom: 8px; border-bottom: 2px solid var(--sn-gold); }
.sn-block-title { font-family: var(--sn-head); font-weight: 700; font-size: 19px; text-transform: uppercase; letter-spacing: .04em; color: #fff; background: var(--sn-navy); padding: 9px 14px; margin: 0 0 14px; border-left: 4px solid var(--sn-gold); }
.sn-meta { color: var(--sn-muted); font-size: 12.5px; margin: 0; }
.sn-dot { color: var(--sn-steel-light); margin: 0 6px; }

/* Badge de catégorie */
.sn-badge {
	display: inline-block; color: #fff; font-family: var(--sn-head); font-weight: 600;
	font-size: 12px; letter-spacing: .04em; text-transform: uppercase; padding: 4px 10px; border-radius: 3px;
}
.sn-badge:hover { color: #fff; opacity: .92; }

/* Accueil : UNE + colonne latérale */
.sn-home { display: grid; grid-template-columns: minmax(0,1fr) 330px; gap: 24px; margin-bottom: 22px; }
.sn-home__main { min-width: 0; }
.sn-home__aside { min-width: 0; }

/* Pages internes avec colonne latérale */
.sn-with-sidebar { display: grid; grid-template-columns: minmax(0,1fr) 330px; gap: 24px; }
.sn-with-sidebar__main { min-width: 0; }
.sn-narrow { max-width: 820px; margin: 0 auto; }

/* =====================================================================
   CARROUSEL « À LA UNE »
   ===================================================================== */
.sn-hero { position: relative; border-radius: var(--sn-radius); overflow: hidden; box-shadow: var(--sn-shadow); margin-bottom: 22px; background: var(--sn-navy-deep); }
.sn-hero__track { position: relative; }
.sn-hero__slide { display: none; position: relative; }
.sn-hero__slide.is-active { display: block; animation: sn-fade .5s ease; }
@keyframes sn-fade { from { opacity: .4; } to { opacity: 1; } }
.sn-hero__media { display: block; aspect-ratio: 16 / 9; }
.sn-hero__media .sn-img, .sn-hero__media svg { width: 100%; height: 100%; object-fit: cover; }
.sn-hero__overlay {
	position: absolute; left: 0; right: 0; bottom: 0; padding: 28px;
	background: linear-gradient(to top, rgba(13,24,64,.94) 8%, rgba(13,24,64,.55) 55%, rgba(13,24,64,0) 100%);
	color: #fff;
}
.sn-hero__flag { display: inline-block; background: var(--sn-gold); color: var(--sn-navy); font-family: var(--sn-head); font-weight: 700; font-size: 12px; letter-spacing: .06em; padding: 4px 10px; border-radius: 3px; margin-right: 6px; text-transform: uppercase; }
.sn-hero__title { font-size: 34px; font-weight: 800; margin: 12px 0 8px; color: #fff; }
.sn-hero__title a { color: #fff; }
.sn-hero__title a:hover { color: var(--sn-gold); }
.sn-hero__excerpt { font-size: 15px; color: var(--sn-text-light); margin: 0 0 16px; max-width: 70ch; }
.sn-hero__arrow {
	position: absolute; top: 42%; transform: translateY(-50%); z-index: 4;
	width: 40px; height: 40px; border: 0; border-radius: 50%; cursor: pointer;
	background: rgba(26,45,94,.78); color: #fff; font-size: 26px; line-height: 1;
	display: flex; align-items: center; justify-content: center;
}
.sn-hero__arrow:hover { background: var(--sn-gold); color: var(--sn-navy); }
.sn-hero__arrow--prev { left: 12px; }
.sn-hero__arrow--next { right: 12px; }
.sn-hero__dots { position: absolute; left: 22px; bottom: 8px; display: flex; gap: 2px; z-index: 4; }
/* Cible tactile élargie (20px) avec un point visible de 10px (background-clip). */
.sn-hero__dot { width: 20px; height: 20px; padding: 5px; border-radius: 50%; border: 0; background: rgba(255,255,255,.5); background-clip: content-box; cursor: pointer; transition: background .15s ease; }
.sn-hero__dot:hover { background: rgba(255,255,255,.8); background-clip: content-box; }
.sn-hero__dot.is-active { background: var(--sn-gold); background-clip: content-box; }

/* =====================================================================
   GRILLES DE CARTES
   ===================================================================== */
.sn-cards-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 22px; }
.sn-cards-grid--archive { grid-template-columns: repeat(3, 1fr); }
.sn-cards-grid--3 { grid-template-columns: repeat(3, 1fr); }

.sn-article-card { padding: 0; overflow: hidden; display: flex; flex-direction: column; margin-bottom: 0; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.sn-article-card:hover { transform: translateY(-4px); box-shadow: var(--sn-shadow-lg); border-color: #d6dae1; }
.sn-article-card__media { position: relative; aspect-ratio: 16 / 10; display: block; overflow: hidden; }
.sn-article-card__media .sn-img, .sn-article-card__media svg { transition: transform .4s ease; }
.sn-article-card:hover .sn-article-card__media .sn-img { transform: scale(1.06); }
.sn-article-card__media .sn-badge { position: absolute; left: 8px; top: 8px; z-index: 2; text-shadow: 0 1px 2px rgba(0,0,0,.45); }
.sn-article-card__body { padding: 12px 14px 14px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.sn-article-card__title { font-size: 16px; margin: 0; line-height: 1.25; }
.sn-article-card__title a { color: var(--sn-navy); transition: color .15s ease; }
.sn-article-card:hover .sn-article-card__title a,
.sn-article-card__title a:hover { color: var(--sn-gold-dark); }
.sn-article-card__excerpt { font-size: 13px; color: var(--sn-muted); margin: 0; }
.sn-article-card__date { margin-top: auto; }

/* Liste compacte */
.sn-listitem { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--sn-line); }
.sn-listitem:last-of-type { border-bottom: 0; }
.sn-listitem__media { flex: none; width: 96px; height: 70px; border-radius: 5px; overflow: hidden; }
.sn-listitem__media .sn-img, .sn-listitem__media svg { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.sn-listitem:hover .sn-listitem__media .sn-img, .sn-listitem:hover .sn-listitem__media svg { transform: scale(1.08); }
.sn-listitem__title { font-size: 14.5px; margin: 0 0 4px; line-height: 1.25; }
.sn-listitem__title a { color: var(--sn-navy); transition: color .15s ease; }
.sn-listitem__title a:hover { color: var(--sn-gold-dark); }

/* Liste « Dernières actualités » en vedette (colonne principale de l'accueil) */
.sn-feature-list { display: grid; gap: 16px; margin-bottom: 22px; }
.sn-feature { display: grid; grid-template-columns: 210px 1fr; background: var(--sn-card); border: 1px solid var(--sn-line); border-radius: var(--sn-radius); box-shadow: var(--sn-shadow); overflow: hidden; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.sn-feature:hover { transform: translateY(-3px); box-shadow: var(--sn-shadow-lg); border-color: #d6dae1; }
.sn-feature__media { position: relative; overflow: hidden; min-height: 150px; }
.sn-feature__media .sn-img, .sn-feature__media svg { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.sn-feature:hover .sn-feature__media .sn-img { transform: scale(1.05); }
.sn-feature__media .sn-badge { position: absolute; left: 8px; top: 8px; z-index: 2; text-shadow: 0 1px 2px rgba(0,0,0,.45); }
.sn-feature__body { padding: 16px 18px; display: flex; flex-direction: column; gap: 8px; justify-content: center; min-width: 0; }
.sn-feature__title { font-size: 19px; line-height: 1.25; margin: 0; }
.sn-feature__title a { color: var(--sn-navy); transition: color .15s ease; }
.sn-feature:hover .sn-feature__title a, .sn-feature__title a:hover { color: var(--sn-gold-dark); }
.sn-feature__excerpt { font-size: 14px; color: var(--sn-muted); line-height: 1.55; margin: 0; }
.sn-feature__meta { font-size: 12.5px; color: var(--sn-muted); margin: 0; }

/* Section deux colonnes (analyses / interviews) */
.sn-triple { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin: 8px 0 22px; }
.sn-triple__col { background: var(--sn-card); border: 1px solid var(--sn-line); border-radius: var(--sn-radius); box-shadow: var(--sn-shadow); padding: 14px; }
.sn-seemore { display: inline-flex; align-items: center; gap: 6px; margin-top: 10px; font-family: var(--sn-head); font-weight: 600; text-transform: uppercase; font-size: 13px; color: var(--sn-gold-dark); }
.sn-seemore:hover { color: var(--sn-navy); }
.sn-seemore .sn-icon { transition: transform .15s ease; }
.sn-seemore:hover .sn-icon { transform: translateX(3px); }

/* =====================================================================
   COLONNE LATÉRALE — widgets
   ===================================================================== */
.sn-ad-wrap, .sn-ad-wrap .sn-ad { margin-bottom: 22px; }

/* Cours des métaux */
.sn-prices__head { display: flex; align-items: center; justify-content: space-between; }
.sn-prices__refresh { border: 0; background: transparent; color: var(--sn-steel); font-size: 18px; cursor: pointer; line-height: 1; }
.sn-prices__refresh:hover { color: var(--sn-gold-dark); transform: rotate(90deg); transition: transform .3s; }
.sn-prices__list { list-style: none; margin: 0; padding: 0; }
.sn-price { display: flex; align-items: center; gap: 10px; padding: 11px 0; border-bottom: 1px solid var(--sn-line); }
.sn-price:last-child { border-bottom: 0; }
.sn-price__icon { flex: none; width: 30px; height: 30px; border-radius: 50%; background: var(--sn-navy); color: var(--sn-gold); font-family: var(--sn-head); font-weight: 700; font-size: 13px; display: flex; align-items: center; justify-content: center; }
.sn-price__meta { display: flex; flex-direction: column; flex: 1; }
.sn-price__label { font-size: 13.5px; font-weight: 600; color: var(--sn-navy); }
.sn-price__unit { font-size: 11px; color: var(--sn-muted); }
.sn-price__value { text-align: right; font-weight: 700; color: var(--sn-text); font-variant-numeric: tabular-nums; }
.sn-price__chg { display: block; font-size: 11.5px; font-weight: 600; }
.sn-price__chg.is-up { color: #1f9d55; }
.sn-price__chg.is-down { color: #d64545; }
.sn-prices__foot { font-size: 11px; color: var(--sn-muted); margin: 10px 0 0; text-align: right; }

/* Vidéo / YouTube */
.sn-video__frame { position: relative; aspect-ratio: 16 / 9; border-radius: 5px; overflow: hidden; background: #000; }
.sn-video__frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.sn-ytchannel .sn-btn { margin-top: 12px; width: 100%; text-align: center; }

/* Portrait */
.sn-portrait__inner { display: flex; gap: 12px; align-items: center; margin-bottom: 12px; }
.sn-portrait__photo { flex: none; width: 72px; height: 72px; border-radius: 50%; overflow: hidden; border: 3px solid var(--sn-gold); }
.sn-portrait__photo .sn-img, .sn-portrait__photo svg { width: 100%; height: 100%; object-fit: cover; }
.sn-portrait__name { display: block; font-family: var(--sn-head); font-size: 17px; color: var(--sn-navy); }
.sn-portrait__role { font-size: 13px; color: var(--sn-muted); }
.sn-portrait .sn-btn { width: 100%; text-align: center; }

/* Premium */
.sn-premium { position: relative; background: linear-gradient(160deg, var(--sn-navy) 0%, var(--sn-navy-deep) 100%); border: 0; color: #fff; }
.sn-premium .sn-section-title { color: #fff; }
.sn-premium__head { display: block; margin-bottom: 14px; padding-right: 38px; }
.sn-premium__head .sn-icon { position: absolute; top: 16px; right: 16px; width: 28px; height: 28px; color: var(--sn-gold); }
.sn-premium__title { font-size: 18px; color: #fff; margin: 0; line-height: 1.15; }
.sn-premium__title span { color: var(--sn-gold); font-size: 15px; }
.sn-premium__list { list-style: none; margin: 0 0 16px; padding: 0; }
.sn-premium__list li { padding: 6px 0 6px 24px; position: relative; font-size: 14px; color: var(--sn-text-light); }
.sn-premium__list li::before { content: '✓'; position: absolute; left: 0; color: var(--sn-gold); font-weight: 700; }
.sn-premium__cta { display: block; text-align: center; width: 100%; }
.sn-premium__pay { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.sn-pay { font-size: 11px; font-weight: 600; padding: 4px 9px; border-radius: 3px; background: #fff; color: var(--sn-navy); }
.sn-pay--orange { background: var(--sn-pay-orange); color: #fff; }
.sn-pay--mobile { background: var(--sn-pay-mobile); color: #1d2733; }
.sn-pay--paycard { background: var(--sn-pay-paycard); color: #fff; }

/* Suivez-nous */
.sn-follow .sn-social { flex-wrap: wrap; }
.sn-follow .sn-social__link { width: 38px; height: 38px; }

/* =====================================================================
   EMPLACEMENTS PUBLICITAIRES
   ===================================================================== */
.sn-ad { max-width: 100%; }
.sn-ad__ph {
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	width: 100%; max-width: var(--ad-w); height: var(--ad-h); margin: 0 auto;
	background: var(--sn-navy); background-image: repeating-linear-gradient(45deg, rgba(255,255,255,.03) 0 12px, transparent 12px 24px);
	border: 1px dashed rgba(255,255,255,.25); border-radius: 5px; color: var(--sn-text-light); text-align: center;
}
.sn-ad__label { font-family: var(--sn-head); font-weight: 600; letter-spacing: .08em; font-size: 14px; text-transform: uppercase; }
.sn-ad__size { font-size: 12px; color: var(--sn-steel-light); margin-top: 4px; }
.sn-ad-inline { margin: 22px 0; display: flex; justify-content: center; }
/* Rangée de 3 bandes publicitaires (occupe toute la largeur). */
.sn-ad-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; width: 100%; margin: 0 0 22px; }
.sn-ad-row .sn-ad { width: 100%; }
.sn-ad-row .sn-ad__ph { max-width: 100%; height: var(--ad-h, 120px); }
.sn-prefooter-ad { background: var(--sn-bg); padding: 20px 0 26px; }
.sn-prefooter-ad .sn-container { display: block; }
.sn-prefooter-ad .sn-ad__caption { display: block; text-align: center; }
.sn-ad__caption { font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--sn-muted); margin-bottom: 8px; }

/* =====================================================================
   NEWSLETTER
   ===================================================================== */
.sn-row--newsletter { margin-top: 8px; }
.sn-newsletter--box {
	background: linear-gradient(120deg, var(--sn-navy) 0%, var(--sn-navy-2) 100%); color: #fff;
	border-radius: var(--sn-radius); padding: 24px 28px; display: grid;
	grid-template-columns: 1fr auto; align-items: center; gap: 20px;
}
.sn-newsletter__title { color: #fff; font-size: 22px; margin: 0 0 4px; display: flex; align-items: center; gap: 8px; }
.sn-newsletter__title .sn-icon { color: var(--sn-gold); }
.sn-newsletter--box p { margin: 0; color: var(--sn-text-light); font-size: 14px; }
.sn-newsletter__fields { display: flex; gap: 0; }
.sn-newsletter__fields input { border: 0; padding: 12px 14px; font-size: 15px; border-radius: 4px 0 0 4px; flex: 1; min-width: 0; outline: none; }
.sn-newsletter__fields button { border: 0; background: var(--sn-gold); color: var(--sn-gold-text); font-family: var(--sn-head); font-weight: 700; letter-spacing: .04em; padding: 0 22px; border-radius: 0 4px 4px 0; cursor: pointer; text-transform: uppercase; }
.sn-newsletter__fields button:hover { background: var(--sn-gold-dark); color: #fff; }
.sn-newsletter__msg { grid-column: 1 / -1; margin: 4px 0 0; font-size: 13.5px; min-height: 1em; }
.sn-newsletter__msg.is-ok { color: #8ef0b8; }
.sn-newsletter__msg.is-err { color: #ffc1c1; }

/* =====================================================================
   ARTICLE
   ===================================================================== */
.sn-archive-head { border-bottom: 3px solid var(--sn-gold); padding-bottom: 10px; margin-bottom: 20px; }
.sn-archive-title { font-size: 30px; font-weight: 800; margin: 0; }
.sn-archive-desc { color: var(--sn-muted); }

.sn-single { background: var(--sn-card); border: 1px solid var(--sn-line); border-radius: var(--sn-radius); box-shadow: var(--sn-shadow); padding: 26px; }
.sn-single__head { margin-bottom: 16px; }
.sn-single__title { font-size: 34px; font-weight: 800; margin: 10px 0 6px; }
.sn-single__subtitle { font-size: 18px; color: var(--sn-steel); margin: 0 0 12px; font-weight: 500; }
.sn-single__meta { color: var(--sn-muted); font-size: 13.5px; display: flex; align-items: center; flex-wrap: wrap; }
.sn-single__author { font-weight: 600; color: var(--sn-navy); }
.sn-single__rt { display: inline-flex; align-items: center; gap: 4px; }
.sn-single__figure { margin: 0 0 20px; border-radius: 6px; overflow: hidden; }
.sn-single__figure figcaption { font-size: 12.5px; color: var(--sn-muted); padding: 6px 2px; }
.sn-single__video { margin-bottom: 20px; }
.sn-single__content { font-size: 17px; line-height: 1.75; color: #2a3340; }
.sn-single__content p { margin: 0 0 1.1em; }
.sn-single__content h2 { font-size: 25px; margin: 1.4em 0 .5em; }
.sn-single__content h3 { font-size: 21px; margin: 1.3em 0 .5em; }
.sn-single__content img { border-radius: 6px; margin: 1em 0; }
.sn-single__content blockquote { border-left: 4px solid var(--sn-gold); margin: 1.3em 0; padding: .8em 1.4em; color: var(--sn-navy); font-style: italic; line-height: 1.7; background: rgba(200,144,10,.07); border-radius: 0 6px 6px 0; }
.sn-single__content a { color: var(--sn-gold-dark); text-decoration: underline; }

/* Étiquettes */
.sn-tags { margin: 22px 0; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.sn-tags__label { font-weight: 600; color: var(--sn-navy); font-size: 14px; }
.sn-tags a { display: inline-block; background: var(--sn-bg); border: 1px solid var(--sn-line); color: var(--sn-steel); font-size: 13px; padding: 4px 11px; border-radius: 999px; }
.sn-tags a:hover { background: var(--sn-gold); color: var(--sn-navy); border-color: var(--sn-gold); }

/* Partage */
.sn-share { display: flex; align-items: center; gap: 8px; margin: 16px 0; }
.sn-share__label { font-family: var(--sn-head); font-weight: 600; text-transform: uppercase; font-size: 13px; color: var(--sn-navy); }
.sn-share__btn { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 5px; color: #fff; }
.sn-share__btn--facebook { background: var(--sn-social-facebook); }
.sn-share__btn--twitter  { background: var(--sn-social-x); }
.sn-share__btn--linkedin { background: var(--sn-social-linkedin); }
.sn-share__btn--whatsapp { background: var(--sn-social-whatsapp); }
.sn-share__btn--email    { background: var(--sn-steel); }
.sn-share__btn:hover { color: #fff; transform: translateY(-2px); transition: transform .12s; }

/* Auteur */
.sn-author { display: flex; gap: 16px; align-items: center; background: var(--sn-bg); border-radius: 6px; padding: 16px; margin: 22px 0; }
.sn-author__avatar { border-radius: 50%; flex: none; }
.sn-author__name { font-family: var(--sn-head); font-size: 18px; color: var(--sn-navy); }
.sn-author__bio { margin: 4px 0 0; font-size: 14px; color: var(--sn-muted); }

.sn-related { margin-top: 26px; }

/* =====================================================================
   COMMENTAIRES
   ===================================================================== */
.sn-comments { background: var(--sn-card); border: 1px solid var(--sn-line); border-radius: var(--sn-radius); box-shadow: var(--sn-shadow); padding: 24px; margin-top: 24px; }
.sn-commentlist { list-style: none; margin: 0 0 20px; padding: 0; }
.sn-commentlist ol { list-style: none; }
.sn-commentlist .comment-body { border-bottom: 1px solid var(--sn-line); padding: 14px 0; }
.sn-commentlist .comment-author { font-weight: 600; color: var(--sn-navy); }
.sn-commentlist .comment-author img { border-radius: 50%; margin-right: 8px; vertical-align: middle; }
.sn-commentlist .comment-meta { font-size: 12px; color: var(--sn-muted); }
.sn-comments__note { font-size: 13px; color: var(--sn-muted); }
.sn-comments input[type=text], .sn-comments input[type=email], .sn-comments input[type=url], .sn-comments textarea {
	width: 100%; border: 1px solid var(--sn-line); border-radius: 5px; padding: 10px 12px; font: inherit; font-size: 15px; margin-top: 4px;
}
.sn-comments label { font-weight: 600; font-size: 14px; color: var(--sn-navy); }
.sn-comments .comment-form-comment, .sn-comments .comment-form-author, .sn-comments .comment-form-email, .sn-comments .comment-form-url { margin-bottom: 14px; }

/* =====================================================================
   FORMULAIRES (publication, abonnement)
   ===================================================================== */
.sn-publish, .sn-subscribe { background: var(--sn-card); border: 1px solid var(--sn-line); border-radius: var(--sn-radius); box-shadow: var(--sn-shadow); padding: 28px; }
.sn-field { margin: 0 0 18px; display: flex; flex-direction: column; }
.sn-field label { font-family: var(--sn-head); font-weight: 600; color: var(--sn-navy); margin-bottom: 6px; font-size: 16px; }
.sn-field .req { color: #d64545; }
.sn-field input[type=text], .sn-field textarea, .sn-pubform select {
	border: 1px solid var(--sn-line); border-radius: 5px; padding: 11px 13px; font: inherit; font-size: 15px; width: 100%;
}
.sn-field--check label { flex-direction: row; }
.sn-help { font-size: 13.5px; color: var(--sn-muted); }

.sn-notice { border-radius: 6px; padding: 12px 16px; margin-bottom: 20px; font-size: 14.5px; }
.sn-notice--success { background: #e6f6ec; color: #16723e; border: 1px solid #bce5cd; }
.sn-notice--error { background: #fdecec; color: #a23131; border: 1px solid #f3c7c7; }

/* =====================================================================
   ABONNEMENT PREMIUM (page-abonnement.php)
   ===================================================================== */

/* Héro plein-écran — fond marine, texte blanc */
.sn-sub-hero {
	width: 100vw;
	position: relative;
	left: 50%;
	margin-left: -50vw;
	background: linear-gradient(135deg, var(--sn-navy-deep) 0%, var(--sn-navy) 70%, #23408a 100%);
	color: #fff;
	padding: 56px 20px 48px;
	margin-bottom: 40px;
	text-align: center;
	overflow: hidden;
}
.sn-sub-hero::before {
	content: '';
	position: absolute;
	top: -60px; right: -60px;
	width: 340px; height: 340px;
	background: radial-gradient(circle, rgba(200,144,10,.18) 0%, transparent 70%);
	pointer-events: none;
}
.sn-sub-hero__inner { max-width: 680px; margin: 0 auto; position: relative; z-index: 1; }
.sn-sub-hero__label { font-family: var(--sn-head); font-size: 13px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--sn-gold); margin-bottom: 18px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.sn-sub-hero__label .sn-icon { color: var(--sn-gold); }
.sn-sub-hero__title { font-size: 38px; font-weight: 800; line-height: 1.1; color: #fff; margin: 0 0 18px; white-space: pre-line; }
.sn-sub-hero__lead { color: rgba(255,255,255,.75); font-size: 1.05rem; margin: 0 auto 32px; line-height: 1.65; max-width: 560px; }
.sn-sub-hero__stats { display: flex; gap: 32px; justify-content: center; flex-wrap: wrap; border-top: 1px solid rgba(255,255,255,.14); padding-top: 24px; }
.sn-sub-hero__stat strong { display: block; font-family: var(--sn-head); font-size: 30px; font-weight: 800; color: var(--sn-gold); }
.sn-sub-hero__stat span { font-size: 13px; color: rgba(255,255,255,.6); }

/* Corps de la page d'abonnement */
.sn-sub-body { max-width: 960px; margin: 0 auto; }

/* Grille 3 colonnes */
.sn-plans { display: grid; gap: 24px; margin-bottom: 32px; }
.sn-plans--3 { grid-template-columns: repeat(3, 1fr); }
.sn-plan { display: flex; flex-direction: column; border: 2px solid var(--sn-line); border-radius: 12px; overflow: hidden; position: relative; background: #fff; box-shadow: var(--sn-shadow); }
.sn-plan--featured { border-color: var(--sn-gold); box-shadow: 0 0 0 3px var(--sn-gold), var(--sn-shadow-lg); }
.sn-plan__tag { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: var(--sn-gold); color: var(--sn-gold-text); font-family: var(--sn-head); font-weight: 700; font-size: 11px; padding: 4px 14px; border-radius: 999px; white-space: nowrap; letter-spacing: .08em; text-transform: uppercase; z-index: 2; }
/* En-tête de carte */
.sn-plan__head { padding: 28px 24px 20px; background: var(--sn-bg); border-bottom: 1px solid var(--sn-line); text-align: center; }
.sn-plan__head--dark { background: linear-gradient(135deg, var(--sn-navy) 0%, var(--sn-navy-2) 100%); border-bottom: 0; }
.sn-plan__name { font-size: 13px; font-weight: 700; color: var(--sn-muted); text-transform: uppercase; letter-spacing: .1em; margin: 0 0 6px; font-family: var(--sn-head); }
.sn-plan--featured .sn-plan__name { color: rgba(255,255,255,.65); }
.sn-plan__price { font-family: var(--sn-head); font-size: 28px; font-weight: 800; color: var(--sn-navy); margin: 0 0 4px; }
.sn-plan__price span { font-size: 14px; color: var(--sn-muted); font-family: var(--sn-body); font-weight: 400; }
.sn-plan--featured .sn-plan__price { color: var(--sn-gold); }
.sn-plan__period { font-size: 13px; color: var(--sn-muted); margin: 0; }
.sn-plan--featured .sn-plan__period { color: rgba(255,255,255,.6); }
/* Liste de fonctionnalités */
.sn-plan__list { flex: 1; list-style: none; margin: 0; padding: 18px 24px; }
.sn-plan__item { padding: 9px 0 9px 26px; position: relative; font-size: 13.5px; border-bottom: 1px solid var(--sn-line); }
.sn-plan__item:last-child { border-bottom: 0; }
.sn-plan__item--yes::before { content: '✓'; position: absolute; left: 0; color: var(--sn-gold); font-weight: 700; font-size: 15px; }
.sn-plan__item--no { color: var(--sn-muted); text-decoration: line-through; opacity: .55; }
.sn-plan__item--no::before { content: '✕'; position: absolute; left: 0; color: #bbb; font-weight: 700; text-decoration: none; font-size: 13px; }
/* Pied de carte */
.sn-plan__footer { padding: 18px 24px 26px; }

/* Boutons supplémentaires */
.sn-btn--navy { background: var(--sn-navy); color: #fff; }
.sn-btn--navy:hover { background: var(--sn-navy-2); color: #fff; }
.sn-btn--ghost { background: transparent; color: var(--sn-steel); border: 2px solid var(--sn-line); }

/* Moyens de paiement — version page abonnement */
.sn-paymethods { text-align: center; border-top: 1px solid var(--sn-line); padding-top: 20px; }
.sn-paymethods__list { display: flex; justify-content: center; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.sn-paymethods .sn-pay { font-size: 14px; padding: 8px 16px; }
.sn-paymethods--sub { background: var(--sn-bg); border: 1px solid var(--sn-line); border-radius: var(--sn-radius); padding: 24px; margin-bottom: 36px; border-top: none; }
.sn-paymethods__label { font-family: var(--sn-head); font-size: 12px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--sn-muted); margin: 0 0 12px; }
.sn-paymethods__note { font-size: 12px; color: var(--sn-muted); margin: 12px 0 0; }
.sn-pay--visa { background: #1a1f71; color: #fff; }

/* FAQ */
.sn-sub-faq { margin: 0 0 32px; }
.sn-faq { border: 1px solid var(--sn-line); border-radius: var(--sn-radius); overflow: hidden; }
.sn-faq__item { border-bottom: 1px solid var(--sn-line); }
.sn-faq__item:last-child { border-bottom: 0; }
.sn-faq__q { list-style: none; padding: 16px 20px; font-family: var(--sn-head); font-weight: 600; font-size: 15.5px; color: var(--sn-navy); cursor: pointer; display: flex; justify-content: space-between; align-items: center; user-select: none; }
.sn-faq__q::after { content: '+'; font-size: 22px; color: var(--sn-gold); flex-shrink: 0; margin-left: 12px; font-weight: 300; }
.sn-faq__item[open] .sn-faq__q::after { content: '\2212'; }
.sn-faq__a { padding: 2px 20px 18px; font-size: 14px; color: var(--sn-muted); line-height: 1.7; margin: 0; }

/* Contact bas de page */
.sn-sub-contact { text-align: center; padding: 16px; margin-bottom: 24px; color: var(--sn-muted); font-size: 14px; }
.sn-sub-contact a { color: var(--sn-gold); font-weight: 600; text-decoration: none; }
.sn-sub-contact a:hover { text-decoration: underline; }

/* =====================================================================
   PAYWALL — Mur de paiement sur les articles Premium
   ===================================================================== */
.sn-paywall { position: relative; }
.sn-paywall__teaser { position: relative; max-height: 220px; overflow: hidden; }
.sn-paywall__teaser::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 140px; background: linear-gradient(to bottom, transparent, #fff); pointer-events: none; }
.sn-paywall__wall { background: #fff; border: 2px solid var(--sn-gold); border-radius: 12px; padding: 34px 28px; text-align: center; margin-top: 10px; box-shadow: var(--sn-shadow-lg); }
.sn-paywall__icon { width: 52px; height: 52px; margin: 0 auto 16px; color: var(--sn-gold); }
.sn-paywall__icon svg { width: 100%; height: 100%; }
.sn-paywall__headline { font-family: var(--sn-head); font-size: 22px; font-weight: 700; color: var(--sn-navy); margin: 0 0 10px; }
.sn-paywall__desc { color: var(--sn-muted); font-size: 14.5px; margin: 0 0 24px; line-height: 1.65; max-width: 460px; margin-left: auto; margin-right: auto; }
.sn-paywall__actions { display: flex; flex-direction: column; align-items: center; gap: 12px; margin-bottom: 20px; }
.sn-paywall__login { font-size: 13px; color: var(--sn-muted); text-decoration: none; }
.sn-paywall__login:hover { color: var(--sn-navy); text-decoration: underline; }
.sn-paywall__pay { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; }

/* Badge Premium sur les cartes d'articles */
.sn-feature__media { position: relative; }
.sn-premium-badge { position: absolute; top: 8px; right: 8px; background: var(--sn-gold); color: var(--sn-gold-text); font-family: var(--sn-head); font-size: 10px; font-weight: 700; letter-spacing: .1em; padding: 3px 8px; border-radius: 3px; text-transform: uppercase; z-index: 2; pointer-events: none; }

/* Responsive abonnement */
@media (max-width: 900px) {
	.sn-plans--3 { grid-template-columns: 1fr; max-width: 440px; margin-left: auto; margin-right: auto; }
	.sn-sub-hero__title { font-size: 28px; }
	.sn-sub-hero { margin-left: calc(50% - 50vw); }
}
@media (max-width: 600px) {
	.sn-sub-hero__stats { gap: 20px; }
	.sn-sub-hero__stat strong { font-size: 24px; }
	.sn-sub-hero { padding: 36px 16px 32px; }
	.sn-paywall__wall { padding: 24px 16px; }
}

/* Contact */
.sn-contact { display: grid; grid-template-columns: 1.6fr 1fr; gap: 24px; align-items: start; }
.sn-contact__form { background: var(--sn-card); border: 1px solid var(--sn-line); border-radius: var(--sn-radius); box-shadow: var(--sn-shadow); padding: 26px; }
.sn-contact__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.sn-contact__info { background: linear-gradient(160deg, var(--sn-navy) 0%, var(--sn-navy-deep) 100%); color: #fff; border-radius: var(--sn-radius); padding: 24px; }
.sn-contact__info .sn-section-title { color: #fff; }
.sn-contact__list { list-style: none; margin: 0 0 18px; padding: 0; }
.sn-contact__list li { display: flex; align-items: flex-start; gap: 12px; padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,.1); }
.sn-contact__list li:last-child { border-bottom: 0; }
.sn-contact__list .sn-icon { color: var(--sn-gold); flex: none; margin-top: 2px; }
.sn-contact__list b { display: block; font-family: var(--sn-head); font-size: 14px; letter-spacing: .03em; text-transform: uppercase; color: var(--sn-gold); }
.sn-contact__list span { color: var(--sn-text-light); font-size: 14.5px; }
.sn-contact__list a { color: var(--sn-text-light); }
.sn-contact__list a:hover { color: #fff; }
.sn-contact__info .sn-social { margin-top: 4px; }
.sn-contact__map { margin-top: 22px; border-radius: var(--sn-radius); overflow: hidden; border: 1px solid var(--sn-line); }
.sn-contact__map svg { display: block; width: 100%; height: 180px; }

/* 404 / vide */
.sn-404 { text-align: center; background: var(--sn-card); border-radius: var(--sn-radius); box-shadow: var(--sn-shadow); padding: 50px 20px; }
.sn-404__code { font-size: 80px; color: var(--sn-gold); margin: 0; }
.sn-404 .sn-search { display: inline-flex; margin: 14px 0; }
.sn-empty { background: var(--sn-card); border-radius: var(--sn-radius); padding: 30px; text-align: center; color: var(--sn-muted); }

/* Pagination */
.pagination, .navigation .nav-links { display: flex; gap: 6px; justify-content: center; margin: 26px 0; flex-wrap: wrap; }
.nav-links .page-numbers { display: inline-block; padding: 8px 14px; background: #fff; border: 1px solid var(--sn-line); border-radius: 4px; color: var(--sn-navy); font-weight: 600; }
.nav-links .page-numbers.current, .nav-links .page-numbers:hover { background: var(--sn-gold); color: var(--sn-navy); border-color: var(--sn-gold); }

/* =====================================================================
   PIED DE PAGE
   ===================================================================== */
.sn-footer { background: linear-gradient(180deg, var(--sn-navy) 0%, var(--sn-navy-deep) 100%); color: #c6cfdd; margin-top: 10px; }

/* Bande supérieure : colonnes (marque, rubriques, journal, newsletter). */
.sn-footer__top { padding: 46px 0 34px; }
.sn-footer__cols { display: grid; grid-template-columns: 1.8fr 1fr 1.1fr 1.5fr; gap: 36px; }
.sn-footer__col { min-width: 0; }
.sn-footer__title { font-family: var(--sn-head); text-transform: uppercase; letter-spacing: .05em; color: #fff; font-size: 16px; margin: 0 0 18px; padding-bottom: 10px; position: relative; }
.sn-footer__title::after { content: ''; position: absolute; left: 0; bottom: 0; width: 34px; height: 2px; background: var(--sn-gold); }
.sn-logo--footer { display: inline-block; background: rgba(255,255,255,.95); padding: 7px 12px; border-radius: 8px; margin-bottom: 16px; }
.sn-logo--footer .sn-logo__text { color: #fff; font-size: 26px; }
.sn-footer__desc { font-size: 14px; line-height: 1.7; color: #aab4c4; margin: 0 0 18px; max-width: 38ch; }
.sn-footer__links { list-style: none; margin: 0; padding: 0; }
.sn-footer__links li { margin: 0 0 10px; }
.sn-footer__links a { color: #c6cfdd; font-size: 14px; display: inline-flex; align-items: center; transition: color .15s ease, transform .15s ease; }
.sn-footer__links a::before { content: '›'; color: var(--sn-gold); margin-right: 8px; font-weight: 700; }
.sn-footer__links a:hover { color: #fff; transform: translateX(3px); }
.sn-footer__nl p { font-size: 14px; color: #aab4c4; line-height: 1.6; margin: 0 0 14px; }
.sn-footer__nlform { display: flex; flex-wrap: wrap; }
.sn-footer__nlform input { flex: 1; min-width: 0; border: 0; padding: 11px 13px; font: inherit; font-size: 14px; border-radius: 4px 0 0 4px; outline: none; }
.sn-footer__nlform .sn-newsletter__msg { flex-basis: 100%; margin: 8px 0 0; font-size: 12.5px; }
.sn-footer__nlform button { border: 0; background: var(--sn-gold); color: var(--sn-gold-text); font-family: var(--sn-head); font-weight: 700; letter-spacing: .03em; text-transform: uppercase; padding: 0 16px; border-radius: 0 4px 4px 0; cursor: pointer; transition: background .15s ease, color .15s ease; }
.sn-footer__nlform button:hover { background: var(--sn-gold-dark); color: #fff; }
.sn-footer__premium { display: inline-flex; align-items: center; gap: 7px; margin-top: 16px; }
.sn-footer__social-label { display: block; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: #8b97a9; margin: 18px 0 8px; }

/* Bande inférieure : copyright + signature + liens légaux. */
.sn-footer__bottom { border-top: 1px solid rgba(255,255,255,.1); padding: 18px 0; }
.sn-footer__bottom-inner { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.sn-footer__copy { margin: 0; color: #8b97a9; font-size: 13px; }
.sn-footer__by a { color: var(--sn-gold); font-weight: 600; }
.sn-footer__by a:hover { color: #fff; text-decoration: underline; }
.sn-footer__legal { display: flex; gap: 18px; flex-wrap: wrap; margin: 0; padding: 0; list-style: none; }
.sn-footer__legal a { color: #8b97a9; font-size: 13px; }
.sn-footer__legal a:hover { color: var(--sn-gold); }
.sn-footer .sn-social__link { background: rgba(255,255,255,.1); }
.sn-footer .sn-social__link:hover { background: var(--sn-gold); color: var(--sn-navy); }

/* Fil d'Ariane */
.sn-breadcrumb { margin: 0 0 16px; }
.sn-breadcrumb ol { list-style: none; display: flex; flex-wrap: wrap; align-items: center; gap: 7px; margin: 0; padding: 0; font-size: 13px; }
.sn-breadcrumb li { display: inline-flex; align-items: center; gap: 7px; color: var(--sn-muted); }
.sn-breadcrumb li:not(:last-child)::after { content: '›'; color: var(--sn-steel-light); }
.sn-breadcrumb a { color: var(--sn-steel); }
.sn-breadcrumb a:hover { color: var(--sn-gold-dark); }
.sn-breadcrumb [aria-current] { color: var(--sn-navy); font-weight: 600; }

/* Bouton « retour en haut » */
.sn-totop { position: fixed; right: 18px; bottom: 18px; z-index: 60; width: 44px; height: 44px; border: 0; border-radius: 50%; background: var(--sn-gold); color: var(--sn-navy); font-size: 22px; line-height: 1; cursor: pointer; box-shadow: var(--sn-shadow-lg); display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transform: translateY(12px); transition: opacity .2s ease, transform .2s ease, visibility .2s ease, background .15s ease; }
.sn-totop.is-visible { opacity: 1; visibility: visible; transform: none; }
.sn-totop:hover { background: var(--sn-gold-dark); color: #fff; }

/* =====================================================================
   ACCESSIBILITÉ — focus clavier visible, états désactivés, césure
   ===================================================================== */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
.sn-prices__refresh:focus-visible,
.sn-hero__arrow:focus-visible { outline: 2px solid var(--sn-gold); outline-offset: 2px; border-radius: 2px; }

/* Sur fond marine : contour clair pour rester visible. */
.sn-menu a:focus-visible,
.sn-nav__toggle:focus-visible,
.sn-nav__more a:focus-visible,
.sn-hero__dot:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }
.sn-hero__dot:focus-visible { outline-offset: -4px; }

/* Sur le ruban blanc des « dernières news ». */
.sn-breaking__btn:focus-visible { outline: 2px solid var(--sn-navy); outline-offset: -2px; }

/* États désactivés (boutons AJAX en cours). */
.sn-prices__refresh:disabled,
.sn-newsletter__fields button:disabled,
.sn-btn:disabled { opacity: .55; cursor: not-allowed; }

/* Évite tout débordement horizontal sur titres très longs. */
.sn-article-card__title, .sn-listitem__title, .sn-hero__title,
.sn-single__title, .sn-archive-title, .sn-portrait__name { overflow-wrap: break-word; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
/* Barre de menu : resserrage progressif pour garder tous les onglets
   sur une seule ligne quand la fenêtre rétrécit. */
@media (max-width: 1180px) {
	.sn-menu a { padding: 13px 12px; letter-spacing: .02em; }
}
@media (max-width: 1024px) {
	.sn-home, .sn-with-sidebar { grid-template-columns: 1fr; }
	.sn-home__aside, .sn-sidebar { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; align-items: start; }
	.sn-home__aside > *, .sn-sidebar > * { margin-bottom: 0; }
	.sn-cards-grid { grid-template-columns: repeat(2, 1fr); }
	.sn-hero__title { font-size: 26px; }
	.sn-menu a { padding: 12px 10px; font-size: 14px; }
	.sn-menu .menu-item-has-children > a::after { margin-left: 5px; }
	.sn-headbanner__art { width: 168px; }
	.sn-logo__text { font-size: 26px; }
	.sn-footer__cols { grid-template-columns: 1fr 1fr; gap: 28px; }
	.sn-footer__brand { grid-column: 1 / -1; }
}

@media (max-width: 860px) {
	.sn-topbar__inner { grid-template-columns: 1fr auto; }
	.sn-headbanner { grid-column: 1 / -1; order: 3; }
	.sn-triple { grid-template-columns: 1fr; }
	.sn-cards-grid--archive, .sn-cards-grid--3 { grid-template-columns: repeat(2,1fr); }
	.sn-newsletter--box { grid-template-columns: 1fr; }
	/* Si les onglets passent à la ligne sur petite tablette, on centre. */
	.sn-menu { justify-content: center; }
	.sn-menu a { padding: 12px 12px; }
	.sn-headbanner__art { width: 130px; }
	.sn-contact, .sn-contact__row { grid-template-columns: 1fr; }
}

@media (max-width: 680px) {
	/* ☰ en haut à droite, menu déroulant en dessous quand ouvert. */
	.sn-nav__inner { flex-wrap: wrap; }
	.sn-nav__toggle { display: inline-flex; margin-left: auto; }
	.sn-menu { display: none; flex-direction: column; width: 100%; flex-basis: 100%; justify-content: flex-start; }
	.sn-menu.is-open { display: flex; }
	.sn-menu > li { display: block; }
	.sn-menu > li > a { display: flex; }
	.sn-menu a { padding: 12px 16px; border-top: 1px solid rgba(255,255,255,.08); }
	/* Communautés / Portraits : masqués dans la barre desktop, affichés ici. */
	.sn-menu > li.sn-menu__extra { display: block; }
	.sn-nav__more { display: none !important; }
	/* Sous-menus : empilés et toujours visibles en mobile (chevron pointé vers le haut). */
	.sn-menu .sub-menu { position: static; display: block; min-width: 0; box-shadow: none; background: rgba(0,0,0,.22); border-radius: 0; }
	.sn-menu .sub-menu a { padding-left: 34px; }
	.sn-menu .menu-item-has-children > a::after { transform: rotate(180deg); opacity: 1; }
	.sn-home__aside, .sn-sidebar { grid-template-columns: 1fr; }
	.sn-cards-grid, .sn-cards-grid--archive, .sn-cards-grid--3, .sn-plans { grid-template-columns: 1fr; }
	.sn-feature { grid-template-columns: 1fr; }
	.sn-feature__media { min-height: 0; aspect-ratio: 16 / 9; }
	.sn-ad-row { grid-template-columns: 1fr; }
	.sn-ad-row .sn-ad:nth-child(n+2) { display: none; } /* 1 bande pub par zone en mobile */
	.sn-footer__cols { grid-template-columns: 1fr; gap: 30px; }
	.sn-footer__bottom-inner { flex-direction: column; text-align: center; }
	.sn-hero__title { font-size: 22px; }
	.sn-hero__overlay { padding: 18px; }
	.sn-single { padding: 18px; }
	.sn-single__title { font-size: 26px; }
	.sn-topbar__right .sn-search { display: none; }
	.sn-newsletter__fields { flex-direction: column; }
	.sn-newsletter__fields input { border-radius: 4px; }
	.sn-newsletter__fields button { border-radius: 4px; margin-top: 8px; padding: 12px; }
	.sn-logo__text { font-size: 22px; }
	/* Bandeau : on masque le train (rognage), texte + CTA suffisent en mobile. */
	.sn-headbanner__art { display: none; }
	.sn-headbanner { padding: 12px 16px; }
	/* Empile l’unité monétaire sous le prix. */
	.sn-plan__price { font-size: 26px; }
	.sn-plan__price span { display: block; font-size: 12px; margin-top: 2px; }
	/* Police 16px sur mobile : évite le zoom auto d’iOS au focus. */
	.sn-field input[type=text], .sn-field textarea, .sn-pubform select,
	.sn-comments input, .sn-comments textarea,
	.sn-search__field, .sn-newsletter__fields input { font-size: 16px; }
}

/* Préférence : réduire les animations */
@media (prefers-reduced-motion: reduce) {
	.sn-breaking__track { animation: none; }
	.sn-hero__slide.is-active { animation: none; }
}

/* =====================================================================
   Profil auteur (author.php)
   ===================================================================== */
.sn-author-head { border-color: var(--sn-navy) !important; }
.sn-author-profile { display: flex; gap: 20px; align-items: flex-start; }
.sn-author-avatar__img { width: 96px; height: 96px; border-radius: 50%; object-fit: cover; border: 3px solid var(--sn-gold); flex-shrink: 0; }
.sn-author-info { flex: 1; }
.sn-author-name { margin: 0 0 8px; }
.sn-author-bio { color: var(--sn-muted); font-size: .94rem; margin: 0 0 8px; line-height: 1.55; }
.sn-author-link { font-size: .85rem; color: var(--sn-gold); font-weight: 600; text-decoration: none; }
.sn-author-link:hover { color: var(--sn-gold-dark); text-decoration: underline; }
.sn-author-articles-title { margin: 28px 0 16px; font-size: 1.1rem; }
@media (max-width: 600px) {
	.sn-author-profile { flex-direction: column; align-items: center; text-align: center; }
	.sn-author-avatar__img { width: 80px; height: 80px; }
}
