/*
Theme Name: Santé Avis
Version: 3.0
Theme URI: https://www.santeavis.com
Author: Santé Avis
Text Domain: santeavis
Author URI: https://www.santeavis.com
License: GNU General Public License version 3.0
License URI: http://www.gnu.org/licenses/gpl-3.0.html
*/

/* ============================================================
   Variables
   ============================================================ */
:root{
  --burg:       #7a1628;
  --burg-dk:    #5c1020;
  --burg-lt:    #9b2035;
  --gold:       #c9923a;
  --gold-lt:    #e0ac55;
  --ink:        #1c1c1e;
  --ink-mid:    #3a3a3c;
  --ink-soft:   #6b6b6e;
  --cream:      #faf8f4;
  --cream-dk:   #f0ece3;
  --white:      #ffffff;
  --rule:       #e0dbd0;
  --rule-dk:    #c8c2b8;
  --r-sm:       2px;
  --r-md:       6px;
  --r-lg:       12px;
  --sh-card:    0 1px 3px rgba(0,0,0,.07),0 4px 16px rgba(0,0,0,.05);
  --sh-hover:   0 4px 14px rgba(0,0,0,.11),0 14px 44px rgba(0,0,0,.09);
  --ease:       .22s cubic-bezier(.4,0,.2,1);
  --fw:         1200px;
  --sw:         300px;
  --fd:         'Cormorant Garamond','Georgia',serif;
  --fu:         'DM Sans','Helvetica Neue',sans-serif;
  /* Heights used for mobile nav positioning (Issue #1 fix) */
  --topbar-h:   28px;
  --header-h:   66px;
}

/* ============================================================
   Reset
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:var(--fu);font-size:1rem;line-height:1.7;color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
iframe,object,embed{max-width:100%} /* prevent injected ad iframes from overflowing */
a{color:inherit;text-decoration:none;transition:color var(--ease)}
ul,ol{list-style:none}

/* ============================================================
   Typography
   ============================================================ */
h1,h2,h3,h4,h5,h6{font-family:var(--fd);line-height:1.18;font-weight:600;color:var(--ink);letter-spacing:-.01em;font-feature-settings:"swsh" 0,"cswh" 0,"calt" 0}
h1{font-size:clamp(2rem,4vw,3.2rem);font-weight:700}
h2{font-size:clamp(1.5rem,2.5vw,2.2rem)}
h3{font-size:clamp(1.15rem,2vw,1.55rem)}
p{margin-bottom:1.2em}
p:last-child{margin-bottom:0}

/* ============================================================
   Layout
   ============================================================ */
.container{width:100%;max-width:var(--fw);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.site-wrapper{display:flex;flex-direction:column;min-height:100vh}
.main-content{flex:1;padding-block:3rem}

/* ============================================================
   TOP BAR
   ============================================================ */
.top-bar{background:var(--burg-dk);color:rgba(255,255,255,.82);font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;padding-block:.42rem}
.top-bar-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.top-bar a{color:rgba(255,255,255,.72);transition:color var(--ease)}
.top-bar a:hover{color:var(--gold-lt)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{background:var(--white);border-bottom:1px solid var(--rule);position:sticky;top:0;z-index:100;transition:box-shadow var(--ease)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:66px}
.site-branding{flex-shrink:0}
.site-title{font-family:var(--fd);font-size:1.75rem;font-weight:700;letter-spacing:-.025em;line-height:1;font-feature-settings:"swsh" 0,"cswh" 0,"calt" 0}
.site-title a{color:var(--ink)}
.site-title a:hover{color:var(--burg)}
.site-title .accent{color:var(--burg)}
.site-tagline{font-size:.68rem;color:var(--ink-soft);letter-spacing:.06em;text-transform:uppercase;margin-top:2px}

/* PRIMARY NAV — flat <a> tags, zero bullets */
.primary-nav{display:flex;align-items:center;gap:.15rem;list-style:none}
.primary-nav a{
  display:inline-block;
  font-size:.71rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-mid);padding:.45rem .65rem;border-radius:var(--r-sm);
  transition:background var(--ease),color var(--ease);
  white-space:nowrap;
  /* Ensure no list indicators from any parent */
  list-style:none;
}
.primary-nav a:hover,.primary-nav a[aria-current]{color:var(--burg);background:rgba(122,22,40,.07)}

/* If fallback or plugin still outputs <ul><li> — neutralise */
.primary-nav ul,.primary-nav li{list-style:none!important;padding:0;margin:0;display:contents}

/* Header utils */
/* Fix #2: .header-actions groups dark-toggle, search, and hamburger — always flush-right */
.header-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0}
.header-search-btn{background:none;border:none;cursor:pointer;padding:.4rem;color:var(--ink-mid);display:flex;align-items:center;border-radius:var(--r-md);transition:color var(--ease),background var(--ease)}
.header-search-btn:hover{color:var(--burg);background:rgba(122,22,40,.07)}
.header-search-btn svg{width:18px;height:18px}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.4rem;color:var(--ink);flex-direction:column;gap:5px}
.menu-toggle span{display:block;width:22px;height:2px;background:currentColor;border-radius:2px;transition:transform var(--ease),opacity var(--ease)}

/* ============================================================
   HERO
   ============================================================ */
