/*
Theme Name: Alexandre Zyzeck
Theme URI: https://alexandre-zyzeck.com
Author: Alexandre Zyzeck
Description: Thème professionnel — Bleu roi & Or — Mobile-first
Version: 4.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: Proprietary
Text Domain: az-theme
*/

/* ============================================================
   VARIABLES
   ============================================================ */
:root {
  --navy:       #0d1b3e;
  --navy-deep:  #060c1a;
  --navy-mid:   #1a3270;
  --gold:       #C9A84C;
  --gold-light: #E8C96A;
  --gold-pale:  rgba(201,168,76,.12);
  --gold-border:rgba(201,168,76,.35);
  --white:      #ffffff;
  --off-white:  #f6f4ef;
  --gray-100:   #ece9e0;
  --gray-300:   #bbb;
  --gray-500:   #555;
  --font-display:'Bebas Neue','Arial Black',sans-serif;
  --font-body:   'DM Sans',Arial,sans-serif;
  --r: 6px;
  --max: 1060px;
  --ease: .22s ease;
}

/* ============================================================
   RESET — MOBILE FIRST
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;min-width:320px;overflow-x:hidden}
body{font-family:var(--font-body);background:var(--white);color:var(--navy);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;word-wrap:break-word}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button,input,textarea,select{font-family:inherit}

.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 1.25rem;min-width:0}
/* Anti-débordement universel — zoom mobile/iPad */
*{max-width:100%}
img,video,iframe,embed,object{max-width:100%;height:auto}
table{width:100%;table-layout:fixed}
pre,code{white-space:pre-wrap;word-break:break-word}
input,textarea,select,button{max-width:100%}

@media(min-width:640px){.container{padding:0 2rem}}
@media(min-width:1080px){.container{padding:0 2.5rem}}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2{font-family:var(--font-display);font-weight:400;letter-spacing:.03em;line-height:1;color:var(--navy)}
h1{font-size:clamp(2.6rem,10vw,6rem)}
h2{font-size:clamp(1.8rem,6vw,3rem)}
h3{font-size:1.1rem;font-weight:700;line-height:1.3;color:var(--navy)}
p{font-size:1rem;color:var(--gray-500);line-height:1.75}

.eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--gold-pale);border:1px solid var(--gold-border);padding:5px 14px;border-radius:3px;margin-bottom:1.25rem}
.eyebrow span{font-family:var(--font-body);font-size:.65rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2s ease-in-out infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border-radius:var(--r);cursor:pointer;transition:all var(--ease);font-size:.82rem;padding:13px 28px;white-space:nowrap;border:none}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--navy)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,.4)}
.btn-secondary{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.3)}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--gray-100)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
@media(max-width:480px){
  .btn{padding:14px 20px;font-size:.8rem}
  .hero-actions .btn{width:100%}
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:sticky;top:0;z-index:200;background:var(--navy);border-bottom:3px solid var(--gold)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:60px}
@media(min-width:640px){.nav-inner{height:68px}}

.site-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:36px;height:36px;background:linear-gradient(135deg,var(--gold),var(--gold-light));border-radius:5px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.15rem;color:var(--navy);flex-shrink:0}
@media(min-width:640px){.logo-mark{width:42px;height:42px;font-size:1.35rem}}
.logo-name{font-size:.9rem;font-weight:700;color:var(--white)}
.logo-sub{font-size:.55rem;font-weight:400;color:var(--gold);letter-spacing:.12em;text-transform:uppercase;margin-top:1px}

.primary-nav{display:none;align-items:center;gap:2px}
@media(min-width:860px){.primary-nav{display:flex}}
.primary-nav a{font-size:.76rem;font-weight:500;color:rgba(255,255,255,.65);padding:6px 14px;border-radius:4px;letter-spacing:.04em;text-transform:uppercase;transition:all var(--ease)}
.primary-nav a:hover,.primary-nav a[aria-current="page"]{color:var(--gold)}
.nav-cta{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--navy)!important;font-weight:700!important;border-radius:var(--r);padding:8px 18px;margin-left:8px}
.nav-cta:hover{filter:brightness(1.1);transform:translateY(-1px)}

.nav-hamburger{display:flex;flex-direction:column;gap:5px;padding:8px;background:none;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}
@media(min-width:860px){.nav-hamburger{display:none}}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:all .25s}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{display:none;flex-direction:column;background:var(--navy);border-top:1px solid rgba(255,255,255,.08);padding:1.5rem 1.25rem 2rem}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:1rem;font-weight:500;color:rgba(255,255,255,.75);padding:13px 0;border-bottom:1px solid rgba(255,255,255,.06);letter-spacing:.04em;text-transform:uppercase;-webkit-tap-highlight-color:transparent}
.mobile-menu a.mobile-cta{margin-top:.75rem;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--navy);text-align:center;border-radius:var(--r);font-weight:700;border:none;padding:14px}

