:root{
  --creme:#FAF7F2;--blanc:#FFFFFF;--fond-alt:#F4F0EA;
  --rouge:#C8321A;--rouge-hover:#E8472C;--or:#D4922A;
  --vert:#3A7D44;--bleu:#2563A8;--violet:#7C3AED;
  --texte:#1C1A17;--texte2:#5A5650;--texte3:#9A9490;
  --bordure:#E8E0D4;--shadow:0 2px 16px rgba(0,0,0,.08);
  --r:10px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--creme);color:var(--texte);font-family:'Source Sans 3',sans-serif;font-size:16px;line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit}
input,textarea,select{font-family:inherit}

/* TICKER */
.ticker{background:var(--rouge);color:#fff;padding:9px 0;overflow:hidden;white-space:nowrap}
.ticker-inner{display:inline-flex;animation:ticker 32s linear infinite}
.ticker-inner:hover{animation-play-state:paused}
.ticker-item{padding:0 32px;font-family:'DM Mono',monospace;font-size:.78rem;letter-spacing:.5px}
.ticker-item::after{content:'•';margin-left:32px;opacity:.5}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* HEADER */
.header{position:sticky;top:0;z-index:200;background:#fff;border-bottom:1px solid var(--bordure);box-shadow:0 1px 8px rgba(0,0,0,.06)}
.header-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:68px;display:flex;align-items:center;gap:32px}
.logo{display:flex;flex-direction:column;line-height:1;flex-shrink:0}
.logo-main{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700}
.logo-main span{color:var(--rouge)}
.logo-sub{font-family:'DM Mono',monospace;font-size:.6rem;letter-spacing:2px;color:var(--texte3);text-transform:uppercase}
.nav{display:flex;gap:4px;flex:1;justify-content:center}
.nav a{padding:7px 14px;border-radius:6px;font-size:.88rem;font-weight:500;color:var(--texte2);transition:all .2s}
.nav a:hover,.nav a.active{background:rgba(200,50,26,.08);color:var(--rouge)}
.header-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:8px;font-size:.85rem;font-weight:600;border:none;transition:all .2s}
.btn-primary{background:var(--rouge);color:#fff}
.btn-primary:hover{background:var(--rouge-hover);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--texte2);border:1.5px solid var(--bordure)}
.btn-secondary:hover{border-color:var(--rouge);color:var(--rouge)}
.btn-sm{padding:6px 14px;font-size:.8rem}

/* MAIN */
.main{max-width:1200px;margin:0 auto;padding:0 24px}

/* HERO */
.hero{padding:48px 0 56px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero-rubrique{display:inline-flex;align-items:center;gap:8px;margin-bottom:16px}
.dot-live{width:8px;height:8px;border-radius:50%;background:var(--rouge);animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.rubrique-label{font-family:'DM Mono',monospace;font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--rouge)}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:900;line-height:1.15;margin-bottom:16px;color:var(--texte)}
.hero-lead{font-size:1.05rem;font-weight:300;color:var(--texte2);margin-bottom:24px;line-height:1.7}
.hero-meta{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}
.meta-author{font-size:.85rem;font-weight:600}
.meta-sep{color:var(--bordure)}
.meta-date{font-family:'DM Mono',monospace;font-size:.75rem;color:var(--texte3)}
.hero-img-wrap{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform 7s ease}
.hero-img-wrap:hover img{transform:scale(1.03)}
.hero-img-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(200,50,26,.15),transparent)}
.hero-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px}
.hero-card{background:#fff;border-radius:8px;padding:18px;border:1px solid var(--bordure);position:relative;overflow:hidden;transition:all .25s}
.hero-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.hero-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--rouge);transform:scaleX(0);transition:transform .3s}
.hero-card:hover::after{transform:scaleX(1)}

/* SECTION */
.section{padding:56px 0}
.section-alt{background:var(--fond-alt)}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}
.section-title{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700}
.voir-tout{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--rouge);transition:gap .2s}
.voir-tout:hover{gap:10px}