.hero-section{background:var(--white);border-bottom:1px solid var(--rule);overflow:hidden}
.hero-article{display:grid;grid-template-columns:1fr 1fr;min-height:480px}
.hero-image-wrap{overflow:hidden;position:relative}
.hero-image-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .65s ease}
.hero-article:hover .hero-image-wrap img{transform:scale(1.04)}
.hero-cat-badge{position:absolute;top:1.4rem;left:1.4rem;background:var(--burg);color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;padding:.28rem .65rem;border-radius:var(--r-sm)}
.hero-content{display:flex;flex-direction:column;justify-content:center;padding:clamp(2rem,5vw,4rem);background:var(--white)}
.hero-eyebrow{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}
.hero-eyebrow::before{content:'';display:block;width:32px;height:2px;background:var(--gold)}
.hero-eyebrow .label{font-family:var(--fu);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--burg)}
.hero-content h1{font-size:clamp(1.8rem,3.2vw,2.7rem);font-weight:700;line-height:1.11;margin-bottom:1.25rem}
.hero-content h1 a{background-image:linear-gradient(var(--burg),var(--burg));background-size:0 1px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .3s,color .2s}
.hero-content h1 a:hover{background-size:100% 1px;color:var(--burg)}
.hero-excerpt{font-size:1.04rem;line-height:1.65;color:var(--ink-mid);margin-bottom:2rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hero-meta{display:flex;align-items:center;gap:1rem;font-size:.78rem;color:var(--ink-soft)}
.hero-meta .author{font-weight:600;color:var(--ink-mid)}
.hero-meta .sep{color:var(--rule-dk)}

/* ============================================================
   ARTICLES LAYOUT
   ============================================================ */
.articles-layout{display:grid;grid-template-columns:1fr var(--sw);gap:3rem;align-items:start}
.articles-feed{display:grid;gap:1.75rem}

/* CARD */
.article-card{background:var(--white);border-radius:var(--r-lg);overflow:hidden;display:grid;grid-template-columns:200px 1fr;box-shadow:var(--sh-card);border:1px solid var(--rule);transition:box-shadow var(--ease),transform var(--ease),border-color var(--ease);align-items:stretch}
.article-card:hover{box-shadow:var(--sh-hover);transform:translateY(-2px);border-color:var(--rule-dk)}
/* Image fills full card height — no wasted space */
.card-image{overflow:hidden;position:relative;min-height:150px}
.card-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.article-card:hover .card-image img{transform:scale(1.06)}
/* Category badge — always visible, bottom of image */
.card-cat{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(90,10,20,.82));color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.75rem .7rem .35rem;display:flex;align-items:flex-end;gap:.4rem;z-index:1}
.card-cat-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-cat-dot{opacity:.6;font-size:.7rem;flex-shrink:0}
.card-cat-date{opacity:.85;font-weight:400;letter-spacing:.04em;text-transform:none;white-space:nowrap;flex-shrink:0}
.card-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;justify-content:center}
.card-body h2{font-size:clamp(1rem,1.7vw,1.22rem);font-weight:600;line-height:1.3;margin-bottom:.6rem}
.card-body h2 a:hover{color:var(--burg)}
.card-excerpt{font-size:.88rem;color:var(--ink-soft);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.9rem}
.read-more{display:inline-flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:700;color:var(--burg);letter-spacing:.06em;text-transform:uppercase;margin-top:auto}
.read-more::after{content:'→';transition:transform var(--ease)}
.read-more:hover::after{transform:translateX(4px)}