/* ============================================================
   HERO
   ============================================================ */
.hero{background:var(--navy);position:relative;overflow:hidden;padding:3.5rem 0 3rem}
@media(min-width:640px){.hero{padding:5rem 0 4rem}}
@media(min-width:860px){.hero{padding:7rem 0 5.5rem}}
.hero::before{content:'';position:absolute;top:-80px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.08) 0%,transparent 70%);pointer-events:none}
.hero::after{content:'AZ';position:absolute;right:.5rem;bottom:-1rem;font-family:var(--font-display);font-size:clamp(6rem,22vw,16rem);color:rgba(255,255,255,.025);line-height:1;pointer-events:none;user-select:none}
.hero-content{position:relative;z-index:1}
.hero-content h1{color:var(--white);margin-bottom:1.25rem}
.hero-content h1 em{color:var(--gold);font-style:normal}
.hero-sub{font-size:1rem;font-weight:300;color:rgba(255,255,255,.7);max-width:520px;line-height:1.85;margin-bottom:2rem}
@media(min-width:640px){.hero-sub{font-size:1.05rem;margin-bottom:2.5rem}}
.hero-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:2.5rem}
@media(min-width:480px){.hero-actions{flex-direction:row;flex-wrap:wrap}}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);overflow:hidden}
.hero-stat{background:var(--navy);padding:.8rem .5rem;text-align:center;min-width:0}
@media(min-width:640px){.hero-stat{padding:1.5rem 1.25rem}}
.hero-stat-num{font-family:var(--font-display);font-size:2rem;color:var(--gold);line-height:1;letter-spacing:.04em}
@media(min-width:640px){.hero-stat-num{font-size:3rem}}
.hero-stat-label{font-size:.58rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:4px}

/* ============================================================
   VIDEO
   ============================================================ */
.video-section{background:var(--navy-deep);padding:3rem 0}
@media(min-width:640px){.video-section{padding:4.5rem 0}}
.video-inner{display:grid;gap:2rem;align-items:center}
@media(min-width:860px){.video-inner{grid-template-columns:1fr 1fr;gap:4rem}}
.video-label{font-size:.65rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}
.video-title{font-family:var(--font-display);font-size:clamp(1.8rem,5vw,2.8rem);color:var(--white);line-height:1;margin-bottom:.9rem}
.video-desc{font-size:.95rem;font-weight:300;color:rgba(255,255,255,.6);line-height:1.8}
.video-wrap{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:16/9;background:var(--navy)}
.video-wrap video{width:100%;height:100%;object-fit:cover;display:block}

/* ============================================================
   BAND
   ============================================================ */
.band{background:var(--gold);padding:.8rem 0;border-top:2px solid var(--gold-light);border-bottom:2px solid var(--gold-light);overflow:hidden;width:100%;max-width:100vw;position:relative}
.band-track{display:flex;gap:2.5rem;white-space:nowrap;animation:marquee 22s linear infinite;will-change:transform;width:max-content}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.band-item{font-size:.66rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--navy);display:inline-flex;align-items:center;gap:12px;flex-shrink:0}
.band-sep{width:4px;height:4px;background:var(--navy);border-radius:50%;opacity:.3;flex-shrink:0}

/* ============================================================
   QUOTE
   ============================================================ */
.manifeste{background:var(--off-white);padding:3.5rem 0;border-left:5px solid var(--gold)}
@media(min-width:640px){.manifeste{padding:5rem 0}}
.manifeste-inner{display:flex;gap:1.5rem;align-items:flex-start}
.manifeste-mark{font-family:var(--font-display);font-size:5rem;color:var(--gold);line-height:.65;flex-shrink:0;opacity:.5;user-select:none}
@media(min-width:640px){.manifeste-mark{font-size:9rem}}
.manifeste blockquote{font-size:1.05rem;font-weight:300;color:var(--navy);line-height:1.75;font-style:italic}
@media(min-width:640px){.manifeste blockquote{font-size:1.25rem}}
.manifeste cite{display:block;font-style:normal;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-top:1.25rem}

/* ============================================================
   ARTICLES — LISTE
   ============================================================ */
