/*
Theme Name: Vice Central
Theme URI: https://tonsite.com
Description: Thème personnalisé Vice Central - Fan Site
Author: Vice Central
Version: 3.0 — Vice Central
Template: twentytwentyfour
Text Domain: gta6insider
*/

:root {
  --sunset: #E85D40;
  --teal:   #3DB8A8;
  --blue:   #3DB8A8;
  --indigo: #7A3A6E;
  --violet: #9B5E8C;
  --gold:   #D4920A;
  --copper: #C87E5A;
  --bg:     #F5F0EC;
  --bg2:    #EDE8E3;
  --bg3:    #E0D8D0;
  --white:  #FFFFFF;
  --ink:    #1A0E28;
  --ink2:   #2E1A3A;
  --ink3:   #4A3858;
  --muted:  #8A7A80;
  --border: rgba(232,93,64,0.12);
  --grad:   linear-gradient(135deg, #E85D40, #9B5E8C, #3DB8A8);
  --grad2:  linear-gradient(135deg, #3DB8A8, #E85D40, #9B5E8C);
  --grad3:  linear-gradient(135deg, #9B5E8C, #D4920A);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'Barlow',sans-serif;font-weight:300;overflow-x:hidden}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--sunset);border-radius:2px}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(245,240,236,0.88);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);transition:background .3s,box-shadow .3s}
header.scrolled{background:rgba(255,252,248,0.96);box-shadow:0 2px 30px rgba(61,184,168,.10)}
.hdr{display:flex;align-items:center;justify-content:space-between;padding:0 48px;height:68px}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo-mark{width:40px;height:40px;background:var(--grad);border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(61,184,168,.35)}
.logo-mark span{font-family:'Bebas Neue',sans-serif;font-size:18px;color:#fff;letter-spacing:1px}
.logo-name{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:4px;color:var(--ink)}
.logo-name em{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-style:normal}
nav{display:flex;align-items:center;gap:2px}
nav a{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink3);text-decoration:none;padding:8px 16px;border-radius:8px;transition:all .2s}
nav a:hover{background:rgba(61,184,168,.08);color:var(--sunset)}
nav a.active{color:var(--sunset);background:rgba(61,184,168,.08)}
.nav-cta{background:var(--grad);color:#fff!important;padding:9px 22px!important;border-radius:10px!important;box-shadow:0 4px 14px rgba(61,184,168,.3);font-weight:700!important}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(61,184,168,.4)!important}

/* TICKER */
.ticker{background:linear-gradient(90deg,var(--sunset),var(--violet));height:30px;display:flex;align-items:center;overflow:hidden}
.ticker-badge{background:rgba(255,255,255,.18);color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;padding:0 20px;height:100%;display:flex;align-items:center;flex-shrink:0;border-right:1px solid rgba(255,255,255,.2);gap:8px}
.ticker-badge::before{content:'';width:6px;height:6px;background:#fff;border-radius:50%;animation:blink 1s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.ticker-scroll{display:flex;animation:scrollt 45s linear infinite;white-space:nowrap}
.ticker-item{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:0 44px;color:rgba(255,255,255,.92);display:flex;align-items:center;gap:12px}
.ticker-item::before{content:'◆';font-size:7px;color:rgba(255,255,255,.5)}
@keyframes scrollt{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:120px 48px 80px;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.blob1{width:700px;height:700px;background:radial-gradient(circle,rgba(232,93,64,.18) 0%,transparent 70%);top:-100px;right:-100px}
.blob2{width:500px;height:500px;background:radial-gradient(circle,rgba(155,94,140,.14) 0%,transparent 70%);bottom:0;left:-50px}
.blob3{width:400px;height:400px;background:radial-gradient(circle,rgba(61,184,168,.12) 0%,transparent 70%);top:30%;left:40%}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(61,184,168,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(61,184,168,.04) 1px,transparent 1px);background-size:48px 48px;mask-image:linear-gradient(180deg,transparent 0%,black 20%,black 80%,transparent 100%)}
.hero-content{position:relative;z-index:2;max-width:680px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(61,184,168,.08);border:1px solid rgba(61,184,168,.2);color:var(--sunset);font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;padding:8px 16px;border-radius:20px;margin-bottom:28px}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--sunset);border-radius:50%;animation:blink 1.5s ease-in-out infinite}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(64px,10vw,140px);line-height:.9;letter-spacing:2px;margin-bottom:24px}
.hero-title .t1{display:block;color:var(--ink)}
.hero-title .t2{display:block;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-title .t3{display:block;background:var(--grad3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-desc{font-size:17px;line-height:1.7;color:var(--ink3);max-width:480px;margin-bottom:40px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:60px}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:2px;text-transform:uppercase;text-decoration:none;padding:14px 30px;border-radius:12px;border:none;cursor:pointer;transition:all .25s}
.btn-grd{background:var(--grad);color:#fff;box-shadow:0 6px 24px rgba(61,184,168,.35)}
.btn-grd:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(61,184,168,.45)}
.btn-out{background:transparent;color:var(--sunset);border:2px solid rgba(61,184,168,.25)}
.btn-out:hover{border-color:var(--sunset);background:rgba(61,184,168,.06)}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap}
.stat-val{font-family:'Bebas Neue',sans-serif;font-size:38px;line-height:1;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-lbl{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:2px}
.hero-vi{position:absolute;right:48px;top:50%;transform:translateY(-50%);z-index:1;pointer-events:none;font-family:'Bebas Neue',sans-serif;font-size:clamp(200px,28vw,480px);line-height:1;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.06;letter-spacing:-10px;user-select:none}

/* COUNTDOWN */
.countdown{background:linear-gradient(135deg,var(--ink) 0%,var(--ink2) 100%);padding:60px 48px;text-align:center;position:relative;overflow:hidden}
.countdown::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 100% at 50% 0%,rgba(232,93,64,.12) 0%,transparent 55%),radial-gradient(ellipse 60% 80% at 80% 100%,rgba(155,94,140,.1) 0%,transparent 60%)}
.cd-inner{position:relative;z-index:1}
.cd-label{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--sunset);margin-bottom:12px}
.cd-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(22px,3.5vw,40px);letter-spacing:4px;color:#fff;margin-bottom:40px}
.cd-boxes{display:flex;gap:12px;justify-content:center}
.cd-box{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);padding:24px 36px;border-radius:16px;min-width:120px;position:relative;overflow:hidden}
.cd-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad)}
.cd-num{font-family:'Bebas Neue',sans-serif;font-size:60px;line-height:1;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block}
.cd-lbl{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.4)}

/* SECTIONS */
section{padding:80px 48px}
.sec-hdr{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;padding-bottom:24px;border-bottom:2px solid var(--border)}
.sec-eye{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:4px;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px}
.sec-ttl{font-family:'Bebas Neue',sans-serif;font-size:clamp(34px,4.5vw,56px);letter-spacing:2px;color:var(--ink)}
.see-all{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;display:flex;align-items:center;gap:6px;transition:gap .2s;white-space:nowrap}
.see-all:hover{gap:12px}

