/*
 * site.css — Thème public News-Rim (inspiration cridem : dense, 3 colonnes)
 * EMPLACEMENT : public_html/assets/css/site.css  | CHMOD 644
 * Identité : rouge #c8102e, vert #006233. Fond beige clair, lisible mobile.
 */
:root{
  --rouge:#c8102e; --vert:#006233; --rouge-fonce:#a00d25;
  --beige:#fdfcf7; --beige-card:#fbf8ef; --bord:#e7e2d4;
  --texte:#1c1c1c; --texte-doux:#5c5c5c; --lien:#0a5ca8;
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:17px}
body{
  font-family:Georgia,'Times New Roman',serif;
  background:var(--beige); color:var(--texte); line-height:1.55;
}
a{color:var(--lien);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}

/* ---- En-tête ---- */
.site-header{background:#fff;border-bottom:3px solid var(--rouge)}
.header-top{max-width:1200px;margin:0 auto;padding:14px 16px;display:flex;
  align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.site-logo{font-family:Arial,sans-serif;font-size:2rem;font-weight:800;color:var(--rouge)}
.site-logo span{color:var(--vert)}
.site-date{font-family:Arial,sans-serif;font-size:.85rem;color:var(--texte-doux)}

/* ---- Menu catégories ---- */
.site-nav{background:var(--vert)}
.site-nav ul{max-width:1200px;margin:0 auto;padding:0 8px;display:flex;
  flex-wrap:wrap;list-style:none}
.site-nav a{display:block;color:#fff;font-family:Arial,sans-serif;font-size:.9rem;
  font-weight:600;padding:11px 16px;text-decoration:none}
.site-nav a:hover{background:rgba(0,0,0,.18);text-decoration:none}

/* ---- Grille 3 colonnes ---- */
.layout{max-width:1200px;margin:18px auto;padding:0 16px;
  display:grid;grid-template-columns:230px 1fr 280px;gap:22px;align-items:start}
.col-left, .col-right{display:flex;flex-direction:column;gap:18px}

/* ---- Widgets latéraux ---- */
.widget{background:var(--beige-card);border:1px solid var(--bord);border-radius:6px;overflow:hidden}
.widget-title{background:var(--rouge);color:#fff;font-family:Arial,sans-serif;
  font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:8px 12px}
.widget-body{padding:12px}
.widget-body ol{margin:0;padding-left:1.1rem}
.widget-body li{margin-bottom:9px;font-size:.95rem;line-height:1.4}
.ad-slot{background:#eee;border:1px dashed #bbb;text-align:center;color:#999;
  font-family:Arial,sans-serif;font-size:.8rem;padding:40px 10px}

/* ---- Flux central ---- */
.feed-title{font-family:Arial,sans-serif;font-size:1rem;color:var(--vert);
  border-bottom:2px solid var(--vert);padding-bottom:6px;margin-bottom:14px;
  text-transform:uppercase;letter-spacing:.5px}
.article-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--bord)}
.article-item:last-child{border-bottom:0}
.article-thumb{flex-shrink:0;width:140px;height:96px;border-radius:6px;overflow:hidden;
  background:linear-gradient(135deg,#e7e2d4,#d8d2c0);position:relative;
  box-shadow:0 1px 3px rgba(0,0,0,.08)}
.article-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.article-item:hover .article-thumb img{transform:scale(1.05)}
.article-item{transition:background .2s}
.article-item:hover{background:rgba(0,0,0,.015)}
.article-body{flex:1;min-width:0}
.article-cat{font-family:Arial,sans-serif;font-size:.72rem;font-weight:700;
  text-transform:uppercase;color:var(--rouge);letter-spacing:.5px}
.article-title{font-size:1.18rem;font-weight:700;line-height:1.3;margin:3px 0 5px;color:var(--texte)}
.article-title a{color:inherit}
.article-title a:hover{color:var(--rouge);text-decoration:none}
.article-excerpt{font-size:.98rem;color:var(--texte-doux);line-height:1.5}
.article-meta{font-family:Arial,sans-serif;font-size:.78rem;color:#888;margin-top:6px}

/* ---- Page article ---- */
.single{background:#fff;border:1px solid var(--bord);border-radius:6px;padding:26px}
.single h1{font-size:2rem;line-height:1.25;color:var(--texte);margin-bottom:10px}
.single .single-meta{font-family:Arial,sans-serif;font-size:.85rem;color:#888;
  border-bottom:1px solid var(--bord);padding-bottom:14px;margin-bottom:18px}
.single .single-hero{margin:0 0 18px;border-radius:6px;overflow:hidden}
.single-content{font-size:1.12rem;line-height:1.75}
.single-content p{margin:0 0 1.1rem}
.single-content h2{font-size:1.5rem;color:var(--vert);margin:1.6rem 0 .8rem}
.single-content h3{font-size:1.25rem;color:var(--vert);margin:1.4rem 0 .6rem}
.single-content blockquote{border-left:4px solid var(--rouge);background:var(--beige-card);
  padding:12px 18px;margin:1.2rem 0;font-style:italic;color:#444}
.single-content img{border-radius:6px;margin:1rem 0}
.single-content a{color:var(--lien)}

/* ---- Pied ---- */
.site-footer{background:#1c1c1c;color:#cfcfcf;margin-top:30px;
  font-family:Arial,sans-serif;font-size:.85rem}
.footer-inner{max-width:1200px;margin:0 auto;padding:26px 16px;text-align:center}
.footer-inner .logo{font-size:1.4rem;font-weight:800;color:#fff;margin-bottom:8px}
.footer-inner .logo span{color:#6fcf97}

/* ---- Responsive ---- */
@media(max-width:980px){
  .layout{grid-template-columns:1fr 280px}
  .col-left{display:none}            /* on masque la colonne gauche sur tablette */
}
@media(max-width:720px){
  html{font-size:16px}
  .layout{grid-template-columns:1fr;gap:16px}
  .col-right{order:3}
  .article-thumb{width:100px;height:72px}
  .article-title{font-size:1.1rem}
  .single{padding:18px}
  .single h1{font-size:1.6rem}
}
/* ============================================================
   ÉCRAN DE CHARGEMENT PREMIUM
   ============================================================ */
#nr-loader{
  position:fixed;inset:0;z-index:99999;
  background:linear-gradient(135deg,#fff 0%,var(--beige) 100%);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .5s ease, visibility .5s ease;
}
#nr-loader.nr-loaded{opacity:0;visibility:hidden}
.nr-loader-inner{display:flex;flex-direction:column;align-items:center;gap:22px;
  animation:nr-pop .6s cubic-bezier(.2,.8,.2,1)}
.nr-loader-logo{max-height:80px;width:auto;animation:nr-pulse 1.4s ease-in-out infinite}
.nr-loader-text{font-family:Arial,sans-serif;font-size:2.6rem;font-weight:800;color:var(--rouge);
  animation:nr-pulse 1.4s ease-in-out infinite}
.nr-loader-text span{color:var(--vert)}
.nr-loader-bar{width:160px;height:4px;background:rgba(0,0,0,.08);border-radius:4px;overflow:hidden}
.nr-loader-bar span{display:block;height:100%;width:40%;border-radius:4px;
  background:linear-gradient(90deg,var(--rouge),var(--vert));
  animation:nr-slide 1.1s ease-in-out infinite}
@keyframes nr-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.06);opacity:.85}}
@keyframes nr-pop{0%{transform:scale(.8);opacity:0}100%{transform:scale(1);opacity:1}}
@keyframes nr-slide{0%{transform:translateX(-100%)}100%{transform:translateX(350%)}}

/* ============================================================
   MENU MOBILE MODERNE (hamburger)
   ============================================================ */
.nr-burger{display:none;background:none;border:0;cursor:pointer;padding:14px 16px;
  flex-direction:column;gap:5px}
.nr-burger span{display:block;width:26px;height:3px;background:#fff;border-radius:3px;
  transition:transform .3s ease, opacity .3s ease}
.nr-burger.nr-active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nr-burger.nr-active span:nth-child(2){opacity:0}
.nr-burger.nr-active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

@media(max-width:720px){
  .site-nav{position:relative}
  .nr-burger{display:flex}
  .site-nav ul{
    display:none;flex-direction:column;width:100%;
    background:var(--vert);
  }
  .site-nav ul.nr-open{display:flex;animation:nr-menu-down .25s ease}
  .site-nav ul li{width:100%;border-top:1px solid rgba(255,255,255,.12)}
  .site-nav a{padding:14px 20px;font-size:1rem}
  @keyframes nr-menu-down{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
}
/* ===== ÉCRAN DE CHARGEMENT PREMIUM ===== */
#nr-loader{position:fixed;inset:0;z-index:99999;
  background:linear-gradient(135deg,#fff 0%,#fdfcf7 100%);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .5s ease, visibility .5s ease}
#nr-loader.nr-loaded{opacity:0;visibility:hidden}
.nr-loader-inner{display:flex;flex-direction:column;align-items:center;gap:22px;
  animation:nr-pop .6s cubic-bezier(.2,.8,.2,1)}
.nr-loader-logo{max-height:80px;width:auto;animation:nr-pulse 1.4s ease-in-out infinite}
.nr-loader-text{font-family:Arial,sans-serif;font-size:2.6rem;font-weight:800;color:#c8102e;
  animation:nr-pulse 1.4s ease-in-out infinite}
.nr-loader-text span{color:#006233}
.nr-loader-bar{width:160px;height:4px;background:rgba(0,0,0,.08);border-radius:4px;overflow:hidden}
.nr-loader-bar span{display:block;height:100%;width:40%;border-radius:4px;
  background:linear-gradient(90deg,#c8102e,#006233);
  animation:nr-slide 1.1s ease-in-out infinite}
@keyframes nr-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.06);opacity:.85}}
@keyframes nr-pop{0%{transform:scale(.8);opacity:0}100%{transform:scale(1);opacity:1}}
@keyframes nr-slide{0%{transform:translateX(-100%)}100%{transform:translateX(350%)}}

/* ===== MENU MOBILE MODERNE (hamburger) ===== */
.nr-burger{display:none;background:none;border:0;cursor:pointer;padding:14px 16px;
  flex-direction:column;gap:5px}
.nr-burger span{display:block;width:26px;height:3px;background:#fff;border-radius:3px;
  transition:transform .3s ease, opacity .3s ease}
.nr-burger.nr-active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nr-burger.nr-active span:nth-child(2){opacity:0}
.nr-burger.nr-active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(max-width:720px){
  .site-nav{position:relative}
  .nr-burger{display:flex}
  .site-nav ul{display:none;flex-direction:column;width:100%;background:#006233}
  .site-nav ul.nr-open{display:flex;animation:nr-menu-down .25s ease}
  .site-nav ul li{width:100%;border-top:1px solid rgba(255,255,255,.12)}
  .site-nav a{padding:14px 20px;font-size:1rem}
  @keyframes nr-menu-down{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
}

/* ===== LOADER PREMIUM ===== */
#nr-loader{position:fixed;inset:0;z-index:99999;background:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .5s ease,visibility .5s ease}
#nr-loader.nr-loaded{opacity:0;visibility:hidden;pointer-events:none}
.nr-loader-inner{display:flex;flex-direction:column;align-items:center;gap:20px;
  animation:nr-pop .5s cubic-bezier(.2,.8,.2,1) both}
.nr-loader-logo{max-height:70px;width:auto;animation:nr-pulse 1.4s ease-in-out infinite}
.nr-loader-text{font-family:Arial,sans-serif;font-size:2.4rem;font-weight:800;
  color:#c8102e;animation:nr-pulse 1.4s ease-in-out infinite}
.nr-loader-text span{color:#006233}
.nr-loader-bar{width:140px;height:4px;background:rgba(0,0,0,.08);border-radius:4px;overflow:hidden}
.nr-loader-bar span{display:block;height:100%;width:35%;border-radius:4px;
  background:linear-gradient(90deg,#c8102e,#006233);
  animation:nr-slide 1s ease-in-out infinite}
@keyframes nr-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}
@keyframes nr-pop{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
@keyframes nr-slide{0%{transform:translateX(-120%)}100%{transform:translateX(400%)}}

/* ===== MENU MOBILE HAMBURGER ===== */
.nr-burger{display:none;flex-direction:column;justify-content:center;gap:5px;
  background:none;border:0;cursor:pointer;padding:12px 16px;min-height:44px}
.nr-burger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;
  transition:transform .28s ease,opacity .28s ease,width .28s ease}
.nr-burger.nr-active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nr-burger.nr-active span:nth-child(2){opacity:0;width:0}
.nr-burger.nr-active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:720px){
  .nr-burger{display:flex}
  .site-nav ul{display:none;flex-direction:column;width:100%;
    background:#006233;border-top:1px solid rgba(255,255,255,.1)}
  .site-nav ul.nr-open{display:flex;animation:nr-slide-down .22s ease}
  .site-nav ul li{width:100%;border-bottom:1px solid rgba(255,255,255,.08)}
  .site-nav ul li:last-child{border-bottom:0}
  .site-nav a{padding:13px 20px;font-size:.95rem;width:100%;display:block}
  .site-nav a:hover{background:rgba(0,0,0,.15);text-decoration:none}
  @keyframes nr-slide-down{from{opacity:0;transform:translateY(-6px)}
    to{opacity:1;transform:translateY(0)}}
  /* Cache la colonne gauche sur mobile */
  .col-left{display:none !important}
}