.articles-section{padding:3.5rem 0;background:var(--white)}
@media(min-width:640px){.articles-section{padding:5rem 0}}
.section-head{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem;border-bottom:3px solid var(--navy);padding-bottom:.9rem}
@media(min-width:640px){.section-head{flex-direction:row;align-items:flex-end;justify-content:space-between}}
.section-head h2{line-height:1}
.section-link{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.section-link:hover{color:var(--navy)}

.articles-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:540px){.articles-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:860px){.articles-grid{grid-template-columns:2fr 1fr}}

.article-card{border:1.5px solid var(--gray-100);border-radius:var(--r);overflow:hidden;background:var(--white);transition:all var(--ease);display:flex;flex-direction:column;text-decoration:none}
.article-card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 12px 32px rgba(13,27,62,.1)}
.article-card.featured{grid-row:auto}
@media(min-width:860px){.article-card.featured{grid-row:span 2}}
.card-img{width:100%;aspect-ratio:16/9;object-fit:cover;background:linear-gradient(145deg,var(--navy),var(--navy-mid));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:2.5rem;color:rgba(201,168,76,.2)}
.article-card.featured .card-img{aspect-ratio:16/9}
@media(min-width:860px){.article-card.featured .card-img{aspect-ratio:4/3}}
.card-body{padding:1.1rem 1.25rem;flex:1;display:flex;flex-direction:column}
.card-cat{font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.card-body h3{font-size:1rem;margin-bottom:.5rem;flex:1;line-height:1.35}
.article-card.featured .card-body h3{font-size:1.2rem}
.card-body p{font-size:.83rem;line-height:1.6}
.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--gray-100)}
.card-read{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);transition:color var(--ease)}
.article-card:hover .card-read{color:var(--gold)}
.card-date{font-size:.68rem;color:var(--gray-300);font-weight:300}

/* ============================================================
   ARTICLE SINGLE — PROPRE, LISIBLE, MOBILE-FIRST
   ============================================================ */
.article-hero{background:var(--navy);padding:2.5rem 0 2rem;position:relative;overflow:hidden}
.article-hero::after{content:'AZ';position:absolute;right:.5rem;bottom:-1rem;font-family:var(--font-display);font-size:clamp(5rem,18vw,12rem);color:rgba(255,255,255,.03);line-height:1;pointer-events:none}
.article-hero-inner{position:relative;z-index:1}
.article-back{display:inline-flex;align-items:center;gap:6px;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:1.25rem;text-decoration:none}
.article-back:hover{color:var(--white)}
.article-title{font-family:var(--font-display);font-size:clamp(2rem,7vw,4rem);color:var(--white);line-height:.95;letter-spacing:.02em;margin-bottom:1.5rem}
.article-meta{display:flex;align-items:center;gap:12px;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap}
.article-avatar{width:38px;height:38px;min-width:38px;background:linear-gradient(135deg,var(--gold),var(--gold-light));border-radius:5px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1rem;color:var(--navy)}
.article-author{font-size:.85rem;font-weight:700;color:var(--white);margin:0}
.article-date-read{font-size:.7rem;color:rgba(255,255,255,.45);margin:0}

/* Image mise en avant */
.article-featured-img{width:100%;max-height:420px;object-fit:cover;display:block}

/* Corps de l'article — typographie soignée */
.article-body{padding:2.5rem 0 4rem;background:var(--white)}
.article-content{font-size:1.05rem;line-height:1.85;color:var(--gray-500);max-width:720px}
.article-content > * + *{margin-top:1.25rem}
.article-content h2{font-family:var(--font-display);font-size:clamp(1.6rem,4vw,2.4rem);color:var(--navy);margin-top:2.5rem;margin-bottom:.75rem;letter-spacing:.02em}
.article-content h3{font-size:1.15rem;font-weight:700;color:var(--navy);margin-top:2rem;margin-bottom:.5rem}
.article-content p{margin-bottom:1.1rem}
.article-content strong{color:var(--navy);font-weight:700}
.article-content em{font-style:italic}
.article-content a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.article-content a:hover{color:var(--navy)}
.article-content ul,.article-content ol{padding-left:1.5rem;margin:1rem 0}
.article-content li{margin-bottom:.4rem;line-height:1.7}
.article-content ul li{list-style:disc}
.article-content ol li{list-style:decimal}
.article-content blockquote{border-left:4px solid var(--gold);padding:.9rem 1.4rem;margin:1.75rem 0;background:var(--off-white);border-radius:0 var(--r) var(--r) 0;font-style:italic;color:var(--navy)}
.article-content blockquote p{color:var(--navy);margin:0}
.article-content img{border-radius:var(--r);margin:1.5rem 0;max-width:100%}
.article-content hr{border:none;border-top:2px solid var(--gray-100);margin:2.5rem 0}
.article-content figure{margin:1.5rem 0}
.article-content figcaption{font-size:.78rem;color:var(--gray-300);text-align:center;margin-top:.5rem}
/* Séparateur Gutenberg */
.article-content .wp-block-separator{border:none;border-top:2px solid var(--gray-100);margin:2.5rem 0}
/* Listes Gutenberg */
.article-content .wp-block-list{padding-left:1.5rem}