/* CARDS ARTICLES */
.articles-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:24px}
.card{background:#fff;border-radius:var(--r);overflow:hidden;border:1px solid var(--bordure);transition:all .25s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card-img{overflow:hidden}
.card-img img{width:100%;object-fit:cover;transition:transform .6s ease,filter .3s}
.card:hover .card-img img{transform:scale(1.04);filter:saturate(1.2)}
.card-body{padding:20px}
.card-big .card-img img{height:260px}
.card-med .card-img img{height:160px}
.pill{display:inline-block;font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:1.5px;text-transform:uppercase;padding:3px 10px;border-radius:20px;margin-bottom:10px;font-weight:500}
.pill-rouge{background:rgba(200,50,26,.1);color:var(--rouge)}
.pill-or{background:rgba(212,146,42,.1);color:var(--or)}
.pill-vert{background:rgba(58,125,68,.1);color:var(--vert)}
.pill-bleu{background:rgba(37,99,168,.1);color:var(--bleu)}
.pill-violet{background:rgba(124,58,237,.1);color:var(--violet)}
.card-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;line-height:1.35;margin-bottom:8px}
.card-excerpt{font-size:.88rem;color:var(--texte2);line-height:1.6;margin-bottom:14px}
.card-meta{font-family:'DM Mono',monospace;font-size:.7rem;color:var(--texte3)}

/* MINI LISTE */
.mini-list{display:flex;flex-direction:column;gap:0}
.mini-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--bordure);transition:background .2s;border-radius:6px;padding:12px}
.mini-item:hover{background:rgba(200,50,26,.04)}
.mini-img{width:88px;height:72px;border-radius:6px;object-fit:cover;flex-shrink:0}
.mini-title{font-size:.9rem;font-weight:600;line-height:1.4;margin-bottom:4px}
.mini-date{font-family:'DM Mono',monospace;font-size:.7rem;color:var(--texte3)}