/* NEWS */
#news{background:var(--white)}
.news-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr;grid-template-rows:auto auto;gap:20px}
.news-card{background:var(--white);border-radius:16px;overflow:hidden;border:1px solid var(--border);cursor:pointer;transition:transform .3s,box-shadow .3s}
.news-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(61,184,168,.12)}
.news-card.featured{grid-row:1/3;display:flex;flex-direction:column}
.card-thumb{overflow:hidden;background:var(--bg3);position:relative}
.news-card.featured .card-thumb{height:320px}
.news-card:not(.featured) .card-thumb{height:200px}
.card-thumb img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .5s}
.news-card:hover .card-thumb img{transform:scale(1.04)}
.tp{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:3px;color:var(--muted);transition:transform .5s;min-height:inherit}
.news-card:hover .tp{transform:scale(1.04)}
.tp1{background:linear-gradient(135deg,#fde8e0,#fad0c0)}
.tp2{background:linear-gradient(135deg,#e0f5f0,#c0e8e0)}
.tp3{background:linear-gradient(135deg,#f5ede8,#e8ddd8)}
.tp4{background:linear-gradient(135deg,#f8ede8,#f0d8d0)}
.tp5{background:linear-gradient(135deg,#e0f5f0,#c8e8e0)}
.tp6{background:linear-gradient(135deg,#fdf0e8,#f5e0d0)}
.card-body{padding:20px}
.news-card.featured .card-body{padding:24px}
.card-tag{display:inline-flex;align-items:center;gap:6px;font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 12px;border-radius:20px;margin-bottom:12px}
.tag-n{background:rgba(61,184,168,.08);color:var(--sunset)}
.tag-b{background:rgba(232,93,64,.1);color:var(--teal)}
.tag-g{background:rgba(155,94,140,.1);color:var(--violet)}
.tag-w{background:rgba(212,146,10,.1);color:#A07200}
.tag-t{background:rgba(212,146,10,.1);color:var(--pink)}
.card-ttl{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;line-height:1.35;color:var(--ink);margin-bottom:12px}
.news-card.featured .card-ttl{font-size:22px}
.card-meta{display:flex;gap:14px;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:1px;color:var(--muted)}

/* TUTOS */
#tutos{background:var(--bg)}
.tutos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tuto-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:28px;cursor:pointer;transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden}
.tuto-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);border-radius:16px 16px 0 0;transform:scaleX(0);transform-origin:left;transition:transform .35s}
.tuto-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(61,184,168,.12)}
.tuto-card:hover::after{transform:scaleX(1)}
.tuto-n{font-family:'Bebas Neue',sans-serif;font-size:72px;line-height:1;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.08;position:absolute;top:8px;right:16px;pointer-events:none}
.tuto-icon{width:48px;height:48px;background:linear-gradient(135deg,rgba(232,93,64,.1),rgba(61,184,168,.1));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:18px;border:1px solid rgba(61,184,168,.12)}
.tuto-ttl{font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:10px;line-height:1.3}
.tuto-desc{font-size:13px;line-height:1.65;color:var(--ink3);margin-bottom:20px}
.tuto-foot{display:flex;align-items:center;gap:10px}
.diff{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 12px;border-radius:20px}
.d-e{background:rgba(61,184,168,.12);color:#1A7A6A}
.d-m{background:rgba(61,184,168,.1);color:var(--sunset)}
.d-h{background:rgba(155,94,140,.1);color:var(--violet)}
.tuto-time{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:1px;color:var(--muted)}

/* VIDEOS */
#videos{background:var(--white)}
.videos-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.video-card{background:var(--white);border:1px solid var(--border);border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .3s,box-shadow .3s}
.video-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(61,184,168,.12)}
.v-thumb{position:relative;height:200px;overflow:hidden}
.v-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:3px;color:var(--muted);transition:transform .4s}
.video-card:hover .v-bg{transform:scale(1.04)}
.v-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;background:rgba(255,255,255,.92);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(61,184,168,.25);backdrop-filter:blur(8px);transition:all .3s;font-size:18px;color:var(--sunset)}
.video-card:hover .v-play{transform:translate(-50%,-50%) scale(1.12);box-shadow:0 8px 30px rgba(61,184,168,.4)}
.v-dur{position:absolute;bottom:10px;right:10px;background:rgba(26,14,40,.75);color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;letter-spacing:.5px}
.v-body{padding:18px 20px}
.v-ttl{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:700;color:var(--ink);margin-bottom:8px;line-height:1.35}
.v-stats{display:flex;gap:16px;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:1px;color:var(--muted)}

/* MAP */
.map-sec{background:var(--bg2)}
.map-wrap{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
.map-info{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:40px}
.map-ttl{font-family:'Bebas Neue',sans-serif;font-size:44px;letter-spacing:2px;color:var(--ink);margin-bottom:6px;line-height:1}
.map-ttl em{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-style:normal}
.map-info p{font-size:14px;line-height:1.7;color:var(--ink3);margin-bottom:28px;margin-top:10px}
.loc-list{list-style:none}
.loc-list li{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:.5px;color:var(--ink2);cursor:pointer;transition:color .2s}
.loc-list li:hover{color:var(--sunset)}
.loc-dot{width:8px;height:8px;border-radius:50%;background:var(--grad);flex-shrink:0}
.map-vis{background:var(--white);border:1px solid var(--border);border-radius:20px;position:relative;overflow:hidden;min-height:400px;display:flex;align-items:center;justify-content:center}
.map-gbg{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(61,184,168,.06) 40px),repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(61,184,168,.06) 40px)}
.map-glow{position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(232,93,64,.12) 0%,transparent 70%);border-radius:50%}
.map-wm{font-family:'Bebas Neue',sans-serif;font-size:90px;letter-spacing:12px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.07;position:relative;z-index:1;user-select:none}
.map-pings{position:absolute;inset:0;z-index:2}
.ping{position:absolute;width:12px;height:12px;background:var(--sunset);border-radius:50%;animation:ping 2.5s ease-out infinite}
.ping::after{content:'';position:absolute;inset:-5px;border-radius:50%;border:1.5px solid rgba(232,93,64,.4)}
.ping:nth-child(1){top:32%;left:42%;animation-delay:0s}
.ping:nth-child(2){top:58%;left:62%;animation-delay:.8s;background:var(--violet)}.ping:nth-child(2)::after{border-color:rgba(155,94,140,.4)}
.ping:nth-child(3){top:72%;left:34%;animation-delay:1.5s;background:var(--blue)}.ping:nth-child(3)::after{border-color:rgba(61,184,168,.4)}
.ping:nth-child(4){top:22%;left:68%;animation-delay:.4s}
@keyframes ping{0%{transform:scale(1);opacity:1}70%{transform:scale(1.4);opacity:.7}100%{transform:scale(1);opacity:1}}

/* FORUM */
.forum-sec{background:var(--bg)}
.forum-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.forum-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:24px;cursor:pointer;transition:transform .3s,box-shadow .3s,border-color .3s}
.forum-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(61,184,168,.1);border-color:rgba(61,184,168,.3)}
.forum-ico{font-size:26px;margin-bottom:14px}
.forum-ttl{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:10px;line-height:1.3}
.forum-snip{font-size:12px;line-height:1.6;color:var(--ink3);margin-bottom:16px}
.forum-meta{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:1px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* NEWSLETTER */
.nl{background:linear-gradient(135deg,var(--ink) 0%,var(--ink2) 100%);padding:80px 48px;text-align:center;position:relative;overflow:hidden}
.nl::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 120% at 50% -20%,rgba(232,93,64,.15) 0%,transparent 55%),radial-gradient(ellipse 60% 80% at 80% 100%,rgba(155,94,140,.1) 0%,transparent 60%)}
.nl-in{position:relative;z-index:1}
.nl-ttl{font-family:'Bebas Neue',sans-serif;font-size:clamp(36px,5vw,64px);letter-spacing:3px;color:#fff;margin-bottom:12px}
.nl-ttl span{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nl-desc{color:rgba(255,255,255,.55);font-size:16px;margin-bottom:36px}
.nl-form{display:flex;max-width:480px;margin:0 auto;border-radius:14px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.3)}
.nl-form input{flex:1;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-right:none;padding:16px 20px;font-family:'Barlow',sans-serif;font-size:14px;color:#fff;outline:none;transition:border-color .2s;border-radius:14px 0 0 14px}
.nl-form input::placeholder{color:rgba(255,255,255,.3)}
.nl-form input:focus{border-color:rgba(232,93,64,.4)}
.nl-form button{background:var(--grad);color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:16px 24px;border:none;cursor:pointer;transition:opacity .2s;white-space:nowrap;border-radius:0 14px 14px 0}
.nl-form button:hover{opacity:.85}

/* FOOTER */
footer{background:var(--bg);border-top:1px solid var(--border);padding:60px 48px 30px}
.ftr-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--border);margin-bottom:28px}
.ftr-brand p{font-size:13px;line-height:1.7;color:var(--muted);max-width:240px;margin-top:14px}
.ftr-col h4{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:18px}
.ftr-col ul{list-style:none}.ftr-col ul li{margin-bottom:10px}
.ftr-col ul li a{font-size:13px;color:var(--ink3);text-decoration:none;transition:color .2s}
.ftr-col ul li a:hover{color:var(--sunset)}
.ftr-bot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.ftr-legal{font-size:12px;color:var(--muted)}
.ftr-legal a{color:var(--sunset);text-decoration:none}
.ftr-disc{font-size:11px;color:var(--muted);max-width:400px;text-align:right;line-height:1.5}

/* REVEAL ANIMATION */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:1024px){
  .news-grid{grid-template-columns:1fr 1fr}
  .news-card.featured{grid-column:1/-1;grid-row:1}
  .tutos-grid{grid-template-columns:1fr 1fr}
  .map-wrap{grid-template-columns:1fr}
  .forum-grid{grid-template-columns:1fr 1fr}
  .ftr-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .hdr{padding:0 20px}
  nav a:not(.nav-cta){display:none}
  section{padding:60px 20px}
  .hero{padding:100px 20px 60px}
  .hero-vi{display:none}
  .cd-boxes{flex-wrap:wrap}
  .cd-box{min-width:90px;padding:18px 24px}
  .cd-num{font-size:44px}
  .news-grid,.tutos-grid,.videos-grid{grid-template-columns:1fr}
  .nl-form{flex-direction:column;border-radius:14px}
  .nl-form input{border-right:1px solid rgba(255,255,255,.1);border-bottom:none;border-radius:14px 14px 0 0}
  .nl-form button{border-radius:0 0 14px 14px}
  .forum-grid{grid-template-columns:1fr}
  .ftr-grid{grid-template-columns:1fr;gap:24px}
  .ftr-bot{flex-direction:column;align-items:flex-start}
  .ftr-disc{text-align:left}
}

/* ====================================================
   ARTICLE - SINGLE.PHP
   ==================================================== */

/* Hero article */
.art-hero{position:relative;padding:120px 48px 0;overflow:hidden;background:var(--bg)}
.art-hero-inner{position:relative;z-index:2;max-width:1100px;margin:0 auto}

/* Breadcrumb */
.art-breadcrumb{display:flex;align-items:center;gap:8px;font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:600;letter-spacing:1px;color:var(--muted);margin-bottom:20px;flex-wrap:wrap}
.art-breadcrumb a{color:var(--sunset);text-decoration:none}
.art-breadcrumb a:hover{text-decoration:underline}
.art-breadcrumb span{color:var(--muted)}

/* Tags */
.art-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.art-tag{display:inline-flex;align-items:center;background:rgba(61,184,168,.08);border:1px solid rgba(61,184,168,.2);color:var(--sunset);font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border-radius:20px}

/* Titre article */
.art-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(36px,5.5vw,72px);line-height:1;letter-spacing:2px;color:var(--ink);margin-bottom:28px;max-width:900px}