/* SECTION HEADER */
.section-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.65rem}
.section-header h2{font-family:var(--fd);font-size:1.25rem;font-weight:700;white-space:nowrap}
.section-header::after{content:'';flex:1;height:1px;background:var(--rule)}

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar{position:sticky;top:80px;display:flex;flex-direction:column;gap:1.75rem}
.sidebar-widget{background:var(--white);border-radius:var(--r-lg);padding:1.6rem;box-shadow:var(--sh-card);border:1px solid var(--rule)}
.widget-title{font-family:var(--fd);font-size:1.05rem;font-weight:700;padding-bottom:.8rem;margin-bottom:1rem;border-bottom:2px solid var(--burg);display:flex;align-items:center;gap:.45rem}
.widget-title::before{content:'';display:inline-block;width:5px;height:5px;background:var(--gold);border-radius:50%}
.tag-cloud{display:flex;flex-wrap:wrap;gap:.4rem}
.tag-cloud a{font-size:.7rem;font-weight:600;color:var(--ink-mid);background:var(--cream);border:1px solid var(--rule);padding:.22rem .62rem;border-radius:50px;transition:background var(--ease),color var(--ease),border-color var(--ease)}
.tag-cloud a:hover{background:var(--burg);color:#fff;border-color:var(--burg)}
.recent-posts-list{display:flex;flex-direction:column;gap:.8rem}
.recent-post-item{display:grid;grid-template-columns:60px 1fr;gap:.75rem;align-items:center}
.recent-thumb{width:60px;height:60px;border-radius:var(--r-md);overflow:hidden;flex-shrink:0}
.recent-thumb img{width:100%;height:100%;object-fit:cover;transition:transform var(--ease)}
.recent-post-item:hover .recent-thumb img{transform:scale(1.08)}
.recent-post-meta{font-size:.7rem;color:var(--ink-soft)}
.recent-post-title{font-size:.83rem;font-weight:600;line-height:1.3}
.recent-post-title a:hover{color:var(--burg)}

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination{display:flex;align-items:center;justify-content:center;gap:.45rem;margin-top:3rem;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding-inline:.6rem;border-radius:var(--r-md);font-size:.82rem;font-weight:600;color:var(--ink-mid);background:var(--white);border:1px solid var(--rule);transition:background var(--ease),color var(--ease),border-color var(--ease)}
.pagination .page-numbers:hover,.pagination .current{background:var(--burg);color:#fff;border-color:var(--burg)}

/* ============================================================
   SINGLE POST
   ============================================================ */
.single-layout{display:grid;grid-template-columns:1fr var(--sw);gap:3rem;align-items:start}
.article-header{margin-bottom:2.25rem}
.breadcrumb{display:flex;align-items:center;gap:.35rem;font-size:.7rem;color:var(--ink-soft);margin-bottom:1rem;flex-wrap:wrap}
.breadcrumb a{color:var(--burg);font-weight:600}
.breadcrumb .sep{color:var(--rule-dk)}
.cats{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1.1rem}
.cat-badge{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--burg);background:rgba(122,22,40,.08);padding:.2rem .55rem;border-radius:var(--r-sm);border:1px solid rgba(122,22,40,.18);transition:background var(--ease),color var(--ease)}
.cat-badge:hover{background:var(--burg);color:#fff}
.article-header h1{font-size:clamp(1.85rem,3.8vw,2.9rem);line-height:1.1;margin-bottom:1.2rem}
.article-meta{display:flex;align-items:center;gap:.9rem;font-size:.76rem;color:var(--ink-soft);padding-bottom:1.2rem;border-bottom:1px solid var(--rule);flex-wrap:wrap}
.meta-author{font-weight:700;color:var(--ink-mid)}
.article-featured-image{width:100%;border-radius:var(--r-lg);overflow:hidden;margin-bottom:2.5rem;box-shadow:var(--sh-card)}
.article-featured-image img{width:100%;max-height:520px;object-fit:cover}
.article-content{font-size:1.05rem;line-height:1.78;color:var(--ink-mid);overflow-wrap:break-word;word-break:break-word}
.article-content h2,.article-content h3,.article-content h4{color:var(--ink);margin-top:2.2em;margin-bottom:.8em}
.article-content h2{font-size:1.65rem}
.article-content h3{font-size:1.28rem;color:var(--burg)}
.article-content p{margin-bottom:1.4em}
.article-content a{color:var(--burg);text-decoration:underline;text-underline-offset:3px}
.article-content blockquote{border-left:3px solid var(--gold);padding:1rem 1.5rem;margin:2rem 0;background:var(--cream);border-radius:0 var(--r-md) var(--r-md) 0;font-family:var(--fd);font-size:1.15rem;font-style:italic;color:var(--ink)}
.article-content ul,.article-content ol{list-style:initial;padding-left:1.5rem;margin-bottom:1.4em}
.article-content li{margin-bottom:.4em}
.article-content img{border-radius:var(--r-md);margin:1.5em 0}
.article-content hr{border:none;border-top:1px solid var(--rule);margin:2em 0}

/* ── Tables inside article content ────────────────────────────
   The core fix: display:block + overflow-x:auto lets the table
   scroll horizontally on mobile instead of breaking the layout.
   All other properties preserve the visual table formatting.    */
.article-content table,
.article-content .wp-block-table table{
  display:block;               /* enables overflow-x scroll    */
  overflow-x:auto;             /* horizontal scroll on mobile  */
  -webkit-overflow-scrolling:touch;
  width:max-content;           /* table sizes to its content   */
  max-width:100%;              /* …but never wider than parent */
  border-collapse:collapse;
  font-size:.92rem;
  line-height:1.5;
  margin-bottom:1.4em;
}
/* Gutenberg block wrapper — also needs to scroll */
.article-content .wp-block-table,
.article-content figure.wp-block-table{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  max-width:100%;
  margin-bottom:1.4em;
}
.article-content th,
.article-content td{
  padding:.65rem .9rem;
  border:1px solid var(--rule);
  text-align:left;
  vertical-align:top;
  min-width:110px;  /* prevents cells from collapsing to zero  */
  word-break:break-word;
  overflow-wrap:break-word;
}
.article-content thead th{
  background:var(--cream-dk);
  font-weight:700;
  font-size:.82rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--ink);
}
.article-content tbody tr:nth-child(even){background:var(--cream)}

/* ── Code & preformatted text ──────────────────────────────── */
.article-content pre{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  background:var(--cream-dk);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  padding:1.1rem 1.25rem;
  font-size:.88rem;
  line-height:1.6;
  margin-bottom:1.4em;
  white-space:pre;
}
.article-content code{
  background:var(--cream-dk);
  border:1px solid var(--rule);
  border-radius:var(--r-sm);
  padding:.12em .35em;
  font-size:.88em;
}
.article-content pre code{
  background:none;
  border:none;
  padding:0;
  font-size:inherit;
}

/* ── Embedded media (iframes, video, etc.) ─────────────────── */
.article-content iframe,
.article-content video,
.article-content object,
.article-content embed{
  max-width:100%;
  height:auto;
}
.article-tags{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;margin-top:2.5rem;padding-top:1.75rem;border-top:1px solid var(--rule)}
.tags-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-right:.25rem}
.tag-pill{font-size:.7rem;color:var(--ink-mid);background:var(--cream);border:1px solid var(--rule);padding:.22rem .65rem;border-radius:50px;transition:all var(--ease)}
.tag-pill:hover{background:var(--burg);color:#fff;border-color:var(--burg)}

/* ============================================================
   SEARCH OVERLAY
   ============================================================ */
.search-overlay{display:none;position:fixed;inset:0;background:rgba(28,28,30,.88);z-index:999;align-items:flex-start;justify-content:center;padding-top:14vh;backdrop-filter:blur(5px)}
.search-overlay.active{display:flex}
.search-form-wrap{background:var(--white);border-radius:var(--r-lg);padding:2.25rem;width:90%;max-width:580px;box-shadow:0 28px 80px rgba(0,0,0,.28)}
.search-form-wrap label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.85rem}
.search-form-inner{display:flex;gap:.5rem}
.search-input{flex:1;padding:.85rem 1.1rem;border:2px solid var(--rule);border-radius:var(--r-md);font-family:var(--fu);font-size:1rem;color:var(--ink);outline:none;transition:border-color var(--ease);background:var(--cream)}
.search-input:focus{border-color:var(--burg);background:var(--white)}
.btn-search{padding:.85rem 1.4rem;background:var(--burg);color:#fff;border:none;border-radius:var(--r-md);font-family:var(--fu);font-size:.82rem;font-weight:700;cursor:pointer;transition:background var(--ease)}
.btn-search:hover{background:var(--burg-dk)}


/* ============================================================
   COOKIE CONSENT — all colors hardcoded, never inherits theme
   ============================================================ */
#sa-cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:#18181b;
  color:rgba(255,255,255,.9);
  padding:1.25rem 0;
  box-shadow:0 -4px 32px rgba(0,0,0,.4);
  transform:translateY(0);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
}
#sa-cookie-banner.sa-hidden{transform:translateY(110%)}
.cookie-inner{display:flex;align-items:center;gap:2rem;flex-wrap:wrap}
.cookie-text{flex:1;min-width:260px}
.cookie-text p{font-size:.84rem;line-height:1.6;color:rgba(255,255,255,.82);margin:0}
.cookie-text a{color:#e0ac55;text-decoration:underline;text-underline-offset:2px}
.cookie-text strong{color:#ffffff}
.cookie-actions{display:flex;gap:.6rem;flex-shrink:0;flex-wrap:wrap}
.btn-ca,.btn-cd,.btn-cp{
  padding:.6rem 1.2rem;border-radius:6px;
  font-family:var(--fu);font-size:.8rem;font-weight:700;
  cursor:pointer;border:none;
  transition:background .22s ease,transform .22s ease;
  letter-spacing:.04em;
}
.btn-ca{background:#7a1628;color:#fff}
.btn-ca:hover{background:#9b2035;transform:translateY(-1px)}
.btn-cd{background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.22)}
.btn-cd:hover{background:rgba(255,255,255,.2)}
.btn-cp{background:none;color:rgba(255,255,255,.5);font-size:.75rem;text-decoration:underline;padding:.6rem .5rem}
.btn-cp:hover{color:rgba(255,255,255,.85)}

/* Prefs overlay */
#sa-cookie-prefs{display:none;position:fixed;inset:0;z-index:10000;background:rgba(10,10,12,.88);backdrop-filter:blur(5px);align-items:center;justify-content:center}
#sa-cookie-prefs.active{display:flex}

/* Prefs modal — fully hardcoded for both light and dark */
.prefs-modal{
  background:#ffffff;color:#1c1c1e;
  border-radius:12px;padding:2.25rem;
  width:90%;max-width:500px;max-height:85vh;
  overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,.35);
}
.prefs-modal h2{font-size:1.3rem;font-weight:600;color:#1c1c1e;margin-bottom:.5rem}
.prefs-modal>p{font-size:.88rem;color:#6b6b6e;margin-bottom:1.5rem;line-height:1.6}
.prefs-modal>p a{color:#7a1628;text-decoration:underline}
.pref-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem 0;border-top:1px solid #e0dbd0}
.pref-row:last-of-type{border-bottom:1px solid #e0dbd0;margin-bottom:1.5rem}
.pref-info strong{font-size:.9rem;font-weight:600;color:#1c1c1e;display:block;margin-bottom:.2rem}
.pref-info span{font-size:.8rem;color:#6b6b6e;line-height:1.5}

/* Toggle switches */
.sa-toggle{position:relative;flex-shrink:0;width:42px;height:24px;margin-top:2px}
.sa-toggle input{opacity:0;width:0;height:0;position:absolute}
.sa-toggle-track{position:absolute;inset:0;background:#c8c2b8;border-radius:24px;cursor:pointer;transition:background .22s ease}
.sa-toggle-track::after{content:'';position:absolute;left:3px;top:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .22s ease;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.sa-toggle input:checked + .sa-toggle-track{background:#7a1628}
.sa-toggle input:checked + .sa-toggle-track::after{transform:translateX(18px)}
.sa-toggle input:disabled + .sa-toggle-track{opacity:.5;cursor:not-allowed}

/* Modal action buttons */
.prefs-modal-actions{display:flex;gap:.6rem;justify-content:flex-end}
.btn-ps{padding:.65rem 1.4rem;background:#7a1628;color:#fff;border:none;border-radius:6px;font-family:var(--fu);font-size:.82rem;font-weight:700;cursor:pointer;transition:background .22s ease}
.btn-ps:hover{background:#5c1020}
.btn-pc{padding:.65rem 1rem;background:none;color:#6b6b6e;border:1px solid #e0dbd0;border-radius:6px;font-family:var(--fu);font-size:.82rem;cursor:pointer;transition:background .22s ease}
.btn-pc:hover{background:#f7f4ee}

/* Dark mode: flip prefs modal to dark — all hardcoded */
[data-theme="dark"] .prefs-modal{
  background:#1e1e24;color:#e8e8ea;
  box-shadow:0 24px 80px rgba(0,0,0,.6);
}
[data-theme="dark"] .prefs-modal h2      {color:#f0f0f4}
[data-theme="dark"] .prefs-modal>p       {color:#8888a0}
[data-theme="dark"] .prefs-modal>p a     {color:#f05070}
[data-theme="dark"] .pref-row            {border-color:#2e2e3a}
[data-theme="dark"] .pref-row:last-of-type{border-color:#2e2e3a}
[data-theme="dark"] .pref-info strong    {color:#e8e8ea}
[data-theme="dark"] .pref-info span      {color:#78788a}
[data-theme="dark"] .sa-toggle-track     {background:#3e3e4e}
[data-theme="dark"] .btn-pc              {color:#8888a0;border-color:#2e2e3a;background:transparent}
[data-theme="dark"] .btn-pc:hover        {background:#28282e}



/* ============================================================
   FOOTER — minimal light bar
   ============================================================ */
.site-footer{background:var(--cream-dk);border-top:1px solid var(--rule);padding:1rem 0}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:.72rem;color:var(--ink-soft);flex-wrap:wrap}
.footer-bottom-links{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}
.footer-bottom-links a{color:var(--ink-soft);transition:color var(--ease)}
.footer-bottom-links a:hover{color:var(--burg)}
#sa-reopen-consent{color:var(--ink-soft);font-size:.72rem;cursor:pointer;background:none;border:none;font-family:var(--fu);transition:color var(--ease);padding:0}
#sa-reopen-consent:hover{color:var(--burg)}
.footer-bar{height:2px;background:linear-gradient(90deg,#2a0008,#7a1628,#c41e3a)}

/* ============================================================
   ARCHIVE / PAGE
   ============================================================ */
.archive-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:2px solid var(--burg)}
.archive-label{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--burg);margin-bottom:.45rem}
.archive-header h1{font-size:clamp(1.5rem,3vw,2.2rem)}
.archive-desc{color:var(--ink-soft);margin-top:.5rem;font-size:.95rem}

/* 404 */
.error-404-wrap{text-align:center;padding:6rem 1rem}
.error-404-wrap h1{font-size:clamp(4rem,12vw,8rem);color:var(--burg);opacity:.12;line-height:1;margin-bottom:1rem}
.error-404-wrap h2{margin-bottom:1rem}
.error-404-wrap p{color:var(--ink-soft);max-width:440px;margin-inline:auto;margin-bottom:2rem}
.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.8rem;background:var(--burg);color:#fff;border-radius:var(--r-md);font-weight:700;font-size:.84rem;letter-spacing:.05em;text-transform:uppercase;transition:background var(--ease),transform var(--ease)}
.btn-primary:hover{background:var(--burg-dk);color:#fff;transform:translateY(-2px)}

/* Scroll reveal — visible by default, JS adds entrance animation */
.sa-reveal{opacity:1;transform:none}
.sa-reveal.sa-animated{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease}
.sa-reveal.visible{opacity:1;transform:translateY(0)}

/* ============================================================
   WP Core
   ============================================================ */
.wp-caption{max-width:100%}
.wp-caption-text{font-size:.8rem;color:var(--ink-soft);text-align:center;margin-top:.5rem}
.screen-reader-text{clip:rect(1px,1px,1px,1px);position:absolute!important;height:1px;width:1px;overflow:hidden}
.alignleft{float:left;margin:0 1.5em 1em 0}
.alignright{float:right;margin:0 0 1em 1.5em}
.aligncenter{margin-inline:auto}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* ── Tablet landscape: sidebar stacks, hero adapts (Fix #3) ── */
@media(max-width:1024px){
  .articles-layout,.single-layout{grid-template-columns:1fr}
  .sidebar{position:static;display:flex;flex-direction:column;gap:1.25rem}
  /* Hero: keep two-col but tighten proportions so image doesn't squash */
  .hero-article{grid-template-columns:1fr 1.2fr;min-height:380px}
  .hero-content h1{font-size:clamp(1.6rem,3vw,2.2rem)}
}

/* ── Mid-range phones: typography breathing room (Fix #7) ── */
@media(max-width:600px){
  .hero-content h1{font-size:clamp(1.6rem,5vw,2rem)}
  .hero-excerpt{font-size:.96rem;-webkit-line-clamp:2}
}

/* ── Mobile (Fix #1 nav offset, Fix #2 menu-toggle, Fix #5 consolidation) ── */
@media(max-width:768px){
  /* Hero: full-width single column */
  .hero-article{grid-template-columns:1fr;min-height:auto}
  .hero-image-wrap{aspect-ratio:16/9}

  /* Cards: stack vertically */
  .article-card{grid-template-columns:1fr}
  /* Fix #6: aspect-ratio + @supports fallback for older mobile browsers */
  .card-image{aspect-ratio:16/9;min-height:unset}
  .card-image img{position:absolute;inset:0}

  /* Fix #1: Nav positioned below actual header bottom via CSS var.
     JS in theme.js overwrites top dynamically on open for even better accuracy. */
  .primary-nav{
    display:none;position:fixed;
    top:calc(var(--topbar-h) + var(--header-h)); /* ≈94px — accounts for top-bar */
    left:0;right:0;bottom:0;
    background:var(--white);
    flex-direction:column;align-items:flex-start;
    padding:1.5rem;gap:.2rem;
    border-top:1px solid var(--rule);
    overflow-y:auto;
    z-index:101; /* above header z-index:100 */
  }
  .primary-nav.open{display:flex}
  .primary-nav a{font-size:.85rem;width:100%;padding:.8rem 1rem}

  /* Fix #2: Show hamburger (it's now inside .header-actions alongside other toggles) */
  .menu-toggle{display:flex}

  /* Footer */
  .footer-bottom{flex-direction:column;text-align:center;gap:.75rem}
  .footer-bottom-links{justify-content:center;flex-wrap:wrap}

  /* Cookie banner */
  .cookie-inner{flex-direction:column;gap:1rem}
  .cookie-actions{width:100%;flex-wrap:wrap}

  /* Sidebar ad: too wide on mobile */
  .sa-box-wrap{display:none}

  /* Popular widget tighter */
  .popular-item{grid-template-columns:44px 1fr;gap:.55rem}
  .popular-thumb{width:44px;height:44px}
  .popular-title{font-size:.8rem}

  /* Search bar */
  .widget-search{padding:.85rem}
  .sidebar-search-input{font-size:.82rem}

  /* All ad placements: collapse to banner height.
     min-height:unset!important beats any inline min-height:Xpx from sa_ad().
     width:100%!important beats inline width:Xpx if still present.
     overflow:hidden clips iframe/img content that ignores the container width. */
  .sa-placement-wide,.sa-placement-strip,
  .sa-ad-728,.sa-ad-468{
    width:100%!important;
    max-width:100%!important;
    height:60px!important;
    min-height:unset!important;
    overflow:hidden!important;
  }
  .sa-placement-wrap,.sa-strip-wrap,.sa-ad-728,.sa-ad-468{padding:.5rem 0}
  /* Wrapper-level clip in case ad content still bleeds */
  .sa-placement-wrap,.sa-strip-wrap{overflow:hidden}

  /* Back to top */
  #sa-back-top{width:36px;height:36px;bottom:5rem;right:1rem}
  #sa-back-top svg{width:15px;height:15px}
}

/* Fix #6 — aspect-ratio @supports fallback */
@supports not (aspect-ratio: 16/9){
  @media(max-width:768px){
    .card-image{padding-top:56.25%;height:0}
    .card-image img{position:absolute;inset:0}
    .hero-image-wrap{padding-top:56.25%;height:0;position:relative}
    .hero-image-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
  }
}

/* ── Small phones ── */
@media(max-width:480px){
  .prefs-modal{padding:1.25rem}
  .btn-ca,.btn-cd{width:100%;text-align:center}
  /* Ticker: too cramped at this width */
  .ticker-wrap{display:none}
  /* Hero: tighter padding */
  .hero-content{padding:1.25rem}
  .hero-content h1{font-size:1.5rem;line-height:1.18}
  /* Card body: tighter */
  .card-body{padding:1rem 1.1rem}
  /* Article content */
  .article-content{font-size:.97rem}
  /* Article headings — scale down for narrow screens */
  .article-content h2{font-size:1.3rem}
  .article-content h3{font-size:1.1rem}
  /* Blockquote — reduce side padding so it doesn't crush text */
  .article-content blockquote{padding:.75rem 1rem;font-size:1rem}
  /* Tables — smaller text and tighter cells so more fits before scrolling */
  .article-content table{font-size:.8rem}
  .article-content th,.article-content td{padding:.45rem .6rem;min-width:80px}
  /* Article header title */
  .article-header h1{font-size:clamp(1.45rem,5.5vw,1.85rem)}
  /* In-article ads */
  .sa-article-mid-ad .sa-placement-strip,
  .sa-article-bottom-ad .sa-placement-wide{width:100%!important;height:60px!important}
  /* floated images: un-float so they don't crush text on tiny screens */
  .alignleft,.alignright{float:none;margin:1em 0;width:100%}
}

/* ============================================================
   NEWS TICKER (top bar — right side)
   ============================================================ */
.ticker-wrap{
  display:flex;
  align-items:center;
  gap:.65rem;
  overflow:hidden;
  max-width:600px;
  flex:1;
  min-width:0;
}

.ticker-pause-btn{
  flex-shrink:0;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  color:rgba(255,255,255,.85);
  width:22px;height:22px;
  border-radius:50%;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:.6rem;
  transition:background var(--ease);
  padding:0;
}
.ticker-pause-btn:hover{background:rgba(255,255,255,.22);}

.ticker{
  overflow:hidden;
  white-space:nowrap;
  flex:1;
  min-width:0;
}

.ticker-track{
  display:inline-flex;
  gap:0;
  animation:sa-ticker 90s linear infinite;
  will-change:transform;
}

.ticker-track.paused{animation-play-state:paused;}

@keyframes sa-ticker{
  0%  {transform:translateX(0);}
  100%{transform:translateX(-50%);}
}

.ticker-item{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding-inline:1.4rem;
  font-size:.67rem;
  font-weight:600;
  letter-spacing:.04em;
  color:rgba(255,255,255,.9);
  white-space:nowrap;
}

.ticker-item::before{
  content:'';
  display:inline-block;
  width:4px;height:4px;
  border-radius:50%;
  background:var(--gold-lt);
  flex-shrink:0;
}

.ticker-item a{
  color:rgba(255,255,255,.9);
  transition:color var(--ease);
}
.ticker-item a:hover{color:var(--gold-lt);}

.ticker-cat{
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--gold-lt);
  margin-right:.2rem;
}

/* ============================================================
   AD SLOTS
   ============================================================ */
/* Base */
.sa-ad{
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--cream-dk);
  border:1px dashed var(--rule-dk);
  border-radius:var(--r-md);
  overflow:hidden;
  position:relative;
  margin-inline:auto;
  font-family:var(--fu);
}

.sa-ad-label{
  position:absolute;
  top:4px;left:6px;
  font-size:.58rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-soft);
  opacity:.55;
}

/* 728×90 — Leaderboard */
.sa-ad-728{
  width:728px;
  max-width:100%;
  height:90px;
}

/* 468×60 — Banner */
.sa-ad-468{
  width:468px;
  max-width:100%;
  height:60px;
}

/* 300×250 — Medium Rectangle */
.sa-ad-300{
  width:300px;
  max-width:100%;
  height:250px;
}

/* Wrappers — overflow:hidden is critical: clips iframe/img ad content wider than viewport */
.ad-leaderboard-wrap{
  display:flex;
  justify-content:center;
  padding:1.25rem 0;
  border-bottom:1px solid var(--rule);
  background:var(--white);
  overflow:hidden;
  max-width:100%;
}

.ad-banner-wrap{
  display:flex;
  justify-content:center;
  padding:1rem 0;
  overflow:hidden;
  max-width:100%;
}

.ad-sidebar-wrap{
  display:flex;
  justify-content:center;
  overflow:hidden;
  max-width:100%;
}

.sa-placement-wrap,.sa-strip-wrap,.sa-box-wrap{
  overflow:hidden;
  max-width:100%;
}

/* Hide leaderboard on small screens — handled in consolidated @media(max-width:768px) block above */

/* ============================================================
   SIDEBAR SEARCH
   ============================================================ */
/* Search widget — standalone bar, no box shadow, no title */
.widget-search{
  background:none;
  border:none;
  box-shadow:none;
  padding:0;
}
.sidebar-search-form{display:flex;gap:.4rem;align-items:stretch}
.sidebar-search-input{
  flex:1;
  padding:.65rem 1rem;
  border:1.5px solid var(--rule);
  border-radius:var(--r-md);
  font-family:var(--fu);
  font-size:.88rem;
  color:var(--ink);
  background:var(--white);
  outline:none;
  transition:border-color var(--ease),box-shadow var(--ease);
  height:42px;
}
.sidebar-search-input:focus{
  border-color:var(--burg);
  box-shadow:0 0 0 3px rgba(122,22,40,.1);
}
.sidebar-search-input::placeholder{color:var(--ink-soft)}
.sidebar-search-btn{
  width:42px;
  height:42px;
  background:var(--burg);
  color:#fff;
  border:none;
  border-radius:var(--r-md);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  transition:background var(--ease);
}
.sidebar-search-btn:hover{background:var(--burg-dk)}
.sidebar-search-btn svg{width:16px;height:16px}

/* ── Articles populaires — thumbnails ── */
.popular-list{display:flex;flex-direction:column;gap:.85rem}
.popular-item{display:grid;grid-template-columns:60px 1fr;gap:.75rem;align-items:center}
.popular-thumb{
  width:60px;height:60px;
  border-radius:var(--r-md);
  overflow:hidden;
  flex-shrink:0;
  display:block;
  background:var(--cream-dk);
}
.popular-thumb img{width:100%;height:100%;object-fit:cover;transition:transform var(--ease)}
.popular-item:hover .popular-thumb img{transform:scale(1.08)}
.popular-info{}
.popular-cat{display:none}
.popular-title{font-size:.82rem;font-weight:600;line-height:1.3;color:var(--ink)}
.popular-title a:hover{color:var(--burg)}
.popular-date{font-size:.68rem;color:var(--ink-soft);margin-top:.15rem}

/* ============================================================
   DARK MODE — full variable override
   ============================================================ */
[data-theme="dark"] {
  --burg:     #e02040;
  --burg-dk:  #b8182e;
  --burg-lt:  #f03050;
  --gold:     #e0ac55;
  --gold-lt:  #f0c070;
  --ink:      #e8e8ea;
  --ink-mid:  #b4b4b8;
  --ink-soft: #78787e;
  --cream:    #0e0e10;
  --cream-dk: #18181c;
  --white:    #1c1c20;
  --rule:     #2c2c32;
  --rule-dk:  #3c3c44;
}

[data-theme="dark"] body { background: var(--cream); }

[data-theme="dark"] .site-header,
[data-theme="dark"] .hero-section,
[data-theme="dark"] .article-card,
[data-theme="dark"] .sidebar-widget,
[data-theme="dark"] .search-form-wrap {
  background: var(--white);
  border-color: var(--rule);
}

/* Popular widget dark mode text */
[data-theme="dark"] .popular-title a { color: #e0e0e4; }
[data-theme="dark"] .popular-title a:hover { color: #f05070; }
[data-theme="dark"] .popular-date { color: #78788a; }
[data-theme="dark"] .widget-title { color: #e8e8ea; border-bottom-color: #e02040; }
[data-theme="dark"] .widget-title::before { background: #e0ac55; }
[data-theme="dark"] .popular-cat { color: #f05070; }




[data-theme="dark"] .top-bar { background: #0a0a0c; }

[data-theme="dark"] .hero-content { background: var(--white); }

[data-theme="dark"] .article-content blockquote { background: var(--cream-dk); }

/* Article tables — dark mode */
[data-theme="dark"] .article-content th,
[data-theme="dark"] .article-content td { border-color: var(--rule); }
[data-theme="dark"] .article-content thead th { background: var(--cream-dk); color: var(--ink); }
[data-theme="dark"] .article-content tbody tr:nth-child(even) { background: var(--cream-dk); }
/* Code blocks — dark mode */
[data-theme="dark"] .article-content pre,
[data-theme="dark"] .article-content code { background: var(--cream-dk); border-color: var(--rule); color: var(--ink); }

[data-theme="dark"] .tag-cloud a,
[data-theme="dark"] .tag-pill { background: var(--cream-dk); border-color: var(--rule); }

[data-theme="dark"] .pagination .page-numbers {
  background: var(--white);
  border-color: var(--rule);
  color: var(--ink-mid);
}

[data-theme="dark"] .search-input,
[data-theme="dark"] .sidebar-search-input {
  background: var(--cream-dk);
  border-color: var(--rule);
  color: var(--ink);
}
[data-theme="dark"] .sidebar-search-input::placeholder { color: var(--ink-soft); }

[data-theme="dark"] .site-footer { background: var(--cream-dk); border-top-color: var(--rule); }
[data-theme="dark"] .footer-bottom { color: var(--ink-soft); }
[data-theme="dark"] .footer-bottom-links a { color: var(--ink-soft); }
[data-theme="dark"] #sa-reopen-consent { color: var(--ink-soft); }

[data-theme="dark"] .sa-placement-wrap,
[data-theme="dark"] .sa-box-wrap { background: var(--cream-dk); border-color: var(--rule); }

/* Smooth theme transition */
body, .site-header, .article-card, .sidebar-widget,
.hero-content, .hero-section, .site-footer {
  transition: background-color .3s ease, border-color .3s ease, color .3s ease;
}

/* ============================================================
   DARK MODE TOGGLE BUTTON
   ============================================================ */
.dark-toggle {
  background: none;
  border: none;
  cursor: pointer;
  padding: .4rem;
  color: var(--ink-mid);
  display: flex;
  align-items: center;
  border-radius: var(--r-md);
  transition: color var(--ease), background var(--ease);
}
.dark-toggle:hover { color: var(--burg); background: rgba(122,22,40,.07); }
[data-theme="dark"] .dark-toggle:hover { background: rgba(255,255,255,.07); }
.dark-toggle svg { width: 18px; height: 18px; }
.dark-toggle .icon-moon { display: block; }
.dark-toggle .icon-sun  { display: none; }
[data-theme="dark"] .dark-toggle .icon-moon { display: none; }
[data-theme="dark"] .dark-toggle .icon-sun  { display: block; }

/* ============================================================
   TICKER BUTTON — SVG icons, no emoji
   ============================================================ */
.ticker-pause-btn { font-size: 0; line-height: 0; }
.ticker-pause-btn svg { width: 10px; height: 10px; display: block; }
.ticker-pause-btn .icon-pause { display: block; }
.ticker-pause-btn .icon-play  { display: none; }
.ticker-pause-btn.is-paused .icon-pause { display: none; }
.ticker-pause-btn.is-paused .icon-play  { display: block; }

/* ============================================================
   INFINITE SCROLL — article separator
   ============================================================ */
.sa-next-article {
  margin-top: 4rem;
  padding-top: 3rem;
  border-top: 2px solid var(--burg);
  position: relative;
}

.sa-next-label {
  position: absolute;
  top: -0.75rem;
  left: 50%;
  transform: translateX(-50%);
  background: var(--burg);
  color: #fff;
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: .22rem .85rem;
  border-radius: 50px;
  white-space: nowrap;
}

.sa-loading-next {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  padding: 2rem;
  color: var(--ink-soft);
  font-size: .85rem;
}

.sa-spinner {
  width: 18px; height: 18px;
  border: 2px solid var(--rule);
  border-top-color: var(--burg);
  border-radius: 50%;
  animation: sa-spin .7s linear infinite;
}

@keyframes sa-spin { to { transform: rotate(360deg); } }

/* Ad placements — neutral class names, no adblocker triggers */
/* overflow:hidden on wrappers is the last line of defence against wide ad content */
.sa-placement-wrap {
  display: flex;
  justify-content: center;
  padding: 1.25rem 0;
  border-bottom: 1px solid var(--rule);
  background: var(--white);
  overflow: hidden;
  max-width: 100%;
}

.sa-strip-wrap {
  display: flex;
  justify-content: center;
  padding: 1rem 0;
  overflow: hidden;
  max-width: 100%;
}

.sa-box-wrap {
  display: flex;
  justify-content: center;
  overflow: hidden;
  max-width: 100%;
}

.sa-placement,
.sa-placement-wide,
.sa-placement-strip,
.sa-placement-box {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--cream-dk);
  border: 1px dashed var(--rule-dk);
  border-radius: var(--r-md);
  overflow: hidden;
  position: relative;
  margin-inline: auto;
  font-family: var(--fu);
}

.sa-placement-note {
  position: absolute;
  top: 4px; left: 6px;
  font-size: .56rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-soft);
  opacity: .5;
}

/* Placement dimensions — mobile overrides handled in consolidated @media(max-width:768px) block */
/* overflow:hidden clips any ad content (iframe, img) wider than the container */
.sa-placement-wide  { width: 728px; max-width: 100%; height: 90px; overflow: hidden; }
.sa-placement-strip { width: 468px; max-width: 100%; height: 60px; overflow: hidden; }
.sa-placement-box   { width: 300px; max-width: 100%; height: 250px; overflow: hidden; }

/* ============================================================
   SCROLL TO TOP
   ============================================================ */
#sa-back-top{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:500;
  width:42px;height:42px;
  background:var(--burg);color:#fff;
  border:none;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 12px rgba(0,0,0,.25);
  opacity:0;transform:translateY(14px);pointer-events:none;
  transition:opacity .3s ease,transform .3s ease,background var(--ease);
}
#sa-back-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
#sa-back-top:hover{background:var(--burg-dk)}
#sa-back-top svg{width:18px;height:18px}

/* ============================================================
   IN-ARTICLE AD PLACEMENTS
   ============================================================ */
.sa-article-mid-ad{
  display:flex;justify-content:center;
  margin:2.5rem 0;
  clear:both;
}
.sa-article-bottom-ad{
  display:flex;justify-content:center;
  margin:2.5rem 0 0;
  clear:both;
}

.sa-article-mid-ad img,
.sa-article-bottom-ad img { margin: 0; border-radius: 0; }

/* Mobile in-article ad overrides handled in consolidated @media(max-width:480px) block above */
