/*
Theme Name:  La Voix Étudiante
Theme URI:   https://lavoixetudiante.fr
Description: Thème enfant GeneratePress — La Voix Étudiante
Author:      La Voix Étudiante
Version:     3.0.0
Template:    generatepress
Text Domain: lavoixetudiante
*/

/* =========================================================
   IMPORT FONTS
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;600;700;800&family=DM+Sans:ital,wght@0,400;0,500;1,400&display=swap');

/* =========================================================
   VARIABLES
   ========================================================= */
:root {
  --lve-night:        #0F1B2D;
  --lve-marine:       #1A3C5E;
  --lve-cyan:         #00E5FF;
  --lve-cyan-glow:    rgba(0,229,255,0.45);
  --lve-cyan-soft:    rgba(0,229,255,0.10);
  --lve-pink:         #FF0080;
  --lve-pink-glow:    rgba(255,0,128,0.38);
  --lve-pink-pale:    #FF85C8;
  --lve-green:        #00FF94;
  --lve-green-glow:   rgba(0,255,148,0.38);
  --lve-yellow:       #F5FF50;
  --lve-yellow-glow:  rgba(245,255,80,0.45);
  --lve-fond:         #F7F8FC;
  --lve-blanc:        #FFFFFF;
  --lve-texte:        #0F1B2D;
  --lve-muted:        #536070;
  --lve-border:       rgba(15,27,45,0.09);
  --lve-ff-title:     'Plus Jakarta Sans', sans-serif;
  --lve-ff-body:      'DM Sans', sans-serif;
  --lve-r-sm:         8px;
  --lve-r-md:         12px;
  --lve-r-lg:         16px;
  --lve-transition:   0.22s ease;
}

/* =========================================================
   ANIMATIONS
   ========================================================= */
@keyframes lve-wave1  { 0%,100%{opacity:.9} 50%{opacity:.35} }
@keyframes lve-wave2  { 0%,100%{opacity:.5} 50%{opacity:1} }
@keyframes lve-pulse  { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.45);opacity:.7} }
@keyframes lve-fadeup { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes lve-breathe-cyan  { 0%,100%{box-shadow:0 0 0 0 transparent} 50%{box-shadow:0 0 18px 2px var(--lve-cyan-glow)} }
@keyframes lve-breathe-pink  { 0%,100%{box-shadow:0 0 0 0 transparent} 50%{box-shadow:0 0 18px 2px var(--lve-pink-glow)} }
@keyframes lve-breathe-green { 0%,100%{box-shadow:0 0 0 0 transparent} 50%{box-shadow:0 0 16px 2px var(--lve-green-glow)} }

/* =========================================================
   RESET & BASE
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: var(--lve-ff-body) !important;
  background: var(--lve-fond) !important;
  color: var(--lve-texte) !important;
  -webkit-font-smoothing: antialiased;
  margin: 0 !important;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--lve-ff-title) !important;
  color: var(--lve-night) !important;
  line-height: 1.3 !important;
  letter-spacing: 0 !important;
}

a { transition: color var(--lve-transition); }

img { max-width: 100%; height: auto; }

/* =========================================================
   LAYOUT
   ========================================================= */
.lve-container { max-width: 1100px; margin: 0 auto; padding: 0 1.5rem; }
.lve-container--narrow { max-width: 780px; margin: 0 auto; padding: 0 1.5rem; }

/* =========================================================
   HEADER
   ========================================================= */
#lve-header {
  background: rgba(247,248,252,0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--lve-border);
  position: sticky;
  top: 0;
  z-index: 200;
  padding: .85rem 0;
}

.lve-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}

/* Logo */
.lve-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none !important;
  flex-shrink: 0;
}
.lve-logo-icon {
  width: 38px;
  height: 34px;
  flex-shrink: 0;
  transition: filter var(--lve-transition);
}
.lve-logo:hover .lve-logo-icon {
  filter: drop-shadow(0 0 6px var(--lve-cyan-glow));
}
.lve-logo-svg .lve-wave-1 { animation: lve-wave1 1.6s ease-in-out infinite; }
.lve-logo-svg .lve-wave-2 { animation: lve-wave2 1.6s ease-in-out infinite .22s; }