/* Meta row */
.art-meta-row{display:flex;align-items:center;justify-content:space-between;padding:20px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:36px;flex-wrap:wrap;gap:16px}
.art-author{display:flex;align-items:center;gap:12px}
.art-avatar{width:44px;height:44px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:20px;color:#fff;flex-shrink:0}
.art-author-name{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;color:var(--ink)}
.art-author-role{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:1px;color:var(--muted)}
.art-meta-right{display:flex;gap:20px;flex-wrap:wrap}
.art-meta-right span{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.5px}

/* Image principale */
.art-thumb{border-radius:20px;overflow:hidden;margin-bottom:0;max-height:520px;box-shadow:0 20px 60px rgba(61,184,168,.12)}
.art-thumb img{width:100%;height:520px;object-fit:cover;display:block}

/* Layout 2 colonnes */
.art-body-wrap{background:var(--bg);padding:0 48px 80px}
.art-layout{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 320px;gap:48px;padding-top:48px}

/* Contenu article */
.art-content{min-width:0}
.art-content h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(26px,3.5vw,40px);letter-spacing:2px;color:var(--ink);margin:48px 0 16px;padding-bottom:12px;border-bottom:2px solid var(--border)}
.art-content h2::before{content:'';display:inline-block;width:4px;height:28px;background:var(--grad);border-radius:2px;margin-right:12px;vertical-align:middle}
.art-content h3{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:700;color:var(--ink2);margin:32px 0 12px}
.art-content p{font-size:16px;line-height:1.85;color:var(--ink3);margin-bottom:20px}
.art-content strong{color:var(--ink);font-weight:600}
.art-content a{color:var(--sunset);text-decoration:none;border-bottom:1px solid rgba(61,184,168,.25);transition:border-color .2s}
.art-content a:hover{border-color:var(--sunset)}
.art-content ul,.art-content ol{padding-left:24px;margin-bottom:20px}
.art-content li{font-size:16px;line-height:1.85;color:var(--ink3);margin-bottom:8px}

/* Images dans le contenu */
.art-content img{width:100%;border-radius:14px;margin:28px 0;box-shadow:0 10px 40px rgba(61,184,168,.10);display:block}
.art-content figure{margin:28px 0}
.art-content figcaption{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:600;letter-spacing:1px;color:var(--muted);text-align:center;margin-top:10px}

/* Blocs spéciaux dans l'article */
.art-content .info-box{background:linear-gradient(135deg,rgba(232,93,64,.06),rgba(61,184,168,.06));border:1px solid rgba(61,184,168,.15);border-left:4px solid var(--blue);border-radius:0 12px 12px 0;padding:20px 24px;margin:28px 0}
.art-content .info-box p{margin:0;font-size:14px}
.art-content .warn-box{background:linear-gradient(135deg,rgba(212,146,10,.06),rgba(155,94,140,.06));border:1px solid rgba(155,94,140,.15);border-left:4px solid var(--violet);border-radius:0 12px 12px 0;padding:20px 24px;margin:28px 0}
.art-content .warn-box p{margin:0;font-size:14px}

/* Timeline dans article */
.timeline{list-style:none;padding:0;margin:32px 0;position:relative}
.timeline::before{content:'';position:absolute;left:16px;top:0;bottom:0;width:2px;background:var(--grad);border-radius:1px}
.timeline li{padding:0 0 28px 48px;position:relative}
.timeline li::before{content:'';position:absolute;left:8px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--grad);box-shadow:0 0 0 4px rgba(61,184,168,.12)}
.timeline-date{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px}
.timeline-title{font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:6px}
.timeline-desc{font-size:14px;line-height:1.7;color:var(--ink3)}

/* Stat cards dans article */
.art-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:32px 0}
.art-stat-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center}
.art-stat-val{font-family:'Bebas Neue',sans-serif;font-size:36px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.art-stat-lbl{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* art-quote — voir définition principale plus bas */

/* ====================================================
   SIDEBAR
   ==================================================== */
.art-sidebar{display:flex;flex-direction:column;gap:20px}
.side-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:24px}
.side-card-title{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--ink);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.side-countdown{background:linear-gradient(135deg,var(--ink),var(--ink2));border-color:transparent}
.side-countdown .side-card-title{color:rgba(255,255,255,.7);border-bottom-color:rgba(255,255,255,.1)}
.side-nl{background:linear-gradient(135deg,var(--ink),var(--ink2));border-color:transparent}
.side-nl .side-card-title{color:rgba(255,255,255,.7);border-bottom-color:rgba(255,255,255,.1)}

/* Articles récents sidebar */
.side-article{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);text-decoration:none;align-items:flex-start;transition:opacity .2s}
.side-article:last-child{border-bottom:none}
.side-article:hover{opacity:.75}
.side-art-thumb{width:64px;height:48px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--bg3)}
.side-art-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.side-art-body{flex:1;min-width:0}
.side-art-ttl{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.side-art-date{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;color:var(--muted)}

/* Navigation précédent/suivant */
.art-nav{background:var(--bg2);border-top:1px solid var(--border);padding:40px 48px}
.art-nav-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:20px}
.art-nav-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:20px 24px;text-decoration:none;transition:all .25s;display:block}
.art-nav-card:hover{border-color:rgba(61,184,168,.3);box-shadow:0 8px 24px rgba(61,184,168,.1);transform:translateY(-2px)}
.art-nav-next{text-align:right}
.art-nav-label{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px}
.art-nav-ttl{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;color:var(--ink);line-height:1.3}

/* Responsive article */
@media(max-width:900px){
  .art-hero{padding:100px 20px 0}
  .art-body-wrap{padding:0 20px 60px}
  .art-layout{grid-template-columns:1fr;gap:32px}
  .art-sidebar{order:-1}
  .art-nav{padding:32px 20px}
  .art-nav-inner{grid-template-columns:1fr}
  .art-stats{grid-template-columns:1fr 1fr}
}
@media(max-width:580px){
  .art-title{font-size:32px}
  .art-meta-row{flex-direction:column;align-items:flex-start}
  .art-stats{grid-template-columns:1fr}
}

/* ====================================================
   HERO SPLIT — nouveau layout
   ==================================================== */

/* Remplace l'ancien hero pleine largeur */
.hero-split{
  display:grid;
  grid-template-columns:1fr 1.15fr;
  min-height:520px;
  padding:0;
  align-items:stretch;
}

/* Supprime le hero-vi et hero-content de l'ancien layout */
.hero-split .hero-vi{display:none}
.hero-split .hero-content{display:none}

/* GAUCHE */
.hero-left{
  padding:100px 40px 60px 48px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
  z-index:2;
}

/* DROITE */
.hero-right{
  padding:100px 40px 48px 36px;
  display:flex;
  flex-direction:column;
  gap:12px;
  position:relative;
  z-index:2;
  justify-content:center;
  border-left:1px solid var(--border);
  background:rgba(255,255,255,0.45);
  backdrop-filter:blur(8px);
}