/* Navigation entre articles */
.article-nav{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:4rem;padding-top:2rem;border-top:2px solid var(--gray-100)}
.article-nav-prev,.article-nav-next{display:flex;flex-direction:column;gap:4px;padding:1rem 1.25rem;border:1.5px solid var(--gray-100);border-radius:var(--r);text-decoration:none;transition:all var(--ease);background:var(--white)}
.article-nav-prev:hover,.article-nav-next:hover{border-color:var(--gold);background:var(--off-white)}
.article-nav-next{text-align:right;margin-left:auto}
.article-nav-label{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-300)}
.article-nav-title{font-size:.88rem;font-weight:600;color:var(--navy);line-height:1.35}
.article-nav-prev:hover .article-nav-title,.article-nav-next:hover .article-nav-title{color:var(--gold)}
@media(max-width:480px){.article-nav{grid-template-columns:1fr}}

/* ============================================================
   PAGE HERO (quelques mots, contact, etc.)
   ============================================================ */
.page-hero{background:var(--navy);padding:3rem 0 2.5rem}
@media(min-width:640px){.page-hero{padding:4.5rem 0 3.5rem}}
.page-hero h1{color:var(--white);margin-bottom:1rem}
.page-hero p{color:rgba(255,255,255,.65);font-size:1.05rem;font-weight:300;max-width:600px;line-height:1.8}

/* ============================================================
   VALEUR / TIMELINE / PARTENAIRES
   ============================================================ */
.value-grid{display:grid;gap:1.1rem;grid-template-columns:1fr;padding:3rem 0}
@media(min-width:540px){.value-grid{grid-template-columns:repeat(2,1fr);padding:4rem 0}}
@media(min-width:860px){.value-grid{grid-template-columns:repeat(3,1fr)}}
.value-card{border:1.5px solid var(--gray-100);border-radius:var(--r);padding:1.4rem;background:var(--white);transition:all var(--ease)}
.value-card:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 8px 24px rgba(13,27,62,.07)}
.value-icon{width:42px;height:42px;background:var(--gold-pale);border:1px solid var(--gold-border);border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:.9rem}
.value-card h3{color:var(--navy);margin-bottom:.4rem}
.value-card p{font-size:.88rem;line-height:1.65}

.timeline{padding:3rem 0}
@media(min-width:640px){.timeline{padding:4.5rem 0}}
.timeline-title{font-family:var(--font-display);font-size:clamp(1.8rem,5vw,2.8rem);color:var(--navy);margin-bottom:2.5rem;border-bottom:3px solid var(--navy);padding-bottom:.75rem}
.tl-item{display:grid;grid-template-columns:80px 1fr;gap:0 1.5rem;position:relative}
@media(min-width:640px){.tl-item{grid-template-columns:100px 1fr;gap:0 2rem}}
.tl-item::before{content:'';position:absolute;left:39px;top:28px;bottom:-2px;width:2px;background:var(--gray-100);z-index:0}
@media(min-width:640px){.tl-item::before{left:49px}}
.tl-item:last-child::before{display:none}
.tl-date{font-size:.72rem;font-weight:700;color:var(--gold);letter-spacing:.04em;padding-top:5px;text-align:right;position:relative;z-index:1;line-height:1.3}
.tl-dot{position:absolute;left:34px;top:6px;width:12px;height:12px;border-radius:50%;background:var(--gold);border:2px solid var(--white);box-shadow:0 0 0 2px var(--gold);z-index:1}
@media(min-width:640px){.tl-dot{left:44px}}
.tl-body{padding:0 0 2.5rem 1rem}
.tl-company{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:.35rem}
.tl-role{font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:.45rem;line-height:1.3}
.tl-desc{font-size:.88rem;color:var(--gray-500);line-height:1.7}
.tl-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:.65rem}
.tl-tag{font-size:.6rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:3px 9px;border-radius:20px;background:var(--gold-pale);color:var(--navy);border:1px solid var(--gold-border)}