.lve-logo-wordmark {
  display: flex;
  flex-direction: column;
  line-height: 1;
}
.lve-logo-name {
  display: flex;
  align-items: baseline;
  gap: 1px;
}
.lve-logo-p1 {
  font-family: var(--lve-ff-title) !important;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--lve-night) !important;
  letter-spacing: 0;
  text-decoration: none;
}
.lve-logo-p2 {
  font-family: var(--lve-ff-title) !important;
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--lve-cyan) !important;
  text-shadow: 0 0 12px var(--lve-cyan-glow);
  letter-spacing: 0;
  transition: text-shadow var(--lve-transition);
}
.lve-logo:hover .lve-logo-p2 {
  text-shadow: 0 0 22px var(--lve-cyan-glow), 0 0 44px rgba(0,229,255,.2);
}
.lve-logo-tld {
  font-family: var(--lve-ff-body);
  font-size: .62rem;
  color: rgba(15,27,45,.2);
  letter-spacing: 1px;
  margin-left: 2px;
}
.lve-logo-tagline {
  font-family: var(--lve-ff-body);
  font-size: .58rem;
  letter-spacing: 1.3px;
  text-transform: uppercase;
  color: rgba(15,27,45,.28);
  margin-top: 3px;
}

/* Nav principale */
.lve-nav {
  display: flex;
  align-items: center;
  gap: .1rem;
  flex-wrap: nowrap;
}
.lve-nav a {
  font-family: var(--lve-ff-body) !important;
  font-size: .83rem;
  font-weight: 500;
  color: var(--lve-muted) !important;
  text-decoration: none !important;
  padding: .4rem .65rem;
  border-radius: var(--lve-r-sm);
  transition: color var(--lve-transition), background var(--lve-transition);
  white-space: nowrap;
}
.lve-nav a:hover,
.lve-nav a.current {
  color: var(--lve-night) !important;
  background: rgba(15,27,45,.05);
}
.lve-nav-cta {
  background: var(--lve-night) !important;
  color: #fff !important;
  border-radius: var(--lve-r-sm) !important;
  padding: .45rem 1rem !important;
  font-weight: 700 !important;
  margin-left: .25rem;
}
.lve-nav-cta:hover {
  background: var(--lve-marine) !important;
  box-shadow: 0 0 14px var(--lve-cyan-glow) !important;
}

/* Hamburger mobile */
.lve-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 4px;
  background: none;
  border: none;
}
.lve-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--lve-night);
  border-radius: 2px;
}

/* Menu mobile */
.lve-mobile-menu {
  display: none;
  flex-direction: column;
  background: var(--lve-blanc);
  border-top: 1px solid var(--lve-border);
  padding: .75rem 1.5rem;
}
.lve-mobile-menu.open { display: flex; }
.lve-mobile-menu a {
  font-family: var(--lve-ff-body) !important;
  font-size: .9rem;
  font-weight: 500;
  color: var(--lve-muted) !important;
  text-decoration: none !important;
  padding: .6rem 0;
  border-bottom: 1px solid var(--lve-border);
}
.lve-mobile-menu a:last-child { border-bottom: none; }

/* =========================================================
   FOOTER
   ========================================================= */
#lve-footer {
  background: var(--lve-night);
  color: rgba(255,255,255,.5);
  padding: 3.5rem 0 1.5rem;
  border-top: 1px solid rgba(255,255,255,.06);
}

.lve-footer-grid {
  display: grid;
  grid-template-columns: 1.5fr repeat(3, 1fr);
  gap: 2.5rem;
  margin-bottom: 2.5rem;
}