.hero-right-hdr{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:4px;
  padding-bottom:14px;
  border-bottom:1px solid var(--border);
}

.hero-right-label{
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:3px;
  text-transform:uppercase;
  background:var(--grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* Article featured (1er) */
.hero-art-featured{
  background:var(--white);
  border-radius:14px;
  border:1px solid var(--border);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:box-shadow .3s,transform .3s;
}
.hero-art-featured:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(61,184,168,.10);
}
.hero-art-thumb{
  height:200px;
  overflow:hidden;
  background:var(--bg3);
  flex-shrink:0;
}
.hero-art-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  display:block;
  transition:transform .4s;
  image-rendering:auto;
}
.hero-art-featured:hover .hero-art-thumb img{transform:scale(1.04)}
.hero-art-body{padding:16px 18px}
.hero-art-ttl-lg{
  font-family:'Barlow Condensed',sans-serif;
  font-size:16px;
  font-weight:700;
  color:var(--ink);
  line-height:1.3;
  margin:8px 0 10px;
}

/* Petits articles (2e, 3e, 4e) */
.hero-art-sm{
  display:flex;
  gap:12px;
  align-items:flex-start;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px 14px;
  text-decoration:none;
  transition:border-color .25s,box-shadow .25s,transform .25s;
}
.hero-art-sm:hover{
  border-color:rgba(61,184,168,.3);
  box-shadow:0 6px 20px rgba(61,184,168,.08);
  transform:translateX(3px);
}
.hero-art-sm-thumb{
  width:60px;
  height:46px;
  border-radius:7px;
  overflow:hidden;
  flex-shrink:0;
  background:var(--bg3);
}
.hero-art-sm-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.hero-art-sm-body{flex:1;min-width:0}
.hero-art-sm-ttl{
  font-family:'Barlow Condensed',sans-serif;
  font-size:13px;
  font-weight:700;
  color:var(--ink);
  line-height:1.3;
  margin-bottom:4px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.hero-art-sm-meta{
  font-family:'Barlow Condensed',sans-serif;
  font-size:10px;
  font-weight:600;
  color:var(--muted);
  letter-spacing:.5px;
}

/* COUNTDOWN — barre horizontale */
.countdown-bar .cd-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
  flex-wrap:wrap;
  text-align:left;
}
.countdown-bar .cd-bar-left{flex:1;min-width:200px}
.countdown-bar .cd-title{font-size:clamp(16px,2vw,26px);margin-bottom:0}
.countdown-bar .cd-boxes{
  flex-direction:row;
  justify-content:flex-end;
}
.countdown-bar .cd-box{min-width:90px;padding:16px 24px}
.countdown-bar .cd-num{font-size:44px}

/* Responsive hero split */
@media(max-width:1024px){
  .hero-split{grid-template-columns:1fr;min-height:auto}
  .hero-right{border-left:none;border-top:1px solid var(--border);padding:40px 20px}
  .hero-left{padding:100px 20px 40px}
  .countdown-bar .cd-inner{flex-direction:column;text-align:center}
  .countdown-bar .cd-boxes{justify-content:center}
}
@media(max-width:640px){
  .hero-art-featured{display:none}
  .hero-art-sm:first-of-type{display:flex}
}

/* ====================================================
   CARTE INTERACTIVE — IFRAME EMBED
   ==================================================== */
.map-embed-wrap{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:0;
  border-radius:20px;
  overflow:hidden;
  border:1px solid var(--border);
  min-height:560px;
  background:var(--white);
}
.map-embed-wrap .map-info{
  padding:36px 28px;
  border-right:1px solid var(--border);
  background:var(--white);
  display:flex;
  flex-direction:column;
}
.map-iframe-container{
  position:relative;
  background:var(--ink);
  min-height:560px;
  display:flex;
  flex-direction:column;
}
.map-iframe-container iframe{
  width:100%;
  height:100%;
  min-height:560px;
  border:none;
  display:block;
  flex:1;
}

/* Loader */
.map-iframe-loader{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  background:var(--ink);
  gap:16px;
  z-index:2;
  color:rgba(255,255,255,.6);
  font-family:'Barlow Condensed',sans-serif;
  font-size:13px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
}
.map-loader-spinner{
  width:40px;
  height:40px;
  border:3px solid rgba(255,255,255,.1);
  border-top-color:#E85D40;
  border-radius:50%;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* Fallback bloqué */
.map-iframe-blocked{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,var(--ink),var(--ink2));
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:16px;
  padding:40px;
  text-align:center;
}
.map-block-icon{font-size:48px}
.map-iframe-blocked h4{
  font-family:'Bebas Neue',sans-serif;
  font-size:28px;
  letter-spacing:2px;
  color:#fff;
}
.map-iframe-blocked p{
  font-family:'Barlow',sans-serif;
  font-size:14px;
  color:rgba(255,255,255,.55);
  max-width:320px;
  line-height:1.6;
}

/* Responsive */
@media(max-width:900px){
  .map-embed-wrap{grid-template-columns:1fr;min-height:auto}
  .map-embed-wrap .map-info{border-right:none;border-bottom:1px solid var(--border);padding:24px 20px}
  .map-iframe-container{min-height:420px}
  .map-iframe-container iframe{min-height:420px}
}
@media(max-width:580px){
  .map-iframe-container{min-height:320px}
  .map-iframe-container iframe{min-height:320px}
}

/* ====================================================
   SECTION MÉDIAS — carousel + vidéos
   ==================================================== */

#media{background:var(--bg);padding-bottom:0}

/* Labels internes */
.media-carousel-label,.media-videos-hdr{
  margin-bottom:16px;
}

/* ====== CAROUSEL ====== */
.media-carousel-wrap{
  margin-bottom:0;
  position:relative;
}
.media-carousel{
  position:relative;
  overflow:hidden;
  border-radius:16px;
  background:var(--ink);
  height:340px;
  cursor:grab;
}
.media-carousel:active{cursor:grabbing}
.media-carousel-track{
  display:flex;
  gap:12px;
  padding:16px;
  will-change:transform;
  transition:transform .1s linear;
  height:100%;
  align-items:center;
}
.media-carousel-slide{
  flex-shrink:0;
  width:320px;
  height:280px;
  border-radius:12px;
  overflow:hidden;
  background:var(--bg3);
  border:1px solid rgba(255,255,255,.06);
}
.media-carousel-slide img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .4s;
  pointer-events:none;
}
.media-carousel-slide:hover img{transform:scale(1.04)}

/* Boutons précédent/suivant */
.carousel-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  color:#fff;
  font-size:18px;
  cursor:pointer;
  backdrop-filter:blur(8px);
  transition:background .2s,transform .2s;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:10;
}
.carousel-btn:hover{background:rgba(61,184,168,.6);transform:translateY(-50%) scale(1.1)}
.carousel-prev{left:16px}
.carousel-next{right:16px}

/* Dégradés sur les bords pour un effet de fondu */
.media-carousel::before,
.media-carousel::after{
  content:'';
  position:absolute;
  top:0;
  bottom:0;
  width:80px;
  z-index:5;
  pointer-events:none;
}
.media-carousel::before{left:0;background:linear-gradient(to right,var(--ink),transparent)}
.media-carousel::after{right:0;background:linear-gradient(to left,var(--ink),transparent)}

/* Hint pause */
.carousel-pause-hint{
  position:absolute;
  bottom:10px;
  left:50%;
  transform:translateX(-50%);
  font-family:'Barlow Condensed',sans-serif;
  font-size:10px;
  font-weight:600;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.25);
  pointer-events:none;
}

/* Empty state */
.media-carousel-empty{
  background:var(--bg2);
  border:2px dashed var(--border);
  border-radius:16px;
  padding:60px 40px;
  text-align:center;
}
.media-empty-icon{font-size:48px;margin-bottom:16px}
.media-carousel-empty p{
  font-size:14px;
  line-height:1.7;
  color:var(--ink3);
}

/* ====== VIDÉOS ====== */
.media-videos-wrap{
  padding-top:48px;
  padding-bottom:80px;
}

/* Responsive */
@media(max-width:768px){
  .media-carousel{height:220px}
  .media-carousel-slide{width:240px;height:180px}
  .media-carousel-track{padding:10px}
}

/* ====================================================
   CARDS PERSONNAGES — image plein fond + dégradé
   ==================================================== */

/* Remplace la grille tuto-card pour la section #personnages */
#personnages .tutos-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

/* La card devient une image pleine hauteur */
#personnages .tuto-card{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  height:320px;
  padding:0;
  cursor:pointer;
  border:none;
  background:#1A0E28;
  transition:transform .3s,box-shadow .3s;
}
#personnages .tuto-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(0,0,0,.3);
}
#personnages .tuto-card::after{content:none}

