/*
Theme Name: Santé Avis
Theme URI: https://www.santeavis.com/
Author: Santé Avis
Author URI: https://www.santeavis.com/
Version: 3.0.0
Tested up to: 6.8
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: santeavis
*/

/* ============================================================
   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;
}

/* ============================================================
   Reset
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--fu);font-size:1rem;line-height:1.7;color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
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;
}

/* Header utils */
.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)}
.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-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
   ============================================================ */
#sa-cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--ink);color:rgba(255,255,255,.9);padding:1.25rem 0;box-shadow:0 -4px 32px rgba(0,0,0,.25);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.55;color:rgba(255,255,255,.8);margin:0}
.cookie-text a{color:var(--gold-lt);text-decoration:underline;text-underline-offset:2px}
.cookie-text strong{color:#fff}
.cookie-actions{display:flex;gap:.6rem;flex-shrink:0;flex-wrap:wrap}
.btn-ca,.btn-cd,.btn-cp{padding:.6rem 1.2rem;border-radius:var(--r-md);font-family:var(--fu);font-size:.8rem;font-weight:700;cursor:pointer;border:none;transition:background var(--ease),transform var(--ease);letter-spacing:.04em}
.btn-ca{background:var(--burg);color:#fff}
.btn-ca:hover{background:var(--burg-lt);transform:translateY(-1px)}
.btn-cd{background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.2)}
.btn-cd:hover{background:rgba(255,255,255,.18)}
.btn-cp{background:none;color:rgba(255,255,255,.5);font-size:.75rem;text-decoration:underline}
.btn-cp:hover{color:rgba(255,255,255,.85)}
#sa-cookie-prefs{display:none;position:fixed;inset:0;z-index:10000;background:rgba(28,28,30,.85);backdrop-filter:blur(4px);align-items:center;justify-content:center}
#sa-cookie-prefs.active{display:flex}
.prefs-modal{background:var(--white);border-radius:var(--r-lg);padding:2.25rem;width:90%;max-width:500px;max-height:85vh;overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,.3)}
.prefs-modal h2{font-size:1.3rem;margin-bottom:.5rem}
.prefs-modal>p{font-size:.88rem;color:var(--ink-soft);margin-bottom:1.5rem;line-height:1.6}
.pref-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem 0;border-top:1px solid var(--rule)}
.pref-row:last-of-type{border-bottom:1px solid var(--rule);margin-bottom:1.5rem}
.pref-info strong{font-size:.9rem;display:block;margin-bottom:.2rem}
.pref-info span{font-size:.8rem;color:var(--ink-soft);line-height:1.5}
.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:var(--rule-dk);border-radius:24px;cursor:pointer;transition:background var(--ease)}
.sa-toggle-track::after{content:'';position:absolute;left:3px;top:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform var(--ease);box-shadow:0 1px 4px rgba(0,0,0,.2)}
.sa-toggle input:checked+.sa-toggle-track{background:var(--burg)}
.sa-toggle input:checked+.sa-toggle-track::after{transform:translateX(18px)}
.sa-toggle input:disabled+.sa-toggle-track{opacity:.5;cursor:not-allowed}
.prefs-modal-actions{display:flex;gap:.6rem;justify-content:flex-end}
.btn-ps{padding:.65rem 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-ps:hover{background:var(--burg-dk)}
.btn-pc{padding:.65rem 1rem;background:none;color:var(--ink-soft);border:1px solid var(--rule);border-radius:var(--r-md);font-family:var(--fu);font-size:.82rem;cursor:pointer;transition:background var(--ease)}
.btn-pc:hover{background:var(--cream)}

/* ============================================================
   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
   ============================================================ */
.sa-reveal{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
   ============================================================ */
@media(max-width:1024px){
  .articles-layout,.single-layout{grid-template-columns:1fr}
  .sidebar{position:static;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
}
@media(max-width:768px){
  .hero-article{grid-template-columns:1fr;min-height:auto}
  .hero-image-wrap{aspect-ratio:16/9}
  .article-card{grid-template-columns:1fr}
  .card-image{aspect-ratio:16/9;min-height:unset}
  .card-image img{position:absolute;inset:0}
  .primary-nav{display:none;position:fixed;inset:66px 0 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:99}
  .primary-nav.open{display:flex}
  .primary-nav a{font-size:.85rem;width:100%;padding:.8rem 1rem}
  .menu-toggle{display:flex}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-bottom-links{justify-content:center}
  .cookie-inner{flex-direction:column;gap:1rem}
  .cookie-actions{width:100%}
}
@media(max-width:480px){
  .prefs-modal{padding:1.5rem}
  .btn-ca,.btn-cd{width:100%;text-align:center}
}

/* ============================================================
   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;
}

/* ============================================================
   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}

/* Most-read list */
.most-read-list{display:flex;flex-direction:column;gap:.85rem}
.most-read-item{display:grid;grid-template-columns:48px 1fr;gap:.7rem;align-items:center}
.most-read-rank{
  width:48px;height:48px;
  border-radius:var(--r-md);
  background:var(--burg);
  color:#fff;
  font-family:var(--fd);
  font-size:1.1rem;
  font-weight:700;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.most-read-item:nth-child(1) .most-read-rank{background:var(--burg)}
.most-read-item:nth-child(2) .most-read-rank{background:var(--burg-lt);opacity:.85}
.most-read-item:nth-child(3) .most-read-rank{background:var(--burg-lt);opacity:.7}
.most-read-item:nth-child(4) .most-read-rank{background:var(--rule-dk);color:var(--ink-mid)}
.most-read-item:nth-child(5) .most-read-rank{background:var(--rule-dk);color:var(--ink-mid)}
.most-read-info .most-read-cat{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--burg);margin-bottom:.2rem}
.most-read-title{font-size:.83rem;font-weight:600;line-height:1.3;color:var(--ink)}
.most-read-title a:hover{color:var(--burg)}

/* ============================================================
   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,
[data-theme="dark"] .prefs-modal {
  background: var(--white);
  border-color: var(--rule);
}

[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); }

[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 */
.sa-placement-wrap {
  display: flex;
  justify-content: center;
  padding: 1.25rem 0;
  border-bottom: 1px solid var(--rule);
  background: var(--white);
}

.sa-strip-wrap {
  display: flex;
  justify-content: center;
  padding: 1rem 0;
}

.sa-box-wrap {
  display: flex;
  justify-content: center;
}

.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;
}

.sa-placement-wide  { width: 728px; max-width: 100%; height: 90px; }
.sa-placement-strip { width: 468px; max-width: 100%; height: 60px; }
.sa-placement-box   { width: 300px; max-width: 100%; height: 250px; }

@media(max-width:768px){
  .sa-placement-wide,
  .sa-placement-strip { height: 60px; }
}
