
:root{--navy:#1b2838;--navy-deep:#0f1922;--navy-mid:#1e2f42;--navy-light:#2a3d54;--gold:#c4a54d;--gold-light:#d4ba6a;--cream:#f5f0e8;--paper:#faf7f1;--warm-gray:#8c8377;--text:#2c2c2c;--text-light:#6b6560}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:'Source Sans 3',sans-serif;background:var(--paper);color:var(--text);overflow-x:hidden}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 32px;height:56px;display:flex;align-items:center;justify-content:space-between;background:rgba(15,25,34,.93);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(196,165,77,.1)}
nav .logo{font-family:'Playfair Display',serif;font-weight:700;font-size:1.05rem;color:#fff;text-decoration:none;letter-spacing:.5px}
nav .logo span{color:var(--gold)}
nav .nav-links{display:flex;gap:28px;list-style:none}
nav .nav-links a{color:rgba(255,255,255,.6);text-decoration:none;font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;font-weight:500;transition:color .3s}
nav .nav-links a:hover,.nav-active{color:var(--gold-light)!important}
nav .nav-links a.nav-cta{color:var(--gold);border:1px solid rgba(196,165,77,.35);padding:5px 14px;border-radius:3px;transition:all .3s}
nav .nav-links a.nav-cta:hover{background:var(--gold);color:var(--navy-deep)}

/* HERO */
.hero{min-height:100vh;background:linear-gradient(160deg,var(--navy-deep) 0%,var(--navy) 55%,var(--navy-mid) 100%);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:80px 32px 60px}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 50% at 75% 55%,rgba(61,90,122,.22),transparent),radial-gradient(ellipse 40% 35% at 12% 25%,rgba(196,165,77,.05),transparent);pointer-events:none}
.hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.013) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.013) 1px,transparent 1px);background-size:72px 72px;pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:940px;width:100%;display:grid;grid-template-columns:1fr 320px;gap:60px;align-items:center;animation:fadeUp .9s ease-out}
.hero-tag{display:inline-flex;align-items:center;gap:10px;font-size:.65rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:28px}
.hero-tag::before{content:'';width:28px;height:1px;background:var(--gold);opacity:.5}
.hero h1{font-family:'Playfair Display',serif;font-size:3.9rem;font-weight:900;color:#fff;line-height:1.04;margin-bottom:22px}
.hero h1 .gold{color:var(--gold)}
.hero-bio{font-size:1.05rem;color:rgba(255,255,255,.55);font-weight:300;line-height:1.75;max-width:500px;margin:0 0 20px}
.hero-research-tagline{font-size:.84rem;color:rgba(196,165,77,.72);font-weight:400;font-style:italic;line-height:1.65;max-width:480px;margin:0 0 36px;padding-left:16px;border-left:2px solid rgba(196,165,77,.22)}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero-cta-primary{display:inline-flex;align-items:center;gap:10px;padding:13px 30px;background:var(--gold);color:var(--navy-deep);text-decoration:none;font-size:.78rem;letter-spacing:2px;text-transform:uppercase;font-weight:700;border-radius:4px;transition:all .3s ease}
.hero-cta-primary:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(196,165,77,.2)}
.hero-cta-secondary{display:inline-flex;align-items:center;gap:10px;padding:13px 30px;border:1px solid rgba(196,165,77,.3);color:rgba(255,255,255,.65);text-decoration:none;font-size:.78rem;letter-spacing:2px;text-transform:uppercase;font-weight:500;border-radius:4px;transition:all .3s ease}
.hero-cta-secondary:hover{border-color:var(--gold-light);color:var(--gold-light)}
.hero-portrait{position:relative}
.hero-portrait img{width:100%;border-radius:8px;box-shadow:0 24px 64px rgba(0,0,0,.45);filter:grayscale(.12) contrast(1.04)}
.hero-portrait::after{content:'';position:absolute;inset:-6px;border:1px solid rgba(196,165,77,.14);border-radius:12px;pointer-events:none}
.scroll-line{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);width:1px;height:48px;background:linear-gradient(to bottom,transparent,var(--gold));animation:pulse 2.2s ease-in-out infinite}

/* SECTIONS */
.section{padding:88px 32px;max-width:900px;margin:0 auto}
.section-label{font-size:.64rem;letter-spacing:5px;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:12px}
.section-title{font-family:'Playfair Display',serif;font-size:2rem;font-weight:700;color:var(--navy);margin-bottom:10px;line-height:1.2}
.section-subtitle{font-size:.9rem;color:var(--warm-gray);font-weight:400;margin-bottom:28px}
.gold-divider{width:44px;height:2px;background:var(--gold);margin-bottom:32px}