.partners-section{background:var(--off-white);padding:3rem 0;border-top:3px solid var(--gold)}
@media(min-width:640px){.partners-section{padding:4rem 0}}
.partners-grid{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-top:2rem}
@media(min-width:640px){.partners-grid{grid-template-columns:repeat(3,1fr)}}
.partner-card{background:var(--white);border:1.5px solid var(--gray-100);border-radius:var(--r);padding:1.2rem;text-align:center;font-weight:700;font-size:.9rem;color:var(--navy);transition:all var(--ease)}
.partner-card:hover{border-color:var(--gold);color:var(--gold)}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-section{background:var(--navy);padding:3.5rem 0;position:relative;overflow:hidden}
@media(min-width:640px){.contact-section{padding:5.5rem 0}}
.contact-section::after{content:'';position:absolute;bottom:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.07) 0%,transparent 70%);pointer-events:none}
.contact-inner{display:grid;gap:2.5rem;position:relative;z-index:1;grid-template-columns:1fr}
@media(min-width:760px){.contact-inner{grid-template-columns:1fr 1fr;gap:4rem}}
.contact-info h2{color:var(--white);margin-bottom:1rem}
.contact-info h2 em{color:var(--gold);font-style:normal}
.contact-info p{color:rgba(255,255,255,.6);font-weight:300;margin-bottom:1.75rem;line-height:1.85}
.contact-detail{display:flex;flex-direction:column;gap:12px}
.contact-item{display:flex;align-items:center;gap:12px}
.contact-icon{width:40px;height:40px;min-width:40px;border-radius:4px;background:rgba(201,168,76,.18);border:1px solid rgba(201,168,76,.5);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--gold);font-style:normal}
.contact-item span{font-size:.88rem;color:rgba(255,255,255,.9);font-weight:400}
.contact-form-wrap{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1.75rem}
@media(min-width:640px){.contact-form-wrap{padding:2.25rem}}
.form-title{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid rgba(201,168,76,.2)}
.form-group{margin-bottom:12px}
.form-group label{display:block;font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:6px}
.form-group input,.form-group textarea{width:100%;max-width:100%;padding:12px 14px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.07);color:var(--white);font-size:.88rem;outline:none;transition:border-color var(--ease);-webkit-appearance:none;box-sizing:border-box}
.form-group input:focus,.form-group textarea:focus{border-color:var(--gold)}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,.2)}
.form-group textarea{resize:vertical;min-height:90px}
.form-row{display:grid;gap:12px;grid-template-columns:1fr}
@media(min-width:560px){.form-row{grid-template-columns:1fr 1fr}}
.form-submit{width:100%;justify-content:center;margin-top:8px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--navy-deep);border-top:1px solid rgba(201,168,76,.18);padding:1.5rem 0}
.footer-inner{display:flex;flex-direction:column;gap:1rem}
@media(min-width:640px){.footer-inner{flex-direction:row;align-items:center;justify-content:space-between}}
.footer-copy{font-size:.68rem;color:rgba(255,255,255,.28);letter-spacing:.05em}
.footer-links{display:flex;gap:16px;flex-wrap:wrap}
.footer-links a{font-size:.65rem;color:rgba(255,255,255,.3);letter-spacing:.07em;text-transform:uppercase;font-weight:500;transition:color var(--ease)}
.footer-links a:hover{color:var(--gold)}

/* ============================================================
   ANIMATIONS
   ============================================================ */
.az-reveal{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.az-reveal.visible{opacity:1;transform:translateY(0)}

/* ============================================================
   FORCE MISE EN PAGE ARTICLE — ÉCRASE TOUT
   ============================================================ */
.single-post .az-article-wrap {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  clear: both !important;
  position: relative !important;
  overflow: hidden !important;
}

/* Neutraliser toutes les grilles et colonnes sur les articles */
.single-post *[class*="col-"],
.single-post *[class*="column"],
.single-post *[class*="grid"],
.single-post *[class*="row"],
.single-post *[class*="wrap"],
.single-post *[class*="container"] {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  flex: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  background: transparent !important;
  border: none !important;
  min-height: 0 !important;
}

/* Exception : garder le container principal intact */
.single-post .article-hero .container,
.single-post .article-body .container {
  max-width: var(--max) !important;
  margin: 0 auto !important;
  padding: 0 1.25rem !important;
  background: transparent !important;
  display: block !important;
}
@media(min-width:640px){
  .single-post .article-hero .container,
  .single-post .article-body .container {
    padding: 0 2rem !important;
  }
}