/* VIDÉOS */
.videos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.video-card{border-radius:var(--r);overflow:hidden;background:#000;position:relative}
.video-thumb{position:relative;aspect-ratio:16/9;overflow:hidden}
.video-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s,filter .3s}
.video-card:hover .video-thumb img{transform:scale(1.05);filter:saturate(1.3)}
.video-overlay{position:absolute;inset:0;background:rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;transition:background .3s}
.video-card:hover .video-overlay{background:rgba(200,50,26,.4)}
.play-circle{width:52px;height:52px;background:rgba(255,255,255,.95);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .3s}
.video-card:hover .play-circle{transform:scale(1.12)}
.play-icon{width:0;height:0;border-style:solid;border-width:9px 0 9px 18px;border-color:transparent transparent transparent var(--rouge);margin-left:3px}
.video-duration{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.75);color:#fff;font-family:'DM Mono',monospace;font-size:.68rem;padding:2px 7px;border-radius:4px}
.video-info{padding:14px;background:#fff}
.video-type{font-family:'DM Mono',monospace;font-size:.68rem;color:var(--rouge);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.video-title{font-size:.92rem;font-weight:700;line-height:1.35}

/* AGENDA */
.agenda-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.event-card{background:#fff;border-radius:var(--r);padding:20px;display:flex;gap:18px;border:1px solid var(--bordure);border-left:4px solid var(--rouge);transition:all .25s}
.event-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.event-card.or{border-left-color:var(--or)}
.event-card.vert{border-left-color:var(--vert)}
.event-card.bleu{border-left-color:var(--bleu)}
.event-date{text-align:center;min-width:52px}
.event-day{font-family:'Playfair Display',serif;font-size:2rem;font-weight:700;line-height:1;color:var(--rouge)}
.event-card.or .event-day{color:var(--or)}
.event-card.vert .event-day{color:var(--vert)}
.event-card.bleu .event-day{color:var(--bleu)}
.event-month{font-family:'DM Mono',monospace;font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:var(--texte3)}
.event-title{font-weight:700;margin-bottom:4px}
.event-desc{font-size:.85rem;color:var(--texte2);margin-bottom:6px}
.event-lieu{font-size:.82rem;color:var(--texte3)}

/* ANNUAIRE */
.filtres{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.filtre-btn{padding:8px 20px;border-radius:24px;border:1.5px solid var(--bordure);background:#fff;font-size:.85rem;font-weight:600;color:var(--texte2);transition:all .2s}
.filtre-btn:hover,.filtre-btn.actif{background:var(--rouge);border-color:var(--rouge);color:#fff}
.annuaire-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.biz-card{background:#fff;border-radius:var(--r);padding:20px;border:1px solid var(--bordure);border-top:3px solid var(--rouge);transition:all .25s}
.biz-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.biz-emoji{font-size:2rem;margin-bottom:10px}
.biz-cat{font-family:'DM Mono',monospace;font-size:.62rem;letter-spacing:1px;text-transform:uppercase;color:var(--texte3);margin-bottom:6px}
.biz-name{font-weight:700;margin-bottom:6px}
.biz-desc{font-size:.83rem;color:var(--texte2);margin-bottom:12px;line-height:1.5}
.biz-badge{display:inline-block;font-size:.72rem;padding:3px 10px;border-radius:20px;background:rgba(58,125,68,.1);color:var(--vert)}

/* STATS */
.stats-band{background:var(--rouge);color:#fff;padding:48px 0}
.stats-grid{max-width:1200px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{text-align:center;padding:16px;border-right:1px solid rgba(255,255,255,.2)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:'Playfair Display',serif;font-size:3.5rem;font-weight:700;line-height:1;display:block}
.stat-label{font-size:.85rem;opacity:.75;margin-top:6px;font-weight:300}

/* NEWSLETTER */
.newsletter-wrap{max-width:640px;margin:0 auto;text-align:center;padding:48px 0}
.newsletter-emoji{font-size:3rem;display:block;margin-bottom:16px;animation:bounce-soft 3s ease-in-out infinite}
@keyframes bounce-soft{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.newsletter-title{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700;margin-bottom:12px}
.newsletter-title em{font-style:italic;color:var(--rouge)}
.newsletter-desc{color:var(--texte2);font-weight:300;margin-bottom:28px}
.newsletter-form{display:flex;gap:0;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px rgba(200,50,26,.15)}
.newsletter-form input{flex:1;padding:14px 20px;border:none;outline:none;font-size:.95rem}
.newsletter-form button{padding:14px 24px;background:var(--rouge);color:#fff;border:none;font-weight:600}
.newsletter-form button:hover{background:var(--rouge-hover)}
.newsletter-note{font-size:.78rem;color:var(--texte3);margin-top:12px}

/* FOOTER */
footer{background:var(--texte);color:#8A8278;padding:56px 0 32px}
.footer-inner{max-width:1200px;margin:0 auto;padding:0 24px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand .logo-main{color:#fff}
.footer-tagline{font-size:.85rem;margin-top:8px;line-height:1.6}
.footer-social{display:flex;gap:10px;margin-top:16px}
.social-btn{width:36px;height:36px;background:rgba(255,255,255,.08);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:background .2s}
.social-btn:hover{background:var(--rouge)}
.footer-col h4{color:#fff;font-size:.85rem;letter-spacing:1px;text-transform:uppercase;font-family:'DM Mono',monospace;margin-bottom:16px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:.88rem;transition:color .2s;display:flex;align-items:center;gap:6px}
.footer-links a::before{content:'—';opacity:0;transition:opacity .2s;color:var(--rouge);font-size:.7rem}
.footer-links a:hover{color:#fff}
.footer-links a:hover::before{opacity:1}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:.78rem}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:.78rem;transition:color .2s}
.footer-legal a:hover{color:#fff}

/* REVEAL */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible{opacity:1;transform:none}
.d1{transition-delay:.05s}.d2{transition-delay:.15s}.d3{transition-delay:.25s}.d4{transition-delay:.35s}.d5{transition-delay:.45s}

/* AUTH MODAL */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:var(--r);padding:40px;width:100%;max-width:440px;position:relative}
.modal h2{font-family:'Playfair Display',serif;font-size:1.6rem;margin-bottom:8px}
.modal-sub{color:var(--texte2);font-size:.9rem;margin-bottom:28px}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:1.3rem;color:var(--texte3);cursor:pointer}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:.82rem;font-weight:600;margin-bottom:6px;color:var(--texte)}
.form-input{width:100%;padding:11px 14px;border:1.5px solid var(--bordure);border-radius:8px;font-size:.95rem;outline:none;transition:border .2s}
.form-input:focus{border-color:var(--rouge)}
.form-error{color:var(--rouge);font-size:.8rem;margin-top:4px;display:none}
.modal-switch{text-align:center;margin-top:16px;font-size:.88rem;color:var(--texte2)}
.modal-switch a{color:var(--rouge);font-weight:600}

/* COMPTE PAGE */
.compte-grid{display:grid;grid-template-columns:260px 1fr;gap:32px;padding:40px 0}
.sidebar-nav{background:#fff;border-radius:var(--r);border:1px solid var(--bordure);padding:24px;height:fit-content}
.sidebar-user{text-align:center;padding-bottom:20px;border-bottom:1px solid var(--bordure);margin-bottom:16px}
.sidebar-avatar{width:72px;height:72px;border-radius:50%;background:var(--rouge);color:#fff;font-size:1.8rem;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.sidebar-name{font-weight:700;margin-bottom:2px}
.sidebar-role{font-family:'DM Mono',monospace;font-size:.65rem;letter-spacing:1px;text-transform:uppercase;color:var(--texte3)}
.sidebar-links{display:flex;flex-direction:column;gap:4px}
.sidebar-link{padding:10px 12px;border-radius:6px;font-size:.9rem;color:var(--texte2);transition:all .2s;display:flex;align-items:center;gap:8px}
.sidebar-link:hover,.sidebar-link.active{background:rgba(200,50,26,.08);color:var(--rouge)}
.compte-content{min-height:400px}
.tab-content{display:none}
.tab-content.active{display:block}
.page-title{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;margin-bottom:6px}
.page-sub{color:var(--texte2);font-size:.9rem;margin-bottom:28px}

/* ANNONCE CARD */
.annonce-card{background:#fff;border-radius:var(--r);border:1px solid var(--bordure);padding:20px;margin-bottom:16px;display:flex;gap:16px;align-items:flex-start}
.annonce-status{font-family:'DM Mono',monospace;font-size:.65rem;padding:3px 10px;border-radius:20px;letter-spacing:1px;text-transform:uppercase;flex-shrink:0}
.status-pending{background:rgba(212,146,42,.1);color:var(--or)}
.status-approved{background:rgba(58,125,68,.1);color:var(--vert)}
.status-rejected{background:rgba(200,50,26,.1);color:var(--rouge)}
.annonce-title{font-weight:700;margin-bottom:4px}
.annonce-meta{font-size:.82rem;color:var(--texte2)}

/* ADMIN */
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px}
.admin-stat{background:#fff;border-radius:var(--r);border:1px solid var(--bordure);padding:20px;border-top:3px solid var(--rouge);text-align:center}
.admin-stat-n{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:700;color:var(--rouge)}
.admin-stat-l{font-size:.82rem;color:var(--texte2);margin-top:4px}
.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--r);overflow:hidden;border:1px solid var(--bordure)}
.admin-table th{background:var(--fond-alt);padding:12px 16px;font-size:.8rem;font-weight:600;text-align:left;font-family:'DM Mono',monospace;letter-spacing:.5px;text-transform:uppercase;color:var(--texte2)}
.admin-table td{padding:12px 16px;border-bottom:1px solid var(--bordure);font-size:.88rem}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--fond-alt)}
.action-btn{padding:4px 12px;border-radius:6px;border:none;font-size:.75rem;font-weight:600;cursor:pointer;margin-right:4px}
.btn-approve{background:rgba(58,125,68,.1);color:var(--vert)}
.btn-reject{background:rgba(200,50,26,.1);color:var(--rouge)}
.btn-approve:hover{background:var(--vert);color:#fff}
.btn-reject:hover{background:var(--rouge);color:#fff}

/* TOAST */
.toast{position:fixed;bottom:24px;right:24px;background:var(--texte);color:#fff;padding:12px 20px;border-radius:8px;font-size:.88rem;z-index:999;transform:translateY(80px);opacity:0;transition:all .3s;max-width:320px}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{background:#2d6a4f}
.toast.error{background:var(--rouge)}

/* RESPONSIVE */
@media(max-width:1100px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-img-wrap{aspect-ratio:16/9;max-height:340px}
  .articles-grid{grid-template-columns:1fr 1fr}
  .card-big{grid-column:span 2}
  .videos-grid{grid-template-columns:1fr 1fr}
  .annuaire-grid{grid-template-columns:1fr 1fr}
  .agenda-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .nav{display:none}
  .admin-stats{grid-template-columns:1fr 1fr}
  .compte-grid{grid-template-columns:1fr}
}
@media(max-width:700px){
  .articles-grid,.videos-grid{grid-template-columns:1fr}
  .card-big{grid-column:auto}
  .hero-cards{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .newsletter-form{flex-direction:column;border-radius:12px;box-shadow:none;gap:8px}
  .newsletter-form input,.newsletter-form button{border-radius:8px!important}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .main{padding:0 16px}
  .admin-stats{grid-template-columns:1fr 1fr}
  .admin-table{font-size:.78rem}
}

.sondage-widget{background:#fff;border:1px solid var(--bordure);border-radius:10px;padding:28px;max-width:520px;margin:0 auto}
.sondage-question{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;margin-bottom:20px;color:var(--texte)}
.sondage-opt{margin-bottom:10px}
.sondage-opt button{width:100%;text-align:left;padding:12px 16px;background:var(--fond-alt);border:1.5px solid var(--bordure);border-radius:8px;font-size:.92rem;cursor:pointer;transition:all .2s}
.sondage-opt button:hover{border-color:var(--rouge);background:rgba(200,50,26,.06)}
.sondage-bar{margin-top:6px;background:var(--fond-alt);border-radius:20px;overflow:hidden;height:8px}
.sondage-fill{height:100%;background:var(--rouge);border-radius:20px;transition:width .8s ease}
.sondage-meta{font-size:.78rem;color:var(--texte3);margin-top:4px;font-family:'DM Mono',monospace}
.sondage-voted .sondage-opt button{cursor:default;border-color:var(--bordure)}
.sondage-winner button{border-color:var(--rouge)!important;background:rgba(200,50,26,.08)!important;font-weight:700}
/* ══════════════════════════════════════
   FIXES MOBILE — overflow + header + nav
══════════════════════════════════════ */

/* Empêcher le débordement horizontal global */
html, body {
  overflow-x: hidden !important;
  max-width: 100vw !important;
}
* { box-sizing: border-box; }

/* Header mobile propre */
.header-inner {
  padding: 0 16px;
  flex-wrap: nowrap;
  overflow: hidden;
}

/* Masquer la nav desktop sur mobile */
@media(max-width: 860px) {
  .nav { display: none !important; }

  .header-inner {
    height: 58px;
    gap: 12px;
    justify-content: space-between;
  }

  /* Logo plus petit sur mobile */
  .logo-main { font-size: 1.2rem; }
  .logo-sub { font-size: .52rem; }

  /* Header right compact */
  .header-right {
    gap: 6px;
    flex-shrink: 0;
  }

  /* Boutons header plus petits */
  .btn-sm { padding: 6px 10px; font-size: .75rem; }
  #user-name { max-width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

  /* Menu hamburger */
  .hamburger {
    display: flex !important;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 4px;
    background: none;
    border: none;
  }
  .hamburger span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--texte);
    border-radius: 2px;
    transition: all .3s;
  }

  /* Menu mobile déroulant */
  .nav-mobile {
    position: fixed;
    top: 58px;
    left: 0;
    right: 0;
    background: #fff;
    border-bottom: 2px solid var(--rouge);
    z-index: 199;
    padding: 8px 0;
    display: none;
    flex-direction: column;
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
  }
  .nav-mobile.open { display: flex !important; }
  .nav-mobile a {
    padding: 13px 20px;
    font-size: .95rem;
    font-weight: 600;
    color: var(--texte2);
    border-bottom: 1px solid var(--bordure);
    transition: all .2s;
  }
  .nav-mobile a:hover, .nav-mobile a.active { color: var(--rouge); background: rgba(200,50,26,.04); }

  /* Main padding mobile */
  .main { padding: 0 14px !important; }

  /* Hero mobile */
  .hero { padding: 28px 0 36px; }
  .hero-grid { grid-template-columns: 1fr !important; gap: 20px; }
  .hero-img-wrap { aspect-ratio: 16/9; max-height: 220px; }
  .hero h1 { font-size: 1.8rem; }
  .hero-lead { font-size: .92rem; }
  .hero-cards { grid-template-columns: 1fr !important; gap: 10px; }

  /* Articles grid mobile */
  .articles-grid { grid-template-columns: 1fr !important; }
  .card-big { grid-column: auto !important; }
  .card-big .card-img img { height: 200px; }
  .card-med .card-img img { height: 160px; }

  /* Videos grid mobile */
  .videos-grid { grid-template-columns: 1fr !important; }

  /* Agenda mobile */
  .agenda-grid { grid-template-columns: 1fr !important; }

  /* Annuaire mobile */
  .annuaire-grid { grid-template-columns: 1fr 1fr !important; }

  /* Stats mobile */
  .stats-grid { grid-template-columns: 1fr 1fr !important; }
  .stat-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,.15); }
  .stat-num { font-size: 2.5rem; }

  /* Newsletter mobile */
  .newsletter-form { flex-direction: column; border-radius: 10px; gap: 8px; box-shadow: none; }
  .newsletter-form input, .newsletter-form button { border-radius: 8px !important; padding: 13px 16px; }

  /* Footer mobile */
  .footer-grid { grid-template-columns: 1fr !important; gap: 28px; }
  .footer-bottom { flex-direction: column; text-align: center; gap: 10px; }
  .footer-legal { flex-wrap: wrap; justify-content: center; gap: 12px; }

  /* Admin mobile */
  .admin-stats { grid-template-columns: 1fr 1fr !important; }
  .admin-table { font-size: .75rem; }
  .admin-table th, .admin-table td { padding: 8px 10px; }
  .compte-grid { grid-template-columns: 1fr !important; }

  /* Compte sidebar mobile */
  .sidebar-nav { margin-bottom: 20px; }
}

@media(max-width: 480px) {
  .annuaire-grid { grid-template-columns: 1fr !important; }
  .admin-stats { grid-template-columns: 1fr !important; }
  .stats-grid { grid-template-columns: 1fr 1fr !important; }
  .filtres { gap: 6px; }
  .filtre-btn { padding: 6px 14px; font-size: .78rem; }
}

/* Ticker mobile */
@media(max-width: 860px) {
  .ticker-item { font-size: .72rem; padding: 0 20px; }
}

/* Hamburger caché sur desktop */
.hamburger { display: none; }

/* ══ BOUTON RETOUR EN HAUT ══ */
#back-to-top {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 44px;
  height: 44px;
  background: var(--rouge);
  color: #fff;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(200,50,26,.4);
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s, transform .3s;
  z-index: 100;
}
#back-to-top.visible {
  opacity: 1;
  pointer-events: auto;
}
#back-to-top:hover { transform: translateY(-3px); }

/* ══ BANNIÈRE ADMIN ══ */
.site-banniere {
  background: var(--rouge);
  color: #fff;
  text-align: center;
  padding: 10px 20px;
  font-size: .88rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.site-banniere.or { background: var(--or); }
.site-banniere.vert { background: var(--vert); }
.site-banniere.bleu { background: var(--bleu); }
.banniere-close {
  background: none;
  border: none;
  color: rgba(255,255,255,.7);
  cursor: pointer;
  font-size: 1rem;
  margin-left: 8px;
}

/* ══ SKELETON LOADING ══ */
.skeleton {
  background: linear-gradient(90deg, #f0ebe3 25%, #e8e0d4 50%, #f0ebe3 75%);
  background-size: 200% 100%;
  animation: skeleton-loading 1.5s infinite;
  border-radius: 6px;
}
@keyframes skeleton-loading {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.skeleton-card {
  background: #fff;
  border: 1px solid var(--bordure);
  border-radius: 10px;
  overflow: hidden;
}
.skeleton-img { height: 180px; }
.skeleton-body { padding: 16px; }
.skeleton-line { height: 14px; margin-bottom: 10px; }
.skeleton-line.short { width: 60%; }

/* ══ BARRE RECHERCHE HEADER ══ */
.search-bar {
  position: relative;
  max-width: 260px;
}
.search-bar input {
  width: 100%;
  padding: 7px 36px 7px 12px;
  border: 1.5px solid var(--bordure);
  border-radius: 20px;
  font-size: .83rem;
  background: var(--fond-alt);
  color: var(--texte);
  transition: border-color .2s, width .3s;
  font-family: Source Sans 3, sans-serif;
}
.search-bar input:focus {
  outline: none;
  border-color: var(--rouge);
  background: #fff;
}
.search-bar button {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--texte3);
  font-size: .9rem;
}
@media(max-width:860px) { .search-bar { display: none; } }

/* ══ PWA ══ */
#pwa-install {
  display: none;
  position: fixed;
  bottom: 80px;
  right: 20px;
  background: #fff;
  border: 1px solid var(--bordure);
  border-radius: 12px;
  padding: 14px 16px;
  box-shadow: 0 8px 24px rgba(0,0,0,.12);
  z-index: 99;
  max-width: 280px;
  font-size: .85rem;
}
#pwa-install.show { display: flex; gap: 10px; align-items: center; flex-direction: column; }