.lve-footer-brand p {
  font-size: .82rem;
  line-height: 1.7;
  max-width: 220px;
  margin-top: .85rem;
  color: rgba(255,255,255,.45);
}

.lve-footer-col h4 {
  font-family: var(--lve-ff-title) !important;
  font-size: .75rem;
  font-weight: 800;
  color: #fff !important;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: .9rem;
}
.lve-footer-col a {
  display: block;
  font-size: .82rem;
  color: rgba(255,255,255,.42) !important;
  text-decoration: none !important;
  margin-bottom: .45rem;
  transition: color var(--lve-transition);
}
.lve-footer-col a:hover { color: var(--lve-cyan) !important; }

.lve-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 1.25rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: .5rem;
  font-size: .75rem;
  color: rgba(255,255,255,.22);
}
.lve-footer-bottom a {
  color: rgba(255,255,255,.3) !important;
  text-decoration: none !important;
  transition: color var(--lve-transition);
}
.lve-footer-bottom a:hover { color: var(--lve-cyan) !important; }
.lve-footer-links { display: flex; gap: 1.25rem; }

/* Logo footer (version claire sur fond sombre) */
#lve-footer .lve-logo-p1 { color: #fff !important; }
#lve-footer .lve-logo-p2 { color: var(--lve-cyan) !important; }
#lve-footer .lve-logo-tld { color: rgba(255,255,255,.2) !important; }
#lve-footer .lve-logo-tagline { color: rgba(255,255,255,.2) !important; }

/* =========================================================
   MASQUER LES ÉLÉMENTS GENERATEPRESS PAR DÉFAUT
   ========================================================= */
.site-header,
.main-navigation,
.site-footer,
.footer-widgets,
#colophon,
.site-info {
  display: none !important;
}

/* =========================================================
   BOUTONS
   ========================================================= */