/* TRAVAUX */
#travaux{background:linear-gradient(170deg,var(--navy-deep) 0%,var(--navy) 60%,var(--navy-light) 100%);padding:88px 32px;position:relative;overflow:hidden}
#travaux::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.01) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.01) 1px,transparent 1px);background-size:56px 56px;pointer-events:none}
.travaux-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.travaux-inner .section-title{color:#fff}
.travaux-inner .section-subtitle{color:rgba(255,255,255,.38)}
.research-question{background:rgba(196,165,77,.07);border:1px solid rgba(196,165,77,.2);border-radius:12px;padding:32px 36px;margin-bottom:36px}
.research-question .rq-label{font-size:.62rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:14px}
.research-question blockquote{font-family:'Playfair Display',serif;font-size:1.15rem;font-style:italic;color:rgba(255,255,255,.82);line-height:1.7}
.research-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:36px}
.pillar{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:24px 20px;transition:all .3s cubic-bezier(.22,1,.36,1)}
.pillar:hover{background:rgba(196,165,77,.08);border-color:rgba(196,165,77,.2);transform:translateY(-3px)}
.pillar-num{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:rgba(196,165,77,.28);margin-bottom:8px;line-height:1}
.pillar-title{font-size:.82rem;font-weight:600;color:#fff;margin-bottom:6px}
.pillar-desc{font-size:.75rem;color:rgba(255,255,255,.4);line-height:1.65;font-weight:300}
.research-method{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.method-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:22px}
.method-card .mc-label{font-size:.62rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:10px}
.method-card p{font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.7;font-weight:300}

/* PAGE HERO */
.page-hero{background:linear-gradient(160deg,var(--navy-deep) 0%,var(--navy) 100%);padding:120px 32px 64px;text-align:center;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.013) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.013) 1px,transparent 1px);background-size:72px 72px;pointer-events:none}
.page-hero-inner{position:relative;z-index:1;max-width:680px;margin:0 auto}
.page-hero h1{font-family:'Playfair Display',serif;font-size:2.8rem;font-weight:900;color:#fff;margin-bottom:10px;line-height:1.1}
.page-hero .section-label{display:inline-block;margin-bottom:14px}
.page-hero-sub{color:rgba(255,255,255,.4);font-size:.85rem;font-weight:300;letter-spacing:1px}

/* À PROPOS */
.bio-section{max-width:700px;margin:0 auto;padding:64px 32px}
.bio-content p{font-size:1.02rem;line-height:1.9;color:var(--text-light);font-weight:300;margin-bottom:22px;text-align:justify;hyphens:auto;-webkit-hyphens:auto}
.bio-content strong{color:var(--text);font-weight:600}
.milestones{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.milestone{padding:22px;background:var(--cream);border-radius:10px;border:1px solid rgba(0,0,0,.04)}
.milestone .year{font-family:'Playfair Display',serif;font-size:1.55rem;font-weight:700;color:var(--navy);margin-bottom:4px}
.milestone .label{font-size:.8rem;color:var(--warm-gray);font-weight:400;line-height:1.5}

/* ÉCLAIRAGES / BLOG GRID */
#eclairages{background:var(--cream);padding:88px 32px}
.eclairages-page{background:var(--cream);padding:88px 32px}
.eclairages-inner{max-width:900px;margin:0 auto}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.blog-card{background:var(--paper);border:1px solid rgba(0,0,0,.06);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:all .3s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.09);border-color:rgba(196,165,77,.3)}
.bc-img{height:160px;background-size:cover;background-position:center;background-color:var(--cream)}
.bc-body{padding:22px;display:flex;flex-direction:column;flex:1}
.bc-tag{font-size:.62rem;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:10px}
.blog-card h3{font-family:'Playfair Display',serif;font-size:.98rem;font-weight:700;color:var(--navy);line-height:1.4;margin-bottom:10px}
.blog-card p{font-size:.8rem;color:var(--text-light);line-height:1.65;font-weight:300;flex:1}
.bc-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px}
.bc-date{font-size:.7rem;color:var(--warm-gray)}
.bc-link{font-size:.72rem;color:var(--gold);font-weight:600;letter-spacing:1px}
.blog-cta-wrap{margin-top:36px}
.btn-navy{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;background:var(--navy);color:#fff;text-decoration:none;font-size:.78rem;letter-spacing:2px;text-transform:uppercase;font-weight:600;border-radius:6px;transition:all .3s}
.btn-navy:hover{background:var(--gold);color:var(--navy-deep)}

/* ── ARTICLE HERO (en-tête sombre) ────────────────────────────────────────── */
.article-hero{background:linear-gradient(170deg,var(--navy-deep) 0%,var(--navy) 100%);padding:100px 32px 52px;position:relative;overflow:hidden}
.article-hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);background-size:64px 64px;pointer-events:none}
.article-hero-inner{max-width:780px;margin:0 auto;position:relative;z-index:1}

