/*
Theme Name: LaSaveur Pro
Theme URI: https://lasaveur.blog
Author: LaSaveur
Description: Thème WordPress premium pour blog culinaire â€” Forest Green & Warm Gold.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: lasaveur
Tags: food, blog, custom-menu, featured-images, threaded-comments
*/

/* ============================================================
   LASAVEUR PRO â€” Ardoise & Cuivre | Style Éditorial | 2026
   ============================================================ */
:root{
  --primary:#1e293b;--primary-dk:#0f172a;--primary-lt:#e2e8f0;
  --accent:#b87333;--accent-dk:#9a5e28;--accent-lt:#fdf0e2;
  --terracotta:#e76f51;--success:#16a34a;
  --bg:#fafaf8;--surface:#ffffff;--surface2:#f4f3f0;--surface3:#fffbf5;
  --text:#141824;--text2:#4a4a5a;--text3:#9e9e9e;
  --border:#e2e0db;--border2:#ceccc6;
  --shadow:0 1px 3px rgba(0,0,0,.07);
  --shadow-md:0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:0 10px 36px rgba(0,0,0,.14);
  --radius:6px;--radius-sm:4px;--radius-lg:10px;--radius-full:9999px;
  --font:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-serif:'Playfair Display',Georgia,serif;
  --tr:.2s ease;--header-h:68px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);
  line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  font-size:clamp(14px,1.5vw,16px)}
a{color:var(--primary);text-decoration:none;transition:color var(--tr)}
a:hover{color:var(--primary-dk)}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:var(--font);-webkit-tap-highlight-color:transparent}
h1,h2,h3,h4{font-family:var(--font-serif);line-height:1.3}
p{margin-bottom:1em}
p:last-child{margin-bottom:0}
.container{max-width:1200px;margin:0 auto;padding:0 clamp(12px,3vw,24px)}

/* WordPress admin bar */
.admin-bar .site-header{top:32px}
@media screen and (max-width:782px){.admin-bar .site-header{top:46px}}

/* WordPress alignments */
.alignleft{float:left;margin:0 1.5em 1em 0}
.alignright{float:right;margin:0 0 1em 1.5em}
.aligncenter{display:block;margin:0 auto 1em}
.alignwide{margin-left:-60px;margin-right:-60px}
.alignfull{margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);width:100vw}

/* TOP BAR */
.top-bar{background:var(--primary-dk);color:rgba(255,255,255,.75);
  padding:6px 0;font-size:.74rem;letter-spacing:.02em}
.top-bar .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}
.top-bar a{color:rgba(255,255,255,.65);text-decoration:underline;text-underline-offset:2px}
.top-bar a:hover{color:#fff}
.top-bar-right{display:flex;align-items:center;gap:16px}

/* HEADER */
.site-header{background:var(--surface);border-bottom:3px solid var(--primary);
  position:sticky;top:0;z-index:200;box-shadow:var(--shadow)}
.header-inner{display:flex;align-items:center;gap:14px;padding:10px 0;min-height:var(--header-h)}
.site-brand{flex-shrink:0}
.site-brand a{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none}
.site-brand a:hover{color:var(--primary)}
.logo-icon{width:44px;height:44px;
  background:linear-gradient(135deg,var(--primary),var(--success));
  border-radius:12px;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.4rem;flex-shrink:0;box-shadow:0 3px 10px rgba(27,67,50,.28)}
.logo-text{font-family:var(--font-serif);font-size:clamp(1.05rem,2.5vw,1.38rem);font-weight:700;line-height:1.2}
.logo-text span{color:var(--primary)}
.logo-sub{display:block;font-size:.64rem;color:var(--text3);font-family:var(--font);
  font-weight:400;letter-spacing:.07em;margin-top:1px;text-transform:uppercase}
.header-search{flex:1;max-width:480px;margin:0 auto}
.header-search form,.header-search .search-form{display:flex;background:var(--surface2);
  border:2px solid var(--border2);border-radius:var(--radius-full);
  overflow:hidden;transition:border-color var(--tr),box-shadow var(--tr)}
.header-search form:focus-within,.header-search .search-form:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(27,67,50,.1)}
.header-search input,.header-search .search-field{flex:1;padding:10px 16px;background:none;border:none;
  outline:none;color:var(--text);font-size:.9rem;font-family:var(--font);min-width:0}
.header-search input::placeholder,.header-search .search-field::placeholder{color:var(--text3)}
.header-search button,.header-search .search-submit{padding:10px 18px;background:var(--primary);color:#fff;
  font-size:.9rem;font-weight:600;transition:background var(--tr);
  white-space:nowrap;flex-shrink:0;min-width:44px;min-height:44px;border:none;cursor:pointer}
.header-search button:hover,.header-search .search-submit:hover{background:var(--primary-dk)}
.header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}
.btn-icon{width:44px;height:44px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  background:var(--surface2);border:1.5px solid var(--border);
  font-size:1.1rem;color:var(--text2);transition:all var(--tr)}
.btn-icon:hover{background:var(--primary-lt);color:var(--primary);border-color:var(--primary)}
.mob-menu-btn{display:none;font-size:1.2rem}