.lve-btn {
  display: inline-block;
  font-family: var(--lve-ff-title) !important;
  font-weight: 700;
  font-size: .875rem;
  letter-spacing: .01em;
  padding: .75rem 1.5rem;
  border-radius: var(--lve-r-md);
  text-decoration: none !important;
  transition: all var(--lve-transition);
  cursor: pointer;
  border: none;
  line-height: 1;
}
.lve-btn-primary { background: var(--lve-night); color: #fff !important; }
.lve-btn-primary:hover { background: var(--lve-marine); box-shadow: 0 0 18px var(--lve-cyan-glow); transform: translateY(-1px); }
.lve-btn-cyan { background: var(--lve-blanc); color: #007A8C !important; border: 1px solid rgba(0,229,255,.5); box-shadow: 0 0 10px rgba(0,229,255,.14); }
.lve-btn-cyan:hover { border-color: var(--lve-cyan); box-shadow: 0 0 16px rgba(0,229,255,.3); transform: translateY(-1px); }
.lve-btn-pink { background: var(--lve-blanc); color: #B0004A !important; border: 1px solid rgba(255,0,128,.4); }
.lve-btn-pink:hover { border-color: var(--lve-pink); box-shadow: 0 0 16px var(--lve-pink-glow); transform: translateY(-1px); }
.lve-btn-cta { background: var(--lve-cyan); color: var(--lve-night) !important; box-shadow: 0 0 20px rgba(0,229,255,.55); }
.lve-btn-cta:hover { box-shadow: 0 0 32px rgba(0,229,255,.8); transform: translateY(-2px); }

/* =========================================================
   BADGES
   ========================================================= */
.lve-badge {
  display: inline-block;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 20px;
  border: 1px solid;
  white-space: nowrap;
}
.lve-b-cyan   { background:#F0FDFF; color:#007A8C; border-color:rgba(0,229,255,.45); box-shadow:0 0 7px rgba(0,229,255,.18); }
.lve-b-pink   { background:#FFF0F7; color:#B0004A; border-color:rgba(255,0,128,.35); box-shadow:0 0 7px rgba(255,0,128,.14); }
.lve-b-green  { background:#F0FFF8; color:#006B3A; border-color:rgba(0,255,148,.45); box-shadow:0 0 7px rgba(0,255,148,.18); }
.lve-b-yellow { background:#FFFBE0; color:#7A7A00; border-color:rgba(245,255,80,.55); box-shadow:0 0 7px rgba(245,255,80,.2); }
.lve-b-pale   { background:#FFF5FB; color:#8A2060; border-color:rgba(255,133,200,.45); }
.lve-b-gray   { background:var(--lve-fond); color:var(--lve-muted); border-color:var(--lve-border); }

/* =========================================================
   SECTIONS
   ========================================================= */
.lve-section        { padding: 4.5rem 0; }
.lve-section--blanc { background: var(--lve-blanc); }
.lve-section--fond  { background: var(--lve-fond); }
.lve-section--dark  { background: var(--lve-night); }

.lve-section-label {
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: 1.1px;
  text-transform: uppercase;
  color: var(--lve-muted);
  margin-bottom: .4rem;
}
.lve-section-title {
  font-family: var(--lve-ff-title) !important;
  font-size: clamp(1.5rem, 3vw, 2.1rem);
  font-weight: 700;
  color: var(--lve-night) !important;
  line-height: 1.3;
  margin-bottom: .4rem;
}
.lve-section-sub {
  font-size: .95rem;
  color: var(--lve-muted);
  max-width: 560px;
  line-height: 1.7;
}
.lve-neon-bar { width: 44px; height: 3px; border-radius: 2px; margin: .6rem 0 1.5rem; }
.lve-nb-cyan   { background:var(--lve-cyan);  box-shadow:0 0 8px var(--lve-cyan-glow); }
.lve-nb-pink   { background:var(--lve-pink);  box-shadow:0 0 8px var(--lve-pink-glow); }
.lve-nb-green  { background:var(--lve-green); box-shadow:0 0 8px var(--lve-green-glow); }
.lve-nb-yellow { background:var(--lve-yellow);box-shadow:0 0 8px var(--lve-yellow-glow); }

/* Accents de couleur dans les titres */
.lve-accent-cyan   { color:var(--lve-cyan)  !important; text-shadow:0 0 14px var(--lve-cyan-glow); }
.lve-accent-pink   { color:var(--lve-pink)  !important; text-shadow:0 0 14px var(--lve-pink-glow); }
.lve-accent-green  { color:#00CC76          !important; text-shadow:0 0 12px var(--lve-green-glow); }
.lve-accent-yellow { color:#8A8A00          !important; }

/* =========================================================
   HERO
   ========================================================= */
.lve-hero {
  background: var(--lve-blanc);
  padding: 5rem 0 4rem;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--lve-border);
}
.lve-hero::before {
  content: '';
  position: absolute;
  top: -120px; right: -120px;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: var(--lve-cyan-soft);
  pointer-events: none;
}
.lve-hero::after {
  content: '';
  position: absolute;
  bottom: -100px; left: -60px;
  width: 320px; height: 320px;
  border-radius: 50%;
  background: rgba(255,0,128,.05);
  pointer-events: none;
}
.lve-hero-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 3rem;
  align-items: center;
  position: relative;
  z-index: 1;
}
.lve-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #F0FDFF;
  border: 1px solid rgba(0,229,255,.5);
  padding: 5px 14px;
  border-radius: 20px;
  margin-bottom: 1.5rem;
  box-shadow: 0 0 10px rgba(0,229,255,.18);
  animation: lve-fadeup .6s ease both;
}
.lve-hero-badge-dot {
  width: 7px; height: 7px;
  background: var(--lve-cyan);
  border-radius: 50%;
  box-shadow: 0 0 6px var(--lve-cyan);
  animation: lve-pulse 2s ease-in-out infinite;
}
.lve-hero-badge span {
  font-size: .68rem;
  font-weight: 500;
  color: #007A8C;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.lve-hero h1 {
  font-size: clamp(2rem, 4.5vw, 3.2rem) !important;
  font-weight: 800 !important;
  line-height: 1.22 !important;
  letter-spacing: 0 !important;
  margin-bottom: 1.25rem !important;
  animation: lve-fadeup .6s .1s ease both;
}
.lve-hero-sub {
  font-size: 1rem;
  color: var(--lve-muted);
  max-width: 520px;
  line-height: 1.75;
  margin-bottom: 2.25rem;
  animation: lve-fadeup .6s .2s ease both;
}
.lve-hero-actions {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  animation: lve-fadeup .6s .3s ease both;
}
.lve-hero-visual { flex-shrink: 0; opacity: .85; }

/* =========================================================
   CARDS DOMAINES
   ========================================================= */
.lve-grid-domaines {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 1rem;
}
.lve-card-domaine {
  background: var(--lve-blanc);
  border: 1px solid var(--lve-border);
  border-radius: var(--lve-r-lg);
  padding: 1.35rem 1.25rem;
  text-decoration: none !important;
  transition: transform var(--lve-transition), box-shadow var(--lve-transition), border-color var(--lve-transition);
  display: block;
  position: relative;
  overflow: hidden;
}
.lve-card-domaine::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  border-radius: var(--lve-r-lg) var(--lve-r-lg) 0 0;
  opacity: 0;
  transition: opacity var(--lve-transition);
}
.lve-card-domaine:hover { transform: translateY(-3px); }
.lve-card-domaine:hover::before { opacity: 1; }
.lve-card-domaine:hover { border-color: rgba(0,229,255,.35); }
.lve-cd-cyan::before   { background:var(--lve-cyan);     box-shadow:0 0 8px var(--lve-cyan-glow); }
.lve-cd-pink::before   { background:var(--lve-pink);     box-shadow:0 0 8px var(--lve-pink-glow); }
.lve-cd-green::before  { background:var(--lve-green);    box-shadow:0 0 8px var(--lve-green-glow); }
.lve-cd-yellow::before { background:var(--lve-yellow);   box-shadow:0 0 8px var(--lve-yellow-glow); }
.lve-cd-pale::before   { background:var(--lve-pink-pale);box-shadow:0 0 8px rgba(255,133,200,.4); }
.lve-card-domaine-icon { font-size: 1.5rem; margin-bottom: .85rem; display: block; }
.lve-card-domaine-title {
  font-family: var(--lve-ff-title) !important;
  font-size: .95rem;
  font-weight: 700;
  color: var(--lve-night) !important;
  line-height: 1.35;
  margin-bottom: .3rem;
}
.lve-card-domaine-sub { font-size: .75rem; color: var(--lve-muted); line-height: 1.5; }
.lve-card-domaine-more {
  display: flex; align-items: center; justify-content: center;
  background: var(--lve-fond);
  border: 1px dashed rgba(15,27,45,.15);
  border-radius: var(--lve-r-lg);
  padding: 1.35rem 1.25rem;
  color: #007A8C !important;
  font-family: var(--lve-ff-title) !important;
  font-size: .85rem;
  font-weight: 700;
  text-decoration: none !important;
  text-align: center;
  transition: background var(--lve-transition), border-color var(--lve-transition);
}
.lve-card-domaine-more:hover { background: #F0FDFF; border-color: rgba(0,229,255,.3); }

/* =========================================================
   CARDS ARTICLES
   ========================================================= */
.lve-grid-articles {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.25rem;
}
.lve-card-article {
  background: var(--lve-blanc);
  border-radius: var(--lve-r-lg);
  overflow: hidden;
  border: 1px solid var(--lve-border);
  transition: transform var(--lve-transition), box-shadow var(--lve-transition);
  display: flex;
  flex-direction: column;
}
.lve-card-article:hover { transform: translateY(-3px); }
.lve-card-article.lve-glow-cyan:hover  { box-shadow:0 0 20px rgba(0,229,255,.2); border-color:rgba(0,229,255,.35); }
.lve-card-article.lve-glow-pink:hover  { box-shadow:0 0 20px rgba(255,0,128,.18); border-color:rgba(255,0,128,.3); }
.lve-card-article.lve-glow-green:hover { box-shadow:0 0 20px rgba(0,255,148,.18); border-color:rgba(0,255,148,.3); }
.lve-card-article-bar { height: 5px; flex-shrink: 0; }
.lve-cab-cyan   { background:var(--lve-cyan);  box-shadow:0 0 8px var(--lve-cyan-glow); }
.lve-cab-pink   { background:var(--lve-pink);  box-shadow:0 0 8px var(--lve-pink-glow); }
.lve-cab-green  { background:var(--lve-green); box-shadow:0 0 8px var(--lve-green-glow); }
.lve-cab-yellow { background:var(--lve-yellow);box-shadow:0 0 8px var(--lve-yellow-glow); }
.lve-card-article-body { padding: 1.25rem; flex: 1; display: flex; flex-direction: column; }
.lve-card-article-title {
  font-family: var(--lve-ff-title) !important;
  font-size: .95rem;
  font-weight: 700;
  color: var(--lve-night) !important;
  line-height: 1.4;
  margin: .6rem 0 .5rem;
  text-decoration: none !important;
  display: block;
}
.lve-card-article-title:hover { color: #007A8C !important; }
.lve-card-article-excerpt { font-size: .82rem; color: var(--lve-muted); line-height: 1.65; flex: 1; margin-bottom: 1rem; }
.lve-card-article-meta { display:flex; justify-content:space-between; align-items:center; border-top:1px solid var(--lve-border); padding-top:.75rem; }
.lve-card-article-date { font-size:.72rem; color:rgba(83,96,112,.6); }
.lve-read-more { font-family:var(--lve-ff-title)!important; font-size:.75rem; font-weight:700; letter-spacing:.04em; text-decoration:none!important; transition:text-shadow var(--lve-transition); }
.lve-read-more:hover { text-shadow: 0 0 8px currentColor; }
.lve-rm-cyan   { color:var(--lve-cyan)!important; }
.lve-rm-pink   { color:var(--lve-pink)!important; }
.lve-rm-green  { color:#00CC76!important; }

/* =========================================================
   STRIP CONSEILS
   ========================================================= */
.lve-strip { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1rem; }
.lve-strip-item {
  background: var(--lve-blanc);
  border: 1px solid var(--lve-border);
  border-radius: var(--lve-r-lg);
  padding: 1.25rem;
  text-decoration: none !important;
  display: flex;
  flex-direction: column;
  gap: .4rem;
  transition: transform var(--lve-transition), box-shadow var(--lve-transition);
}
.lve-strip-item:hover { transform: translateY(-2px); }
.lve-strip-item.lve-s-cyan:hover   { box-shadow:0 0 16px rgba(0,229,255,.2); border-color:rgba(0,229,255,.3); }
.lve-strip-item.lve-s-green:hover  { box-shadow:0 0 16px rgba(0,255,148,.18); border-color:rgba(0,255,148,.28); }
.lve-strip-item.lve-s-yellow:hover { box-shadow:0 0 16px rgba(245,255,80,.2); border-color:rgba(245,255,80,.4); }
.lve-strip-item.lve-s-pink:hover   { box-shadow:0 0 16px rgba(255,0,128,.15); border-color:rgba(255,0,128,.28); }
.lve-strip-item-emoji { font-size: 1.4rem; }
.lve-strip-item-title { font-family:var(--lve-ff-title)!important; font-size:.9rem; font-weight:700; color:var(--lve-night)!important; line-height:1.35; }
.lve-strip-item-sub { font-size:.75rem; color:var(--lve-muted); line-height:1.5; }

/* =========================================================
   TÉMOIGNAGES
   ========================================================= */
.lve-grid-temos { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.25rem; }
.lve-card-temo {
  background: var(--lve-blanc);
  border: 1px solid var(--lve-border);
  border-radius: var(--lve-r-lg);
  padding: 1.5rem;
  position: relative;
}
.lve-card-temo::before {
  content: '\201C';
  font-family: var(--lve-ff-title);
  font-size: 3.5rem;
  line-height: 1;
  position: absolute;
  top: .6rem; left: 1rem;
  color: var(--lve-cyan);
  opacity: .14;
  pointer-events: none;
}
.lve-card-temo-text  { font-style:italic; font-size:.9rem; color:var(--lve-night); line-height:1.7; margin-bottom:1rem; padding-top:.8rem; }
.lve-card-temo-name  { font-weight:700; font-size:.85rem; color:var(--lve-night); }
.lve-card-temo-meta  { font-size:.75rem; color:var(--lve-muted); margin-top:2px; }

/* =========================================================
   CTA BAND
   ========================================================= */
.lve-cta-band {
  background: var(--lve-night);
  padding: 4rem 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.lve-cta-band::before {
  content: '';
  position: absolute;
  top: -60px; left: 50%; transform: translateX(-50%);
  width: 600px; height: 300px;
  border-radius: 50%;
  background: var(--lve-cyan-soft);
  pointer-events: none;
}
.lve-cta-band h2 { font-size:clamp(1.6rem,3vw,2.2rem)!important; font-weight:700!important; color:#fff!important; line-height:1.3!important; margin-bottom:.75rem; position:relative; }
.lve-cta-band p  { color:rgba(255,255,255,.6); max-width:520px; margin:0 auto 2rem; line-height:1.7; font-size:.95rem; position:relative; }

/* =========================================================
   BREADCRUMB
   ========================================================= */
.lve-breadcrumb { padding: .85rem 0; border-bottom: 1px solid var(--lve-border); background: var(--lve-blanc); }
.lve-breadcrumb-inner { display:flex; align-items:center; gap:.4rem; font-size:.78rem; color:var(--lve-muted); }
.lve-breadcrumb-inner a { color:var(--lve-muted)!important; text-decoration:none!important; transition:color var(--lve-transition); }
.lve-breadcrumb-inner a:hover { color:#007A8C!important; }
.lve-breadcrumb-inner .sep { opacity:.35; }
.lve-breadcrumb-inner .current { color:var(--lve-night); font-weight:600; }

/* =========================================================
   PAGE HERO (pages intérieures)
   ========================================================= */
.lve-page-hero {
  background: var(--lve-blanc);
  padding: 3.5rem 0 3rem;
  border-bottom: 1px solid var(--lve-border);
  position: relative;
  overflow: hidden;
}
.lve-page-hero::before {
  content: '';
  position: absolute;
  top: -80px; right: -80px;
  width: 380px; height: 380px;
  border-radius: 50%;
  background: var(--lve-cyan-soft);
  pointer-events: none;
}
.lve-page-hero h1 { font-size:clamp(1.8rem,4vw,2.8rem)!important; font-weight:800!important; line-height:1.22!important; margin-bottom:.85rem; position:relative; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 900px) {
  .lve-footer-grid { grid-template-columns: 1fr 1fr; }
  .lve-hero-inner { grid-template-columns: 1fr; }
  .lve-hero-visual { display: none; }
}
@media (max-width: 640px) {
  .lve-nav { display: none; }
  .lve-hamburger { display: flex; }
  .lve-section { padding: 2.75rem 0; }
  .lve-hero { padding: 3rem 0 2.5rem; }
  .lve-grid-domaines { grid-template-columns: repeat(2, 1fr); }
  .lve-grid-articles { grid-template-columns: 1fr; }
  .lve-strip { grid-template-columns: 1fr; }
  .lve-footer-grid { grid-template-columns: 1fr; gap: 1.5rem; }
}