/* Fil d'Ariane */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.72rem;color:rgba(255,255,255,.35);margin-bottom:22px;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.4);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--gold-light)}
.bc-sep{opacity:.35;font-size:.65rem}

/* Badge + méta */
.article-hero-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.ah-badge{display:inline-flex;align-items:center;padding:4px 11px;background:rgba(196,165,77,.18);border:1px solid rgba(196,165,77,.35);color:var(--gold-light);font-size:.62rem;letter-spacing:2.5px;text-transform:uppercase;font-weight:700;border-radius:3px}
.ah-meta-item{font-size:.76rem;color:rgba(255,255,255,.45);font-weight:300}
.ah-meta-sep{color:rgba(255,255,255,.2);font-size:.7rem}

/* Titre */
.article-hero-title{font-family:'Playfair Display',serif;font-size:2.5rem;font-weight:900;color:#fff;line-height:1.18;margin-bottom:16px;max-width:680px}

/* Excerpt / chapeau */
.article-hero-excerpt{font-size:1rem;color:rgba(255,255,255,.5);font-weight:300;line-height:1.7;max-width:620px;margin-bottom:28px}

/* Auteur */
.article-hero-author{display:flex;align-items:center;gap:14px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08)}
.ah-author-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid rgba(196,165,77,.3);flex-shrink:0}
.ah-author-info{display:flex;flex-direction:column;gap:2px;flex:1}
.ah-author-name{font-size:.86rem;font-weight:700;color:rgba(255,255,255,.85);text-decoration:none;transition:color .2s}
.ah-author-name:hover{color:var(--gold-light)}
.ah-author-role{font-size:.72rem;color:rgba(255,255,255,.35);font-weight:300}
.ah-linkedin{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:6px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.45);flex-shrink:0;transition:all .2s}
.ah-linkedin:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.25);color:rgba(255,255,255,.85)}

/* ── CORPS ARTICLE ─────────────────────────────────────────────────────────── */
.article-page{max-width:720px;margin:0 auto;padding:52px 32px 80px}
.article-header-img{max-width:580px;margin:0 auto 44px;border-radius:10px;overflow:hidden;box-shadow:0 6px 28px rgba(0,0,0,.1);border:1px solid rgba(0,0,0,.05)}
.article-header-img img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.article-meta{font-size:.78rem;color:var(--warm-gray);margin-bottom:36px;padding-bottom:20px;border-bottom:1px solid rgba(0,0,0,.06);display:flex;align-items:center;gap:8px}
.article-author{font-weight:600;color:var(--text-light)}
.article-sep{opacity:.4}
.article-body{font-size:1.02rem;line-height:1.9;color:var(--text-light);font-weight:300;text-align:justify;hyphens:auto;-webkit-hyphens:auto}
.article-body p{margin-bottom:20px}
.article-body h2{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--navy);margin:36px 0 14px;font-weight:700}
.article-body h3{font-size:1.1rem;color:var(--navy);margin:28px 0 10px;font-weight:600}
.article-body strong{color:var(--text);font-weight:600}
.article-body em{font-style:italic}
.article-body blockquote{border-left:2px solid var(--gold);padding:12px 20px;margin:24px 0;font-style:italic;color:var(--warm-gray);background:var(--cream);border-radius:0 6px 6px 0}
.article-body ul,.article-body ol{padding-left:24px;margin-bottom:20px}
.article-body li{margin-bottom:6px;line-height:1.7}
.article-body a{color:var(--gold);text-decoration:underline}