/* Image de fond (photo mise en avant WP ou placeholder coloré) */
.pc-img-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center top;
  transition:transform .5s;
}
#personnages .tuto-card:hover .pc-img-bg{
  transform:scale(1.05);
}

/* Dégradé */
.pc-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(
    to bottom,
    rgba(26,14,40,0.05) 0%,
    rgba(26,14,40,0.15) 30%,
    rgba(26,14,40,0.72) 62%,
    rgba(26,14,40,0.97) 100%
  );
}

/* Numéro filigrane */
#personnages .tuto-n{
  position:absolute;
  top:12px;
  right:16px;
  font-family:'Bebas Neue',sans-serif;
  font-size:54px;
  color:rgba(255,255,255,.09);
  line-height:1;
  letter-spacing:2px;
  background:none;
  -webkit-text-fill-color:rgba(255,255,255,.09);
  pointer-events:none;
  z-index:1;
}

/* Contenu bas de carte */
.pc-body{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:20px 22px;
  z-index:2;
}

/* Masquer les anciens éléments qui ne s'affichent plus */
#personnages .tuto-icon{display:none}

/* Badge rôle */
.pc-role-badge{
  display:inline-flex;
  align-items:center;
  font-family:'Barlow Condensed',sans-serif;
  font-size:10px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:20px;
  margin-bottom:10px;
}
.role-prot{background:rgba(232,93,64,.25);color:#7ff0ff;border:1px solid rgba(232,93,64,.3)}
.role-ally{background:rgba(155,94,140,.25);color:#d4b8ff;border:1px solid rgba(155,94,140,.3)}
.role-crim{background:rgba(212,146,10,.25);color:#ffb3e6;border:1px solid rgba(212,146,10,.3)}
.role-anta{background:rgba(212,146,10,.25);color:#ffe08a;border:1px solid rgba(212,146,10,.3)}

/* Titre */
#personnages .tuto-ttl{
  font-family:'Bebas Neue',sans-serif;
  font-size:26px;
  letter-spacing:2px;
  color:#fff;
  line-height:1.05;
  margin-bottom:8px;
}
#personnages .tuto-ttl a{color:#fff}

/* Extrait */
#personnages .tuto-desc{
  font-family:'Barlow',sans-serif;
  font-size:12px;
  font-weight:300;
  line-height:1.6;
  color:rgba(255,255,255,.7);
  margin-bottom:14px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* Lien lire */
#personnages .tuto-foot{
  display:flex;
  align-items:center;
  border:none;
  padding:0;
  gap:0;
}
#personnages .tuto-time{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.75);
  transition:color .2s;
}
#personnages .tuto-card:hover .tuto-time{color:#fff}

/* Barre gradient bas de carte au hover */
.pc-accent-bar{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:3px;
  background:linear-gradient(90deg,#E85D40,#3DB8A8,#9B5E8C);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s;
  z-index:3;
}
#personnages .tuto-card:hover .pc-accent-bar{transform:scaleX(1)}

/* Couleurs de fond fallback quand pas d'image (rotation) */
.pc-fallback-1{background:linear-gradient(135deg,#1A0E28,#1A3050)}
.pc-fallback-2{background:linear-gradient(135deg,#1A0A28,#3A1050)}
.pc-fallback-3{background:linear-gradient(135deg,#1A0E28,#102840)}
.pc-fallback-4{background:linear-gradient(135deg,#28100A,#501828)}
.pc-fallback-5{background:linear-gradient(135deg,#0A2820,#104030)}
.pc-fallback-6{background:linear-gradient(135deg,#201028,#402050)}

/* Responsive */
@media(max-width:1024px){
  #personnages .tutos-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  #personnages .tutos-grid{grid-template-columns:1fr}
  #personnages .tuto-card{height:260px}
}

/* ====================================================
   CITATIONS art-quote — Variante B (card compacte + badge)
   ==================================================== */

.art-quote {
  position: relative;
  overflow: hidden;
  padding: 18px 24px 16px 20px;
  border-left: 3px solid #3DB8A8;
  border-radius: 0 10px 10px 0;
  background: linear-gradient(135deg, rgba(61,184,168,.06), rgba(155,94,140,.04));
  border-top: 1px solid rgba(61,184,168,.12);
  border-right: 1px solid rgba(61,184,168,.08);
  border-bottom: 1px solid rgba(61,184,168,.08);
  margin: 32px 0;
}
.art-quote::after {
  content: '';
  position: absolute;
  top: -30px;
  right: -30px;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, rgba(61,184,168,.08), transparent 70%);
  pointer-events: none;
}
.art-quote::before { content: none; }
.art-quote-badge {
  display: inline-flex;
  align-items: center;
  background: rgba(61,184,168,.1);
  border: 1px solid rgba(61,184,168,.25);
  border-radius: 20px;
  padding: 3px 10px;
  margin-bottom: 10px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #3DB8A8;
}
.art-quote p {
  font-family: 'Barlow', sans-serif;
  font-size: 17px;
  font-weight: 400;
  font-style: italic;
  line-height: 1.65;
  color: var(--ink, #2E1A3A);
  margin: 0 0 12px;
  position: relative;
  z-index: 1;
}
.art-quote p::before { content: none; }
.art-quote cite {
  display: block;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--ink3, #8A7A80);
  font-style: normal;
  position: relative;
  z-index: 1;
}

/* Halo de fond */
.art-quote::after {
  content: '';
  position: absolute;
  top: -30px;
  right: -30px;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, rgba(61,184,168,.08), transparent 70%);
  pointer-events: none;
}
/* art-quote p::before — désactivé */
.art-quote p::before { content: none; }
.art-quote p {
  font-family: 'Barlow', sans-serif;
  font-size: 17px;
  font-weight: 400;
  font-style: italic;
  line-height: 1.65;
  color: var(--ink, #2E1A3A);
  margin: 0 0 14px;
  position: relative;
  z-index: 1;
}
.art-quote p::before { content: none; }
.art-quote cite {
  display: block;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--ink3, #8A7A80);
  font-style: normal;
  position: relative;
  z-index: 1;
}

/* ====================================================
   ARTICLE CONTENT — classes manquantes
   ==================================================== */

/* Stat cards */
.art-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:28px 0}
.art-stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:18px;text-align:center}
.art-stat-val{font-family:'Bebas Neue',sans-serif;font-size:30px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;display:block}
.art-stat-lbl{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:4px;display:block}

/* Grille de détails (cards catégorie / mécaniques) */
.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:24px 0}
.detail-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:14px 16px}
.detail-cat{font-family:'Barlow Condensed',sans-serif;font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px;display:block}
.detail-txt{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--ink);line-height:1.35;display:block}

/* Banner de records */
.record-banner{background:linear-gradient(135deg,#1A0E28,#2E1A3A);border-radius:16px;padding:28px 32px;margin:28px 0;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;text-align:center}
.rec-val{font-family:'Bebas Neue',sans-serif;font-size:40px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;display:block}
.rec-lbl{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:4px;display:block}

/* Timeline */
.timeline{list-style:none;padding:0;margin:28px 0;position:relative}
.timeline::before{content:'';position:absolute;left:14px;top:0;bottom:0;width:2px;background:var(--grad);border-radius:1px}
.timeline li{padding:0 0 24px 44px;position:relative}
.timeline li::before{content:'';position:absolute;left:7px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--grad);box-shadow:0 0 0 4px rgba(61,184,168,.1)}
.timeline-date{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:3px;display:block}
.timeline-title{font-family:'Barlow Condensed',sans-serif;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:5px;display:block}
.timeline-desc{font-size:14px;line-height:1.7;color:var(--ink3)}

/* Info & warn boxes */
.info-box{background:linear-gradient(135deg,rgba(232,93,64,.06),rgba(61,184,168,.06));border:1px solid rgba(61,184,168,.15);border-left:4px solid var(--blue);border-radius:0 12px 12px 0;padding:18px 22px;margin:26px 0;font-size:15px;color:var(--ink3);line-height:1.7}
.warn-box{background:linear-gradient(135deg,rgba(155,94,140,.06),rgba(212,146,10,.06));border:1px solid rgba(155,94,140,.15);border-left:4px solid var(--violet);border-radius:0 12px 12px 0;padding:18px 22px;margin:26px 0;font-size:15px;color:var(--ink3);line-height:1.7}

/* Quote */
/* art-quote — voir definition principale ci-dessus */

/* Responsive articles */
@media(max-width:768px){
  .art-stats{grid-template-columns:repeat(2,1fr)}
  .details-grid{grid-template-columns:1fr}
  .record-banner{grid-template-columns:1fr}
}

/* ====================================================
   LIGHTBOX — popup images articles
   ==================================================== */

/* Overlay */
.lb-overlay{
  position:fixed;
  inset:0;
  background:rgba(5,12,25,.93);
  backdrop-filter:blur(8px);
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
}
.lb-overlay.lb-open{
  opacity:1;
  pointer-events:auto;
}

/* Conteneur image */
.lb-box{
  position:relative;
  max-width:90vw;
  max-height:90vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  transform:scale(.95);
  transition:transform .25s ease;
}
.lb-overlay.lb-open .lb-box{
  transform:scale(1);
}

/* Image */
.lb-img{
  max-width:90vw;
  max-height:80vh;
  object-fit:contain;
  border-radius:12px;
  box-shadow:0 32px 80px rgba(0,0,0,.6);
  display:block;
}

/* Légende */
.lb-caption{
  margin-top:14px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:13px;
  font-weight:600;
  letter-spacing:1px;
  color:rgba(255,255,255,.55);
  text-align:center;
  max-width:600px;
  line-height:1.5;
}

/* Compteur */
.lb-counter{
  margin-top:6px;
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.25);
}

/* Bouton fermer */
.lb-close{
  position:absolute;
  top:-44px;
  right:0;
  width:36px;
  height:36px;
  border-radius:50%;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;
  font-size:18px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .2s;
  line-height:1;
}
.lb-close:hover{ background:rgba(255,255,255,.2); }

/* Navigation précédent / suivant */
.lb-prev,
.lb-next{
  position:fixed;
  top:50%;
  transform:translateY(-50%);
  width:48px;
  height:48px;
  border-radius:50%;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  font-size:20px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .2s,transform .2s;
  z-index:10000;
}
.lb-prev{ left:20px; }
.lb-next{ right:20px; }
.lb-prev:hover{ background:rgba(61,184,168,.4); transform:translateY(-50%) scale(1.1); }
.lb-next:hover{ background:rgba(61,184,168,.4); transform:translateY(-50%) scale(1.1); }
.lb-prev.lb-hidden,
.lb-next.lb-hidden{ display:none; }

/* Loader spinner */
.lb-loader{
  width:40px;
  height:40px;
  border:3px solid rgba(255,255,255,.1);
  border-top-color:#3DB8A8;
  border-radius:50%;
  animation:lb-spin .7s linear infinite;
  display:none;
}
.lb-loading .lb-loader{ display:block; }
.lb-loading .lb-img{ display:none; }
@keyframes lb-spin{ to{ transform:rotate(360deg); } }

/* Curseur zoom sur les images cliquables dans les articles */
.entry-content figure img,
.art-content figure img,
.entry-content img:not(.wp-post-image):not(.avatar),
.art-content img,
[class*="img-duo"] img,
[class*="img-trio"] img{
  cursor:zoom-in;
  transition:transform .3s,box-shadow .3s;
}
.entry-content figure img:hover,
.art-content figure img:hover,
[class*="img-duo"] img:hover,
[class*="img-trio"] img:hover{
  transform:scale(1.015);
  box-shadow:0 8px 30px rgba(0,0,0,.2);
}

/* ====================================================
   SECTION LIEUX — cards image plein fond + améliorations
   ==================================================== */

/* Section fond légèrement différent des personnages */
.lieux-sec{
  background:linear-gradient(180deg, var(--bg2) 0%, var(--bg) 100%);
}

/* Réutilise la grille personnages */
#lieux .tutos-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

/* Card lieux — même base que personnages */
.lieu-card{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  height:320px;
  padding:0;
  cursor:pointer;
  border:none;
  background:#1A0E28;
  transition:transform .3s,box-shadow .3s;
  display:block;
  text-decoration:none;
}
.lieu-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(0,0,0,.35);
}

/* Image zoom au hover */
.lieu-card .pc-img-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  transition:transform .5s;
}
.lieu-card:hover .pc-img-bg{
  transform:scale(1.05);
}

/* Dégradé lieux : plus coloré, légèrement bleuté sur les bords */
.lieu-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(to bottom,
      rgba(26,14,40,0.0)  0%,
      rgba(26,14,40,0.1)  25%,
      rgba(26,14,40,0.68) 58%,
      rgba(26,14,40,0.97) 100%),
    linear-gradient(to right,
      rgba(61,184,168,0.08) 0%,
      transparent 40%);
}

/* Numéro filigrane */
#lieux .tuto-n{
  position:absolute;
  top:12px;
  right:16px;
  font-family:'Bebas Neue',sans-serif;
  font-size:54px;
  color:rgba(255,255,255,.08);
  line-height:1;
  letter-spacing:2px;
  background:none;
  -webkit-text-fill-color:rgba(255,255,255,.08);
  pointer-events:none;
  z-index:1;
}

/* Point de localisation animé (coin haut gauche) */
.lieu-pin{
  position:absolute;
  top:16px;
  left:16px;
  width:10px;
  height:10px;
  color:var(--sunset);
  font-size:10px;
  line-height:1;
  z-index:2;
  animation:lieu-pulse 2s ease-in-out infinite;
}
.lieu-pin::after{
  content:'';
  position:absolute;
  inset:-4px;
  border-radius:50%;
  border:1px solid var(--cyan);
  opacity:.4;
  animation:lieu-ring 2s ease-in-out infinite;
}
@keyframes lieu-pulse{
  0%,100%{opacity:.6}
  50%{opacity:1}
}
@keyframes lieu-ring{
  0%,100%{transform:scale(1);opacity:.4}
  50%{transform:scale(1.6);opacity:0}
}

/* Corps bas de carte */
.lieu-card .pc-body{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:20px 22px;
  z-index:2;
}

/* Titres et textes */
#lieux .tuto-ttl{
  font-family:'Bebas Neue',sans-serif;
  font-size:24px;
  letter-spacing:2px;
  color:#fff;
  line-height:1.05;
  margin-bottom:8px;
}
#lieux .tuto-desc{
  font-family:'Barlow',sans-serif;
  font-size:12px;
  font-weight:300;
  line-height:1.6;
  color:rgba(255,255,255,.68);
  margin-bottom:12px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
#lieux .tuto-foot{border:none;padding:0}
#lieux .tuto-time{
  font-family:'Barlow Condensed',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
  transition:color .2s;
}
.lieu-card:hover .tuto-time{color:#fff}

/* Barre accent lieux : dégradé bleu-cyan (différent des personnages) */
.lieu-bar{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:3px;
  background:linear-gradient(90deg,#3DB8A8,#E85D40,#3DB8A8);
  background-size:200% 100%;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s cubic-bezier(.22,.61,.36,1);
  z-index:3;
  animation:none;
}
.lieu-card:hover .lieu-bar{
  transform:scaleX(1);
  animation:lieu-bar-shine 1.5s linear infinite;
}
@keyframes lieu-bar-shine{
  0%{background-position:0% 0%}
  100%{background-position:200% 0%}
}

/* Badges types de zone — palette carte/géographie */
.lieu-ville    {background:rgba(61,184,168,.25);color:#8ec6ff;border:1px solid rgba(61,184,168,.4)}
.lieu-archipel {background:rgba(232,93,64,.22);color:#7ff0ff;border:1px solid rgba(232,93,64,.35)}
.lieu-marecage {background:rgba(30,160,80,.22);color:#7de8a0;border:1px solid rgba(30,160,80,.35)}
.lieu-cote     {background:rgba(200,160,40,.22);color:#ffe08a;border:1px solid rgba(200,160,40,.35)}
.lieu-industrie{background:rgba(180,80,40,.22);color:#ffb08a;border:1px solid rgba(180,80,40,.35)}
.lieu-montagne {background:rgba(120,100,200,.22);color:#ccc0ff;border:1px solid rgba(120,100,200,.35)}

/* Responsive */
@media(max-width:1024px){
  #lieux .tutos-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  #lieux .tutos-grid{grid-template-columns:1fr}
  .lieu-card{height:260px}
}

/* ====================================================
   HERO MAGAZINE — Layout A
   ==================================================== */
.hero-mag{background:var(--white);padding:0;margin-top:98px}
.hero-mag-inner{width:100%;max-width:100%;padding:0}

/* Ligne haute : hero + colonne */
.mag-top{display:grid;grid-template-columns:1.85fr 1fr;gap:0;align-items:start;width:100%}

/* Grande hero image */
.mag-hero{
  display:block;
  position:relative;
  border-radius:0;
  overflow:hidden;
  height:440px;
  text-decoration:none;
  background:var(--bg3);
}
.mag-hero img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;
  transition:transform .5s;
}
.mag-hero:hover img{transform:scale(1.03)}
.mag-hero-overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:32px 36px 28px;
  background:linear-gradient(0deg,rgba(26,14,40,.92) 0%,rgba(26,14,40,.5) 60%,transparent 100%);
}
.mag-hero-ttl{
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(20px,2.4vw,30px);
  font-weight:800;
  color:#fff;
  line-height:1.2;
  margin:8px 0 7px;
}
.mag-hero-meta{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:600;letter-spacing:1px;color:rgba(255,255,255,.45)}

/* Colonne latérale */
.mag-side{display:flex;flex-direction:column;gap:0;padding:0 24px;background:var(--white);height:440px;overflow-y:auto}
.mag-side-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:10px;margin-bottom:4px;
  border-bottom:1px solid var(--border);
}
.mag-side-item{
  display:grid;grid-template-columns:80px 1fr;gap:10px;
  padding:10px 0;
  border-bottom:1px solid var(--border);
  text-decoration:none;
  transition:background .2s;
}
.mag-side-item:hover .mag-side-ttl{color:var(--sunset)}
.mag-side-thumb{
  width:80px;height:60px;
  border-radius:8px;overflow:hidden;
  flex-shrink:0;background:var(--bg3);
}
.mag-side-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.mag-side-item:hover .mag-side-thumb img{transform:scale(1.05)}
.mag-side-ttl{
  font-family:'Barlow Condensed',sans-serif;
  font-size:13px;font-weight:700;
  color:var(--ink);line-height:1.35;
  margin-top:2px;
}
.mag-side-meta{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:600;letter-spacing:.5px;color:var(--muted);margin-top:4px}

/* Grille basse : 4 articles */
.mag-grid4{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  border-top:1px solid var(--border);
  padding-bottom:0;
}
.mag-card{display:block;text-decoration:none;border-radius:0;overflow:hidden;background:var(--white);border-right:1px solid var(--border);transition:background .25s}
.mag-card:last-child{border-right:none}
.mag-card:hover{background:var(--bg)}
.mag-card-thumb{height:160px;overflow:hidden;background:var(--bg3)}
.mag-card-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.mag-card:hover .mag-card-thumb img{transform:scale(1.04)}
.mag-card-body{padding:14px 18px 18px}
.mag-card-ttl{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;color:var(--ink);line-height:1.35;margin:6px 0 5px}

/* Responsive */
@media(max-width:900px){
  .mag-top{grid-template-columns:1fr}
  .mag-hero{height:280px}
  .mag-side{height:auto;overflow-y:visible}
  .mag-grid4{grid-template-columns:repeat(2,1fr)}
  .mag-card{border-bottom:1px solid var(--border)}
}
@media(max-width:580px){
  .mag-grid4{grid-template-columns:1fr}
}

/* ====================================================
   LAYOUT W3 — Design magazine (inspiré index__3_.html)
   ==================================================== */

/* ── HERO ──────────────────────────────────────────── */
.w3-hero{
  position:relative;
  min-height:520px;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  margin-top:98px;
}
.w3-hero-bg{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,#fdf0ea 0%,#f5e4d8 25%,#ede0d4 50%,#f0e8e0 75%,var(--bg) 100%),
    radial-gradient(ellipse 70% 60% at 15% 40%,rgba(232,93,64,.14) 0%,transparent 55%),
    radial-gradient(ellipse 60% 50% at 80% 60%,rgba(155,94,140,.10) 0%,transparent 55%),
    radial-gradient(ellipse 40% 40% at 50% 20%,rgba(61,184,168,.08) 0%,transparent 50%);
}
.w3-hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(61,184,168,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(61,184,168,.06) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:linear-gradient(to bottom,transparent,black 30%,black 70%,transparent);
}
.w3-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:160px;
  background:linear-gradient(to bottom,transparent,var(--bg));
  z-index:5;pointer-events:none;
}
.w3-hero-content{
  position:relative;z-index:10;
  max-width:1400px;margin:0 auto;padding:0 48px 72px;width:100%;
}
.w3-hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--sunset);color:#fff;
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:2px;padding:4px 12px;border-radius:3px;
  margin-bottom:20px;
  box-shadow:0 4px 16px rgba(61,184,168,.35);
}
.w3-hero-tag::before{content:'';width:6px;height:6px;background:#fff;border-radius:50%;animation:blink 1.5s ease-in-out infinite}
.w3-hero-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(42px,7vw,96px);
  line-height:.95;letter-spacing:1px;
  color:var(--ink);
  margin-bottom:20px;
  max-width:860px;
  text-shadow:0 2px 20px rgba(255,255,255,.7);
}
.w3-hero-meta{display:flex;align-items:center;gap:16px}
.w3-hero-meta-date{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.5px}
.w3-hero-meta-sep{color:rgba(61,184,168,.3)}
.w3-hero-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(135deg,var(--sunset),var(--violet));
  color:#fff;font-family:'Barlow Condensed',sans-serif;
  font-size:14px;font-weight:700;letter-spacing:1.5px;
  padding:13px 28px;border-radius:5px;
  margin-top:28px;
  box-shadow:0 6px 24px rgba(61,184,168,.4);
  transition:opacity .2s,transform .2s,box-shadow .2s;
}
.w3-hero-btn:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 10px 32px rgba(61,184,168,.5)}
.w3-hero-btn svg{transition:transform .2s}
.w3-hero-btn:hover svg{transform:translateX(4px)}

/* Image mise en avant dans le hero */
.w3-hero-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform .5s;
}
.w3-hero:hover .w3-hero-img{transform:scale(1.02)}
.w3-hero-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(
    105deg,
    rgba(245,240,236,.92) 0%,
    rgba(240,228,220,.80) 40%,
    rgba(220,200,190,.40) 70%,
    transparent 100%
  );
}
/* Quand image présente : masquer le bg dégradé générique */
.w3-hero:has(.w3-hero-img) .w3-hero-bg{opacity:0}
.w3-hero:has(.w3-hero-img) .w3-hero-grid{opacity:.4}
.w3-sec-label{
  display:flex;align-items:center;gap:14px;
  margin-bottom:32px;
  padding-bottom:20px;
  border-bottom:2px solid var(--border);
}
.w3-sec-label h2{
  font-family:'Bebas Neue',sans-serif;font-size:28px;
  letter-spacing:2px;color:var(--ink);
}
.w3-sec-label::before{
  content:'';display:block;width:4px;height:28px;
  background:linear-gradient(180deg,var(--sunset),var(--teal));
  border-radius:2px;flex-shrink:0;
}
.w3-see-all{
  margin-left:auto;
  font-family:'Barlow Condensed',sans-serif;font-size:12px;
  font-weight:700;letter-spacing:1.5px;color:var(--muted);
  text-transform:uppercase;display:flex;align-items:center;gap:6px;
  transition:color .2s;
}
.w3-see-all:hover{color:var(--sunset)}

/* ── NEWS SECTION ──────────────────────────────────── */
.w3-news-section{padding:60px 0}
#news.w3-news-section .container{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
#news.w3-news-section .w3-sec-label{grid-column:1/-1}

.w3-news-card{
  background:var(--white);
  border:1px solid rgba(61,184,168,.1);
  border-radius:10px;overflow:hidden;
  transition:transform .25s,border-color .25s,box-shadow .25s;
  box-shadow:0 2px 12px rgba(0,0,0,.05);
}
.w3-news-card:hover{
  transform:translateY(-6px);
  border-color:rgba(61,184,168,.3);
  box-shadow:0 16px 48px rgba(61,184,168,.12),0 4px 16px rgba(0,0,0,.07);
}
.w3-news-featured{grid-column:auto}
.w3-news-img{
  position:relative;
  overflow:hidden;
  aspect-ratio:16/7;
}
.w3-news-featured .w3-news-img{aspect-ratio:16/7}
.w3-news-img a{display:block;width:100%;height:100%;position:relative}
/* Image principale en cover */
.w3-news-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;
  position:relative;z-index:1;
  transition:transform .5s;
}
.w3-news-card:hover .w3-news-img img{transform:scale(1.04)}
/* Dégradé subtil en bas de l'image */
.w3-news-img a::after{
  content:'';
  position:absolute;bottom:0;left:0;right:0;height:50%;
  background:linear-gradient(to bottom,transparent,rgba(26,14,40,.45));
  z-index:2;pointer-events:none;
}
.w3-cat-tag{
  position:absolute;top:12px;left:12px;z-index:4;
  font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:3px 10px;border-radius:3px;
}
.w3-news-body{padding:12px 16px 14px}
.w3-news-body h3{
  font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;
  line-height:1.3;margin-bottom:6px;color:var(--ink);
  transition:color .2s;
}
.w3-news-featured .w3-news-body h3{font-size:14px}
.w3-news-card:hover .w3-news-body h3{color:var(--sunset)}
.w3-news-body a{text-decoration:none;color:inherit}
.w3-news-body p{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:12px}
.w3-news-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:10px;border-top:1px solid rgba(0,0,0,.07);
}
.w3-news-date,.w3-news-read{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;
  font-weight:600;letter-spacing:.5px;color:var(--muted);
}