/* NAV */
.site-nav{
  background:linear-gradient(135deg,#060d1a 0%,#1e293b 55%,#141e30 100%);
  border-bottom:2px solid rgba(184,115,51,.5);
  position:relative;}
.nav-list{
  display:flex;align-items:center;gap:0;padding:0;
  flex-wrap:wrap;justify-content:center;
  list-style:none;margin:0;}
.nav-list li{position:relative}
.nav-list li a{
  display:flex;align-items:center;gap:9px;
  height:56px;padding:0 28px;
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.05rem;font-weight:600;font-style:italic;
  color:rgba(255,255,255,.78);
  letter-spacing:.05em;white-space:nowrap;
  transition:color .3s ease,background .3s ease;
  position:relative;border-radius:0;}
.nav-list li a .nav-icon{
  font-style:normal;font-size:.95rem;
  opacity:.7;transition:opacity .3s,transform .3s;}
.nav-list li a::after{
  content:'';position:absolute;
  bottom:0;left:50%;right:50%;height:2px;
  background:linear-gradient(90deg,transparent,#b87333,transparent);
  transition:left .35s cubic-bezier(.4,0,.2,1),right .35s cubic-bezier(.4,0,.2,1);}
.nav-list li a:hover{color:#b87333;background:rgba(184,115,51,.06)}
.nav-list li a:hover::after{left:18px;right:18px}
.nav-list li a:hover .nav-icon{opacity:1;transform:scale(1.15)}
.nav-list li a.active,.nav-list li.current-menu-item>a,.nav-list li.current_page_item>a{
  color:#b87333;}
.nav-list li a.active::after,
.nav-list li.current-menu-item>a::after,
.nav-list li.current_page_item>a::after{left:18px;right:18px}
.nav-list li a.active .nav-icon{opacity:1}
.nav-list li+li::before{
  content:'\2736';position:absolute;left:-1px;top:50%;
  transform:translateY(-50%);
  font-size:.4rem;color:rgba(184,115,51,.35);pointer-events:none;}
.nav-list li.nav-cta{margin-left:14px}
.nav-list li.nav-cta a{
  height:38px;padding:0 22px;
  border:1.5px solid rgba(184,115,51,.55);
  border-radius:var(--radius-full);
  color:#b87333;font-size:.88rem;
  background:rgba(184,115,51,.07);
  font-style:normal;font-family:var(--font);
  font-weight:700;letter-spacing:.06em;}
.nav-list li.nav-cta a::after{display:none}
.nav-list li.nav-cta a:hover{
  background:#b87333;color:#060d1a;
  border-color:#b87333;transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(184,115,51,.35);}
.nav-list li.nav-cta a:hover .nav-icon{transform:none}
/* dropdown */
.nav-list li{position:relative}
.nav-list .sub-menu{display:none;position:absolute;top:100%;left:0;
  background:var(--surface);box-shadow:var(--shadow-lg);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  min-width:200px;z-index:100;flex-direction:column;gap:0;padding:6px 0;list-style:none}
.nav-list li:hover>.sub-menu{display:flex}
.nav-list .sub-menu a{height:auto;padding:9px 18px;border-radius:0;font-size:.85rem}
.nav-list .sub-menu a:hover{background:var(--primary-lt);color:var(--primary)}
.cat-pills{display:flex;gap:7px;padding:8px 0;overflow-x:auto;scrollbar-width:none}
.cat-pills::-webkit-scrollbar{display:none}
.cat-pill{display:inline-flex;align-items:center;height:30px;padding:0 14px;
  border-radius:var(--radius-full);font-size:.76rem;font-weight:600;
  color:#fff;white-space:nowrap;transition:filter var(--tr),transform var(--tr);flex-shrink:0}
.cat-pill:hover{filter:brightness(.9);color:#fff;transform:translateY(-1px)}
.pill-ma{background:linear-gradient(135deg,#1b4332,#40916c)}
.pill-fr{background:linear-gradient(135deg,#1e3a5f,#2563eb)}
.pill-it{background:linear-gradient(135deg,#881337,#be123c)}
.pill-ds{background:linear-gradient(135deg,#7c2d12,#ea580c)}
.pill-rp{background:linear-gradient(135deg,#065f46,#059669)}
.pill-rh{background:linear-gradient(135deg,#5b21b6,#7c3aed)}

/* HERO */
.hero{background:
  linear-gradient(135deg,rgba(13,40,24,.94) 0%,rgba(27,67,50,.88) 55%,rgba(64,145,108,.80) 100%),
  url('https://images.unsplash.com/photo-1414235077428-338989a2e8c0?w=1920&q=80') center/cover no-repeat;
  color:#fff;padding:clamp(56px,9vw,100px) clamp(16px,4vw,24px);
  text-align:center;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:60px;
  background:var(--bg);clip-path:ellipse(52% 100% at 50% 100%)}
.hero-inner{max-width:700px;margin:0 auto;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);
  border-radius:var(--radius-full);padding:5px 16px;font-size:.74rem;
  font-weight:600;letter-spacing:.06em;margin-bottom:20px;backdrop-filter:blur(8px);color:#fff}
.hero h1{font-family:var(--font-serif);font-size:clamp(1.7rem,5vw,3rem);
  font-weight:700;color:#fff;margin-bottom:14px;line-height:1.18}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero-desc{font-size:clamp(.88rem,2vw,1.05rem);color:rgba(255,255,255,.82);
  margin-bottom:28px;max-width:540px;margin-left:auto;margin-right:auto;line-height:1.72}
.hero-search{display:flex;max-width:500px;margin:0 auto 26px;
  background:rgba(255,255,255,.14);border:2px solid rgba(255,255,255,.3);
  border-radius:var(--radius-full);overflow:hidden;backdrop-filter:blur(10px)}
.hero-search input{flex:1;padding:13px 20px;background:none;border:none;
  outline:none;color:#fff;font-size:.95rem;font-family:var(--font);min-width:0}
.hero-search input::placeholder{color:rgba(255,255,255,.6)}
.hero-search button{padding:13px 24px;background:var(--accent);color:#1c1c2e;
  font-weight:700;font-size:.9rem;font-family:var(--font);
  transition:filter var(--tr);white-space:nowrap;flex-shrink:0;min-height:50px}
.hero-search button:hover{filter:brightness(1.08)}
.hero-stats{display:flex;align-items:center;gap:14px;justify-content:center;
  flex-wrap:wrap;font-size:.83rem;color:rgba(255,255,255,.65);margin-bottom:18px}
.hs{opacity:.35}
.hero-pills{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.hero-pill{display:inline-flex;align-items:center;height:34px;padding:0 16px;
  border-radius:var(--radius-full);font-size:.79rem;font-weight:600;
  border:1.5px solid rgba(255,255,255,.4);color:#fff;
  background:rgba(255,255,255,.08);backdrop-filter:blur(4px);
  transition:background var(--tr),transform var(--tr)}
.hero-pill:hover{background:rgba(255,255,255,.22);color:#fff;transform:translateY(-2px)}

/* CATEGORIES */
.cats-sec{padding:clamp(28px,4vw,48px) 0 clamp(14px,2vw,22px)}
.cats-sec-hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px}
.cats-sec-title{font-family:var(--font-serif);font-size:clamp(1.25rem,2.5vw,1.58rem);font-weight:700}
.cats-sec-sub{color:var(--text2);font-size:.83rem;margin-top:3px}
.cats-grid{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(clamp(90px,11vw,126px),1fr));gap:12px}
.cat-card{display:flex;flex-direction:column;align-items:center;gap:7px;
  border-radius:var(--radius);padding:clamp(16px,2.5vw,22px) 10px;
  text-align:center;background:var(--surface);border:2px solid var(--border);
  transition:transform var(--tr),box-shadow var(--tr),border-color var(--tr);
  position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent}
.cat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--primary);transform:scaleX(0);transform-origin:left;transition:transform var(--tr)}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--primary)}
.cat-card:hover::before{transform:scaleX(1)}
.cat-ico{font-size:clamp(1.5rem,3.5vw,2rem);line-height:1}
.cat-nm{font-size:.76rem;font-weight:700;color:var(--text);line-height:1.3}
.cat-desc{font-size:.7rem;color:var(--text3);line-height:1.4}
.cat-card:hover .cat-nm{color:var(--primary)}

/* LAYOUT */
.main-grid{display:block;padding:clamp(18px,3vw,36px) 0}
.sec-hd{display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--border)}
.sec-title{font-family:var(--font-serif);font-size:clamp(1.1rem,2.5vw,1.38rem);
  font-weight:700;color:var(--text);display:flex;align-items:center;gap:10px}
.sec-title::before{content:'';width:5px;height:22px;background:var(--primary);
  border-radius:3px;display:inline-block;flex-shrink:0}
.see-all{font-size:.78rem;font-weight:600;color:var(--primary);
  padding:6px 16px;border:1.5px solid var(--primary);
  border-radius:var(--radius-full);transition:all var(--tr);
  white-space:nowrap;min-height:36px;display:flex;align-items:center;gap:4px}
.see-all:hover{background:var(--primary);color:#fff}

/* GRILLE ARTICLES */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(12px,2vw,20px);margin-bottom:28px}
.post-card{background:var(--surface);border-radius:var(--radius);
  overflow:hidden;border:1.5px solid var(--border);
  transition:transform var(--tr),box-shadow var(--tr),border-color var(--tr);
  display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--primary)}
.posts-grid .post-card:first-child{grid-column:span 2;flex-direction:row;max-height:270px}
.posts-grid .post-card:first-child .card-img-wrap{
  width:52%;min-width:52%;height:270px;flex-shrink:0;aspect-ratio:auto;border-radius:0}
.posts-grid .post-card:first-child .card-body{justify-content:center;padding:clamp(16px,2.5vw,28px)}
.posts-grid .post-card:first-child .card-title{font-size:clamp(1.05rem,2vw,1.38rem);margin-bottom:10px}
.posts-grid .post-card:first-child .card-img-wrap::after{
  content:'â˜… En vedette';position:absolute;top:10px;left:10px;
  background:var(--accent);color:#1c1c2e;padding:3px 10px;
  border-radius:var(--radius-full);font-size:.65rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;z-index:2}
.card-img-wrap{position:relative;overflow:hidden;aspect-ratio:16/9;background:var(--surface2)}
.card-img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post-card:hover .card-img{transform:scale(1.05)}
.no-img{display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--primary-lt),var(--accent-lt));
  aspect-ratio:16/9;font-size:2.2rem;opacity:.5}
.card-cat{position:absolute;top:10px;left:10px;padding:3px 10px;
  background:var(--primary);color:#fff;font-size:.68rem;font-weight:700;
  border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;z-index:1}
.card-body{padding:clamp(12px,2vw,18px);flex:1;display:flex;flex-direction:column}
.card-meta-row{display:flex;align-items:center;gap:6px;
  font-size:.73rem;color:var(--text3);margin-bottom:8px}
.card-title{font-family:var(--font-serif);font-size:clamp(.9rem,1.8vw,1.02rem);
  font-weight:700;line-height:1.42;margin-bottom:8px}
.card-title a{color:var(--text)}
.card-title a:hover{color:var(--primary)}
.card-excerpt{font-size:.83rem;color:var(--text2);line-height:1.58;
  margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:3;
  -webkit-box-orient:vertical;overflow:hidden;flex:1}
.card-footer{display:flex;align-items:center;justify-content:flex-end;
  margin-top:auto;padding-top:8px;border-top:1px solid var(--border)}
.card-read-more{font-size:.8rem;font-weight:600;color:var(--primary);
  display:flex;align-items:center;gap:4px}
.arr{transition:transform var(--tr);display:inline-block}
.post-card:hover .arr{transform:translateX(3px)}

/* NEWSLETTER */
.nl-banner{background:linear-gradient(135deg,var(--primary-dk),var(--primary));
  border-radius:var(--radius-lg);padding:clamp(24px,4vw,40px);
  text-align:center;margin:clamp(22px,3vw,38px) 0;color:#fff;
  position:relative;overflow:hidden}
.nl-title{font-family:var(--font-serif);font-size:clamp(1.1rem,2.5vw,1.5rem);
  font-weight:700;margin-bottom:8px}
.nl-sub{font-size:.88rem;opacity:.82;margin-bottom:22px;
  max-width:440px;margin-left:auto;margin-right:auto}
.nl-form{display:flex;max-width:420px;margin:0 auto;gap:8px}
.nl-input{flex:1;padding:12px 16px;border:none;border-radius:var(--radius-full);
  font-family:var(--font);font-size:.88rem;min-width:0;outline:none;color:var(--text)}
.nl-btn{padding:12px 22px;background:var(--accent);color:var(--text);border:none;
  border-radius:var(--radius-full);font-weight:700;font-size:.88rem;font-family:var(--font);
  cursor:pointer;transition:filter var(--tr);white-space:nowrap;min-height:46px}
.nl-btn:hover{filter:brightness(1.08)}

/* ARTICLE SINGLE */
.article-wrap{background:var(--surface);border-radius:var(--radius-lg);
  box-shadow:var(--shadow);padding:clamp(20px,4vw,44px);max-width:840px;margin:0 auto}
.post-cats{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}
.post-cat{padding:5px 14px;background:var(--primary-lt);color:var(--primary);
  border-radius:var(--radius-full);font-size:.73rem;font-weight:700;
  text-transform:uppercase;transition:all var(--tr)}
.post-cat:hover{background:var(--primary);color:#fff}
.post-h1{font-family:var(--font-serif);font-size:clamp(1.4rem,3.5vw,2.2rem);
  font-weight:700;line-height:1.25;margin-bottom:18px}
.post-meta-row{display:flex;flex-wrap:wrap;gap:14px;font-size:.8rem;color:var(--text3);
  margin-bottom:22px;padding-bottom:16px;border-bottom:1.5px solid var(--border)}
.post-meta-row span{display:flex;align-items:center;gap:6px}
.post-feat-img{border-radius:var(--radius);overflow:hidden;
  margin-bottom:24px;box-shadow:var(--shadow-md)}
.post-feat-img img{width:100%;max-height:480px;object-fit:cover}
.toc-box{background:var(--surface2);border:1.5px solid var(--border);
  border-left:4px solid var(--primary);border-radius:var(--radius);
  padding:16px 20px;margin-bottom:24px;display:none}
.toc-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.toc-ttl{font-weight:700;font-size:.9rem;color:var(--primary)}
.toc-tog{width:28px;height:28px;background:var(--primary);color:#fff;
  border-radius:50%;font-size:.85rem;display:flex;align-items:center;justify-content:center}
#toc-list ol{padding-left:18px}
#toc-list li{font-size:.85rem;margin:5px 0}
#toc-list a{color:var(--text2)}
#toc-list a:hover{color:var(--primary)}
.post-body{font-size:clamp(.95rem,1.8vw,1.06rem);line-height:1.85;color:var(--text)}
.post-body h2{font-family:var(--font-serif);font-size:clamp(1.2rem,2.5vw,1.55rem);
  margin:clamp(28px,4vw,40px) 0 14px;padding-bottom:10px;border-bottom:2px solid var(--border)}
.post-body h3{font-family:var(--font-serif);font-size:clamp(1.05rem,2vw,1.22rem);
  margin:20px 0 10px;color:var(--primary-dk)}
.post-body p{margin-bottom:18px}
.post-body ul,.post-body ol{padding-left:22px;margin-bottom:18px}
.post-body ul{list-style:disc}.post-body ol{list-style:decimal}
.post-body li{margin-bottom:7px}
.post-body table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.88rem;
  display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
.post-body th{background:var(--primary);color:#fff;padding:11px 14px;text-align:left;white-space:nowrap}
.post-body td{padding:11px 14px;border-bottom:1px solid var(--border)}
.post-body tr:nth-child(even) td{background:var(--surface2)}
.post-body blockquote{border-left:4px solid var(--accent);background:var(--accent-lt);
  padding:14px 20px;margin:20px 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  font-style:italic;color:var(--text2)}
.post-body code{background:var(--surface2);padding:2px 7px;border-radius:4px;
  font-size:.875rem;border:1px solid var(--border)}
.post-body img{border-radius:var(--radius);margin:18px auto;box-shadow:var(--shadow-md)}
.post-body a{text-decoration:underline;text-underline-offset:3px}
/* entry-content alias pour compatibilité WP */
.entry-content{font-size:clamp(.95rem,1.8vw,1.06rem);line-height:1.85;color:var(--text)}
.entry-content h2{font-family:var(--font-serif);font-size:clamp(1.2rem,2.5vw,1.55rem);margin:clamp(28px,4vw,40px) 0 14px;padding-bottom:10px;border-bottom:2px solid var(--border)}
.entry-content h3{font-family:var(--font-serif);font-size:clamp(1.05rem,2vw,1.22rem);margin:20px 0 10px;color:var(--primary-dk)}
.entry-content p{margin-bottom:18px}
.entry-content ul,.entry-content ol{padding-left:22px;margin-bottom:18px}
.entry-content ul{list-style:disc}.entry-content ol{list-style:decimal}
.entry-content li{margin-bottom:7px}
.entry-content blockquote{border-left:4px solid var(--accent);background:var(--accent-lt);padding:14px 20px;margin:20px 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-style:italic;color:var(--text2)}
.entry-content img{border-radius:var(--radius);margin:18px auto;box-shadow:var(--shadow-md)}
.entry-content a{text-decoration:underline;text-underline-offset:3px}
.entry-content table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.88rem}
.entry-content th{background:var(--primary);color:#fff;padding:11px 14px;text-align:left}
.entry-content td{padding:11px 14px;border-bottom:1px solid var(--border)}
.entry-content tr:nth-child(even) td{background:var(--surface2)}
.post-tags{display:flex;flex-wrap:wrap;gap:7px;align-items:center;margin:22px 0}
.tag-lbl{font-size:.8rem;font-weight:600;color:var(--text3)}
.post-tag{padding:4px 12px;background:var(--surface2);color:var(--text2);
  border:1.5px solid var(--border);border-radius:var(--radius-full);
  font-size:.77rem;transition:all var(--tr)}
.post-tag:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.share-bar{background:var(--surface2);border-radius:var(--radius);
  padding:16px 20px;margin:22px 0;display:flex;align-items:center;
  gap:14px;flex-wrap:wrap;border:1px solid var(--border)}
.share-lbl{font-weight:700;font-size:.86rem;white-space:nowrap}
.share-btns{display:flex;gap:7px;flex-wrap:wrap}
.shr{display:inline-flex;align-items:center;height:38px;padding:0 18px;
  border-radius:var(--radius-full);font-size:.8rem;font-weight:600;
  color:#fff;transition:filter var(--tr),transform var(--tr)}
.shr:hover{filter:brightness(.88);color:#fff;transform:translateY(-1px)}
.shr-fb{background:#1877f2}.shr-tw{background:#1da1f2}
.shr-wa{background:#25d366}.shr-tg{background:#0088cc}
.related-sec{margin-top:40px}
.related-ttl{font-family:var(--font-serif);font-size:1.15rem;font-weight:700;
  margin-bottom:18px;padding-bottom:12px;border-bottom:2px solid var(--border)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.rel-card{background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius);overflow:hidden;transition:transform var(--tr),box-shadow var(--tr)}
.rel-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.rel-card img{width:100%;aspect-ratio:16/9;object-fit:cover;margin:0}
.rel-card-body{padding:12px 14px}
.rel-card-title{font-family:var(--font-serif);font-size:.86rem;font-weight:600;
  line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden;color:var(--text)}
.rel-card-title:hover{color:var(--primary)}

/* COMMENTS */
.comments-wrap{margin-top:30px;padding-top:24px;border-top:2px solid var(--border)}
.comments-ttl{font-family:var(--font-serif);font-size:1.1rem;font-weight:700;margin-bottom:16px}
.comment-list{list-style:none;margin:0;padding:0}
.comment-list .comment{padding:16px 0;border-bottom:1px solid var(--border)}
.comment-author-name{font-weight:600;font-size:.9rem;color:var(--text)}
.comment-meta-info{font-size:.78rem;color:var(--text3);margin-bottom:8px}
.comment-text{font-size:.9rem;color:var(--text2);line-height:1.7}
.comment-respond{margin-top:28px}
.comment-reply-title{font-family:var(--font-serif);font-size:1.05rem;font-weight:700;margin-bottom:16px}
.comment-form label{display:block;font-size:.85rem;font-weight:600;margin-bottom:5px;color:var(--text)}
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea{width:100%;padding:10px 14px;border:1.5px solid var(--border2);
  border-radius:var(--radius-sm);background:var(--surface2);color:var(--text);
  font-family:var(--font);font-size:.9rem;margin-bottom:14px;outline:none;
  transition:border-color var(--tr)}
.comment-form input:focus,.comment-form textarea:focus{border-color:var(--primary)}
.comment-form textarea{resize:vertical;min-height:120px}
.comment-form .submit,.comment-add-btn{padding:12px 28px;background:var(--primary);color:#fff;
  border:none;border-radius:var(--radius-full);font-weight:600;font-size:.9rem;
  font-family:var(--font);cursor:pointer;transition:background var(--tr);
  min-height:46px;display:inline-flex;align-items:center;gap:7px}
.comment-form .submit:hover,.comment-add-btn:hover{background:var(--primary-dk);color:#fff}

/* BREADCRUMB */
.breadcrumb{background:var(--surface2);border-bottom:1px solid var(--border);padding:9px 0}
.bc-list{display:flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:.78rem;color:var(--text3)}
.bc-list a{color:var(--text2)}
.bc-list a:hover{color:var(--primary)}
.bc-sep{opacity:.4}

/* PAGER / PAGINATION */
.pager{display:flex;justify-content:space-between;align-items:center;margin:32px 0;gap:12px}
.pager-btn{display:inline-flex;align-items:center;gap:6px;padding:0 24px;height:46px;
  background:var(--surface);color:var(--text2);border:2px solid var(--border);
  border-radius:var(--radius-full);font-size:.86rem;font-weight:500;transition:all var(--tr)}
.pager-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
/* WP paginate_links */
.pagination{display:flex;justify-content:center;margin:32px 0}
.pagination ul{display:flex;gap:6px;list-style:none;flex-wrap:wrap}
.page-numbers{display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;padding:0 12px;
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  font-size:.86rem;font-weight:500;color:var(--text2);background:var(--surface);transition:all var(--tr)}
a.page-numbers:hover,.page-numbers.current{background:var(--primary);color:#fff;border-color:var(--primary)}

/* LABEL/ARCHIVE HERO */
.label-hero{background:linear-gradient(135deg,var(--primary-dk),var(--primary));
  color:#fff;padding:clamp(28px,4vw,44px) clamp(20px,4vw,48px);
  border-radius:var(--radius-lg);text-align:center;margin-bottom:28px;box-shadow:var(--shadow-md)}
.label-hero h1{font-family:var(--font-serif);font-size:clamp(1.4rem,3vw,2rem);margin-bottom:10px;color:#fff}
.label-hero p{font-size:.92rem;opacity:.85;margin:0}
.label-hero-count{display:inline-flex;align-items:center;gap:6px;margin-top:14px;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);
  border-radius:var(--radius-full);padding:5px 16px;font-size:.8rem;font-weight:600;
  backdrop-filter:blur(4px)}

/* SIDEBAR */
.sidebar{display:none!important}

/* FOOTER */
.site-footer{background:var(--primary-dk);color:rgba(255,255,255,.5);
  margin-top:clamp(40px,6vw,72px)}
.foot-top{padding:clamp(36px,5vw,58px) 0 clamp(24px,3vw,38px)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(20px,3vw,40px)}
.foot-brand-logo{font-family:var(--font-serif);font-size:clamp(1.2rem,2.5vw,1.55rem);
  font-weight:700;color:#fff;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.foot-brand-logo span{color:var(--accent)}
.foot-desc{font-size:.84rem;line-height:1.8;margin-bottom:20px;color:rgba(255,255,255,.48)}
.foot-social{display:flex;gap:10px;flex-wrap:wrap}
.foot-soc-btn{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.55);display:flex;align-items:center;justify-content:center;
  font-size:1rem;transition:background var(--tr),transform var(--tr),color var(--tr);text-decoration:none}
.foot-soc-btn:hover{background:var(--accent);color:#1c1c2e;transform:translateY(-2px)}
.foot-col-title{color:#fff;font-size:.88rem;font-weight:700;
  margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-links{display:flex;flex-direction:column;gap:9px;list-style:none;padding:0;margin:0}
.foot-links a{font-size:.83rem;color:rgba(255,255,255,.5);
  transition:color var(--tr);display:flex;align-items:center;gap:6px}
.foot-links a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.08);padding:18px 0;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:10px;font-size:.79rem}
.foot-legal{display:flex;gap:16px;flex-wrap:wrap;list-style:none;padding:0;margin:0}
.foot-legal a{color:rgba(255,255,255,.45);transition:color var(--tr)}
.foot-legal a:hover{color:#fff}

/* SCROLL TOP */
.scroll-top{position:fixed;bottom:24px;right:24px;width:48px;height:48px;
  background:var(--primary);color:#fff;border-radius:50%;
  display:none;align-items:center;justify-content:center;
  font-size:1.25rem;box-shadow:var(--shadow-lg);z-index:300;transition:all var(--tr)}
.scroll-top:hover{background:var(--primary-dk);transform:translateY(-3px)}
.scroll-top.vis{display:flex}

/* COOKIE BAR */
.cookie-bar{position:fixed;bottom:0;left:0;right:0;
  background:var(--primary-dk);color:rgba(255,255,255,.9);
  padding:14px clamp(16px,3vw,22px);z-index:999;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;border-top:3px solid var(--accent);
  transform:translateY(100%);transition:transform .4s ease}
.cookie-bar.show{transform:translateY(0)}
.cookie-bar p{font-size:.84rem;max-width:640px;line-height:1.55;margin:0}
.cookie-bar a{color:var(--accent);text-decoration:underline}
.cookie-btns{display:flex;gap:8px;flex-shrink:0}
.btn-accept{padding:9px 20px;background:var(--accent);color:#1c1c2e;
  border-radius:var(--radius-full);font-weight:700;font-size:.83rem;min-height:42px;
  border:none;cursor:pointer;font-family:var(--font)}
.btn-decline{padding:9px 16px;background:transparent;color:rgba(255,255,255,.6);
  border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-full);font-size:.83rem;min-height:42px;
  cursor:pointer;font-family:var(--font)}
.btn-decline:hover{border-color:rgba(255,255,255,.6);color:#fff}

/* PAGES LÉGALES */
.page-legal{max-width:820px;margin:clamp(20px,3vw,40px) auto;padding:0 0 40px}
.page-legal-hero{background:linear-gradient(135deg,#0d2818,#1b4332);
  border-radius:var(--radius-lg);padding:clamp(24px,4vw,44px);
  text-align:center;color:#fff;margin-bottom:32px}
.page-legal-hero h1{font-family:var(--font-serif);font-size:clamp(1.5rem,3.5vw,2rem);margin-bottom:8px;color:#fff}
.page-legal-hero p{opacity:.75;font-size:.88rem;margin:0}
.page-legal h2{font-family:var(--font-serif);color:var(--primary);font-size:1.15rem;
  margin:28px 0 12px;padding-bottom:8px;border-bottom:2px solid var(--primary-lt)}
.page-legal p,.page-legal li{font-size:.93rem;color:var(--text2);line-height:1.8}
.page-legal ul{padding-left:22px;margin-bottom:1em}
.page-legal ul li{list-style:disc;margin-bottom:8px;color:var(--text2)}
.page-legal a{color:var(--primary);font-weight:600}
.legal-table{width:100%;border-collapse:collapse;font-size:.88rem;margin:12px 0 20px}
.legal-table th,.legal-table td{padding:10px 14px;border:1px solid var(--border);text-align:left}
.legal-table th{background:var(--primary-lt);font-weight:600;color:var(--primary)}
.legal-table tr:nth-child(even) td{background:var(--surface2)}
.legal-contact-box{background:var(--surface2);border:1.5px solid var(--border);
  border-radius:var(--radius);padding:20px;margin-top:28px}
.legal-footer{background:var(--primary-lt);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px;margin-top:20px;text-align:center;font-size:.83rem}
.legal-footer a{color:var(--primary);font-weight:600}

/* SEARCH â€” no results */
.no-results{text-align:center;padding:clamp(40px,8vw,80px) 0}
.no-results h2{font-family:var(--font-serif);font-size:clamp(1.3rem,3vw,1.8rem);margin-bottom:12px}
.no-results p{color:var(--text2);margin-bottom:24px}

/* RESPONSIVE 1024px */
@media(max-width:1024px){
  .foot-grid{grid-template-columns:1fr 1fr}
  .cats-grid{grid-template-columns:repeat(4,1fr)}
  .related-grid{grid-template-columns:repeat(2,1fr)}
  .posts-grid{grid-template-columns:repeat(2,1fr)}
  .posts-grid .post-card:first-child{grid-column:span 2}
  .alignwide{margin-left:0;margin-right:0}
}
/* RESPONSIVE 768px */
@media(max-width:768px){
  .top-bar{display:none}
  .mob-menu-btn{display:flex}
  .site-nav{position:relative}
  .nav-list{display:none;flex-direction:column;gap:0;
    position:absolute;top:100%;left:0;right:0;
    background:linear-gradient(180deg,#060d1a,#1e293b);
    box-shadow:0 12px 40px rgba(0,0,0,.4);
    z-index:300;padding:8px 0;
    border-top:1px solid rgba(184,115,51,.3);}
  .nav-list.open{display:flex}
  .nav-list li+li::before{display:none}
  .nav-list li a{height:50px;border-radius:0;font-size:1rem;
    padding:0 26px;color:rgba(255,255,255,.82);
    border-bottom:1px solid rgba(184,115,51,.1);}
  .nav-list li a::after{display:none}
  .nav-list li a:hover{color:#b87333;background:rgba(184,115,51,.1)}
  .nav-list li.nav-cta{margin-left:0}
  .nav-list li.nav-cta a{
    height:50px;border-radius:0;border:none;
    background:rgba(184,115,51,.12);
    color:#b87333;font-family:'Playfair Display',serif;
    font-style:italic;font-size:1rem;font-weight:600;letter-spacing:.05em;
    border-bottom:1px solid rgba(184,115,51,.1);}
  .nav-list li.nav-cta a:hover{transform:none;box-shadow:none;
    background:rgba(184,115,51,.2)}
  .posts-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .posts-grid .post-card:first-child{flex-direction:column;max-height:none;grid-column:span 2}
  .posts-grid .post-card:first-child .card-img-wrap{width:100%;min-width:0;aspect-ratio:16/9;height:auto}
  .foot-grid{grid-template-columns:1fr 1fr;gap:22px}
  .foot-bottom{flex-direction:column;text-align:center}
  .foot-legal{justify-content:center}
  .pager{flex-wrap:wrap;justify-content:center;gap:8px}
}
/* RESPONSIVE 480px */
@media(max-width:480px){
  .posts-grid{grid-template-columns:1fr;gap:10px}
  .posts-grid .post-card:first-child{grid-column:auto;flex-direction:column;max-height:none}
  .posts-grid .post-card:first-child .card-img-wrap{width:100%;height:auto;aspect-ratio:16/9}
  .post-card:not(:first-child){flex-direction:row;max-height:110px}
  .post-card:not(:first-child) .card-img-wrap{width:110px;min-width:110px;aspect-ratio:auto;height:110px}
  .card-body{padding:10px 12px}
  .card-excerpt{display:none}
  .cats-grid{grid-template-columns:repeat(3,1fr);gap:8px}
  .cat-card{padding:12px 6px}
  .hero-search{flex-direction:column;border-radius:var(--radius-sm)}
  .hero-search input{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.2)}
  .hero-search button{width:100%;border-radius:0 0 var(--radius-sm) var(--radius-sm)}
  .related-grid{grid-template-columns:1fr}
  .share-bar{flex-direction:column;align-items:flex-start}
  .foot-grid{grid-template-columns:1fr}
  .cookie-bar{flex-direction:column;align-items:flex-start}
  .cookie-btns{width:100%;justify-content:center}
  .btn-accept,.btn-decline{flex:1;text-align:center;justify-content:center}
  .nl-form{flex-direction:column;gap:10px}
  .nl-btn{width:100%}
}
/* RESPONSIVE 360px */
@media(max-width:360px){
  .cats-grid{grid-template-columns:repeat(2,1fr)}
  .hero-pill{height:30px;padding:0 12px;font-size:.75rem}
}

/* ── YOUTUBE SECTION ── */
.yt-section{padding:clamp(36px,5vw,60px) 0;border-top:1px solid var(--border)}
.yt-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.yt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.yt-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform var(--tr),box-shadow var(--tr);cursor:pointer}
.yt-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.yt-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:#000}
.yt-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.yt-card:hover .yt-thumb img{transform:scale(1.06)}
.yt-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.25);transition:background var(--tr)}
.yt-card:hover .yt-overlay{background:rgba(0,0,0,.5)}
.yt-btn{width:52px;height:52px;background:#ff0000;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(255,0,0,.4);transition:transform var(--tr)}
.yt-card:hover .yt-btn{transform:scale(1.1)}
.yt-btn::after{content:'';border-left:19px solid #fff;border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:4px}
.yt-info{padding:14px 16px;flex:1}
.yt-title{font-family:var(--font-serif);font-size:.9rem;font-weight:700;color:var(--text);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:6px}
.yt-date{font-size:.74rem;color:var(--text3)}
.yt-empty{grid-column:1/-1;text-align:center;padding:44px;color:var(--text3)}
.yt-subscribe{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;background:#ff0000;color:#fff;border-radius:var(--radius-full);font-weight:700;font-size:.86rem;transition:filter var(--tr),transform var(--tr)}
.yt-subscribe:hover{filter:brightness(.88);color:#fff;transform:translateY(-1px)}
.yt-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:9999;align-items:center;justify-content:center;padding:20px}
.yt-modal.open{display:flex}
.yt-modal-wrap{position:relative;width:100%;max-width:920px}
.yt-modal-frame{position:relative;aspect-ratio:16/9;background:#000;border-radius:var(--radius);overflow:hidden}
.yt-modal-frame iframe{width:100%;height:100%;border:none}
.yt-modal-close{position:absolute;top:-46px;right:0;background:none;border:none;color:#fff;font-size:2.2rem;cursor:pointer;opacity:.8;transition:opacity var(--tr);line-height:1}
.yt-modal-close:hover{opacity:1}
@media(max-width:768px){.yt-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.yt-grid{grid-template-columns:1fr}}
/* PRINT */
@media print{
  .site-header,.site-nav,.site-footer,.top-bar,
  .share-bar,.related-sec,.scroll-top,.cookie-bar,.toc-box,
  .breadcrumb,.pager,.nl-banner{display:none!important}
  .article-wrap{box-shadow:none;padding:0}
  body{background:#fff;color:#000}
}