/* AUTHOR CARD */
.article-footer{margin-top:56px;padding-top:32px;border-top:1px solid rgba(0,0,0,.06)}
.author-card{display:inline-flex;align-items:center;gap:16px;padding:16px 20px;background:var(--cream);border-radius:12px;text-decoration:none;color:inherit;border:1px solid rgba(0,0,0,.05);transition:all .3s}
.author-card:hover{border-color:rgba(196,165,77,.3);box-shadow:0 4px 16px rgba(0,0,0,.06)}
.author-card img{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid rgba(196,165,77,.2)}
.author-name{font-weight:700;font-size:.88rem;color:var(--navy);margin-bottom:2px}
.author-role{font-size:.72rem;color:var(--warm-gray);font-weight:300}

/* FOOTER */
footer{background:var(--navy-deep);padding:52px 32px;text-align:center}
footer .footer-name{font-family:'Playfair Display',serif;font-size:1.1rem;color:#fff;font-weight:600;margin-bottom:6px}
footer .footer-name span{color:var(--gold)}
footer .footer-tagline{font-size:.78rem;color:rgba(255,255,255,.3);font-weight:300;margin-bottom:24px}
footer .footer-links{display:flex;justify-content:center;gap:24px;list-style:none;margin-bottom:28px}
footer .footer-links a{color:rgba(255,255,255,.4);text-decoration:none;font-size:.73rem;letter-spacing:1px;text-transform:uppercase;font-weight:500;transition:color .3s}
footer .footer-links a:hover{color:var(--gold-light)}
footer .footer-links-legal{margin-top:-16px;margin-bottom:20px}
footer .footer-links-legal a{opacity:.45;font-size:.68rem}
footer .copyright{font-size:.67rem;color:rgba(255,255,255,.18);letter-spacing:.5px}

@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:.25}50%{opacity:1}}
.reveal{opacity:0;transform:translateY(20px);transition:all .65s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

@media(max-width:768px){
  .hero h1{font-size:2.7rem}.hero-content{grid-template-columns:1fr 240px;gap:32px}
  .research-pillars,.research-method,.milestones,.blog-grid{grid-template-columns:1fr}
}
@media(max-width:520px){
  nav{padding:0 16px;height:50px}nav .nav-links{gap:10px}nav .nav-links a{font-size:.65rem;letter-spacing:.5px}
  .hero{padding:70px 20px 50px}.hero h1{font-size:2.2rem}
  .hero-content{grid-template-columns:1fr}.hero-portrait{order:-1;display:flex;justify-content:center}
  .hero-portrait img{width:200px;border-radius:50%}.hero-portrait::after{display:none}
  .hero-bio,.hero-research-tagline{margin:0 auto 20px}.hero-ctas{justify-content:center}
  .section,#travaux,#eclairages,.eclairages-page{padding:60px 20px}
  .research-question{padding:22px 20px}.research-question blockquote{font-size:1rem}
  .section-title,.page-hero h1{font-size:1.8rem}
  .bio-section{padding:48px 20px}
  .article-page{padding:32px 20px 60px}
  .article-cover{height:220px}
}

/* ── SHARE BAR ─────────────────────────────────────────────────────────────── */
.share-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:22px 0;margin:36px 0 0;border-top:1px solid rgba(0,0,0,.06)}
.share-label{font-size:.68rem;letter-spacing:3px;text-transform:uppercase;color:var(--warm-gray);font-weight:700;margin-right:4px}
.share-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:6px;font-size:.76rem;font-weight:600;text-decoration:none;border:1px solid transparent;cursor:pointer;font-family:inherit;transition:all .25s;background:var(--cream)}
.share-li{color:#0a66c2;border-color:rgba(10,102,194,.2)}.share-li:hover{background:#0a66c2;color:#fff;border-color:#0a66c2}
.share-x{color:#000;border-color:rgba(0,0,0,.15)}.share-x:hover{background:#000;color:#fff;border-color:#000}
.share-copy{color:var(--navy);border-color:rgba(27,40,56,.2)}.share-copy:hover{background:var(--navy);color:#fff}
.share-print{color:var(--warm-gray);border-color:rgba(140,131,119,.25)}.share-print:hover{background:var(--warm-gray);color:#fff}

/* ── PRINT / PDF ───────────────────────────────────────────────────────────── */
@media print{
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  header,footer,.share-bar,.back-link,.article-footer,nav{display:none!important}
  body{background:#fff;color:#111;font-size:11pt}
  .article-page{max-width:100%;padding:0}
  .article-hero{padding:20pt 0 12pt;background:#fff!important}
  .article-hero-title{color:#111!important;font-size:18pt}
  .article-hero-excerpt{color:#444!important}
  .ah-author-name{color:#111!important}
  .breadcrumb,.ah-linkedin{display:none!important}
  .article-page h1{font-size:20pt;color:#111;margin:16pt 0 8pt}
  .article-meta{color:#555;font-size:9pt;margin-bottom:18pt}
  .article-body{font-size:11pt;line-height:1.75;color:#111}
  .article-body h2{font-size:14pt;break-after:avoid}
  .article-body h3{font-size:12pt;break-after:avoid}
  .article-body blockquote{border-left:3px solid #c4a54d;padding:8pt 12pt;color:#444;background:#f9f6f0}
  .article-body a::after{content:" (" attr(href) ")";font-size:8pt;color:#888}
  /* Author block in print */
  .print-author{display:block!important;border-top:1pt solid #ddd;margin-top:24pt;padding-top:12pt;font-size:9pt;color:#555}
}
.print-author{display:none}


/* ── LEGAL HERO ────────────────────────────────────────────────────────────── */
.legal-hero{background:linear-gradient(160deg,var(--navy-deep) 0%,var(--navy) 100%);padding:100px 32px 44px;position:relative;overflow:hidden}
.legal-hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);background-size:64px 64px;pointer-events:none}
.legal-hero-inner{max-width:780px;margin:0 auto;position:relative;z-index:1}
.legal-hero h1{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:900;color:#fff;margin-top:18px;line-height:1.15}

/* ── LEGAL PAGE BODY ───────────────────────────────────────────────────────── */
.legal-page{background:var(--paper);padding:56px 32px 80px}
.legal-inner{max-width:720px;margin:0 auto}
.legal-intro{background:var(--cream);border-left:3px solid var(--gold);border-radius:0 8px 8px 0;padding:18px 22px;font-size:.95rem;color:var(--text-light);line-height:1.75;margin-bottom:40px}
.legal-section{margin-bottom:40px;padding-bottom:36px;border-bottom:1px solid rgba(0,0,0,.06)}
.legal-section:last-child{border-bottom:none;margin-bottom:0}
.legal-section h2{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700;color:var(--navy);margin-bottom:14px}
.legal-section h3{font-size:.9rem;font-weight:700;color:var(--navy);margin:22px 0 10px;text-transform:uppercase;letter-spacing:.5px}
.legal-section p{font-size:.92rem;color:var(--text-light);line-height:1.8;margin-bottom:12px;font-weight:300}
.legal-section ul{padding-left:20px;margin-bottom:12px}
.legal-section li{font-size:.92rem;color:var(--text-light);line-height:1.75;font-weight:300;margin-bottom:4px}
.legal-section a{color:var(--gold);text-decoration:underline}
.legal-section code{background:rgba(0,0,0,.05);border-radius:3px;padding:1px 5px;font-size:.82rem;font-family:'Courier New',monospace}
.cookie-table{width:100%;border-collapse:collapse;font-size:.82rem;margin-top:10px}
.cookie-table th{background:var(--navy);color:#fff;padding:9px 12px;text-align:left;font-size:.68rem;letter-spacing:1px;text-transform:uppercase;font-weight:600}
.cookie-table td{padding:9px 12px;border-bottom:1px solid #e2e8f0;color:var(--text-light);vertical-align:top}
.cookie-table tr:last-child td{border-bottom:none}
.cookie-table tr:nth-child(even) td{background:#fafafa}

/* ── COOKIE BANNER ─────────────────────────────────────────────────────────── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--navy-deep);border-top:1px solid rgba(196,165,77,.2);padding:18px 32px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;transform:translateY(0);transition:transform .4s cubic-bezier(.22,1,.36,1)}
.cookie-banner.hidden{transform:translateY(120%)}
.cookie-text{flex:1;font-size:.8rem;color:rgba(255,255,255,.55);font-weight:300;line-height:1.6;min-width:200px}
.cookie-text a{color:var(--gold-light);text-decoration:underline}
.cookie-text strong{color:rgba(255,255,255,.75);font-weight:600}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-btn{padding:8px 18px;border-radius:5px;font-size:.76rem;font-weight:600;border:none;cursor:pointer;font-family:inherit;transition:all .2s;letter-spacing:.3px}
.cookie-accept{background:var(--gold);color:var(--navy-deep)}.cookie-accept:hover{background:var(--gold-light)}
.cookie-decline{background:transparent;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.5)}.cookie-decline:hover{border-color:rgba(255,255,255,.4);color:rgba(255,255,255,.75)}

@media(max-width:520px){
  .legal-hero{padding:80px 20px 32px}
  .legal-page{padding:40px 20px 60px}
  .legal-hero h1{font-size:1.7rem}
  .cookie-banner{padding:14px 20px}
  .cookie-actions{width:100%}.cookie-btn{flex:1;text-align:center}
}

/* ── BLOCS SPÉCIAUX articles ──────────────────────────────────────────────── */
.article-body .pull-quote{border-left:2px solid var(--gold);padding:14px 22px;margin:28px 0;font-style:italic;color:var(--warm-gray);background:var(--cream);border-radius:0 8px 8px 0}
.article-body .pull-quote small{display:block;margin-top:10px;font-size:.8rem;font-style:normal;color:#9ca3af}
.article-body .data-box{background:linear-gradient(135deg,var(--cream) 0%,var(--paper) 100%);border:1px solid rgba(196,165,77,.25);border-left:3px solid var(--gold);border-radius:8px;padding:22px 26px;margin:32px 0;display:flex;flex-direction:column;gap:4px}
.article-body .data-value{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:700;color:var(--navy);line-height:1}
.article-body .data-label{font-size:.92rem;color:var(--text-light);font-weight:400;margin-top:6px}
.article-body .data-source{font-size:.73rem;color:#9ca3af;margin-top:8px}
.article-body .callout{background:rgba(196,165,77,.07);border:1px solid rgba(196,165,77,.18);border-radius:8px;padding:18px 22px;margin:28px 0;font-size:.94rem;color:var(--text-light);line-height:1.75}
.article-body .callout strong{display:block;color:var(--navy);font-size:.68rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:10px}
.article-body .section-sep{border:none;border-top:1px solid rgba(0,0,0,.08);margin:40px 0}

/* ── BREADCRUMB in page-hero (light backgrounds) ──────────── */
.page-hero .breadcrumb{margin-bottom:12px}
.page-hero .breadcrumb a{color:rgba(255,255,255,.45)}
.page-hero .breadcrumb a:hover{color:rgba(255,255,255,.8)}
.page-hero .breadcrumb span{color:rgba(255,255,255,.3)}
.breadcrumb .bc-current{color:rgba(255,255,255,.55);font-style:italic}

/* ── RÉFÉRENCES BIBLIOGRAPHIQUES ──────────────────────────── */
.refs-page{padding:60px 0 80px}
.refs-inner{max-width:800px;margin:0 auto;padding:0 20px}
.refs-norm{font-style:italic;color:var(--warm-gray);margin-bottom:40px;font-size:.95rem}
.refs-section{margin-bottom:48px}
.refs-h2{font-family:'Playfair Display',Georgia,serif;font-size:1.25rem;color:var(--navy);
  margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--gold)}
.refs-list{list-style:none;padding:0;margin:0}
.refs-item{font-size:.9rem;line-height:1.65;color:var(--warm-gray);
  padding:8px 0 8px 22px;text-indent:-22px;border-bottom:1px solid var(--paper)}
.refs-item:last-child{border-bottom:none}
.refs-item em{color:var(--navy)}
.refs-item a{color:var(--gold);text-decoration:none;word-break:break-all}
.refs-item a:hover{text-decoration:underline}

/* ── RÉFÉRENCES PAR ARTICLE ────────────────────────────────── */
.article-refs{max-width:740px;margin:48px auto 0;padding:32px 20px 0;
  border-top:2px solid var(--gold)}
.refs-heading{font-family:'Playfair Display',Georgia,serif;font-size:1.2rem;
  color:var(--navy);margin-bottom:6px}
.refs-norm-label{font-style:italic;color:var(--warm-gray);font-size:.82rem;margin-bottom:20px}
.refs-subheading{font-size:.85rem;font-weight:700;color:var(--gold);
  text-transform:uppercase;letter-spacing:1.5px;margin:20px 0 10px}
.article-refs .refs-list{list-style:none;padding:0;margin:0}
.article-refs .refs-item{font-size:.85rem;line-height:1.65;color:var(--warm-gray);
  padding:7px 0 7px 20px;text-indent:-20px;border-bottom:1px solid var(--paper)}
.article-refs .refs-item:last-child{border-bottom:none}
.article-refs .refs-item em{color:var(--navy)}
.article-refs .refs-item a{color:var(--gold);text-decoration:none;word-break:break-all;font-size:.78rem}
.article-refs .refs-item a:hover{text-decoration:underline}