/* ── DIVIDER ───────────────────────────────────────── */
.w3-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(61,184,168,.15),transparent);margin:0}

/* ── RESPONSIVE ────────────────────────────────────── */
@media(max-width:1024px){
  #news.w3-news-section .container{grid-template-columns:1fr 1fr}
  .w3-news-featured{grid-column:1/3}
}
@media(max-width:768px){
  .w3-hero{min-height:380px}
  .w3-hero-content{padding:0 24px 56px}
  #news.w3-news-section .container{grid-template-columns:1fr}
  .w3-news-featured{grid-column:1}
  .w3-news-featured .w3-news-img{height:220px}
}

/* ====================================================
   HP NEWS — Style page catégorie (dark cards)
   ==================================================== */
.hp-news-section{padding:52px 0 60px;background:var(--white)}
.hp-news-section .container{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.hp-news-section .w3-sec-label{grid-column:1/-1}

/* Card commune */
.hp-card{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  text-decoration:none;
  display:block;
  background:#111828;
  transition:transform .32s cubic-bezier(.22,.61,.36,1),box-shadow .32s;
}
.hp-card:hover{
  transform:translateY(-6px) scale(1.01);
  box-shadow:0 24px 55px rgba(0,0,0,.35);
}

/* Card featured : pleine largeur */
.hp-card-featured{grid-column:1/-1;display:grid;grid-template-columns:1.6fr 1fr;grid-template-rows:1fr}
.hp-card-featured .hp-card-img{height:100%;min-height:260px}
.hp-card-featured .hp-card-body{padding:28px 28px;display:flex;flex-direction:column;justify-content:center}
.hp-card-featured .hp-card-title{font-size:28px}
.hp-card-featured .hp-card-exc{-webkit-line-clamp:3}

/* Image */
.hp-card-img{overflow:hidden;height:180px;position:relative}
.hp-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.22,.61,.36,1)}
.hp-card:hover .hp-card-img img{transform:scale(1.06)}
.hp-card-noimg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:44px;letter-spacing:3px;color:rgba(255,255,255,.08)}

/* Body */
.hp-card-body{padding:16px 18px 18px;background:rgba(255,255,255,.025)}
.hp-card-badge{
  display:inline-block;
  font-family:'Barlow Condensed',sans-serif;font-size:9px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:3px 9px;border-radius:20px;
  border:1px solid;
  margin-bottom:8px;
}
.hp-card-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:20px;letter-spacing:1.5px;
  color:#fff;line-height:1.1;
  margin-bottom:8px;
}
.hp-card-exc{
  font-family:'Barlow',sans-serif;font-size:13px;font-weight:300;
  line-height:1.65;color:rgba(255,255,255,.45);
  display:-webkit-box;-webkit-box-orient:vertical;
  -webkit-line-clamp:2;overflow:hidden;
  margin-bottom:12px;
}
.hp-card-foot{display:flex;align-items:center;justify-content:space-between}
.hp-card-date{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:1px;color:rgba(255,255,255,.22)}
.hp-card-cta{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.35);
  display:flex;align-items:center;gap:5px;
  transition:color .2s,gap .2s;
}
.hp-card:hover .hp-card-cta{color:#fff;gap:9px}

/* Barre couleur hover */
.hp-card-bar{
  position:absolute;bottom:0;left:0;right:0;height:3px;
  transform:scaleX(0);transform-origin:left;
  transition:transform .38s cubic-bezier(.22,.61,.36,1);
  z-index:3;
}
.hp-card:hover .hp-card-bar{transform:scaleX(1)}

/* Responsive */
@media(max-width:1024px){
  .hp-news-section .container{grid-template-columns:repeat(2,1fr)}
  .hp-card-featured{grid-template-columns:1fr;grid-template-rows:200px auto}
}
@media(max-width:640px){
  .hp-news-section .container{grid-template-columns:1fr}
  .hp-card-featured{grid-column:1}
}

/* ====================================================
   HP NEWS SECTION — exact layout catégorie
   ==================================================== */
.hp-news-section{padding:52px 0 60px;background:var(--white)}
.hp-news-inner{
  max-width:1300px;margin:0 auto;padding:0 40px;
  --cat-grad:linear-gradient(135deg,#E85D40,#3DB8A8);
  --cat-color:#E85D40;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.hp-news-inner .w3-sec-label{grid-column:1/-1}

/* Featured : premier article pleine largeur */
.hp-news-inner .cat-card:first-of-type{grid-column:1/-1}
.hp-news-inner .cat-card:first-of-type .cat-card-img-wrap{height:380px}
.hp-news-inner .cat-card:first-of-type .cat-card-no-img{height:380px}
.hp-news-inner .cat-card:first-of-type .cat-card-title{font-size:30px}
.hp-news-inner .cat-card:first-of-type .cat-card-exc{-webkit-line-clamp:3}

/* Autres cards */
.hp-news-inner .cat-card .cat-card-img-wrap{height:210px}
.hp-news-inner .cat-card .cat-card-no-img{height:210px;font-size:44px}
.hp-news-inner .cat-card .cat-card-body{padding:18px 20px 20px}
.hp-news-inner .cat-card .cat-card-title{font-size:20px}
.hp-news-inner .cat-card .cat-card-exc{-webkit-line-clamp:2}

/* Responsive */
@media(max-width:1024px){
  .hp-news-inner{grid-template-columns:repeat(2,1fr);padding:0 24px}
  .hp-news-inner .cat-card:first-of-type{grid-column:1/-1}
}
@media(max-width:640px){
  .hp-news-inner{grid-template-columns:1fr}
  .hp-news-inner .cat-card:first-of-type{grid-column:1}
}

/* ====================================================
   CAT-CARD — styles communs (homepage + catégorie)
   ==================================================== */
.cat-card{
  position:relative;border-radius:16px;overflow:hidden;
  text-decoration:none;display:block;
  background:linear-gradient(160deg,#ffffff 0%,#fdf5f0 60%,#f5ede8 100%);
  border:1px solid var(--border);
  box-shadow:0 2px 12px rgba(26,14,40,.06);
  transition:transform .32s cubic-bezier(.22,.61,.36,1),box-shadow .32s;
}
.cat-card:hover{
  transform:translateY(-5px);
  box-shadow:0 18px 45px rgba(26,14,40,.14),0 0 0 1px rgba(232,93,64,.2);
  border-color:rgba(232,93,64,.25);
}
.cat-card-img-wrap{position:relative;overflow:hidden}
.cat-card-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.22,.61,.36,1)}
.cat-card:hover .cat-card-img{transform:scale(1.05)}
.cat-card-no-img{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(232,93,64,.08),rgba(155,94,140,.06));font-size:44px}
.cat-card-body{padding:18px 20px 20px;background:transparent}
.cat-badge{
  display:inline-block;font-family:'Barlow Condensed',sans-serif;
  font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  padding:3px 9px;border-radius:20px;
  background:rgba(61,184,168,.08);color:var(--sunset);
  border:1px solid rgba(61,184,168,.15);
  margin-bottom:8px;
}
.cat-card-title{
  font-family:'Bebas Neue',sans-serif;letter-spacing:1.5px;
  color:var(--ink);line-height:1.1;margin-bottom:8px;font-size:20px;
}
.cat-card-exc{
  font-family:'Barlow',sans-serif;font-size:13px;font-weight:400;
  line-height:1.65;color:var(--ink3);
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;
  overflow:hidden;margin-bottom:12px;
}
.cat-card-foot{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--border)}
.cat-card-date{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:1px;color:var(--muted)}
.cat-card-cta{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;color:var(--muted);
  display:flex;align-items:center;gap:5px;transition:color .2s,gap .2s;
}
.cat-card:hover .cat-card-cta{color:var(--sunset);gap:9px}
.cat-card-bar{
  position:absolute;bottom:0;left:0;right:0;height:3px;
  background:var(--cat-grad,linear-gradient(135deg,#E85D40,#3DB8A8));
  transform:scaleX(0);transform-origin:left;
  transition:transform .38s cubic-bezier(.22,.61,.36,1);z-index:3;
}
.cat-card:hover .cat-card-bar{transform:scaleX(1)}
